/* home.css — generated from concepts/shared.css + montcalmV2.2 styles. Homepage only. */
/* ============================================================================
   SHARED BASE for all concept pages.
   Holds tokens + the styling for PRESERVED sections (range, stats, CTA) +
   shared primitives (reveal, marquee, manifesto, buttons).
   Each concept page adds ONLY its hero + signature interaction on top.
   ============================================================================ */
:root{
  --ink:#0F2A44; --navy:#0F2A44; --teal:#1FB6B0; --teal-d:#159a95;
  --paper:#F7FAFB; --line:rgba(15,42,68,.1); --muted:#536272;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
body{margin:0;background:var(--paper);color:var(--ink);
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;-webkit-font-smoothing:antialiased}
::selection{background:rgba(31,182,176,.25)}
img{max-width:100%}
.x-wrap{max-width:1180px;margin:0 auto;padding:0 clamp(24px,6vw,90px)}

.pflag{position:fixed;top:10px;right:12px;z-index:5000;font-family:"IBM Plex Mono",monospace;
  font-size:10px;letter-spacing:.05em;color:#fff;background:rgba(15,42,68,.9);padding:6px 10px;border-radius:8px;text-decoration:none}
.pflag b{color:#7fd9d4}
.cgallery-link{position:fixed;top:10px;left:12px;z-index:5000;font-family:"IBM Plex Mono",monospace;
  font-size:10px;letter-spacing:.05em;color:#fff;background:rgba(31,182,176,.95);padding:6px 10px;border-radius:8px;text-decoration:none;font-weight:600}

/* ---------- buttons ---------- */
.btn-x{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:15.5px;
  padding:16px 30px;border-radius:14px;text-decoration:none;border:1px solid transparent;cursor:pointer;
  transition:transform .2s var(--ease),box-shadow .2s,background .2s,border-color .2s}
.btn-fill{background:var(--ink);color:#fff}
.btn-fill:hover{background:#15395c;transform:translateY(-2px);box-shadow:0 18px 38px rgba(15,42,68,.26)}
.btn-fill .ar{transition:transform .25s var(--ease)} .btn-fill:hover .ar{transform:translateX(5px)}
.btn-ghost{color:var(--ink);border-color:var(--line)} .btn-ghost:hover{border-color:var(--teal);transform:translateY(-2px)}

/* ---------- reveal primitive ---------- */
.rv{opacity:0;transform:translateY(38px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;overflow:hidden;padding:18px 0}
.marquee-track{display:flex;gap:48px;white-space:nowrap;width:max-content;animation:marq 34s linear infinite}
.marquee span{font-family:"IBM Plex Mono",monospace;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:#67768a;display:inline-flex;gap:48px;align-items:center}
.marquee span::after{content:"•";color:var(--teal)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- manifesto ---------- */
.manifesto{padding:clamp(110px,18vh,220px) 0;background:var(--paper)}
.manifesto p{font-family:"Inter Tight",sans-serif;font-weight:500;letter-spacing:-.02em;
  font-size:clamp(26px,4vw,56px);line-height:1.18;max-width:18ch;margin:0;color:var(--ink)}
.manifesto .word{display:inline-block;opacity:.12;transition:opacity .5s var(--ease)}
.manifesto .word.lit{opacity:1}
.manifesto .em{color:var(--teal)}

/* ---------- stats (Stripe-style · content preserved) ---------- */
.xstats{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(60px,9vh,110px) 0}
.xstats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.xstat{padding:0 clamp(16px,2.4vw,40px);border-left:1px solid var(--line)}
.xstat:first-child{border-left:0;padding-left:0}
.xstat .num{font-family:"Inter Tight",sans-serif;font-weight:600;letter-spacing:-.03em;font-size:clamp(40px,5.5vw,72px);line-height:1;color:var(--ink)}
.xstat .num b{color:var(--teal);font-weight:600}
.xstat .lab{font-size:14px;color:var(--muted);margin-top:14px;line-height:1.4}
@media(max-width:820px){.xstats-grid{grid-template-columns:repeat(2,1fr);gap:40px 0}.xstat{border-left:0;padding:0 20px}.xstat:nth-child(odd){padding-left:0}}

/* ---------- range (content preserved · sleek cards) ---------- */
.xrange{padding:clamp(90px,14vh,160px) 0;background:var(--paper)}
.xrange .x-wrap{max-width:min(1560px,94vw)}   /* wider so the bed cards fill more of the screen */
.xhead{margin-bottom:clamp(36px,6vh,64px);max-width:680px}
.xhead .ey{font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal-d);margin:0 0 14px;display:flex;align-items:center;gap:10px}
.xhead .ey::before{content:"";width:26px;height:1.5px;background:var(--teal)}
.xhead h2{font-family:"Inter Tight",sans-serif;font-weight:600;letter-spacing:-.025em;font-size:clamp(32px,4.4vw,58px);line-height:1.02;margin:0;color:var(--ink)}
.beds{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
@media(max-width:1040px){.beds{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.beds{grid-template-columns:1fr}}
.bed{position:relative;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;text-decoration:none;color:inherit;display:flex;flex-direction:column;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s}
.bed:hover{transform:translateY(-8px);box-shadow:0 30px 60px rgba(15,42,68,.16);border-color:transparent}
.bed-thumb{aspect-ratio:5/4;background:linear-gradient(160deg,#F4F8F9,#E7F0F1);display:grid;place-items:center;overflow:hidden}
.bed-thumb img{width:88%;height:88%;object-fit:contain;transition:transform .5s var(--ease)}
.bed:hover .bed-thumb img{transform:scale(1.06)}
.bed-body{padding:26px 26px 28px;display:flex;flex-direction:column;flex:1}
.bed-title{font-family:"Inter Tight",sans-serif;font-weight:600;font-size:23px;margin:0 0 16px;color:var(--ink)}
.bed-title .sub{display:block;font-family:"Inter",sans-serif;font-weight:500;font-size:13px;color:var(--teal-d);margin-top:3px}
.bed-feats{list-style:none;margin:0 0 18px;padding:0;display:flex;flex-direction:column;gap:8px;flex:1}
.bed-feats li{font-size:14.5px;color:var(--muted);padding-left:18px;position:relative;line-height:1.45}
.bed-feats li::before{content:"";position:absolute;left:0;top:7px;width:6px;height:6px;border-radius:50%;background:var(--teal)}
.bed-more{display:inline-flex;align-items:center;gap:8px;font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);font-weight:500}
.bed-more .ar{color:var(--teal);transition:transform .25s var(--ease)}
.bed:hover .bed-more .ar{transform:translateX(5px)}

/* ---------- CTA (content preserved) ---------- */
.xcta-sec{position:relative;overflow:hidden;padding:clamp(100px,16vh,180px) 0;background:var(--ink);color:#fff;text-align:center}
.xcta-sec .glow{position:absolute;inset:-30%;filter:blur(80px);z-index:0;background:radial-gradient(36% 40% at 50% 30%, rgba(31,182,176,.4), transparent 60%)}
.xcta-sec .x-wrap{position:relative;z-index:1}
.xcta-sec .ey{font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);margin:0 0 18px}
.xcta-sec h2{font-family:"Inter Tight",sans-serif;font-weight:600;letter-spacing:-.025em;font-size:clamp(34px,5vw,68px);line-height:1.02;margin:0 0 18px}
.xcta-sec p{font-size:clamp(16px,1.4vw,18.5px);line-height:1.6;color:rgba(255,255,255,.72);max-width:520px;margin:0 auto 34px}
.xcta-sec .btn-fill{background:var(--teal);color:var(--ink)}
.xcta-sec .btn-fill:hover{background:#33c4be;box-shadow:0 18px 40px rgba(31,182,176,.4)}

@media(prefers-reduced-motion:reduce){
  .rv{opacity:1!important;transform:none!important}
  .marquee-track,.manifesto .word{animation:none!important}
  .manifesto .word{opacity:1!important}
}


/* ---- V2.2 hero + living-background + add-ons ---- */

  /* =================== COMBINATION SIGNATURE ===================
     Hero  : Living Particles (ambient, cursor-reactive) + Kinetic Type headline
     Moment: Cursor Spotlight "inspect the engineering" band, lower on the page
     ============================================================ */

  /* ---------- HERO ---------- */
  .cb-hero{position:relative;min-height:100vh;display:grid;align-items:center;overflow:hidden;background:#F7FAFB}
  .cb-particles{position:fixed;inset:0;width:100vw;height:100vh;z-index:0;pointer-events:none}
  /* keep the centre clean for type */
  .cb-hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
    background:radial-gradient(60% 55% at 50% 48%, rgba(247,250,251,.85) 0%, rgba(247,250,251,.2) 55%, transparent 80%)}
  .cb-hero-inner{position:relative;z-index:2;width:100%}
  .cb-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal-d);margin-bottom:20px;opacity:0;transition:opacity .8s var(--ease) .1s}
  .cb-eyebrow::before{content:"";width:30px;height:1.5px;background:var(--teal)}
  .cb-hero.in .cb-eyebrow{opacity:1}
  /* Brand IS the headline now */
  .cb-h1{font-family:"Inter Tight",sans-serif;font-weight:600;letter-spacing:-.03em;font-size:clamp(54px,9.4vw,132px);line-height:.94;margin:0 0 16px}
  /* Value line is now the supporting subheading */
  .cb-sub{font-family:"Inter Tight",sans-serif;font-weight:500;letter-spacing:-.015em;font-size:clamp(20px,2.7vw,34px);line-height:1.12;color:var(--ink);margin:0 0 26px;max-width:20ch;opacity:0;transform:translateY(14px);transition:opacity .8s var(--ease) .46s,transform .8s var(--ease) .46s}
  .cb-hero.in .cb-sub{opacity:1;transform:none}
  .cb-wmask{display:inline-block;overflow:hidden;vertical-align:bottom;padding-bottom:.04em}
  .cb-w{display:inline-block;transform:translateY(115%);transition:transform .9s cubic-bezier(.16,1,.3,1)}
  .cb-hero.in .cb-w{transform:none}
  .cb-w.accent{color:var(--teal)}
  .cb-lede{font-size:clamp(16px,1.5vw,20px);line-height:1.6;color:#46586a;max-width:560px;margin:0 0 38px;opacity:0;transform:translateY(16px);transition:opacity .8s var(--ease) .58s,transform .8s var(--ease) .58s}
  .cb-lede .emph{color:var(--teal);font-weight:700}
  .cb-lede .aka{color:var(--ink);font-weight:500}
  .cb-hero.in .cb-lede{opacity:1;transform:none}
  .cb-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;opacity:0;transform:translateY(16px);transition:opacity .8s var(--ease) .68s,transform .8s var(--ease) .68s}
  .cb-hero.in .cb-cta{opacity:1;transform:none}

  /* ---------- CAPABILITIES (replaces the spotlight band) ---------- */
  .cb-pillars{padding:clamp(80px,14vh,160px) 0;background:var(--paper);border-top:1px solid var(--line)}
  .cb-pillars .ey{font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal-d);margin:0 0 14px;display:flex;align-items:center;gap:10px}
  .cb-pillars .ey::before{content:"";width:26px;height:1.5px;background:var(--teal)}
  .cb-pillars h2{font-family:"Inter Tight",sans-serif;font-weight:600;letter-spacing:-.025em;font-size:clamp(30px,4.2vw,54px);line-height:1.03;margin:0 0 clamp(40px,6vh,66px);max-width:16ch}
  .cb-pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,4vw,56px)}
  @media(max-width:780px){.cb-pgrid{grid-template-columns:1fr;gap:36px}}
  .cb-pillar{border-top:1px solid var(--line);padding-top:24px}
  .cb-pillar .n{font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.14em;color:var(--teal-d);margin:0 0 18px}
  .cb-pillar h3{font-family:"Inter Tight",sans-serif;font-weight:600;font-size:clamp(20px,2vw,26px);margin:0 0 12px;color:var(--ink)}
  .cb-pillar p{font-size:15px;line-height:1.62;color:var(--muted);margin:0}

  @media (prefers-reduced-motion:reduce){
    .cb-w{transform:none!important}.cb-eyebrow,.cb-sub,.cb-lede,.cb-cta{opacity:1!important;transform:none!important}
  }

  /* ================= LAB ADD-ONS (toggleable) ================= */
  /* control panel */
  .labpanel{position:fixed;left:50%;bottom:16px;transform:translateX(-50%);z-index:6000;display:flex;gap:3px;align-items:center;
    background:rgba(15,42,68,.94);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:7px 8px;border-radius:14px;box-shadow:0 18px 40px rgba(15,42,68,.32);font-family:"IBM Plex Mono",monospace}
  .labpanel .lp-lbl{color:#7fd9d4;font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:0 8px}
  .labpanel button{border:0;cursor:pointer;font-family:inherit;font-size:11px;color:rgba(255,255,255,.55);background:transparent;padding:7px 9px;border-radius:8px;transition:all .15s;white-space:nowrap}
  .labpanel button.on{color:#0F2A44;background:#1FB6B0;font-weight:600}
  .labpanel button:not(.on):hover{color:#fff;background:rgba(255,255,255,.08)}
  @media(max-width:820px){.labpanel{overflow-x:auto;max-width:95vw}.labpanel .lp-lbl{display:none}}

  /* (1) section scroll transitions — applied only when fx-scroll is on */
  .fx-scroll .lab-band{opacity:0;transform:translateY(44px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
  .fx-scroll .lab-band.seen{opacity:1;transform:none}

  /* (2) magnetic/tilt range cards — snappier transition while active */
  .fx-magnet .bed{transition:transform .14s var(--ease),box-shadow .35s var(--ease),border-color .35s}

  /* (3) trust signals marquee */
  .lab-trust{display:none;padding:46px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .fx-trust .lab-trust{display:block}
  .lab-trust-label{text-align:center;font-family:"IBM Plex Mono",monospace;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:0 0 22px}
  .lab-trust-marq{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
  .lab-trust-track{display:flex;gap:16px;width:max-content;animation:labmarq 34s linear infinite}
  .lab-trust-track .b{font-family:"Inter Tight",sans-serif;font-weight:600;font-size:14.5px;color:var(--ink);opacity:.72;border:1px solid var(--line);border-radius:999px;padding:11px 19px;white-space:nowrap;display:inline-flex;align-items:center;gap:9px}
  .lab-trust-track .b .dot{width:6px;height:6px;border-radius:50%;background:var(--teal);flex:none}
  @keyframes labmarq{to{transform:translateX(-50%)}}

  /* (4) 20-year timeline */
  .lab-timeline{display:none;padding:clamp(80px,13vh,150px) 0;background:var(--paper)}
  .fx-timeline .lab-timeline{display:block}
  .lab-timeline .ey{font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal-d);margin:0 0 14px;display:flex;align-items:center;gap:10px}
  .lab-timeline .ey::before{content:"";width:26px;height:1.5px;background:var(--teal)}
  .lab-timeline h2{font-family:"Inter Tight",sans-serif;font-weight:600;letter-spacing:-.025em;font-size:clamp(30px,4.2vw,54px);line-height:1.03;margin:0 0 clamp(42px,6vh,64px)}
  .lab-timeline h2 b{color:var(--teal);font-weight:600}
  .lab-tl{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
  .lab-tl-line{position:absolute;left:0;right:0;top:9px;height:2px;background:linear-gradient(90deg,var(--teal),rgba(31,182,176,.15))}
  .lab-tl-item{position:relative;padding-top:34px;opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
  .lab-tl-item.seen{opacity:1;transform:none}
  .lab-tl-item::before{content:"";position:absolute;top:2px;left:0;width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid var(--teal)}
  .lab-tl-year{font-family:"Inter Tight",sans-serif;font-weight:700;font-size:21px;color:var(--ink);margin-bottom:8px}
  .lab-tl-item p{font-size:13.5px;line-height:1.5;color:var(--muted);margin:0;max-width:90%}
  @media(max-width:780px){.lab-tl{grid-template-columns:1fr;gap:0}.lab-tl-line{left:6px;right:auto;top:0;bottom:0;width:2px;height:auto}
    .lab-tl-item{padding-top:0;padding-left:34px;padding-bottom:30px}.lab-tl-item::before{top:1px;left:0}}
  .lab-note{font-family:"IBM Plex Mono",monospace;font-size:11px;color:var(--muted);opacity:.7;margin:30px 0 0}

  /* ===== V2.2 — living particle field across the WHOLE page ===== */
  .site-nav{z-index:1000}            /* keep site.css's sticky positioning; just sit above the field */
  main{position:relative;z-index:1}
  .site-footer{position:relative;z-index:1}
  /* let the field flow behind these bands */
  .cb-hero,.manifesto,.cb-pillars,.xrange,.lab-timeline{background:transparent}
  .cb-hero::after{background:radial-gradient(58% 52% at 50% 46%, rgba(247,250,251,.78) 0%, rgba(247,250,251,.15) 55%, transparent 80%)}
  /* lightly frosted panels keep dense copy crisp while still showing the field */
  .marquee,.xstats,.lab-trust{background:rgba(255,255,255,.6);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
  /* solids that float over the field */
  .xcta-sec{background:rgba(15,42,68,.94)}
