/* =========================================================
   Multichoice Outdoors — Cinematic homepage layer
   Light & airy · editorial · motion-first
   (loads after main.css; reuses brand variables)
   ========================================================= */

:root{
  --paper: #f6f3ee;       /* warmer airy paper for the cinematic home */
  --paper-2: #efe9e0;
  --edge: rgba(38,43,48,.10);
  --container-wide: 1440px;
}

/* keep the cinematic home on its own airy canvas */
body.cine { background: var(--paper); color: var(--ink); }

.container--wide{ max-width: var(--container-wide); }
.cine section{ position: relative; }

/* ---------- scroll progress ---------- */
.scroll-progress{
  position: fixed; top: 0; left: 0; height: 3px; width: 100%; z-index: 300;
  transform: scaleX(0); transform-origin: 0 50%;
  background: linear-gradient(90deg, var(--clay), var(--sky));
}

/* ---------- grain + atmosphere ---------- */
.grain-fixed{ position: fixed; inset: 0; z-index: 1; pointer-events: none; opacity: .5; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.4'/%3E%3C/svg%3E"); }

/* ---------- masked word reveal ---------- */
.split .w{ display: inline-block; overflow: hidden; vertical-align: top; padding-bottom: .16em; margin-bottom: -.16em; padding-right: .08em; margin-right: -.08em; }
.split .wi{ display: inline-block; will-change: transform; }

/* ---------- editorial type ---------- */
.cine-eyebrow{ font-family: var(--body); text-transform: uppercase; letter-spacing: .34em; font-size: .74rem; font-weight: 600; color: var(--clay);
  display: inline-flex; align-items: center; gap: 12px; }
.cine-eyebrow::before{ content:''; width: 30px; height: 1px; flex: none; background: linear-gradient(90deg, var(--clay), transparent); }
.cine-eyebrow .eb-dot{ display: inline-block; width: 4px; height: 4px; border-radius: 50%; background: currentColor; vertical-align: middle; margin: 0 .18em .12em; }
.cine-title{ font-family: var(--display); font-weight: 800; line-height: 1.0; letter-spacing: -.03em; font-size: clamp(3rem, 9vw, 8.4rem); color: var(--ink); }
.cine-title em{ font-style: italic; font-weight: 600; color: var(--clay); }
.cine-h2{ font-family: var(--display); font-weight: 700; line-height: 1.08; letter-spacing: -.028em; font-size: clamp(2.1rem, 5.4vw, 4.6rem); }
.cine-lead{ font-size: clamp(1.05rem, 1.4vw, 1.25rem); color: var(--ink-soft); line-height: 1.6; }
.idx{ font-family: var(--body); font-weight: 700; font-size: .8rem; letter-spacing: .2em; color: var(--sage); }

/* ---------- header on a light hero (not over a dark hero) ---------- */
.cine .site-header:not(.scrolled){ background: transparent; box-shadow: none; }
.cine .site-header:not(.scrolled):not(.over-hero) .nav-link,
.cine .site-header:not(.scrolled):not(.over-hero) .phone-pill{ color: var(--ink); }
/* keep the current-page link highlighted before scrolling (page indicator) */
.cine .site-header:not(.scrolled):not(.over-hero) .nav-link.active{ color: var(--clay); }
.site-header.home:not(.scrolled) .nav-link.active{ color: var(--clay); }
.site-header.over-hero:not(.scrolled) .nav-link.active{ color: var(--sky); }
/* keep the call pill readable where it sits over the hero image on first load */
.cine .site-header:not(.scrolled):not(.over-hero) .phone-pill{ background: rgba(246,243,238,.72); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); border-color: rgba(38,43,48,.16); }

/* neutralise main.css's CSS-transition reveals on cine pages — GSAP drives them */
.cine [data-reveal]{ opacity: 1; transform: none; transition: none; }

/* ---------- inner-page cinematic polish ---------- */
.cine .h-display, .cine .h-1{ letter-spacing: -.03em; line-height: 1.0; }
.cine .section, .cine .section--tight{ position: relative; }
/* upgrade card & surface hovers site-wide */
.cine .service-card{ transition: transform .55s var(--ease), box-shadow .55s var(--ease); }
.cine .service-card:hover{ transform: translateY(-8px); }
.cine .surface, .cine .rounded-img{ will-change: transform; }
/* page-hero: give inner heroes more editorial air */
.cine .bg-bone2:first-of-type{ background: var(--paper-2); }

/* =====================================================
   1 · CINEMATIC HERO
   ===================================================== */
.cine-hero{ min-height: 100svh; display: grid; grid-template-columns: 1.05fr .95fr; align-items: stretch; overflow: hidden; }
.cine-hero__left{ display: flex; flex-direction: column; justify-content: center; padding: 150px clamp(24px,5vw,90px) 90px; max-width: 820px; }
.cine-hero__left .cine-title{ margin: 26px 0 0; }
.cine-sub{ margin: 30px 0 0; max-width: 440px; }
.cine-cta{ display: flex; align-items: center; gap: 20px; margin-top: 40px; flex-wrap: wrap; }
.cine-hero__media{ position: relative; overflow: hidden; will-change: transform; }
.cine-hero__media img{ position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.cine-hero__media::after{ content:''; position: absolute; inset: 0; background: linear-gradient(100deg, var(--paper) 0%, rgba(246,243,238,.12) 26%, transparent 50%); }
.cine-hero__badge{ position: absolute; left: 28px; bottom: 28px; z-index: 3; display: flex; gap: 22px; align-items: center;
  background: rgba(246,243,238,.72); backdrop-filter: blur(10px); border: 1px solid var(--edge); border-radius: 16px; padding: 14px 20px; }
.cine-hero__badge .n{ font-family: var(--display); font-weight: 800; font-size: 1.5rem; line-height: 1; }
.cine-hero__badge small{ display: block; font-size: .72rem; color: var(--ink-soft); margin-top: 3px; }

.scroll-cue{ position: absolute; left: clamp(24px,5vw,90px); bottom: 34px; z-index: 4; display: inline-flex; align-items: center; gap: 12px;
  font-size: .72rem; letter-spacing: .28em; text-transform: uppercase; color: var(--ink-soft); }
.scroll-cue .bar{ position: relative; width: 46px; height: 1px; background: var(--edge); overflow: hidden; }
.scroll-cue .bar::after{ content:''; position: absolute; inset: 0; width: 40%; background: var(--clay); animation: cue 1.9s var(--ease) infinite; }
@keyframes cue{ 0%{ transform: translateX(-110%);} 60%,100%{ transform: translateX(260%);} }

/* =====================================================
   running word marquee (transition beat)
   ===================================================== */
.cine-marquee{ position: relative; border-top: 1px solid var(--edge); border-bottom: 1px solid var(--edge); padding: 32px 0; overflow: hidden; background: var(--paper);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 9%, #000 91%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 9%, #000 91%, transparent); }
.cine-marquee__row{ display: inline-flex; white-space: nowrap; gap: 0; align-items: center; animation: slide 42s linear infinite; }
@media (hover: hover){ .cine-marquee:hover .cine-marquee__row{ animation-play-state: paused; } }
.cine-marquee__row span{ font-family: var(--display); font-weight: 600; font-size: clamp(1.2rem,2.1vw,1.95rem); letter-spacing: .08em; text-transform: uppercase; color: var(--ink); display: inline-flex; align-items: center; }
.cine-marquee__row span::after{ content: '◆'; color: var(--clay); font-size: .42em; opacity: .8; margin: 0 clamp(28px,3.4vw,52px); transform: translateY(-.18em); }
@keyframes slide{ to{ transform: translateX(-50%);} }

/* =====================================================
   2 · IMMERSIVE PROJECT SHOWCASE (pinned horizontal)
   ===================================================== */
.showcase{ background: var(--ink); color: var(--bone); position: relative; }
.show-sticky{ position: sticky; top: 0; height: 100vh; overflow: hidden; display: flex; align-items: center; }
.showcase .show-intro{ position: absolute; top: 0; left: 0; z-index: 5; padding: 96px clamp(24px,5vw,90px) 0; pointer-events: none; }
.showcase .show-intro .cine-eyebrow{ color: var(--sky); }
.showcase .show-intro .cine-eyebrow::before{ background: linear-gradient(90deg, var(--sky), transparent); }
.show-track{ display: flex; align-items: center; gap: clamp(20px, 2.4vw, 40px); padding: 0 clamp(24px,5vw,90px); width: max-content; will-change: transform; }
.show-panel{ flex: 0 0 auto; width: clamp(360px, 42vw, 560px); height: 68vh; position: relative; border-radius: 22px; overflow: hidden; }
.show-panel:first-child{ margin-left: clamp(24px, 16vw, 240px); }
.show-media{ position: absolute; inset: 0; overflow: hidden; }
.show-media img{ width: 100%; height: 100%; object-fit: cover; will-change: transform; }
.show-panel::after{ content:''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(16,22,26,.82)); }
.show-cap{ position: absolute; left: 0; bottom: 0; z-index: 2; padding: 30px 32px; width: 100%; }
.show-cap .idx{ color: var(--sky); }
.show-cap h3{ font-family: var(--display); font-weight: 700; font-size: clamp(1.5rem,2.4vw,2.2rem); color: var(--bone); margin: 8px 0 4px; letter-spacing: -.02em; }
.show-cap p{ color: rgba(244,247,249,.74); font-size: .95rem; }
.show-cap .tag{ position: absolute; right: 32px; bottom: 34px; font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; color: var(--sky); }
.show-end{ flex: 0 0 auto; width: clamp(300px, 32vw, 460px); display: flex; flex-direction: column; justify-content: center; gap: 22px; padding-left: 20px; }
.show-end h3{ font-family: var(--display); font-weight: 700; font-size: clamp(1.8rem,3vw,2.8rem); color: var(--bone); letter-spacing: -.02em; line-height: 1.02; }

/* =====================================================
   3 · CRAFTSMANSHIP (split reveal)
   ===================================================== */
.craft{ padding: clamp(72px,7.8vw,112px) 0 0; }
.craft__head{ max-width: 760px; }

/* pinned scroll-scrub: the timeline sticks in view while you scroll through this tall track */
.craft__scroll{ position: relative; height: 360vh; margin-top: clamp(-160px,-12vw,-80px); }
.craft__pin{ position: sticky; top: 0; height: 100vh; display: flex; align-items: center; }
.craft__pin > .container{ width: 100%; }

/* ---- interactive horizontal timeline ---- */
.timeline--h{ margin-top: clamp(50px,6vw,76px); --tl-active-x: 10%; }
.craft__pin .timeline--h{ margin-top: 0; }
.tl-rail{ position: relative; display: grid; grid-template-columns: repeat(5, 1fr); }
.tl-track{ position: absolute; left: 10%; right: 10%; top: 27px; height: 6px; background: rgba(38,43,48,.10); border-radius: 99px; box-shadow: inset 0 1px 2px rgba(38,43,48,.08); }
.tl-progress{ position: absolute; left: 0; right: 0; top: 0; height: 100%; border-radius: 99px; background: linear-gradient(90deg, var(--clay), var(--sky)); box-shadow: 0 2px 14px -1px rgba(47,147,201,.6), inset 0 1px 0 rgba(255,255,255,.35); transform-origin: left center; transform: scaleX(0); transition: transform .18s linear; will-change: transform; }
.tl-node{ position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 16px; background: none; border: 0; padding: 0; cursor: pointer; font: inherit; color: inherit; }
.tl-dot{ width: 60px; height: 60px; border-radius: 50%; display: grid; place-items: center; background: #fff; border: 2px solid var(--edge); transition: transform .5s var(--ease), border-color .45s var(--ease), background .45s var(--ease), box-shadow .45s var(--ease); }
.tl-num{ font-family: var(--display); font-weight: 800; font-size: 1rem; color: var(--ink-soft); transition: color .45s var(--ease); }
.tl-label{ font-family: var(--display); font-weight: 600; font-size: .92rem; letter-spacing: -.01em; color: var(--ink-soft); text-align: center; transition: color .45s var(--ease); }
.tl-node:hover .tl-dot{ border-color: rgba(47,147,201,.5); transform: translateY(-2px); }
.tl-node.is-done .tl-dot{ border-color: var(--clay); }
.tl-node.is-done .tl-num{ color: var(--clay); }
.tl-node.is-active .tl-dot{ border-color: transparent; background: linear-gradient(135deg, var(--clay), var(--sky)); box-shadow: 0 14px 30px -8px rgba(47,147,201,.65); transform: scale(1.14); }
.tl-node.is-active .tl-num{ color: #fff; }
.tl-node.is-active .tl-label{ color: var(--ink); }

.tl-stage{ position: relative; margin-top: clamp(36px,4vw,52px); display: grid; }
.tl-panel{ grid-area: 1 / 1; opacity: 0; transform: translateY(14px) scale(.992); pointer-events: none; overflow: hidden; will-change: opacity, transform;
  background: linear-gradient(180deg,#fff,#fcfbf8); border: 1px solid var(--edge); border-radius: 24px; padding: clamp(28px,4vw,48px);
  box-shadow: 0 36px 80px -48px rgba(38,43,48,.5); transition: opacity .55s var(--ease), transform .65s cubic-bezier(.22,.61,.36,1); }
.tl-panel.is-active{ opacity: 1; transform: none; pointer-events: auto; transition-delay: .06s; }
.tl-ghost{ position: absolute; top: -16px; right: 18px; font-family: var(--display); font-weight: 800; line-height: 1; font-size: clamp(7rem,13vw,12rem); color: rgba(47,147,201,.07); pointer-events: none; }
.tl-when{ position: relative; z-index: 1; display: inline-block; font-family: var(--body); font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--clay); font-weight: 700; }
.tl-stage .tl-title{ position: relative; z-index: 1; font-family: var(--display); font-weight: 700; font-size: clamp(1.5rem,2.6vw,2.2rem); color: var(--ink); margin-top: 12px; letter-spacing: -.02em; max-width: 20ch; }
.tl-stage .tl-desc{ position: relative; z-index: 1; color: var(--ink-soft); font-size: clamp(1rem,1.3vw,1.15rem); line-height: 1.6; margin-top: 14px; max-width: 64ch; }

/* ---- clearer "which step am I on" signifiers ---- */
/* future steps recede so the current + completed ones stand out */
.tl-node{ transition: opacity .45s var(--ease); }
.tl-node:not(.is-active):not(.is-done){ opacity: .4; }
.tl-node:not(.is-active):not(.is-done):hover{ opacity: .72; }
/* bolder active label + a live counter total */
.tl-node.is-active .tl-label{ color: var(--ink); font-weight: 800; }
.tl-total{ color: var(--ink-soft); opacity: .5; font-weight: 700; }
/* pulsing ring on the active dot ("you are here") */
.tl-node.is-active .tl-dot{ animation: tl-pulse 2.1s ease-out infinite; }
@keyframes tl-pulse{
  0%{   box-shadow: 0 14px 30px -8px rgba(47,147,201,.6), 0 0 0 0 rgba(47,147,201,.45); }
  70%{  box-shadow: 0 14px 30px -8px rgba(47,147,201,.6), 0 0 0 16px rgba(47,147,201,0); }
  100%{ box-shadow: 0 14px 30px -8px rgba(47,147,201,.6), 0 0 0 0 rgba(47,147,201,0); }
}
/* notch on the panel that tracks under the active node, linking dot -> content */
.tl-stage::before{ content:''; position: absolute; top: -8px; left: var(--tl-active-x,10%); width: 18px; height: 18px;
  background: #fff; border-left: 1px solid var(--edge); border-top: 1px solid var(--edge); border-radius: 4px 0 0 0;
  transform: translateX(-50%) rotate(45deg); z-index: 3; pointer-events: none; transition: left .55s var(--ease); }
@media (max-width: 680px){ .tl-stage::before{ display: none; } }
@media (prefers-reduced-motion: reduce){ .tl-node.is-active .tl-dot{ animation: none; } }

.craft__foot{ margin-top: clamp(44px,5vw,64px); display: flex; align-items: center; justify-content: space-between; gap: 30px; flex-wrap: wrap; padding-top: 34px; border-top: 1px solid var(--edge); }
.craft__stat{ display: flex; align-items: baseline; gap: 14px; }
.craft__stat .n{ font-family: var(--display); font-weight: 800; font-size: clamp(2.4rem,4vw,3.2rem); line-height: 1; color: var(--clay); }
.craft__stat-label{ color: var(--ink-soft); font-size: .95rem; max-width: 280px; }
@media (max-width: 680px){
  .tl-dot{ width: 50px; height: 50px; }
  .tl-track{ top: 22px; }
  .tl-num{ font-size: .9rem; }
  .tl-label{ font-size: .76rem; }
}
@media (max-width: 460px){
  .tl-label{ display: none; }
  .tl-node{ gap: 0; }
}

/* =====================================================
   4 · SERVICES — interactive expanding rows
   ===================================================== */
.svc{ background: var(--ink); color: var(--bone); padding: clamp(72px,7.8vw,112px) 0; overflow: hidden; }
.svc .cine-eyebrow{ color: var(--sky); } .svc .cine-eyebrow::before{ background: linear-gradient(90deg,var(--sky),transparent); }
.svc-list{ margin-top: 50px; border-top: 1px solid var(--line-light); }
.svc-row{ position: relative; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 28px;
  padding: clamp(22px,3vw,38px) 8px; border-bottom: 1px solid var(--line-light); cursor: pointer; transition: padding .5s var(--ease); }
.svc-row .svc-idx{ font-family: var(--body); font-weight: 700; font-size: .82rem; color: var(--sage-soft); letter-spacing: .12em; }
.svc-row .svc-name{ font-family: var(--display); font-weight: 700; font-size: clamp(1.7rem,4vw,3.2rem); letter-spacing: -.02em; color: var(--bone);
  transition: transform .5s var(--ease), color .4s; }
.svc-row .svc-go{ width: 50px; height: 50px; border-radius: 50%; border: 1px solid var(--line-light); display: grid; place-items: center; color: var(--bone);
  transition: background .4s, color .4s, transform .5s var(--ease); flex: none; }
.svc-row .svc-desc{ grid-column: 2 / 3; max-width: 540px; color: rgba(244,247,249,.66); font-size: .98rem; max-height: 0; opacity: 0; overflow: hidden;
  transition: max-height .55s var(--ease), opacity .45s, margin .5s var(--ease); }
.svc-row .svc-thumb{ position: absolute; right: 12%; top: 50%; width: 280px; height: 190px; border-radius: 16px; overflow: hidden; pointer-events: none;
  transform: translateY(-50%) scale(.85); opacity: 0; transition: opacity .5s var(--ease), transform .6s var(--ease); z-index: 3; box-shadow: var(--shadow-soft); }
.svc-row .svc-thumb img{ width: 100%; height: 100%; object-fit: cover; }
.svc-row.is-open{ }
.svc-row.is-open .svc-name{ transform: translateX(16px); color: var(--sky); }
.svc-row.is-open .svc-go{ background: var(--clay); border-color: var(--clay); transform: rotate(-45deg); }
.svc-row.is-open .svc-desc{ max-height: 80px; opacity: 1; margin-top: 14px; }
.svc-row.is-open .svc-thumb{ opacity: 1; transform: translateY(-50%) scale(1); }
@media (hover:none){ .svc-row .svc-thumb{ display:none; } }

/* =====================================================
   5 · PARTNERS — animated reveal band
   ===================================================== */
.cine-partners{ padding: clamp(64px,6.8vw,96px) 0; text-align: center; }
.cine-partners .p-grid{ margin-top: 46px; display: grid; grid-template-columns: repeat(6,1fr); gap: 0; border: 1px solid var(--edge); border-radius: 20px; overflow: hidden; background: #fff; }
.cine-partners .p-cell{ height: 128px; display: flex; align-items: center; justify-content: center; padding: 26px; border-right: 1px solid var(--edge); overflow: hidden; }
.cine-partners .p-cell:last-child{ border-right: 0; }
.cine-partners .p-cell img{ width: auto; max-width: 100%; }

/* ---------- reviews (premium light tiles) ---------- */
.reviews{ padding: clamp(32px,3.4vw,44px) 0 clamp(72px,7.8vw,112px); margin-top: clamp(-160px,-12vw,-80px); text-align: center; }
.reviews__head{ max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; }
.reviews .cine-h2 em{ font-style: italic; font-weight: 600; color: var(--clay); }
.reviews__rating{ margin-top: 26px; display: inline-flex; align-items: center; gap: 12px; padding: 11px 22px; border-radius: 100px;
  background: #fff; border: 1px solid var(--edge); box-shadow: 0 14px 34px -22px rgba(38,43,48,.45); font-size: .94rem; color: var(--ink-soft); }
.reviews__rating .stars{ color: #e3a93b; letter-spacing: 2px; font-size: 1rem; }
.reviews__rating strong{ color: var(--ink); font-weight: 700; }

.rev-grid{ margin-top: 58px; display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; text-align: left; }
.rev-card{ position: relative; overflow: hidden; display: flex; flex-direction: column; gap: 18px; padding: 40px 34px 30px;
  background: linear-gradient(180deg, #fff, #fcfbf8); border: 1px solid var(--edge); border-radius: 24px;
  box-shadow: 0 30px 60px -36px rgba(38,43,48,.30), 0 2px 5px rgba(38,43,48,.035);
  transition: transform .55s var(--ease), box-shadow .55s var(--ease), border-color .45s var(--ease); }
.rev-card::before{ content: ''; position: absolute; left: 0; right: 0; top: 0; height: 3px; opacity: 0; transform: scaleX(.4); transform-origin: left;
  background: linear-gradient(90deg, var(--clay), var(--sky)); transition: opacity .45s var(--ease), transform .55s var(--ease); }
.rev-card:hover{ transform: translateY(-8px); border-color: rgba(47,147,201,.22);
  box-shadow: 0 46px 84px -40px rgba(38,43,48,.42), 0 3px 8px rgba(38,43,48,.05); }
.rev-card:hover::before{ opacity: 1; transform: scaleX(1); }
.rev-card__q{ position: absolute; top: 14px; right: 26px; font-family: var(--display); font-weight: 800; font-size: 6rem; line-height: 1;
  color: rgba(47,147,201,.10); pointer-events: none; }
.rev-card__stars{ position: relative; z-index: 1; color: #e3a93b; letter-spacing: 3px; font-size: 1.05rem; }
.rev-card blockquote{ position: relative; z-index: 1; margin: 0; font-size: 1.07rem; line-height: 1.64; color: var(--ink); }
.rev-card figcaption{ display: flex; align-items: center; gap: 13px; margin-top: auto; padding-top: 22px; border-top: 1px solid var(--edge); }
.rev-av{ width: 48px; height: 48px; border-radius: 50%; display: grid; place-items: center; flex-shrink: 0;
  background: linear-gradient(135deg, var(--clay), var(--sky)); color: #fff; font-family: var(--display); font-weight: 700; font-size: .95rem;
  box-shadow: 0 8px 18px -8px rgba(47,147,201,.6); }
.rev-who{ display: flex; flex-direction: column; line-height: 1.3; }
.rev-who strong{ font-family: var(--display); font-weight: 700; font-size: 1rem; color: var(--ink); }
.rev-who small{ color: var(--ink-soft); font-size: .85rem; margin-top: 2px; }
.rev-verified{ margin-left: auto; display: grid; place-items: center; width: 26px; height: 26px; border-radius: 50%; flex-shrink: 0;
  background: rgba(47,147,201,.10); color: var(--clay); }
.rev-verified svg{ width: 15px; height: 15px; }
@media (max-width: 920px){ .rev-grid{ grid-template-columns: 1fr; max-width: 560px; margin-left: auto; margin-right: auto; } }

/* ---------- FAQ (home) ---------- */
.faq-sec{ padding: clamp(64px,6.8vw,102px) 0; }
.faq-grid{ display: grid; grid-template-columns: .82fr 1.18fr; gap: clamp(36px,6vw,90px); align-items: start; }
.faq-intro .cine-h2{ font-size: clamp(1.9rem,4vw,3.2rem); }
.faq-list{ display: flex; flex-direction: column; gap: 14px; }
.faq-item{ background: linear-gradient(180deg,#fff,#fcfbf8); border: 1px solid var(--edge); border-radius: 18px; overflow: hidden; transition: border-color .4s var(--ease), box-shadow .4s var(--ease); }
.faq-item[open]{ border-color: rgba(47,147,201,.28); box-shadow: 0 26px 54px -40px rgba(38,43,48,.45); }
.faq-item summary{ list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 22px clamp(20px,2.4vw,28px); font-family: var(--display); font-weight: 600; font-size: clamp(1.05rem,1.5vw,1.22rem); color: var(--ink); letter-spacing: -.01em; }
.faq-item summary::-webkit-details-marker{ display: none; }
.faq-plus{ position: relative; width: 20px; height: 20px; flex: none; }
.faq-plus::before, .faq-plus::after{ content: ''; position: absolute; background: var(--clay); border-radius: 2px; transition: transform .35s var(--ease), opacity .35s var(--ease); }
.faq-plus::before{ top: 9px; left: 0; width: 20px; height: 2px; }
.faq-plus::after{ left: 9px; top: 0; width: 2px; height: 20px; }
.faq-item[open] .faq-plus::after{ transform: rotate(90deg); opacity: 0; }
.faq-a{ padding: 0 clamp(20px,2.4vw,28px) 24px; color: var(--ink-soft); font-size: 1rem; line-height: 1.65; max-width: 62ch; }
@media (max-width: 860px){ .faq-grid{ grid-template-columns: 1fr; gap: 30px; } }
.cine-partners .p-cell:nth-child(1) img{ max-height: 42px; }
.cine-partners .p-cell:nth-child(2) img{ max-height: 32px; }
.cine-partners .p-cell:nth-child(3) img{ max-height: 30px; }
.cine-partners .p-cell:nth-child(4) img{ max-height: 54px; }
.cine-partners .p-cell:nth-child(5) img{ max-height: 110px; max-width: none; }
.cine-partners .p-cell:nth-child(6) img{ max-height: 84px; max-width: none; }

/* =====================================================
   6 · LOCATIONS toggle
   ===================================================== */
/* ---------- locations (premium dark band) ---------- */
.loc{ position: relative; overflow: hidden; background: var(--ink); color: var(--bone); padding: clamp(72px,7.8vw,112px) 0; }
.loc .container{ position: relative; z-index: 1; }
.loc__glow{ position: absolute; top: -22%; left: -12%; width: 60%; height: 130%; z-index: 0; pointer-events: none; background: radial-gradient(ellipse at center, rgba(95,190,240,.15), transparent 62%); }
.loc .cine-eyebrow{ color: var(--sky); }
.loc .cine-eyebrow::before{ background: linear-gradient(90deg, var(--sky), transparent); }
.loc .cine-h2{ color: var(--bone); }
.loc__head{ display: flex; flex-direction: column; align-items: flex-start; gap: 24px; margin-bottom: 46px; }
.loc__tabs{ display: inline-flex; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: 100px; padding: 6px; margin-bottom: 22px; }
.loc__tabs button{ border: 0; background: transparent; font-family: var(--display); font-weight: 700; font-size: 1rem; padding: 12px 30px; border-radius: 100px; cursor: pointer; color: rgba(244,247,249,.7); transition: color .35s var(--ease), background .35s var(--ease), box-shadow .35s var(--ease); }
.loc__tabs button.active{ background: linear-gradient(135deg, var(--clay), var(--sky)); color: #fff; box-shadow: 0 12px 26px -8px rgba(47,147,201,.6); }
.loc__stage{ position: relative; }
.loc__pane{ position: absolute; inset: 0; opacity: 0; visibility: hidden; transform: translateY(16px); transition: opacity .6s var(--ease), transform .6s var(--ease), visibility .6s; }
.loc__pane.active{ position: relative; opacity: 1; visibility: visible; transform: none; }
.loc__inner{ display: grid; grid-template-columns: 1.12fr .88fr; gap: clamp(34px,5vw,72px); align-items: center; }
.loc__media{ position: relative; border-radius: 24px; overflow: hidden; aspect-ratio: 16/11; box-shadow: 0 48px 90px -44px rgba(0,0,0,.7); }
.loc__media img{ width: 100%; height: 100%; object-fit: cover; transition: transform 8s ease; }
.loc__pane.active .loc__media img{ transform: scale(1.06); }
.loc__media::after{ content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 48%, rgba(16,22,26,.55)); }
.loc__badge{ position: absolute; left: 18px; top: 18px; z-index: 2; font-family: var(--body); font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; font-weight: 600; color: #fff; background: rgba(16,22,26,.5); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); padding: 8px 14px; border-radius: 99px; border: 1px solid rgba(255,255,255,.14); }
.loc__city{ font-family: var(--display); font-weight: 800; font-size: clamp(2.4rem,4.5vw,3.6rem); letter-spacing: -.03em; line-height: 1; color: var(--bone); }
.loc__lead{ color: rgba(244,247,249,.78); font-size: clamp(1.05rem,1.4vw,1.2rem); line-height: 1.62; margin-top: 18px; max-width: 440px; }
.loc__chips{ display: flex; flex-wrap: wrap; gap: 9px; margin: 24px 0 30px; }
.loc__chips .chip{ background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.13); color: rgba(244,247,249,.86); }
.loc__chips .chip .dot{ background: var(--sky); }

/* =====================================================
   7 · CINEMATIC CLOSING CTA
   ===================================================== */
.cine-cta-sec{ position: relative; min-height: 96vh; display: flex; align-items: center; overflow: hidden; color: var(--bone); }
.cine-cta-sec__bg{ position: absolute; inset: 0; z-index: 0; background: #10161a; }
.cine-cta-sec__bg img{ width: 100%; height: 120%; object-fit: cover; object-position: center top; }
.cine-cta-sec__bg::after{ content:''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(16,22,26,.7), rgba(16,22,26,.82)); }
.cine-cta-sec .container{ position: relative; z-index: 2; padding-top: 104px; padding-bottom: 104px; }
.cine-cta-sec .big{ font-family: var(--display); font-weight: 800; font-size: clamp(2.6rem,8vw,7rem); line-height: .94; letter-spacing: -.035em; max-width: 16ch; }
.cine-cta-sec em{ font-style: italic; color: var(--sky); font-weight: 600; }

/* =====================================================
   buttons (cinematic variants build on main.css)
   ===================================================== */
.btn--xl{ padding: 1.25em 2.1em; font-size: 1.05rem; }
.btn--line{ background: transparent; border: 1px solid currentColor; color: inherit; }
.btn--line:hover{ background: currentColor; }
.btn--line:hover span{ color: var(--paper); }
.link-underline{ position: relative; font-weight: 600; }
.link-underline::after{ content:''; position: absolute; left: 0; bottom: -4px; width: 100%; height: 2px; background: currentColor; transform: scaleX(0); transform-origin: right; transition: transform .45s var(--ease); }
.link-underline:hover::after{ transform: scaleX(1); transform-origin: left; }

/* btn sheen */
.btn--primary{ position: relative; overflow: hidden; }
.btn--primary::after{ content:''; position: absolute; top: 0; left: -130%; width: 55%; height: 100%; transform: skewX(-18deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent); transition: left .6s var(--ease); }
.btn--primary:hover::after{ left: 150%; }

/* =====================================================
   responsive
   ===================================================== */
@media (max-width: 1024px){
  .craft__grid{ grid-template-columns: 1fr; } .craft__media{ aspect-ratio: 16/11; }
  .loc__inner{ grid-template-columns: 1fr; }
}
@media (max-width: 880px){
  .cine-hero{ grid-template-columns: 1fr; min-height: auto; }
  .cine-hero__left{ padding: 100px 24px 44px; }
  .cine-hero__media{ height: 62vh; }
  .cine-hero__media::after{ background: linear-gradient(180deg, transparent 60%, var(--paper)); }
  .scroll-cue{ display: none; }
  .showcase{ height: auto !important; }
  .show-sticky{ position: static; height: auto; overflow: visible; display: block; }
  .show-track{ width: auto; transform: none !important; overflow-x: auto; scroll-snap-type: x proximity; overscroll-behavior-x: contain; scroll-padding-left: 20px; padding: 20px 20px 40px; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .show-track::-webkit-scrollbar{ display: none; }
  .show-panel{ width: 78vw; height: 58vh; scroll-snap-align: start; } .show-panel:first-child{ margin-left: 0; }
  .show-intro{ position: static !important; padding: 24px 20px 6px !important; }
  .show-end{ width: 70vw; }
  .cine-partners .p-grid{ grid-template-columns: repeat(3,1fr); }
  .cine-partners .p-cell:nth-child(3n){ border-right: 0; }
  .cine-partners .p-cell{ border-bottom: 1px solid var(--edge); }
  .svc-row{ grid-template-columns: auto 1fr auto; }
  .svc-row .svc-thumb{ display: none; }
}
@media (max-width: 520px){
  .cine-partners .p-grid{ grid-template-columns: repeat(2,1fr); }
  /* 2-col: right border on left column (incl. Colorbond), none on right column */
  .cine-partners .p-cell:nth-child(3n){ border-right: 1px solid var(--edge); }
  .cine-partners .p-cell:nth-child(2n){ border-right: 0; }
  .cine-cta{ gap: 14px; }
}

/* Home hero eyebrow: keep "Adelaide & Sydney ·" on one line, "Outdoor Living" beneath */
@media (max-width: 560px){
  .cine-hero .cine-eyebrow{ align-items: flex-start; line-height: 1.5; }
  .cine-hero .cine-eyebrow::before{ margin-top: 7px; }
  .cine-hero .cine-eyebrow .eb-city{ display: block; margin-top: 1px; }
  /* Locations hero stats: stack + left-align so they line up neatly */
  .loc-hero-stats{ flex-direction: column !important; align-items: flex-start !important; gap: 9px !important; }
  .loc-hero-stats .sep{ display: none !important; }
}

/* ============ MOBILE POLISH (phones) ============ */
@media (max-width: 880px){
  /* Timeline: keep the original tap-through rail look, just remove the pinned scroll-scrub */
  .craft{ padding: clamp(56px,11vw,84px) 0 clamp(28px,7vw,48px); }
  .craft__scroll{ height: auto !important; margin-top: clamp(14px,4vw,26px) !important; }
  .craft__pin{ position: static !important; height: auto !important; display: block !important; }
  .reviews{ margin-top: clamp(20px,5vw,34px) !important; }

  /* CTA quote section: drop the low-res photo, use a premium dark pattern */
  .cine-cta-sec__bg img{ display: none !important; }
  .cine-cta-sec__bg::after{ display: none !important; }
  .cine-cta-sec__bg{
    background-color: #0f1a22;
    background-image:
      radial-gradient(120% 80% at 8% -10%, rgba(47,147,201,.30), transparent 58%),
      radial-gradient(110% 70% at 108% 112%, rgba(95,190,240,.18), transparent 55%),
      repeating-linear-gradient(135deg, rgba(255,255,255,.035) 0 1.5px, transparent 1.5px 22px),
      linear-gradient(158deg, #14232f, #0d151b);
  }
}
