/* =========================================================================
   FloDo Access — Website Mockup
   Design system + components + motion
   Aesthetic: "discreet vault" — deep navy, brass accents, cinematic imagery
   Built by Gamma Advertising | Mockup v1
   ========================================================================= */

/* ---------- Tokens ---------- */
:root{
  /* Brand */
  --navy-900:#070d1f;
  --navy-800:#0a1430;
  --navy-700:#0e1c43;
  --navy-600:#122a5c;
  --navy-500:#1c3a73;
  --blue-400:#3f6fb5;
  --blue-300:#5b8def;
  --blue-200:#b9cbe6;
  --red:#e0473b;
  --red-dark:#b8362c;

  /* Metallics — from the product's brass hardware / gold valuables */
  --gold:#c9a86a;
  --gold-bright:#e4c98a;
  --gold-deep:#9b7d44;

  /* Neutrals */
  --cream:#f5f2ea;
  --cream-2:#ece7db;
  --ink:#141a2b;
  --ink-soft:#3a4256;
  --paper:#ffffff;

  /* Text */
  --t-hi:#f6f8fc;
  --t-mid:#c4cee0;
  --t-low:#8593ad;
  --t-ink:#1a2238;
  --t-ink-soft:#566079;

  /* Lines & surfaces */
  --line:rgba(255,255,255,.10);
  --line-soft:rgba(255,255,255,.06);
  --surface:rgba(255,255,255,.03);
  --surface-2:rgba(255,255,255,.05);

  /* Type */
  --display:"Archivo","Inter",system-ui,sans-serif;
  --sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  /* Layout */
  --wrap:1240px;
  --wrap-narrow:880px;
  --radius:14px;
  --radius-lg:22px;
  --gap:clamp(20px,4vw,40px);
  --section-y:clamp(72px,11vw,150px);

  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--sans);
  background:var(--navy-800);
  color:var(--t-mid);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
::selection{background:var(--gold);color:var(--navy-900)}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--display);color:var(--t-hi);font-weight:800;line-height:1.04;letter-spacing:-.025em}
.display{font-size:clamp(2.8rem,7.2vw,5.6rem);font-weight:800;letter-spacing:-.035em;line-height:.98}
h2.section-title{font-size:clamp(2.05rem,4.6vw,3.45rem);font-weight:800}
h3{font-size:clamp(1.25rem,2.2vw,1.55rem);font-weight:700;letter-spacing:-.02em}
.serif-italic{font-style:normal;color:var(--gold);font-weight:inherit}
.eyebrow{
  font-family:var(--sans);font-weight:600;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);opacity:.7}
.eyebrow.center::after{content:"";width:26px;height:1px;background:var(--gold);opacity:.7}
.eyebrow.center{justify-content:center}
.lead{font-size:clamp(1.05rem,1.7vw,1.28rem);color:var(--t-mid);line-height:1.62}
.muted{color:var(--t-low)}

/* ---------- Layout ---------- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.narrow{max-width:var(--wrap-narrow)}
.section{padding:var(--section-y) 0}
.center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}
.stack-sm>*+*{margin-top:14px}
.eyebrow+h2,.eyebrow+h1{margin-top:18px}
.section-head{max-width:720px;margin-bottom:clamp(36px,5vw,60px)}
.section-head.center{margin-inline:auto}
.section-head p{margin-top:18px}

/* tone variants */
.tone-light{background:var(--cream);color:var(--t-ink-soft)}
.tone-light h1,.tone-light h2,.tone-light h3,.tone-light h4{color:var(--t-ink)}
.tone-light .lead{color:var(--t-ink-soft)}
.tone-light .eyebrow{color:var(--gold-deep)}
.tone-light .eyebrow::before,.tone-light .eyebrow.center::after{background:var(--gold-deep)}
.tone-deep{background:var(--navy-900)}
.tone-grad{background:linear-gradient(180deg,var(--navy-800),var(--navy-900))}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-weight:600;font-size:.95rem;letter-spacing:.01em;
  padding:15px 28px;border-radius:100px;position:relative;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s,color .3s;
  white-space:nowrap;line-height:1;
}
.btn .arrow{transition:transform .35s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-primary{background:var(--gold);color:var(--navy-900);box-shadow:0 10px 30px -10px rgba(201,168,106,.55)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px -10px rgba(201,168,106,.7);background:var(--gold-bright)}
.btn-light{background:var(--t-hi);color:var(--navy-900)}
.btn-light:hover{transform:translateY(-2px);background:#fff}
.btn-ghost{border:1px solid var(--line);color:var(--t-hi)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.tone-light .btn-ghost{border-color:rgba(20,26,43,.18);color:var(--t-ink)}
.tone-light .btn-ghost:hover{border-color:var(--gold-deep);color:var(--gold-deep)}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red-dark);transform:translateY(-2px)}
.btn-lg{padding:18px 36px;font-size:1.02rem}
.btn-sm{padding:11px 20px;font-size:.85rem}
.btn-block{width:100%}
.link-arrow{display:inline-flex;align-items:center;gap:.5em;font-weight:600;color:var(--gold);font-size:.95rem;transition:gap .3s}
.link-arrow:hover{gap:.9em}
.tone-light .link-arrow{color:var(--gold-deep)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .4s var(--ease),backdrop-filter .4s,border-color .4s,padding .4s;
  border-bottom:1px solid transparent;padding:18px 0;
}
.site-header.scrolled{
  background:rgba(7,13,31,.82);backdrop-filter:blur(16px) saturate(1.3);
  border-bottom-color:var(--line-soft);padding:11px 0;
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px;z-index:2}
.brand img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  font-size:.9rem;font-weight:500;color:var(--t-mid);padding:9px 14px;border-radius:8px;
  position:relative;transition:color .25s;
}
.nav-links a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:5px;height:1px;background:var(--gold);
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);
}
.nav-links a:hover{color:var(--t-hi)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{color:var(--t-hi)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-cta .cart-btn{display:flex;align-items:center;gap:7px;color:var(--t-mid);font-size:.88rem;font-weight:500;transition:color .25s;position:relative}
.nav-cta .cart-btn:hover{color:var(--gold)}
.cart-count{position:absolute;top:-7px;right:-10px;background:var(--red);color:#fff;font-size:.62rem;font-weight:700;min-width:16px;height:16px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.menu-toggle{display:none;flex-direction:column;gap:5px;padding:8px;z-index:2}
.menu-toggle span{width:24px;height:2px;background:var(--t-hi);border-radius:2px;transition:.3s var(--ease)}
.menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding-top:120px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:120%;object-fit:cover;will-change:transform}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg,var(--navy-900) 8%,rgba(7,13,31,.72) 42%,rgba(7,13,31,.25) 78%),
    linear-gradient(0deg,var(--navy-900) 2%,transparent 42%);
}
.hero-inner{position:relative;z-index:2;max-width:760px}
.hero h1{margin:22px 0 0}
.hero .lead{margin:26px 0 38px;max-width:540px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:9px;color:var(--t-low);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase}
.hero-scroll .line{width:1px;height:46px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.hero-scroll .line::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--gold-bright);animation:scrolldot 2.2s var(--ease) infinite}
@keyframes scrolldot{0%{top:-50%}60%,100%{top:120%}}

/* small page hero (interior pages) */
.page-hero{position:relative;padding:190px 0 clamp(60px,9vw,110px);overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 80% -10%,rgba(63,111,181,.22),transparent 60%)}
.page-hero .eyebrow{margin-bottom:18px}
.page-hero h1{font-size:clamp(2.4rem,5.4vw,4.1rem)}
.page-hero p{max-width:560px;margin-top:20px}
.page-hero.with-img::after{content:"";position:absolute;inset:0;z-index:-1}

/* ---------- Trust strip ---------- */
.trust-strip{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);background:var(--navy-900)}
.trust-strip .wrap{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-top:26px;padding-bottom:26px}
.trust-item{display:flex;align-items:center;gap:12px;color:var(--t-mid);font-size:.9rem;font-weight:500}
.trust-item svg{color:var(--gold);flex-shrink:0}

/* ---------- Feature columns ---------- */
.cols-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.cols-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap)}
.feature{padding:34px 30px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);transition:transform .5s var(--ease),border-color .5s,background .5s;position:relative;overflow:hidden}
.feature::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),transparent);transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease)}
.feature:hover{transform:translateY(-6px);border-color:rgba(201,168,106,.35);background:var(--surface-2)}
.feature:hover::before{transform:scaleX(1)}
.feature .ico{width:52px;height:52px;border-radius:13px;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,rgba(201,168,106,.18),rgba(201,168,106,.04));color:var(--gold);margin-bottom:22px;border:1px solid rgba(201,168,106,.22)}
.feature h3{margin-bottom:10px}
.feature p{font-size:.96rem}
.tone-light .feature{background:#fff;border-color:rgba(20,26,43,.08);box-shadow:0 1px 0 rgba(20,26,43,.03)}
.tone-light .feature:hover{border-color:rgba(155,125,68,.35);box-shadow:0 24px 50px -30px rgba(20,26,43,.25)}
.tone-light .feature p{color:var(--t-ink-soft)}

/* ---------- Split media ---------- */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(34px,5vw,72px);align-items:center}
.split.rev .split-media{order:2}
.split-media{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3.2}
.split-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.split-media:hover img{transform:scale(1.05)}
.split-media .tag{position:absolute;left:18px;bottom:18px;background:rgba(7,13,31,.7);backdrop-filter:blur(8px);border:1px solid var(--line);color:var(--t-hi);font-size:.78rem;font-weight:600;padding:9px 16px;border-radius:100px}
.split-body .checklist{margin-top:26px}
.checklist li{display:flex;gap:13px;align-items:flex-start;padding:11px 0;border-bottom:1px solid var(--line-soft);font-size:1rem}
.checklist li:last-child{border-bottom:none}
.checklist .chk{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:rgba(201,168,106,.15);color:var(--gold);display:flex;align-items:center;justify-content:center;margin-top:1px}
.tone-light .checklist li{color:var(--t-ink)}
.tone-light .checklist li{border-color:rgba(20,26,43,.08)}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);counter-reset:step;position:relative}
.steps::before{content:"";position:absolute;top:28px;left:9%;right:9%;height:2px;z-index:0;background:linear-gradient(90deg,var(--gold-deep),var(--gold) 50%,var(--gold-deep));opacity:.45}
.step{position:relative;padding-top:80px}
.step::before{
  counter-increment:step;content:counter(step,decimal-leading-zero);
  position:absolute;top:0;left:0;width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:1.3rem;font-weight:800;color:var(--navy-900);
  background:linear-gradient(145deg,var(--gold-bright),var(--gold-deep));
  box-shadow:0 14px 30px -12px rgba(201,168,106,.6);
  -webkit-text-stroke:0;opacity:1;line-height:1;margin:0;z-index:2;
}
.step h3{margin-bottom:9px}
.step p{font-size:.95rem}
.step-line{display:none}
@media (max-width:980px){.steps::before{display:none}}

/* ---------- Stat band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat .num{font-family:var(--display);font-size:clamp(2.4rem,4.6vw,3.6rem);color:var(--gold-bright);line-height:1}
.stat .lbl{font-size:.82rem;letter-spacing:.06em;color:var(--t-low);margin-top:10px;text-transform:uppercase}

/* ---------- Image showcase / parallax band ---------- */
.showband{position:relative;min-height:62vh;display:flex;align-items:center;overflow:hidden}
.showband .pbg{position:absolute;inset:0;z-index:0}
.showband .pbg img{width:100%;height:128%;object-fit:cover;will-change:transform}
.showband .pbg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,13,31,.55),rgba(7,13,31,.78))}
.showband .wrap{position:relative;z-index:2}
.showband blockquote{font-family:var(--display);font-size:clamp(1.6rem,3.4vw,2.7rem);color:var(--t-hi);max-width:880px;line-height:1.22;font-weight:400}
.showband cite{display:block;margin-top:24px;font-family:var(--sans);font-style:normal;font-size:.92rem;color:var(--gold);letter-spacing:.05em}

/* ---------- CTA band ---------- */
.cta-band{position:relative;text-align:center;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(90% 130% at 50% 0%,rgba(63,111,181,.2),transparent 55%)}
.cta-band .wrap{position:relative;z-index:2}
.cta-band h2{font-size:clamp(2.1rem,4.6vw,3.4rem)}
.cta-band p{max-width:520px;margin:20px auto 36px}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- Cards / community ---------- */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:26px}
.card{border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);transition:transform .5s var(--ease),border-color .5s}
.card:hover{transform:translateY(-6px);border-color:rgba(201,168,106,.3)}
.card .ph{aspect-ratio:16/10;overflow:hidden;position:relative}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.card:hover .ph img{transform:scale(1.06)}
.card .ph .badge{position:absolute;top:14px;left:14px;background:var(--gold);color:var(--navy-900);font-size:.72rem;font-weight:700;padding:6px 12px;border-radius:100px;letter-spacing:.03em}
.card .body{padding:24px}
.card .body .meta{font-size:.78rem;color:var(--gold);letter-spacing:.05em;text-transform:uppercase;font-weight:600;margin-bottom:9px}
.card .body h3{font-size:1.2rem;margin-bottom:10px}
.card .body p{font-size:.92rem}

/* ---------- Team ---------- */
.owner-split{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(34px,5vw,68px);align-items:center}
.owner-photo{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/4.4;background:linear-gradient(145deg,var(--navy-600),var(--navy-800))}
.owner-photo img{width:100%;height:100%;object-fit:cover}
.owner-photo .frame-note{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--t-low);text-align:center;padding:30px}
.owner-photo .frame-note .av{width:96px;height:96px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:2rem;color:var(--gold)}
.quote-lg{font-family:var(--display);font-size:clamp(1.3rem,2.4vw,1.85rem);color:var(--t-hi);line-height:1.34;font-weight:400;margin:26px 0;padding-left:24px;border-left:2px solid var(--gold)}
.role-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:10px}
.role-card{padding:24px 20px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);text-align:center}
.role-card .ico{color:var(--gold);margin:0 auto 14px}
.role-card h4{font-size:1.02rem;color:var(--t-hi);margin-bottom:6px}
.role-card p{font-size:.85rem}

/* ---------- FAQ ---------- */
.faq-tabs{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:46px}
.faq-tab{padding:10px 20px;border:1px solid var(--line);border-radius:100px;font-size:.86rem;font-weight:600;color:var(--t-mid);transition:.3s}
.faq-tab:hover{color:var(--t-hi);border-color:var(--gold)}
.faq-tab.active{background:var(--gold);color:var(--navy-900);border-color:var(--gold)}
.faq-group{margin-bottom:44px}
.faq-group>h3{font-size:1.3rem;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line-soft)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:20px;width:100%;text-align:left;padding:22px 4px;font-size:1.05rem;font-weight:600;color:var(--t-hi);font-family:var(--sans)}
.faq-q .pm{flex-shrink:0;width:26px;height:26px;border-radius:50%;border:1px solid var(--gold);color:var(--gold);display:flex;align-items:center;justify-content:center;transition:transform .4s var(--ease),background .3s,color .3s;position:relative}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:currentColor;border-radius:2px}
.faq-q .pm::before{width:11px;height:1.6px}
.faq-q .pm::after{width:1.6px;height:11px;transition:transform .4s var(--ease)}
.faq-item.open .faq-q .pm{background:var(--gold);color:var(--navy-900)}
.faq-item.open .faq-q .pm::after{transform:rotate(90deg) scaleX(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq-a-inner{padding:0 4px 24px;font-size:.98rem;color:var(--t-mid);max-width:760px}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
.field label{font-size:.8rem;font-weight:600;letter-spacing:.04em;color:var(--t-mid);text-transform:uppercase}
.field input,.field select,.field textarea{
  background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:14px 16px;
  color:var(--t-hi);font-family:inherit;font-size:.98rem;transition:border-color .3s,background .3s;
}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:rgba(201,168,106,.05)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23c9a86a' d='M6 8 0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.field input::placeholder,.field textarea::placeholder{color:var(--t-low)}
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(34px,5vw,64px);align-items:start}
.contact-info{border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px;background:var(--surface)}
.contact-info .row{display:flex;gap:15px;padding:18px 0;border-bottom:1px solid var(--line-soft);align-items:flex-start}
.contact-info .row:last-child{border-bottom:none}
.contact-info .ico{color:var(--gold);flex-shrink:0;margin-top:2px}
.contact-info .row .k{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--t-low);margin-bottom:3px}
.contact-info .row .v{color:var(--t-hi);font-weight:500}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-900);border-top:1px solid var(--line-soft);padding:70px 0 34px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:46px;border-bottom:1px solid var(--line-soft)}
.foot-brand img{height:36px;margin-bottom:20px}
.foot-brand p{font-size:.92rem;max-width:320px;color:var(--t-low)}
.foot-col h4{font-family:var(--sans);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--t-low);margin-bottom:18px;font-weight:600}
.foot-col a{display:block;font-size:.94rem;color:var(--t-mid);padding:6px 0;transition:color .25s,padding-left .25s}
.foot-col a:hover{color:var(--gold);padding-left:5px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding-top:26px}
.foot-bottom p{font-size:.82rem;color:var(--t-low)}
.foot-legal{font-size:.78rem;color:var(--t-low);max-width:640px;line-height:1.55;margin-top:14px}
.foot-social{display:flex;gap:12px}
.foot-social a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--t-mid);transition:.3s}
.foot-social a:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-3px)}

/* ---------- Product / commerce ---------- */
.product-hero{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,4vw,56px);align-items:center;padding-top:160px}
.gallery-main{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3.3;border:1px solid var(--line);position:relative}
.gallery-main img{width:100%;height:100%;object-fit:cover}
.gallery-thumbs{display:flex;gap:12px;margin-top:14px}
.gallery-thumbs button{flex:1;border-radius:11px;overflow:hidden;aspect-ratio:4/3;border:1px solid var(--line);opacity:.55;transition:.3s}
.gallery-thumbs button.active{opacity:1;border-color:var(--gold)}
.gallery-thumbs img{width:100%;height:100%;object-fit:cover}
.buybox .price{display:flex;align-items:baseline;gap:12px;margin:18px 0}
.buybox .price .now{font-family:var(--display);font-size:2.6rem;color:var(--t-hi)}
.buybox .price .note{font-size:.86rem;color:var(--t-low)}
.opt-group{margin:22px 0}
.opt-group .opt-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--t-mid);font-weight:600;margin-bottom:11px;display:flex;justify-content:space-between}
.opt-row{display:flex;gap:10px;flex-wrap:wrap}
.opt{border:1px solid var(--line);border-radius:11px;padding:12px 16px;font-size:.9rem;color:var(--t-mid);font-weight:500;transition:.25s;background:var(--surface);text-align:left}
.opt small{display:block;color:var(--t-low);font-size:.74rem;font-weight:400;margin-top:2px}
.opt:hover{border-color:rgba(201,168,106,.4);color:var(--t-hi)}
.opt.selected{border-color:var(--gold);background:rgba(201,168,106,.08);color:var(--t-hi)}
.opt.selected small{color:var(--gold)}
.qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:11px;overflow:hidden}
.qty button{padding:12px 16px;color:var(--t-hi);font-size:1.1rem;transition:background .2s}
.qty button:hover{background:var(--surface-2)}
.qty input{width:48px;text-align:center;background:none;border:none;color:var(--t-hi);font-size:1rem;font-family:inherit}
.buy-actions{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}
.buy-trust{display:flex;flex-wrap:wrap;gap:18px;margin-top:24px;padding-top:24px;border-top:1px solid var(--line-soft)}
.buy-trust span{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--t-low)}
.buy-trust svg{color:var(--gold)}
.spec-table{width:100%;border-collapse:collapse;margin-top:10px}
.spec-table tr{border-bottom:1px solid var(--line-soft)}
.spec-table td{padding:15px 4px;font-size:.96rem}
.spec-table td:first-child{color:var(--t-low);width:42%}
.spec-table td:last-child{color:var(--t-hi);font-weight:500;text-align:right}
.tbc{font-style:italic;color:var(--t-low)!important;font-weight:400!important}

/* ---------- Cart drawer ---------- */
.drawer-overlay{position:fixed;inset:0;background:rgba(7,13,31,.6);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:.4s;z-index:200}
.drawer-overlay.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(440px,100%);background:var(--navy-800);border-left:1px solid var(--line);transform:translateX(100%);transition:transform .5s var(--ease);z-index:201;display:flex;flex-direction:column;overflow:hidden}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--line-soft)}
.drawer-head h3{font-size:1.2rem}
.drawer-close{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);color:var(--t-hi);display:flex;align-items:center;justify-content:center;transition:.3s}
.drawer-close:hover{border-color:var(--gold);color:var(--gold);transform:rotate(90deg)}
.drawer-body{flex:1;overflow-y:auto;padding:20px 24px;position:relative}
.cart-line{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line-soft);position:relative;padding-right:28px}
.cart-line img{width:72px;height:64px;object-fit:cover;border-radius:9px;flex-shrink:0}
.cart-line .cl-info{flex:1;min-width:0}
.cart-line .cl-info h4{font-family:var(--sans);font-size:.95rem;color:var(--t-hi);margin-bottom:3px;padding-right:8px}
.cart-line .cl-opt{font-size:.78rem;color:var(--t-low)}
.cart-line .cl-price{color:var(--gold);font-weight:600;font-size:.95rem;flex-shrink:0;align-self:flex-start;padding-top:2px}
.cart-line .cl-remove{font-size:.76rem;color:var(--t-low);margin-top:6px;text-align:left}
.cart-line .cl-remove:hover{color:var(--red)}
.cart-line .cl-line-close{position:absolute;top:14px;right:0;width:26px;height:26px;border-radius:50%;border:1px solid var(--line);color:var(--t-low);display:flex;align-items:center;justify-content:center;font-size:.72rem;line-height:1;transition:.25s;flex-shrink:0}
.cart-line .cl-line-close:hover{border-color:var(--gold);color:var(--gold)}
.cart-inline-confirm{position:absolute;inset:0;background:rgba(7,13,31,.94);backdrop-filter:blur(6px);z-index:12;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s,visibility .3s}
.cart-inline-confirm.open{opacity:1;visibility:visible;pointer-events:auto}
.cart-inline-confirm .cart-confirm{width:100%;transform:none}
.cart-confirm-overlay{position:fixed;inset:0;background:rgba(7,13,31,.72);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:.35s;z-index:10050;display:flex;align-items:center;justify-content:center;padding:24px;pointer-events:none}
.cart-confirm-overlay.open{opacity:1;visibility:visible;pointer-events:auto}
.cart-confirm{background:var(--navy-800);border:1px solid var(--line);border-radius:var(--radius-lg);width:min(380px,100%);padding:28px 26px;transform:translateY(12px) scale(.98);transition:.35s var(--ease);text-align:center}
.cart-confirm-overlay.open .cart-confirm{transform:none}
.cart-confirm h4{font-size:1.05rem;margin-bottom:10px;color:var(--t-hi)}
.cart-confirm p{font-size:.9rem;color:var(--t-mid);line-height:1.55;margin-bottom:22px}
.cart-confirm-msg{display:flex;flex-direction:column;gap:12px;text-align:center}
.cart-confirm-lead{display:block;color:var(--t-mid);font-size:.9rem;line-height:1.55}
.cart-confirm-detail{display:flex;flex-direction:column;gap:5px;padding:14px 16px;background:var(--navy-900);border:1px solid var(--line-soft);border-radius:10px;text-align:left}
.cart-confirm-detail strong{color:var(--t-hi);font-size:.95rem;font-weight:600}
.cart-confirm-var{color:var(--gold);font-size:.85rem;font-weight:600}
.cart-confirm-qty{color:var(--t-low);font-size:.8rem}
.cart-confirm-actions{display:flex;gap:10px}
.cart-confirm-actions .btn{flex:1}
.cart-empty{text-align:center;color:var(--t-low);padding:50px 0}
.drawer-foot{padding:24px;border-top:1px solid var(--line)}
.drawer-foot .subtotal{display:flex;justify-content:space-between;margin-bottom:7px;color:var(--t-hi);font-weight:600;font-size:1.05rem}
.drawer-foot .ship-note{font-size:.8rem;color:var(--t-low);margin-bottom:16px}

/* ---------- Checkout modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(7,13,31,.78);backdrop-filter:blur(6px);opacity:0;visibility:hidden;transition:.4s;z-index:300;display:flex;align-items:center;justify-content:center;padding:24px;overflow:hidden}
.modal-overlay.open{opacity:1;visibility:visible}
.checkout{background:var(--navy-800);border:1px solid var(--line);border-radius:var(--radius-lg);width:min(880px,calc(100vw - 48px));max-height:90vh;overflow-x:hidden;overflow-y:auto;transform:translateY(20px) scale(.98);transition:.45s var(--ease)}
.modal-overlay.open .checkout{transform:none}
.checkout-grid{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(0,.9fr);min-width:0;width:100%}
.checkout-main{padding:28px 26px;min-width:0;max-width:100%;overflow:hidden;position:relative}
.checkout-loader{position:absolute;inset:0;z-index:12;display:flex;align-items:center;justify-content:center;background:rgba(7,13,31,.88);backdrop-filter:blur(4px);border-radius:var(--radius-lg)}
.checkout-loader[hidden]{display:none!important}
.checkout-loader-inner{text-align:center;padding:24px;max-width:280px}
.checkout-spinner{width:44px;height:44px;margin:0 auto 18px;border:3px solid rgba(201,168,106,.2);border-top-color:var(--gold);border-radius:50%;animation:checkoutSpin .75s linear infinite}
.checkout-loader-inner p{font-size:.92rem;color:var(--t-mid);line-height:1.5;margin:0}
.checkout-form.is-processing{pointer-events:none;opacity:.55}
@keyframes checkoutSpin{to{transform:rotate(360deg)}}
.checkout-aside{padding:28px 26px;background:var(--navy-900);border-left:1px solid var(--line-soft);min-width:0;max-width:100%;overflow:hidden}
.checkout-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;gap:12px;min-width:0}
.checkout-head h3{min-width:0}
.checkout-head .badge-secure{display:flex;align-items:center;gap:7px;font-size:.76rem;color:var(--gold);flex-shrink:0}
.pay-stripe{margin-top:14px;min-width:0;max-width:100%}
.pay-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--t-mid);font-weight:600;margin:18px 0 10px}
#payment-element{background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:14px 16px;min-height:44px;max-width:100%}
.stripe-card-wrap{background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:12px 14px;min-height:44px;width:100%;max-width:100%;min-width:0;overflow:hidden}
.stripe-card-wrap .StripeElement,.stripe-card-wrap iframe{width:100%!important;max-width:100%!important;min-width:0!important}
.payment-message{font-size:.86rem;margin-top:10px;min-height:0;word-break:break-word}
.payment-message:not(:empty){min-height:1.2em}
.payment-message.is-error{color:var(--red)}
.payment-message.is-info{color:var(--t-mid)}
.test-mode-notice{margin-top:12px;padding:12px 14px;border-radius:11px;border:1px solid rgba(201,168,106,.35);background:rgba(201,168,106,.1);font-size:.84rem;line-height:1.55;color:var(--t-hi)}
.test-mode-notice strong{color:var(--gold-bright);font-weight:600}
.test-mode-notice[hidden]{display:none!important;margin:0;padding:0;border:0}
.stripe-mode-badge{font-size:.72rem;color:var(--t-low);font-weight:500}
.checkout-form{display:flex;flex-direction:column;min-width:0;width:100%;max-width:100%;overflow:hidden}
.checkout-form .form-grid{margin-bottom:4px;min-width:0;width:100%}
.checkout-form .field{min-width:0}
.checkout-form .field input{width:100%;min-width:0;max-width:100%}
.checkout-form .pay-stripe{margin-top:8px}
.checkout-form .btn-lg{margin-top:16px;width:100%}
.checkout-aside .summary-line{gap:10px;align-items:flex-start}
.checkout-aside .summary-line span:first-child{flex:1;min-width:0;overflow-wrap:anywhere;word-break:break-word;padding-right:6px;line-height:1.45}
.checkout-aside .summary-line span:last-child{flex-shrink:0;white-space:nowrap}
.checkout-success{padding:60px 40px;text-align:center}
.checkout-success-icon{width:74px;height:74px;border-radius:50%;background:rgba(201,168,106,.14);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:var(--gold)}
.checkout-success h3{font-size:1.7rem;margin-bottom:12px}
.checkout-success p{color:var(--t-mid);max-width:420px;margin:0 auto 8px}
.checkout-success-ref{color:var(--gold);font-weight:600;font-size:.9rem;margin-bottom:8px!important}
.checkout-success-note{font-size:.85rem!important;color:var(--t-low)!important;margin-bottom:28px!important}
.order-success-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 24px;text-align:center}
.order-success-card{max-width:480px;background:var(--navy-800);border:1px solid var(--line);border-radius:var(--radius-lg);padding:48px 36px}
.ty-page{padding:120px 0 80px;min-height:80vh}
.ty-hero{text-align:center;margin-bottom:40px}
.ty-icon{width:80px;height:80px;border-radius:50%;background:rgba(201,168,106,.14);color:var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 22px}
.ty-icon.ty-icon-fail{background:rgba(232,93,93,.12);color:var(--red)}
.ty-hero h1{font-size:clamp(1.8rem,4vw,2.4rem);margin:12px 0 14px}
.ty-hero .lead{max-width:560px;margin:0 auto}
.ty-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.ty-card{background:var(--navy-800);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px 26px}
.ty-card h2{font-size:1.05rem;margin-bottom:16px;color:var(--t-hi)}
.ty-dl{display:grid;gap:12px}
.ty-dl div{display:grid;gap:3px}
.ty-dl dt{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--t-low);font-weight:600}
.ty-dl dd{font-size:.95rem;color:var(--t-hi);margin:0}
.ty-mono{font-size:.82rem;word-break:break-all;color:var(--t-mid)}
.ty-items-card{margin-bottom:24px}
.ty-items{display:grid;gap:0}
.ty-item{display:flex;gap:14px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--line-soft)}
.ty-item:last-child{border-bottom:none}
.ty-item img{width:64px;height:56px;object-fit:cover;border-radius:8px;flex-shrink:0}
.ty-item-info{flex:1;min-width:0}
.ty-item-info h4{font-family:var(--sans);font-size:.95rem;margin-bottom:4px}
.ty-var{color:var(--gold);font-size:.84rem;font-weight:600;margin-bottom:2px}
.ty-qty{font-size:.78rem;color:var(--t-low)}
.ty-item-price{color:var(--gold);font-weight:600;font-size:.95rem;flex-shrink:0}
.ty-totals{margin-top:18px;padding-top:8px;border-top:1px solid var(--line)}
.ty-next{background:var(--navy-800);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px 26px;margin-bottom:32px}
.ty-next h3{font-size:1.05rem;margin-bottom:14px}
.ty-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:8px}
.pf-cause-card{margin-bottom:20px}
.pf-cause{font-size:1rem;line-height:1.65;color:var(--t-hi);margin:0}
.pf-tips{margin-top:4px}
@media(max-width:720px){.ty-grid{grid-template-columns:1fr}.ty-page{padding-top:100px}}
.summary-line{display:flex;justify-content:space-between;padding:9px 0;font-size:.92rem;color:var(--t-mid)}
.summary-line.total{border-top:1px solid var(--line);margin-top:10px;padding-top:16px;color:var(--t-hi);font-weight:700;font-size:1.15rem}
.powered{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:18px;font-size:.78rem;color:var(--t-low)}
.powered b{color:#635bff}
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(120px);background:var(--gold);color:var(--navy-900);font-weight:600;padding:14px 26px;border-radius:100px;z-index:400;box-shadow:0 16px 40px -12px rgba(201,168,106,.6);transition:transform .5s var(--ease)}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ---------- Reveal animations ---------- */
/* Visible by default; animate in as enhancement when .in is added.
   Guarantees content is never hidden if the reveal observer misfires. */
[data-reveal]{}
[data-reveal].in{animation:revUp .9s var(--ease-out) backwards}
[data-reveal="left"].in{animation-name:revLeft}
[data-reveal="right"].in{animation-name:revRight}
[data-reveal="scale"].in{animation-name:revScale}
[data-reveal-delay="1"].in{animation-delay:.08s}
[data-reveal-delay="2"].in{animation-delay:.16s}
[data-reveal-delay="3"].in{animation-delay:.24s}
[data-reveal-delay="4"].in{animation-delay:.32s}
@keyframes revUp{from{opacity:0;transform:translateY(34px)}to{opacity:1;transform:none}}
@keyframes revLeft{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:none}}
@keyframes revRight{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:none}}
@keyframes revScale{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:none}}
.clip-reveal{clip-path:inset(0 0 0 0)}
.clip-reveal.in{animation:clipwipe 1.1s var(--ease) backwards}
@keyframes clipwipe{from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}
@media (prefers-reduced-motion:reduce){
  [data-reveal],.clip-reveal{opacity:1!important;transform:none!important;clip-path:none!important;transition:none!important}
  .hero-bg img,.showband .pbg img{transform:none!important}
}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .nav-links{
    position:fixed;top:0;right:0;height:100dvh;width:min(320px,82%);
    background:var(--navy-900);border-left:1px solid var(--line);
    flex-direction:column;align-items:stretch;justify-content:center;gap:6px;padding:40px 28px;
    transform:translateX(100%);transition:transform .5s var(--ease);
  }
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.15rem;padding:14px 16px}
  .menu-toggle{display:flex}
  .nav-cta .cart-btn span.lbl{display:none}
  .split,.owner-split,.product-hero,.contact-grid,.checkout-grid{grid-template-columns:1fr}
  .split.rev .split-media{order:0}
  .cols-3,.steps,.role-cards{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr;gap:36px 20px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .checkout-aside{border-left:none;border-top:1px solid var(--line-soft)}
}
@media (max-width:620px){
  body{font-size:16px}
  .modal-overlay{padding:12px}
  .checkout{width:calc(100vw - 24px)}
  .checkout-main,.checkout-aside{padding:20px 16px}
  .cols-3,.steps,.cols-2,.role-cards,.form-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr}
  .hero{min-height:92vh}
  .trust-strip .wrap{justify-content:flex-start;gap:18px}
  .gallery-thumbs{flex-wrap:wrap}
}

/* =========================================================================
   v2 ENHANCEMENTS — more imagery, more motion, lighter rhythm
   ========================================================================= */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:300;background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright));box-shadow:0 0 12px rgba(201,168,106,.6);transition:width .1s linear}

@keyframes kenburns{0%{transform:scale(1.05) translate(0,0)}100%{transform:scale(1.16) translate(-1.5%,-1.5%)}}
.kenburns img{animation:kenburns 22s ease-in-out infinite alternate}
@media (prefers-reduced-motion:reduce){.kenburns img{animation:none}}

.glow-orb{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;z-index:0;pointer-events:none;background:radial-gradient(circle,rgba(63,111,181,.55),transparent 70%);animation:floaty 14s ease-in-out infinite alternate}
.glow-orb.gold{background:radial-gradient(circle,rgba(201,168,106,.4),transparent 70%);animation-duration:18s}
@keyframes floaty{0%{transform:translate(0,0) scale(1)}100%{transform:translate(40px,-30px) scale(1.15)}}
@media (prefers-reduced-motion:reduce){.glow-orb{animation:none}}

.marquee{overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:18px;width:max-content;animation:marquee 42s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track img{height:230px;width:auto;border-radius:14px;object-fit:cover;filter:grayscale(.15) brightness(.92);transition:filter .5s,transform .5s}
.marquee-track img:hover{filter:none;transform:scale(1.03)}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(calc(-50% - 9px))}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none;flex-wrap:wrap;width:auto;justify-content:center}}

.rail-wrap{margin:0 -24px}
.rail{display:flex;gap:22px;overflow-x:auto;padding:6px 24px 26px;scroll-snap-type:x mandatory;scrollbar-width:none}
.rail::-webkit-scrollbar{display:none}
.rail-item{flex:0 0 clamp(280px,42vw,460px);scroll-snap-align:center;position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;border:1px solid var(--line)}
.rail-item img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.rail-item:hover img{transform:scale(1.06)}
.rail-item .cap{position:absolute;left:0;right:0;bottom:0;padding:30px 22px 18px;background:linear-gradient(0deg,rgba(7,13,31,.85),transparent);color:var(--t-hi);font-weight:600;font-size:1rem}
.rail-hint{display:flex;align-items:center;gap:8px;color:var(--t-low);font-size:.8rem;letter-spacing:.04em;justify-content:center;margin-top:6px}

.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:14px;grid-auto-flow:dense}
.gallery .g{position:relative;border-radius:14px;overflow:hidden;cursor:zoom-in;border:1px solid var(--line)}
.gallery .g img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease),filter .5s;pointer-events:none}
.gallery .g::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(7,13,31,.5),transparent 55%);opacity:0;transition:opacity .4s;pointer-events:none}
.gallery .g:hover img{transform:scale(1.08)}
.gallery .g:hover::after{opacity:1}
.gallery .g.tall{grid-row:span 2}
.gallery .g.wide{grid-column:span 2}
.gallery .g .zoom{position:absolute;right:12px;bottom:12px;width:34px;height:34px;border-radius:50%;background:rgba(7,13,31,.6);backdrop-filter:blur(6px);color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);transition:.4s;pointer-events:none}
.gallery .g:hover .zoom{opacity:1;transform:none}
.gallery-main{cursor:zoom-in}
.gallery-main .gallery-zoom{position:absolute;right:14px;bottom:14px;width:38px;height:38px;border-radius:50%;background:rgba(7,13,31,.55);backdrop-filter:blur(6px);color:#fff;display:flex;align-items:center;justify-content:center;opacity:.85;transition:.35s;pointer-events:none;z-index:2}
.gallery-main:hover .gallery-zoom{opacity:1;background:rgba(7,13,31,.72)}
.lightbox{position:fixed;inset:0;background:rgba(5,9,20,.94);z-index:10060;display:flex;align-items:center;justify-content:center;padding:30px;opacity:0;visibility:hidden;transition:.4s}
.lightbox.open{opacity:1;visibility:visible}
.lightbox .lb-stage{display:flex;flex-direction:column;align-items:center;gap:14px;max-width:min(96vw,1200px);width:100%}
.lightbox img{max-width:100%;max-height:min(78vh,900px);width:auto;height:auto;border-radius:12px;transform:scale(.96);transition:transform .4s var(--ease);box-shadow:0 40px 100px -30px rgba(0,0,0,.8);object-fit:contain}
.lightbox.open img{transform:none}
.lightbox .lb-caption{color:rgba(232,237,247,.88);font-size:.92rem;text-align:center;max-width:640px;line-height:1.5}
.lightbox .lb-counter{color:var(--gold);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600}
.lightbox .lb-close{position:absolute;top:24px;right:28px;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);color:#fff;font-size:1.3rem;display:flex;align-items:center;justify-content:center;transition:.3s;background:rgba(7,13,31,.35)}
.lightbox .lb-close:hover{border-color:var(--gold);color:var(--gold);transform:rotate(90deg)}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;border:1px solid var(--line);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem;transition:.3s;background:rgba(7,13,31,.4)}
.lightbox .lb-nav:hover{border-color:var(--gold);color:var(--gold)}
.lightbox .lb-prev{left:22px}.lightbox .lb-next{right:22px}
@media (max-width:640px){
  .lightbox{padding:16px}
  .lightbox .lb-close{top:14px;right:14px}
  .lightbox .lb-nav{width:44px;height:44px;font-size:1.2rem}
  .lightbox .lb-prev{left:8px}
  .lightbox .lb-next{right:8px}
  .lightbox img{max-height:70vh}
}

.imageband{position:relative;min-height:84vh;display:flex;align-items:flex-end;overflow:hidden}
.imageband .ib-bg{position:absolute;inset:0;z-index:0}
.imageband .ib-bg img{width:100%;height:108%;object-fit:cover}
.imageband .ib-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(7,13,31,.96) 2%,rgba(7,13,31,.55) 38%,rgba(7,13,31,.32) 60%,rgba(7,13,31,.7)),linear-gradient(90deg,rgba(7,13,31,.82),rgba(7,13,31,.12) 60%)}
.imageband .wrap{position:relative;z-index:2;padding-bottom:clamp(50px,8vw,90px)}
.imageband h2{font-size:clamp(2.2rem,5vw,4rem);max-width:780px}
.imageband p{max-width:520px;margin-top:18px}
.imageband .ib-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:clamp(36px,5vw,56px);padding-top:clamp(28px,4vw,40px);border-top:1px solid rgba(255,255,255,.18);max-width:920px}
.ib-stat .num{font-family:var(--display);font-size:clamp(2rem,4vw,3.1rem);color:var(--gold-bright);line-height:1;font-weight:800}
.ib-stat .lbl{font-size:.76rem;letter-spacing:.07em;color:rgba(255,255,255,.66);margin-top:9px;text-transform:uppercase}
@media (max-width:620px){.imageband .ib-stats{grid-template-columns:1fr 1fr;gap:28px 18px}}

.media-stack{position:relative}
.media-stack .m1{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line)}
.media-stack .m1 img{width:100%;display:block;transition:transform 1.1s var(--ease)}
.media-stack:hover .m1 img{transform:scale(1.05)}
.media-stack{padding-bottom:34px;padding-right:18px}
.media-stack .m1{position:relative;z-index:1}
.media-stack .m2{position:absolute;right:0;bottom:0;width:42%;border-radius:16px;overflow:hidden;border:5px solid var(--navy-800);box-shadow:0 34px 70px -28px rgba(0,0,0,.78);z-index:2}
.media-stack.in .m2{animation:m2in 1s var(--ease) .15s backwards}
@keyframes m2in{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.media-stack .m2 img{width:100%;display:block;aspect-ratio:4/3;object-fit:cover}
.tone-light .media-stack .m2,.tone-platinum .media-stack .m2,.tone-sand .media-stack .m2{border-color:#fff}
.media-badge{position:absolute;left:16px;top:16px;background:var(--gold);color:var(--navy-900);font-weight:700;font-size:.78rem;letter-spacing:.01em;padding:9px 15px;border-radius:100px;box-shadow:0 12px 26px -12px rgba(201,168,106,.6);z-index:3}

.words .w{display:inline-block}
.words.in .w{animation:revWord .6s var(--ease) backwards}
@keyframes revWord{from{opacity:0;transform:translateY(.5em)}to{opacity:1;transform:none}}

.photo-feature{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:340px;display:flex;align-items:flex-end;border:1px solid var(--line)}
.photo-feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.photo-feature:hover img{transform:scale(1.07)}
.photo-feature::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(7,13,31,.9),rgba(7,13,31,.05) 60%)}
.photo-feature .pf-body{position:relative;z-index:2;padding:28px}
.photo-feature .pf-body h3{color:#fff;margin-bottom:6px}
.photo-feature .pf-body p{color:var(--t-mid);font-size:.92rem}

@media (max-width:980px){
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .gallery .g.wide{grid-column:span 1}
  .media-stack .m2{position:relative;right:auto;bottom:auto;width:64%;margin:14px 0 0 auto;transform:none;opacity:1}
}
@media (max-width:620px){
  .gallery{grid-template-columns:1fr 1fr;grid-auto-rows:140px}
  .marquee-track img{height:160px}
}

/* =========================================================================
   v3 — video hero + film embeds + real home imagery
   ========================================================================= */
.hero-video{position:absolute;inset:0;z-index:1;overflow:hidden}
.hero-video iframe{position:absolute;top:50%;left:50%;width:100vw;height:56.25vw;min-height:100%;min-width:177.78vh;transform:translate(-50%,-50%);border:0;pointer-events:none}
.hero-video::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--navy-900) 6%,rgba(7,13,31,.72) 42%,rgba(7,13,31,.25) 78%),linear-gradient(0deg,var(--navy-900) 2%,transparent 42%)}
.hero .hero-bg{z-index:0}

/* Film section */
.film-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.film{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);background:#000;aspect-ratio:16/9}
.film iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.film .film-label{position:absolute;left:16px;top:14px;z-index:2;background:rgba(7,13,31,.65);backdrop-filter:blur(6px);color:var(--t-hi);font-size:.78rem;font-weight:600;padding:7px 14px;border-radius:100px;pointer-events:none}
@media (max-width:820px){.film-grid{grid-template-columns:1fr}}

/* Drive-hosted imagery note: images use Google Drive thumbnail URLs */
.gdrive-note{font-size:.78rem;color:var(--t-low);text-align:center;margin-top:18px}

/* =========================================================================
   v4 — ELEVATION: lighter surfaces, preloader, transitions, wow motion
   ========================================================================= */

/* ---- lighter surfaces ---- */
:root{
  --platinum:#eaf0f1;        /* cool light */
  --sand:#f3efe6;            /* warm light */
  --mist:#dfe7ee;
}
.tone-platinum{background:var(--platinum);color:#3a4660}
.tone-platinum h1,.tone-platinum h2,.tone-platinum h3,.tone-platinum h4{color:#141c30}
.tone-platinum .lead{color:#48526b}
.tone-platinum .eyebrow{color:var(--gold-deep)}
.tone-platinum .eyebrow::before,.tone-platinum .eyebrow.center::after{background:var(--gold-deep)}
.tone-platinum .muted{color:#7a849c}
.tone-sand{background:var(--sand);color:#4a4434}
.tone-sand h1,.tone-sand h2,.tone-sand h3{color:#241f15}
.tone-sand .eyebrow{color:var(--gold-deep)}
/* lift the dark sections with a soft luminous mesh so it never reads flat-black */
.tone-grad,.tone-deep{position:relative}
.mesh{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.mesh::before,.mesh::after{content:"";position:absolute;border-radius:50%;filter:blur(90px);opacity:.5}
.mesh::before{width:46%;height:60%;left:-8%;top:-10%;background:radial-gradient(circle,rgba(63,111,181,.5),transparent 70%)}
.mesh::after{width:42%;height:55%;right:-6%;bottom:-12%;background:radial-gradient(circle,rgba(201,168,106,.32),transparent 70%)}
.section>.wrap,.cta-band>.wrap{position:relative;z-index:1}

/* ---- image / video page hero (internal pages) ---- */
.page-hero.has-media{padding-top:clamp(150px,20vh,230px);min-height:74vh;display:flex;align-items:flex-end;color:#fff}
.page-hero .ph-media{position:absolute;inset:0;z-index:-2;overflow:hidden}
.page-hero .ph-media img{width:100%;height:118%;object-fit:cover;will-change:transform}
.page-hero .ph-media iframe{position:absolute;top:50%;left:50%;width:100vw;height:56.25vw;min-height:100%;min-width:177.78vh;transform:translate(-50%,-50%);border:0;pointer-events:none}
.page-hero.has-media::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(7,13,31,.55) 0%,rgba(7,13,31,.35) 45%,rgba(7,13,31,.9) 100%)}
.page-hero.has-media .wrap{padding-bottom:clamp(40px,6vw,72px)}
.page-hero.has-media h1{color:#fff}
.page-hero.has-media .lead{color:rgba(255,255,255,.85)}

/* ---- PRELOADER ---- */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--navy-900);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;transition:opacity .6s ease}
.preloader .pl-mark{display:grid;grid-template-columns:repeat(2,34px);grid-template-rows:repeat(2,34px);gap:6px;transform:rotate(0deg)}
.preloader .pl-sq{border-radius:5px;opacity:0;transform:scale(.2) translateY(10px);animation:plpop .6s var(--ease-out) forwards}
.preloader .pl-sq.s1{background:#b9cbe6;animation-delay:.05s}
.preloader .pl-sq.s2{background:#3f6fb5;animation-delay:.18s}
.preloader .pl-sq.s3{background:#e0473b;animation-delay:.31s}
.preloader .pl-sq.s4{background:#1c2b6b;animation-delay:.44s}
@keyframes plpop{0%{opacity:0;transform:scale(.2) translateY(10px) rotate(-25deg)}60%{opacity:1;transform:scale(1.12) translateY(0) rotate(4deg)}100%{opacity:1;transform:scale(1) translateY(0) rotate(0)}}
.preloader .pl-word{font-family:var(--display);font-weight:800;letter-spacing:.04em;color:#fff;font-size:1.15rem;opacity:0;animation:plword .6s ease .7s forwards}
.preloader .pl-word b{color:#fff}
@keyframes plword{to{opacity:1}}
.preloader .pl-bar{width:170px;height:2px;background:rgba(255,255,255,.12);border-radius:2px;overflow:hidden}
.preloader .pl-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright));animation:plbar 1.5s var(--ease) .5s forwards}
@keyframes plbar{to{width:100%}}
.preloader.done{opacity:0;pointer-events:none}
/* curtain reveal panels */
.preloader.done .pl-curtain{transform:translateY(-100%)}
body.preloading{overflow:hidden}
@media (prefers-reduced-motion:reduce){.preloader{display:none}}

/* ---- PAGE TRANSITION curtain ---- */
.page-curtain{position:fixed;inset:0;z-index:9000;background:var(--navy-900);transform:translateY(100%);pointer-events:none;display:flex;align-items:center;justify-content:center}
.page-curtain .pc-mark{display:grid;grid-template-columns:repeat(2,26px);grid-template-rows:repeat(2,26px);gap:5px;opacity:0;transition:opacity .3s}
.page-curtain .pc-mark i{border-radius:4px}
.page-curtain .pc-mark .s1{background:#b9cbe6}.page-curtain .pc-mark .s2{background:#3f6fb5}.page-curtain .pc-mark .s3{background:#e0473b}.page-curtain .pc-mark .s4{background:#1c2b6b}
.page-curtain.in{animation:curtainIn .5s var(--ease) forwards}
.page-curtain.out{animation:curtainOut .6s var(--ease) forwards}
@keyframes curtainIn{0%{transform:translateY(100%)}100%{transform:translateY(0)}}
@keyframes curtainOut{0%{transform:translateY(0)}100%{transform:translateY(-100%)}}
.page-curtain.in .pc-mark{opacity:1}

/* ---- 3D tilt ---- */
.tilt{transform-style:preserve-3d;transition:transform .25s var(--ease)}
.tilt-inner{transform:translateZ(28px)}
@media (prefers-reduced-motion:reduce){.tilt{transform:none!important}}

/* ---- magnetic buttons ---- */
.btn{will-change:transform}

/* ---- headline mask reveal ---- */
.mask-rise{overflow:hidden;display:block}
.mask-rise>span{display:block;transform:translateY(110%);transition:transform .9s var(--ease-out)}
.mask-rise.in>span{transform:none}

/* ---- reverse marquee + duo ---- */
.marquee-track.rev{animation-direction:reverse}

/* ---- video band (reusable) ---- */
.video-band{position:relative;overflow:hidden}
.video-band .vb-frame{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/9;background:#000;box-shadow:0 50px 120px -50px rgba(0,0,0,.8)}
.video-band .vb-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---- shine sweep on key images ---- */
.shine{position:relative;overflow:hidden}
.shine::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.18),transparent);transform:skewX(-18deg);transition:left .9s var(--ease)}
.shine:hover::after{left:120%}

/* light-tone fixups for components on light bg */
.tone-platinum .feature,.tone-sand .feature{background:#fff;border-color:rgba(20,26,43,.08)}
.tone-platinum .checklist li,.tone-sand .checklist li{color:#1a2238;border-color:rgba(20,26,43,.1)}
.tone-platinum .spec-table td:last-child{color:#141c30}

/* ---- light-tone component overrides (so sections can go bright) ---- */
.tone-light .section-head p,.tone-platinum .section-head p,.tone-sand .section-head p,
.tone-light .muted,.tone-platinum .muted,.tone-sand .muted{color:#5b6478}
.tone-platinum .section-head p,.tone-sand .section-head p{color:#5b6478}
.tone-platinum .muted,.tone-sand .muted{color:#74809a}
.tone-light .role-card,.tone-platinum .role-card,.tone-sand .role-card{background:#fff;border-color:rgba(20,26,43,.08)}
.tone-light .role-card h4,.tone-platinum .role-card h4,.tone-sand .role-card h4{color:#141c30}
.tone-light .role-card p,.tone-platinum .role-card p,.tone-sand .role-card p{color:#5b6478}
.tone-light .step h3,.tone-platinum .step h3,.tone-sand .step h3{color:#141c30}
.tone-light .step p,.tone-platinum .step p,.tone-sand .step p{color:#5b6478}
.tone-light .step::before,.tone-platinum .step::before,.tone-sand .step::before{color:var(--navy-900);-webkit-text-stroke:0;opacity:1}
.tone-platinum .feature p,.tone-sand .feature p,.tone-light .feature p{color:#5b6478}
.tone-platinum .feature h3,.tone-sand .feature h3{color:#141c30}

/* ---- light FAQ ---- */
.tone-platinum .faq-tab,.tone-sand .faq-tab{border-color:rgba(20,26,43,.16);color:#48526b}
.tone-platinum .faq-tab:hover,.tone-sand .faq-tab:hover{color:#141c30;border-color:var(--gold-deep)}
.tone-platinum .faq-tab.active,.tone-sand .faq-tab.active{background:var(--gold-deep);color:#fff;border-color:var(--gold-deep)}
.tone-platinum .faq-group>h3,.tone-sand .faq-group>h3{color:#141c30;border-color:rgba(20,26,43,.14)}
.tone-platinum .faq-item,.tone-sand .faq-item{border-color:rgba(20,26,43,.1)}
.tone-platinum .faq-q,.tone-sand .faq-q{color:#1a2238}
.tone-platinum .faq-q .pm,.tone-sand .faq-q .pm{border-color:var(--gold-deep);color:var(--gold-deep)}
.tone-platinum .faq-item.open .faq-q .pm,.tone-sand .faq-item.open .faq-q .pm{background:var(--gold-deep);color:#fff}
.tone-platinum .faq-a-inner,.tone-sand .faq-a-inner{color:#566079}

/* ---- light forms / contact ---- */
.tone-platinum .field label,.tone-sand .field label{color:#48526b}
.tone-platinum .field input,.tone-platinum .field select,.tone-platinum .field textarea,
.tone-sand .field input,.tone-sand .field select,.tone-sand .field textarea{background:#fff;border-color:rgba(20,26,43,.14);color:#1a2238}
.tone-platinum .field input::placeholder,.tone-platinum .field textarea::placeholder{color:#9aa3b5}
.tone-platinum .field input:focus,.tone-platinum .field select:focus,.tone-platinum .field textarea:focus{border-color:var(--gold-deep);background:#fffdf8}
.tone-platinum .contact-info,.tone-sand .contact-info{background:#fff;border-color:rgba(20,26,43,.1)}
.tone-platinum .contact-info .row,.tone-sand .contact-info .row{border-color:rgba(20,26,43,.08)}
.tone-platinum .contact-info .row .v,.tone-sand .contact-info .row .v{color:#141c30}
.tone-platinum .contact-info .row .k,.tone-platinum .contact-info p{color:#5b6478}
.tone-platinum .contact-info h3{color:#141c30}

/* =========================================================================
   v7 — COHESION POLISH: a11y focus, richer interior heroes, section depth
   Extends the existing system; does not alter homepage layout.
   ========================================================================= */

/* ---- Accessible keyboard focus (was missing on links/buttons) ---- */
a:focus-visible,button:focus-visible,.btn:focus-visible,
.opt:focus-visible,.faq-q:focus-visible,.faq-tab:focus-visible,
.gallery .g:focus-visible,.nav-links a:focus-visible{
  outline:2px solid var(--gold);outline-offset:3px;border-radius:6px;
}
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible{
  outline:2px solid var(--gold);outline-offset:1px;
}
.tone-light a:focus-visible,.tone-platinum a:focus-visible,.tone-sand a:focus-visible,
.tone-light .btn:focus-visible,.tone-platinum .faq-q:focus-visible{outline-color:var(--gold-deep)}

/* ---- Richer interior page heroes (parity with homepage hero energy) ---- */
.page-hero.has-media{position:relative}
.page-hero.has-media .ph-media img{animation:none}
.page-hero.has-media.kb .ph-media img{animation:kenburns 26s ease-in-out infinite alternate}
.page-hero .glow-orb{z-index:-1}
/* warm gold hairline grounding the hero, echoing the brand accent */
.page-hero.has-media::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:2px;z-index:0;
  background:linear-gradient(90deg,transparent,rgba(201,168,106,.55),transparent);
}
/* headline word-reveal inherits .words; ensure hero words start hidden cleanly */
.page-hero .words .w{will-change:opacity,transform}
@media (prefers-reduced-motion:reduce){.page-hero.has-media.kb .ph-media img{animation:none}}

/* subtle scroll cue for interior heroes */
.ph-scroll{position:absolute;right:24px;bottom:22px;z-index:2;display:flex;align-items:center;gap:9px;color:rgba(255,255,255,.6);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase}
.ph-scroll .dot{width:5px;height:5px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(201,168,106,.6);animation:phpulse 2.4s var(--ease) infinite}
@keyframes phpulse{0%{box-shadow:0 0 0 0 rgba(201,168,106,.55)}70%{box-shadow:0 0 0 9px rgba(201,168,106,0)}100%{box-shadow:0 0 0 0 rgba(201,168,106,0)}}
@media (max-width:620px){.ph-scroll{display:none}}
@media (prefers-reduced-motion:reduce){.ph-scroll .dot{animation:none}}

/* ---- Atmospheric depth helper for otherwise-flat dark sections ---- */
.section.has-depth{position:relative;overflow:hidden}

/* ---- Product hero: lift the buy area onto a lit, layered surface ---- */
.product-hero{position:relative;z-index:1}
.gallery-main{box-shadow:0 40px 90px -50px rgba(0,0,0,.75)}
.buybox .price .now{transition:color .3s var(--ease)}

/* ---- Owner photo gets the same cinematic depth as homepage media ---- */
.owner-photo{box-shadow:0 50px 110px -55px rgba(0,0,0,.7)}
.owner-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(7,13,31,.35));opacity:.0;transition:opacity .6s var(--ease);pointer-events:none}
.owner-photo:hover::after{opacity:1}

/* ---- Section flow: gentle gold divider option between like-tone sections ---- */
.tone-deep+.tone-deep,.tone-grad+.tone-grad{position:relative}

/* ---- Card / feature lift consistency on hover (focus parity) ---- */
.card:focus-within{transform:translateY(-6px);border-color:rgba(201,168,106,.3)}
.feature:focus-within{transform:translateY(-6px);border-color:rgba(201,168,106,.35)}

/* =========================================================================
   v8 — addressing review notes: motion block, cohesion fixes
   ========================================================================= */

/* ---- ambient (background) Vimeo loop inside a framed band ---- */
.vb-frame.vb-loop{box-shadow:0 60px 130px -50px rgba(0,0,0,.85)}
.vb-frame.vb-loop iframe{pointer-events:none}
.vb-frame.vb-loop::after{content:"";position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 90px 10px rgba(7,13,31,.45);z-index:2}
.vb-caption{position:absolute;left:18px;bottom:16px;z-index:3;display:flex;align-items:center;gap:9px;color:var(--t-hi);font-size:.8rem;font-weight:600;background:rgba(7,13,31,.55);backdrop-filter:blur(8px);border:1px solid var(--line);padding:9px 16px;border-radius:100px}
.vb-caption .ld{width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(201,168,106,.6);animation:phpulse 2.4s var(--ease) infinite}
@media (prefers-reduced-motion:reduce){.vb-caption .ld{animation:none}}

/* ---- stage chips (replaces the event-photo rail) ---- */
.stage-chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:clamp(24px,3vw,34px)}
.stage-chip{display:flex;align-items:center;gap:11px;padding:11px 20px;border:1px solid var(--line);border-radius:100px;font-size:.9rem;font-weight:500;color:var(--t-mid);background:var(--surface);transition:border-color .3s,color .3s,transform .3s var(--ease)}
.stage-chip:hover{border-color:rgba(201,168,106,.4);color:var(--t-hi);transform:translateY(-2px)}
.stage-chip b{color:var(--gold);font-family:var(--display);font-weight:800;font-size:.95rem}

/* =========================================================================
   v8b — RESPONSIVE / OVERFLOW HARDENING
   Guarantee: nothing bleeds past the viewport at any size or orientation.
   ========================================================================= */
html{overflow-x:hidden}
img,iframe,video,svg{max-width:100%}
/* let flex/grid children shrink instead of forcing overflow */
.nav,.hero-actions,.cta-actions,.buy-actions,.buy-trust,.trust-strip .wrap,
.split,.product-hero,.contact-grid,.checkout-grid,.owner-split,.stats,.ib-stats,
.cols-3,.cols-2,.steps,.role-cards,.foot-grid,.faq-q,.film-grid,.stage-chips{min-width:0}
.nav>*,.split>*,.product-hero>*,.owner-split>*,.contact-grid>*,.checkout-grid>*{min-width:0}
/* long words in big display type never spill */
h1,h2,h3,h4,.display,.section-title,.lead,.quote-lg,blockquote,.faq-q,.cart-line h4{overflow-wrap:break-word}
.btn{max-width:100%}
.spec-table td,.contact-info .row .v{overflow-wrap:break-word}

/* phones: action groups stack full-width so buttons can't overflow */
@media (max-width:600px){
  .btn{white-space:normal;text-align:center}
  .btn-lg{padding:16px 24px;font-size:.98rem}
  .hero-actions,.cta-actions,.buy-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn,.cta-actions .btn,.buy-actions .btn,.buy-actions a{width:100%}
  .media-stack{padding:0}
}

/* header fits on narrow screens (CTA still in the mobile menu + on every page) */
@media (max-width:560px){
  .nav-cta .btn-primary{display:none}
  .site-header{padding:14px 0}
  .site-header.scrolled{padding:10px 0}
  .brand img{height:30px}
}

/* short / landscape phones: don't force full-height heroes */
@media (max-height:560px) and (orientation:landscape){
  .hero{min-height:auto;padding-top:104px;padding-bottom:56px}
  .hero-scroll{display:none}
  .page-hero.has-media{min-height:auto;padding-top:120px}
  .ph-scroll{display:none}
}

/* ultra-narrow safety net (<=380px) */
@media (max-width:380px){
  .wrap{padding:0 18px}
  body{font-size:15.5px}
  .display{font-size:clamp(2.15rem,8.8vw,2.7rem)}
  h2.section-title{font-size:clamp(1.65rem,6.8vw,2.05rem)}
  .stats,.imageband .ib-stats{grid-template-columns:1fr 1fr}
  .trust-strip .wrap{gap:14px}
  .btn-lg{padding:15px 20px}
  .nav-links{width:min(300px,90%)}
}

/* ---- Press / "In the news" cards ---- */
a.card{display:block;color:inherit}
.card .ph .play-ico{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:58px;height:58px;border-radius:50%;background:rgba(7,13,31,.5);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.55);color:#fff;display:flex;align-items:center;justify-content:center;transition:.4s var(--ease);z-index:2}
.card:hover .ph .play-ico{background:var(--gold);color:var(--navy-900);border-color:var(--gold);transform:translate(-50%,-50%) scale(1.08)}
.press-link{display:inline-flex;align-items:center;gap:.5em;font-weight:600;color:var(--gold);font-size:.92rem}
.press-link svg{flex-shrink:0}

/* ---- Internal hero crop: bias toward subject so faces/heads aren't cut ---- */
.page-hero .ph-media img{object-position:center 28%}

/* ---- Google reCAPTCHA v3 badge (compact icon, bottom-right) ---- */
.grecaptcha-badge{
  visibility:visible !important;
  width:70px !important;
  height:60px !important;
  overflow:hidden !important;
  z-index:9990 !important;
  bottom:14px !important;
  right:14px !important;
  box-shadow:0 2px 10px rgba(7,13,31,.16) !important;
  border-radius:4px !important;
  transition:width .25s ease,box-shadow .25s ease !important;
}
.grecaptcha-badge:hover{
  width:256px !important;
  box-shadow:0 4px 16px rgba(7,13,31,.22) !important;
}
.foot-recaptcha{
  margin-top:12px;
  font-size:.72rem;
  line-height:1.55;
  color:#7a8aa8;
  opacity:.85;
}
.foot-recaptcha a{
  color:inherit;
  text-decoration:underline;
  text-underline-offset:2px;
}
@media (max-width:640px){
  .grecaptcha-badge{
    width:64px !important;
    height:56px !important;
    bottom:10px !important;
    right:10px !important;
  }
  .grecaptcha-badge:hover{
    width:64px !important;
  }
}
