/* R5 Executive — shared service-page chrome (svc- namespace) */
:root { --r5-cream-2: #FAF8F5; --r5-taupe: #6B5638; --r5-charcoal: #1C1917; }

.svc-eyebrow { font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--r5-grey); font-weight: 500; }
.svc-eyebrow.light { color: rgba(255,255,255,.55); }
.svc-btn { display: inline-flex; align-items: center; gap: 10px; padding: 15px 28px; border-radius: 100px; font-size: 13px; font-weight: 500; letter-spacing: .04em; transition: transform .3s ease, background .3s ease, color .3s ease, border-color .3s ease; cursor: pointer; text-decoration: none; }
.svc-btn-primary { background: #fff; color: var(--r5-dark); }
.svc-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(0,0,0,.25); }
.svc-btn-ghost { border: 1px solid rgba(255,255,255,.45); color: #fff; }
.svc-btn-ghost:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.7); }
.svc-btn-dark { background: var(--r5-dark); color: #fff; }
.svc-btn-dark:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(0,0,0,.2); }
.svc-btn .ar { display: inline-block; width: 14px; height: 1px; background: currentColor; position: relative; }
.svc-btn .ar::after { content: ""; position: absolute; right: 0; top: -3px; width: 7px; height: 7px; border-top: 1px solid currentColor; border-right: 1px solid currentColor; transform: rotate(45deg); }

/* HERO */
.svc-hero { position: relative; min-height: 92vh; display: flex; align-items: flex-end; color: #fff; overflow: hidden; background: #0e0d0c; }
.svc-hero-bg { position: absolute; inset: 0; z-index: 1; }
.svc-hero-bg img { width: 100%; height: 100%; object-fit: cover; animation: svcKb 22s ease-in-out infinite alternate; }
@keyframes svcKb { 0% { transform: scale(1.04); } 100% { transform: scale(1.12) translateY(-2%); } }
.svc-hero-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.5) 0%, rgba(0,0,0,.2) 35%, rgba(0,0,0,.6) 78%, rgba(0,0,0,.88) 100%); }
.svc-hero-content { position: relative; z-index: 2; width: 100%; padding: 0 40px 100px; }
.svc-hero-grid { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1.4fr .9fr; gap: 60px; align-items: end; }
.svc-hero .crumb { display: flex; gap: 14px; font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.55); margin-bottom: 24px; flex-wrap: wrap; }
.svc-hero .crumb a { color: rgba(255,255,255,.55); transition: color .3s; text-decoration: none; }
.svc-hero .crumb a:hover { color: #fff; }
.svc-hero .crumb span.sep { color: rgba(255,255,255,.3); }
.svc-hero .crumb span.cur { color: #fff; }
.svc-hero h1 { font-family: var(--r5-serif); font-size: clamp(48px, 7vw, 108px); font-weight: 300; line-height: .98; letter-spacing: -.02em; color: #fff; margin: 0; }
.svc-hero h1 em { font-style: italic; font-weight: 400; color: #e9e1d3; }
.svc-hero .lead { font-size: 16px; line-height: 1.85; color: rgba(255,255,255,.78); margin: 0 0 30px; max-width: 380px; }
.svc-hero .hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.svc-hero .hero-stats { display: flex; gap: 36px; margin-top: 42px; flex-wrap: wrap; }
.svc-hero .hero-stats > div { font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.55); }
.svc-hero .hero-stats b { display: block; font-family: var(--r5-serif); font-size: 28px; font-weight: 300; letter-spacing: 0; text-transform: none; color: #fff; margin-bottom: 4px; }
@media (max-width:900px) { .svc-hero-grid { grid-template-columns: 1fr; gap: 24px; } .svc-hero-content { padding: 0 24px 60px; } }

/* ANCHOR strip */
.svc-anchor-strip { background: #fff; border-bottom: 1px solid var(--r5-border); position: sticky; top: 70px; z-index: 50; }
.svc-anchor-strip-inner { max-width: 1280px; margin: 0 auto; padding: 18px 40px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: center; }
.svc-anchor-strip-inner .label { font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--r5-grey); font-weight: 500; margin-right: 14px; }
.svc-anchor-strip-inner a { font-size: 13px; color: #666; padding: 8px 16px; border-radius: 100px; transition: background .3s ease, color .3s ease; text-decoration: none; }
.svc-anchor-strip-inner a:hover { background: var(--r5-cream-2); color: var(--r5-dark); }
@media (max-width:900px) { .svc-anchor-strip { display: none; } }

/* STANDARD */
.svc-standard { padding: 140px 40px; background: var(--r5-cream); }
.svc-standard-grid { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; align-items: start; }
.svc-standard-l h2 { font-family: var(--r5-serif); font-size: clamp(36px, 5vw, 60px); font-weight: 300; line-height: 1.05; letter-spacing: -.015em; margin: 0 0 24px; color: var(--r5-dark); }
.svc-standard-l h2 em { font-style: italic; color: var(--r5-taupe); }
.svc-standard-l .meta { font-family: var(--r5-serif); font-size: 18px; font-style: italic; color: var(--r5-taupe); margin: 30px 0 0; }
.svc-standard-r p { font-size: 16px; line-height: 1.85; color: #666; margin: 0 0 22px; }
.svc-standard-r p:first-of-type { font-family: var(--r5-serif); font-size: 22px; font-weight: 300; color: var(--r5-dark); line-height: 1.5; letter-spacing: -.005em; }
.svc-standard-r p:first-of-type em { font-style: italic; color: var(--r5-taupe); }
@media (max-width:900px) { .svc-standard-grid { grid-template-columns: 1fr; gap: 40px; } }

/* METHOD */
.svc-method { padding: 140px 40px; background: #fff; }
.svc-method-head { max-width: 780px; margin: 0 auto 80px; text-align: center; }
.svc-method-head h2 { font-family: var(--r5-serif); font-size: clamp(36px, 4.6vw, 56px); font-weight: 300; line-height: 1.08; letter-spacing: -.015em; margin: 0 auto 20px; color: var(--r5-dark); }
.svc-method-head h2 em { font-style: italic; color: var(--r5-taupe); }
.svc-method-head p { font-size: 15px; line-height: 1.8; color: #888; max-width: 520px; margin: 0 auto; }
.svc-method-grid { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--r5-border); border: 1px solid var(--r5-border); border-radius: 2px; overflow: hidden; }
.svc-method-step { background: #fff; padding: 48px 36px; position: relative; }
.svc-method-step .ord { position: absolute; top: 24px; right: 30px; font-family: var(--r5-serif); font-size: 14px; font-style: italic; color: var(--r5-taupe); letter-spacing: .04em; }
.svc-method-step h3 { font-family: var(--r5-serif); font-size: 24px; font-weight: 400; color: var(--r5-dark); margin: 36px 0 16px; line-height: 1.15; }
.svc-method-step p { font-size: 13.5px; line-height: 1.75; color: #777; margin: 0; }
.svc-method-step .ico { width: 44px; height: 44px; border: 1px solid var(--r5-border); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--r5-serif); font-style: italic; color: var(--r5-taupe); font-size: 18px; }
@media (max-width:900px) { .svc-method-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width:560px) { .svc-method-grid { grid-template-columns: 1fr; } }

/* FEATURES */
.svc-features { padding: 140px 40px; background: var(--r5-cream-2); }
.svc-features-head { max-width: 1280px; margin: 0 auto 60px; display: flex; justify-content: space-between; align-items: end; gap: 40px; flex-wrap: wrap; }
.svc-features-head h2 { font-family: var(--r5-serif); font-size: clamp(34px, 4.4vw, 52px); font-weight: 300; line-height: 1.08; letter-spacing: -.015em; max-width: 560px; margin: 0; color: var(--r5-dark); }
.svc-features-head h2 em { font-style: italic; color: var(--r5-taupe); }
.svc-features-head p { font-size: 14px; line-height: 1.7; color: #888; max-width: 340px; margin: 0; }
.svc-feat-grid { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--r5-border); border: 1px solid var(--r5-border); border-radius: 2px; overflow: hidden; }
.svc-feat { background: #fff; padding: 36px 30px; display: flex; flex-direction: column; gap: 14px; min-height: 200px; }
.svc-feat .num { font-family: var(--r5-serif); font-size: 13px; font-style: italic; color: var(--r5-taupe); letter-spacing: .04em; }
.svc-feat h3 { font-family: var(--r5-serif); font-size: 22px; font-weight: 400; color: var(--r5-dark); line-height: 1.15; letter-spacing: -.005em; margin: 0; }
.svc-feat p { font-size: 13.5px; line-height: 1.7; color: #777; margin: 0; }
@media (max-width:900px) { .svc-feat-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width:560px) { .svc-feat-grid { grid-template-columns: 1fr; } }

/* FLEET pair */
.svc-fleet-pair { padding: 140px 40px; background: var(--r5-cream); }
.svc-fp-head { max-width: 880px; margin: 0 auto 60px; text-align: center; }
.svc-fp-head h2 { font-family: var(--r5-serif); font-size: clamp(34px, 4.4vw, 52px); font-weight: 300; line-height: 1.08; letter-spacing: -.015em; margin: 0 auto 18px; color: var(--r5-dark); max-width: none; }
.svc-fp-head h2 em { font-style: italic; color: var(--r5-taupe); }
.svc-fp-head p { font-size: 14px; line-height: 1.8; color: #888; max-width: 520px; margin: 0 auto; }
.svc-fp-grid { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.svc-fpcard { background: #fff; border-radius: 4px; border: 1px solid var(--r5-border); overflow: hidden; display: flex; flex-direction: column; transition: transform .4s ease, box-shadow .4s ease; text-decoration: none; color: inherit; }
.svc-fpcard:hover { transform: translateY(-3px); box-shadow: 0 16px 40px rgba(0,0,0,.06); }
.svc-fpcard .fpimg { aspect-ratio: 5/3; overflow: hidden; background: var(--r5-cream-2); }
.svc-fpcard .fpimg img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s ease; }
.svc-fpcard:hover .fpimg img { transform: scale(1.04); }
.svc-fpcard .fpbody { padding: 30px 28px 32px; display: flex; flex-direction: column; flex: 1; gap: 12px; }
.svc-fpcard .fptag { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--r5-grey); font-weight: 500; }
.svc-fpcard h3 { font-family: var(--r5-serif); font-size: 24px; font-weight: 400; color: var(--r5-dark); margin: 0; }
.svc-fpcard h3 em { font-style: italic; color: var(--r5-taupe); }
.svc-fpcard p { font-size: 13.5px; line-height: 1.7; color: #888; flex: 1; margin: 0; }
.svc-fpcard .fpmeta { display: flex; gap: 24px; padding-top: 14px; border-top: 1px solid var(--r5-border); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--r5-grey); }
.svc-fpcard .fpmeta b { display: block; font-family: var(--r5-serif); font-size: 18px; font-weight: 300; color: var(--r5-dark); letter-spacing: 0; text-transform: none; margin-bottom: 2px; }
.svc-fpcard .fparrow { margin-top: 6px; font-size: 13px; font-weight: 500; color: var(--r5-dark); display: inline-flex; align-items: center; gap: 8px; }
.svc-fpcard.lead { background: var(--r5-charcoal); color: #fff; border-color: var(--r5-charcoal); }
.svc-fpcard.lead h3 { color: #fff; }
.svc-fpcard.lead .fpbody p { color: rgba(255,255,255,.7); }
.svc-fpcard.lead .fptag { color: #d8c9ad; }
.svc-fpcard.lead .fpmeta { border-top-color: rgba(255,255,255,.15); color: rgba(255,255,255,.55); }
.svc-fpcard.lead .fpmeta b { color: #fff; }
.svc-fpcard.lead .fparrow { color: #fff; }
@media (max-width:900px) { .svc-fp-grid { grid-template-columns: 1fr; } }

/* QUOTE */
.svc-quote { padding: 140px 40px; background: var(--r5-cream-2); text-align: center; }
.svc-quote blockquote { max-width: 880px; margin: 0 auto; font-family: var(--r5-serif); font-size: clamp(26px, 3.4vw, 38px); font-weight: 300; line-height: 1.4; color: var(--r5-dark); }
.svc-quote blockquote em { font-style: italic; color: var(--r5-taupe); }
.svc-quote .by { display: block; margin: 34px auto 0; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--r5-grey); font-weight: 500; max-width: none; }

/* TRUSTED — auto-scrolling marquee */
.svc-trusted { padding: 90px 0; background: var(--r5-cream-2); border-top: 1px solid var(--r5-border); text-align: center; overflow: hidden; }
.svc-trusted .svc-eyebrow { display: block; margin: 0 auto 48px; max-width: none; padding: 0 40px; }
.svc-trusted-logos {
  display: flex;
  align-items: center;
  width: max-content;
  gap: 64px;
  animation: r5-trust-marquee 36s linear infinite;
  will-change: transform;
}
.svc-trusted-logos img { max-height: 36px; width: auto; opacity: .55; filter: grayscale(1); transition: opacity .3s ease, filter .3s ease; flex-shrink: 0; }
.svc-trusted-logos img:hover { opacity: 1; filter: grayscale(0); }
.svc-trusted:hover .svc-trusted-logos { animation-play-state: paused; }
@keyframes r5-trust-marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .svc-trusted-logos { animation: none; flex-wrap: wrap; justify-content: center; width: auto; max-width: 1180px; margin: 0 auto; padding: 0 40px; }
}

/* FAQ */
.svc-faq { padding: 140px 40px; background: #fff; }
.svc-faq-inner { max-width: 880px; margin: 0 auto; }
.svc-faq-head { text-align: center; margin-bottom: 60px; }
.svc-faq-head h2 { font-family: var(--r5-serif); font-size: clamp(34px, 4.4vw, 52px); font-weight: 300; line-height: 1.08; letter-spacing: -.015em; margin: 0 auto 18px; color: var(--r5-dark); max-width: none; }
.svc-faq-head h2 em { font-style: italic; color: var(--r5-taupe); }
.svc-faq-list { display: flex; flex-direction: column; }
.svc-faq-item { border-top: 1px solid var(--r5-border); padding: 24px 0; }
.svc-faq-item:last-child { border-bottom: 1px solid var(--r5-border); }
.svc-faq-item summary { cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 30px; }
.svc-faq-item summary::-webkit-details-marker { display: none; }
.svc-faq-item summary h3 { font-family: var(--r5-serif); font-size: 21px; font-weight: 400; color: var(--r5-dark); letter-spacing: -.005em; line-height: 1.3; margin: 0; }
.svc-faq-item summary .toggle { flex: 0 0 auto; width: 30px; height: 30px; border: 1px solid var(--r5-border); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; color: var(--r5-grey); transition: transform .3s ease, background .3s ease, color .3s ease; }
.svc-faq-item[open] summary .toggle { transform: rotate(45deg); background: var(--r5-dark); color: #fff; border-color: var(--r5-dark); }
.svc-faq-item p { margin: 16px 0 0; font-size: 14.5px; line-height: 1.85; color: #666; max-width: 680px; }

/* BLEED */
.svc-bleed { height: 78vh; min-height: 520px; position: relative; overflow: hidden; }
.svc-bleed img { width: 100%; height: 100%; object-fit: cover; }
.svc-bleed::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.15), rgba(0,0,0,.5)); }
.svc-bleed-text { position: absolute; left: 0; right: 0; bottom: 60px; text-align: center; color: #fff; z-index: 2; padding: 0 40px; }
.svc-bleed-text .svc-eyebrow { color: rgba(255,255,255,.7); margin-bottom: 20px; display: block; max-width: none; }
.svc-bleed-text h3 { font-family: var(--r5-serif); font-size: clamp(28px, 4vw, 46px); font-weight: 300; line-height: 1.2; max-width: 780px; margin: 0 auto; letter-spacing: -.01em; font-style: italic; color: #fff; }

/* FINAL */
.svc-final { padding: 160px 40px; background: var(--r5-dark); color: #fff; text-align: center; }
.svc-final .svc-eyebrow { display: block; margin: 0 auto 32px; max-width: none; }
.svc-final h2 { font-family: var(--r5-serif); font-size: clamp(40px, 5.5vw, 76px); font-weight: 300; line-height: 1.05; letter-spacing: -.02em; margin: 0 auto 30px; color: #fff; max-width: 880px; }
.svc-final h2 em { font-style: italic; color: #d8c9ad; }
.svc-final p { max-width: 580px; margin: 0 auto 50px; font-size: 15px; line-height: 1.85; color: rgba(255,255,255,.72); }
.svc-final-actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* TIMELINE (charcoal — used by event-transport "brief", wedding "ceremony") */
.svc-timeline { display: grid; grid-template-columns: 160px 1fr; gap: 0; border-top: 1px solid var(--r5-border); }
.svc-timeline.dark { border-top-color: rgba(255,255,255,.12); }
.svc-tl-row { display: contents; }
.svc-tl-time { padding: 28px 30px 28px 0; border-bottom: 1px solid var(--r5-border); font-family: var(--r5-serif); font-size: 24px; font-weight: 300; color: var(--r5-taupe); font-style: italic; }
.svc-timeline.dark .svc-tl-time { border-bottom-color: rgba(255,255,255,.12); color: #d8c9ad; }
.svc-tl-body { padding: 28px 0; border-bottom: 1px solid var(--r5-border); border-left: 1px solid var(--r5-border); padding-left: 40px; }
.svc-timeline.dark .svc-tl-body { border-bottom-color: rgba(255,255,255,.12); border-left-color: rgba(255,255,255,.12); }
.svc-tl-body h3 { font-family: var(--r5-serif); font-size: 20px; font-weight: 400; color: var(--r5-dark); margin: 0 0 8px; }
.svc-timeline.dark .svc-tl-body h3 { color: #fff; }
.svc-tl-body p { font-size: 14px; line-height: 1.75; color: #777; max-width: 560px; margin: 0; }
.svc-timeline.dark .svc-tl-body p { color: rgba(255,255,255,.65); }
@media (max-width:900px) { .svc-timeline { grid-template-columns: 1fr; } .svc-tl-time { padding: 18px 0 0; border-bottom: 0; } .svc-tl-body { padding: 8px 0 28px; border-left: 0; padding-left: 0; } }

/* =========================================
   MOBILE — tighter typography + horizontal swipe carousels
   ========================================= */

/* Reusable swipe pattern */
@media (max-width: 760px) {
  /* HERO — denser */
  .svc-hero { min-height: 80vh; }
  .svc-hero .lead { font-size: 14px; line-height: 1.7; max-width: 100%; }
  .svc-hero .hero-stats { gap: 18px; margin-top: 28px; }
  .svc-hero .hero-stats b { font-size: 22px; }
  .svc-hero h1 { font-size: clamp(38px, 11vw, 64px); }
  .svc-hero-content { padding: 0 24px 50px; }

  /* STANDARD — tighter body copy */
  .svc-standard { padding: 80px 24px; }
  .svc-standard-r p { font-size: 15px; line-height: 1.7; }
  .svc-standard-r p:first-of-type { font-size: 19px; line-height: 1.45; }

  /* METHOD — keep section + grid within 24px margins (static 2-col grid, not a swipe) */
  .svc-method { padding: 80px 24px; }
  .svc-method-head { padding: 0; }
  .svc-method-step { padding: 32px 22px; }
  .svc-method-step h3 { font-size: 19px; margin: 22px 0 10px; }
  .svc-method-step p { font-size: 13px; line-height: 1.6; }

  /* FEATURES, FEAT-GRID — section retains horizontal padding; grid bleeds via -margin */
  .svc-features { padding: 70px 24px 80px; }
  .svc-features-head { padding: 0; margin-bottom: 32px; }
  .svc-feat-grid {
    display: flex; flex-wrap: nowrap; gap: 14px;
    overflow-x: auto; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 0 24px 8px; margin: 0 -24px;
    background: transparent; border: 0; border-radius: 0;
    scrollbar-width: none;
  }
  .svc-feat-grid::-webkit-scrollbar { display: none; }
  .svc-feat {
    flex: 0 0 78%; min-width: 250px; max-width: 320px;
    scroll-snap-align: start;
    border: 1px solid var(--r5-border); border-radius: 6px;
    min-height: 0; padding: 28px 24px;
  }
  .svc-feat h3 { font-size: 19px; }

  /* FLEET-PAIR — section retains horizontal padding; grid bleeds via -margin */
  .svc-fleet-pair { padding: 70px 24px 80px; }
  .svc-fp-head { padding: 0; }
  .svc-fp-grid {
    display: flex; flex-wrap: nowrap; gap: 14px;
    overflow-x: auto; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 0 24px 8px; margin: 0 -24px;
    grid-template-columns: none;
    scrollbar-width: none;
  }
  .svc-fp-grid::-webkit-scrollbar { display: none; }
  .svc-fpcard {
    flex: 0 0 82%; min-width: 280px; max-width: 340px;
    scroll-snap-align: start;
  }

  /* QUOTE */
  .svc-quote { padding: 70px 24px; }
  .svc-quote blockquote { font-size: 22px; line-height: 1.45; }

  /* TRUSTED */
  .svc-trusted { padding: 60px 0; }
  .svc-trusted-logos { gap: 40px; animation-duration: 28s; }

  /* FAQ */
  .svc-faq { padding: 70px 24px; }
  .svc-faq-head { margin-bottom: 36px; }
  .svc-faq-item { padding: 18px 0; }
  .svc-faq-item summary h3 { font-size: 17px; line-height: 1.3; }
  .svc-faq-item p { font-size: 14px; line-height: 1.7; margin-top: 12px; }

  /* INTRO (narrow) */
  .svc-intro { padding: 70px 24px 50px; }
  .svc-intro h2 { font-size: 22px; line-height: 1.45; }
  .svc-intro p { font-size: 14px; }

  /* FINAL */
  .svc-final { padding: 90px 24px 80px; }
  .svc-final h2 { font-size: clamp(34px, 9vw, 50px); }
  .svc-final p { font-size: 14px; margin-bottom: 32px; }

  /* TIMELINE — compact stacked list */
  .svc-timeline { grid-template-columns: 1fr; gap: 0; }
  .svc-tl-time { padding: 14px 0 0; border-bottom: 0; font-size: 18px; }
  .svc-tl-body { padding: 4px 0 18px; border-left: 0; padding-left: 0; }
  .svc-tl-body h3 { font-size: 17px; }
  .svc-tl-body p { font-size: 13px; line-height: 1.6; }

  /* BLEED — half viewport instead of 78vh, less dominant */
  .svc-bleed { height: 50vh; min-height: 360px; }
  .svc-bleed-text { bottom: 32px; padding: 0 24px; }
  .svc-bleed-text h3 { font-size: clamp(22px, 6.5vw, 30px); }

  /* ANCHOR strip — already display:none on mobile, leave it */
}

/* Visual hint that there's more to swipe — fade right edge */
@media (max-width: 760px) {
  .svc-feat-grid, .svc-fp-grid {
    -webkit-mask-image: linear-gradient(to right, black 0%, black 92%, transparent 100%);
    mask-image: linear-gradient(to right, black 0%, black 92%, transparent 100%);
  }
}

/* =========================================
   MOBILE — page-specific grids (at-, et-, pt-, fc-, wc-, cc-)
   ========================================= */
@media (max-width: 760px) {
  /* Generic swipe row helper applied via class composition below */
  .at-airports, .at-pricing-grid, .et-roles-grid, .pt-occ-grid, .pt-dest-grid,
  .fc-week-grid, .fc-clubs-grid, .wc-pk-grid,
  .cc-aud-grid, .cc-feat-grid, .cc-fp-grid, .cc-procure-r {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 14px !important;
    overflow: visible !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 0 24px 8px !important;
    margin: 0 -24px !important;
    grid-template-columns: none !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    max-width: none !important;
    scrollbar-width: none;
    -webkit-mask-image: linear-gradient(to right, black 0%, black 92%, transparent 100%);
    mask-image: linear-gradient(to right, black 0%, black 92%, transparent 100%);
  }
  .at-airports::-webkit-scrollbar, .at-pricing-grid::-webkit-scrollbar,
  .et-roles-grid::-webkit-scrollbar, .pt-occ-grid::-webkit-scrollbar,
  .pt-dest-grid::-webkit-scrollbar, .fc-week-grid::-webkit-scrollbar,
  .fc-clubs-grid::-webkit-scrollbar, .wc-pk-grid::-webkit-scrollbar,
  .cc-aud-grid::-webkit-scrollbar, .cc-feat-grid::-webkit-scrollbar,
  .cc-fp-grid::-webkit-scrollbar { display: none; }

  .at-airport, .at-pcard, .et-role, .pt-occ, .pt-dest,
  .fc-day, .fc-club, .wc-pk,
  .cc-aud, .cc-feat, .cc-fpcard, .cc-procure-cell {
    flex: 0 0 82% !important;
    min-width: 270px !important;
    max-width: 340px;
    scroll-snap-align: start;
    border-right: 0 !important;
    border-bottom: 1px solid var(--r5-border);
  }
  /* Dark variants need the bottom border in light-on-dark */
  .at-airport, .pt-dest, .fc-day {
    border-bottom: 1px solid rgba(255,255,255,.12);
  }

  /* Specific tightening per page — sections keep 24px horizontal padding so
     heads/lists/quotes never go edge-to-edge; carousels use margin: 0 -24px
     (with !important above) to bleed beyond. */
  .at-coverage { padding: 70px 24px 80px !important; }
  .at-pricing { padding: 70px 24px 80px !important; }
  .at-coverage-head, .at-pricing-head { padding: 0; margin-bottom: 32px; gap: 18px; }
  .at-coverage-head h2, .at-pricing-head h2 { font-size: clamp(28px, 7vw, 38px); }
  .at-airport h3 { font-size: 18px; }
  .at-pcard { background: #fff; border: 1px solid var(--r5-border) !important; border-radius: 6px !important; }
  .at-airport.home::before { top: 18px; right: 18px; }

  .et-roles, .et-discretion, .et-clients { padding: 70px 24px 80px !important; }
  .et-roles-head { padding: 0; margin-bottom: 32px; }
  .et-disc-grid { padding: 0; gap: 28px; }
  .et-disc-l h2, .et-clients h2 { font-size: clamp(28px, 7vw, 38px); }
  .et-disc-row { padding: 16px 0; }
  .et-disc-row h3 { font-size: 17px; }
  .et-clients-grid { gap: 32px; }
  .et-clients-grid img { max-height: 30px; }
  .et-role { background: #fff; border: 1px solid var(--r5-border) !important; border-radius: 6px !important; min-height: 0 !important; }
  .et-role h3 { font-size: 19px; }

  .pt-occasions, .pt-destinations { padding: 70px 24px 80px !important; }
  .pt-occ-head, .pt-dest-head { padding: 0; margin-bottom: 32px; }
  .pt-occ-head h2, .pt-dest-head h2 { font-size: clamp(28px, 7vw, 38px); }
  .pt-occ { background: #fff; border: 1px solid var(--r5-border) !important; border-radius: 6px !important; }
  .pt-occ h3 { font-size: 20px; }
  .pt-dest { padding: 28px 22px; }

  .fc-week, .fc-trust, .fc-clubs { padding: 70px 24px 80px !important; }
  .fc-week-head { padding: 0; margin-bottom: 32px; gap: 18px; }
  .fc-week-head h2, .fc-clubs h2 { font-size: clamp(28px, 7vw, 38px); }
  .fc-trust-grid { padding: 0; grid-template-columns: 1fr; gap: 30px; }
  .fc-trust-row { padding: 16px 0; }
  .fc-trust-row h3 { font-size: 17px; }
  .fc-day { padding: 24px 20px; min-height: 0 !important; }
  .fc-day h3 { font-size: 14px; }
  .fc-club .badge { width: 64px; height: 64px; font-size: 26px; }

  .wc-ceremony, .wc-packages, .wc-keepsake { padding: 70px 24px 80px !important; }
  .wc-cer-inner { padding: 0; }
  .wc-cer-head { padding: 0; margin-bottom: 32px; }
  .wc-cer-head h2 { font-size: clamp(28px, 7vw, 38px); }
  .wc-pk-head { padding: 0; margin-bottom: 32px; }
  .wc-pk-head h2 { font-size: clamp(28px, 7vw, 38px); }
  .wc-pk { padding: 32px 26px; }
  .wc-pk h3 { font-size: 26px; }
  .wc-pk-foot b { font-size: 28px; }
  .wc-ks-grid { gap: 28px; }
  .wc-ks-r h2 { font-size: clamp(28px, 7vw, 38px); }

  /* Corporate Chauffeur (cc-) */
  .cc-hero { min-height: 80vh; }
  .cc-hero .lead { font-size: 14px; line-height: 1.7; max-width: 100%; }
  .cc-hero .hero-stats { gap: 18px; margin-top: 28px; }
  .cc-hero .hero-stats b { font-size: 22px; }
  .cc-hero h1 { font-size: clamp(38px, 11vw, 64px); }
  .cc-hero-content { padding: 0 24px 50px; }
  .cc-standard, .cc-brief, .cc-audience, .cc-features, .cc-numbers, .cc-procure, .cc-accounts, .cc-fleet-pair, .cc-svc-quote, .cc-trusted, .cc-faq, .cc-final { padding: 70px 24px 80px; }
  .cc-standard-grid { gap: 30px; }
  .cc-standard-r p { font-size: 15px; line-height: 1.7; }
  .cc-standard-r p:first-of-type { font-size: 19px; line-height: 1.45; }
  .cc-brief-head { gap: 18px; margin-bottom: 32px; }
  .cc-brief-head h2, .cc-aud-head h2, .cc-features-head h2, .cc-procure-l h2, .cc-fp-head h2, .cc-faq-head h2 { font-size: clamp(28px, 7vw, 38px); }
  .cc-aud-head, .cc-features-head, .cc-fp-head, .cc-faq-head { gap: 18px; margin-bottom: 32px; }
  .cc-aud, .cc-feat { background: #fff; border: 1px solid var(--r5-border) !important; border-radius: 6px !important; min-height: 0 !important; }
  .cc-aud h3, .cc-feat h3 { font-size: 18px; }
  .cc-num-grid { grid-template-columns: 1fr 1fr !important; display: grid !important; gap: 28px !important; padding: 0; margin: 0; mask-image: none !important; -webkit-mask-image: none !important; }
  .cc-num-cell .big { font-size: 38px; }
  .cc-num-cell { flex: unset !important; min-width: 0 !important; max-width: none; border: 0 !important; }
  .cc-procure-inner { gap: 30px; }
  .cc-procure-r { grid-template-columns: 1fr !important; }
  .cc-procure-cell { padding: 22px 20px; }
  .cc-accounts-inner { grid-template-columns: 1fr !important; }
  .cc-acc-side { padding: 40px 26px; }
  .cc-acc-side h3 { font-size: 24px; }
  .cc-svc-quote blockquote { font-size: 22px; line-height: 1.45; }
  .cc-faq-item { padding: 18px 0; }
  .cc-faq-item summary h3 { font-size: 17px; line-height: 1.3; }
  .cc-faq-item p { font-size: 14px; line-height: 1.7; margin-top: 12px; }
  .cc-final h2 { font-size: clamp(34px, 9vw, 50px); }
  .cc-final p { font-size: 14px; margin-bottom: 32px; }
}
