/* ============================================================
   ONEFINITY — CINEMATIC DESIGN SYSTEM (shared across all pages)
   ============================================================ */
:root{
  --night:#0A0D0C; --panel:#121613; --ink:#EFF3F0;
  --ink2:rgba(239,243,240,.7); --mute:rgba(239,243,240,.46);
  --line:rgba(255,255,255,.09);
  --green:#479D6E; --dark:#2F6949; --glow:#8FD1AA;
}
html{scroll-behavior:smooth}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
body{background:#0A0D0C;overflow-x:hidden}
::-webkit-scrollbar{width:9px}::-webkit-scrollbar-thumb{background:#232B27;border-radius:8px}::-webkit-scrollbar-track{background:#0A0D0C}

/* fixed GPU particle canvas — sits behind all content, fades out past hero */
#pcanvas{position:fixed;inset:0;width:100vw;height:100vh;z-index:1;pointer-events:none;display:block}
#hero .hero-ui{transition:opacity .4s ease}

/* ---- reveal-on-scroll ---- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-d0{transition-delay:0s}.reveal-d1{transition-delay:.09s}.reveal-d2{transition-delay:.18s}
.reveal-d3{transition-delay:.27s}.reveal-d4{transition-delay:.36s}.reveal-d5{transition-delay:.45s}
.text-gradient{background:linear-gradient(120deg,#C8E2D4,#479D6E 60%);-webkit-background-clip:text;background-clip:text;color:transparent}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none!important}}

/* ---- split-line + word reveals ---- */
.split-line{overflow:hidden}
.split-line > span{display:inline-block;transform:translateY(110%);filter:blur(6px);opacity:0;transition:transform 1s cubic-bezier(.16,1,.3,1),filter 1s cubic-bezier(.16,1,.3,1),opacity 1s cubic-bezier(.16,1,.3,1)}
.split-line.in > span{transform:translateY(0);filter:blur(0);opacity:1}
.word-anim{display:inline-block;overflow:hidden;vertical-align:top}
.word-anim > span{display:inline-block;transform:translateY(110%);transition:transform .9s cubic-bezier(.16,1,.3,1)}
.word-anim.in > span{transform:translateY(0)}

/* ---- shared buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:.95rem;padding:.85rem 1.7rem;border-radius:999px;transition:transform .25s cubic-bezier(.16,1,.3,1),background .25s,color .25s,box-shadow .25s;cursor:pointer;line-height:1}
.btn-primary{background:#EFF3F0;color:#0A0D0C}
.btn-primary:hover{box-shadow:0 20px 40px rgba(255,255,255,.14)}
.btn-green{background:linear-gradient(120deg,#479D6E,#2F6949);color:#EFF3F0}
.btn-green:hover{box-shadow:0 18px 38px rgba(71,157,110,.35)}
.btn-ghost{border:1px solid rgba(255,255,255,.4);color:#EFF3F0}
.btn-ghost:hover{background:#EFF3F0;color:#0A0D0C}
.magnetic{transition:transform .25s cubic-bezier(.16,1,.3,1)}
.kicker{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--green);font-weight:600}

/* ---- page hero (inner pages) ---- */
.page-hero{position:relative;padding:9rem 1.5rem 4rem;overflow:hidden;border-bottom:1px solid var(--line)}
@media(min-width:1024px){.page-hero{padding:11rem 2.5rem 5rem}}
.page-hero h1{font-family:'Space Grotesk',sans-serif;font-weight:800;line-height:.98;letter-spacing:-.03em;color:#fff;font-size:clamp(2.4rem,7vw,5rem)}
.page-hero p{color:var(--ink2);max-width:560px;margin-top:1.25rem;font-size:1.05rem}

/* ---- generic surfaces / cards ---- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:18px}
.glass{background:rgba(15,20,18,.72);backdrop-filter:blur(18px);border:1px solid var(--line)}
.hairline{border-color:var(--line)}
.field{width:100%;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:12px;padding:.85rem 1rem;color:#EFF3F0;font-size:.98rem;transition:border-color .25s,background .25s}
.field:focus{outline:none;border-color:var(--green);background:rgba(71,157,110,.06)}
.field::placeholder{color:var(--mute)}
label.lbl{display:block;font-size:.8rem;color:var(--ink2);margin-bottom:.4rem;font-weight:500}

/* ---- sticky pinned-image scroll story (Apple-style, homepage) ---- */
.pin-wrap{position:relative}
.pin-media{position:sticky;top:0;height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.pin-media img{position:absolute;inset:0;margin:auto;max-width:min(72vw,760px);max-height:70vh;object-fit:contain;opacity:0;transform:scale(.94);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.pin-media img.active{opacity:1;transform:scale(1)}
.pin-caption{min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:4rem 2.5rem}
.pin-caption .num{font-family:'JetBrains Mono',monospace;font-size:.8rem;color:#479D6E;letter-spacing:.16em;margin-bottom:1rem;opacity:.5;transition:opacity .5s}
.pin-caption.active .num{opacity:1}
.pin-caption h3{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(1.6rem,3.4vw,2.6rem);line-height:1.12;letter-spacing:-.02em;margin-bottom:1rem;opacity:.35;transform:translateX(-8px);transition:opacity .6s,transform .6s}
.pin-caption.active h3{opacity:1;transform:translateX(0)}
.pin-caption p{color:rgba(239,243,240,.6);max-width:420px;font-size:1.02rem;opacity:0;transition:opacity .6s .1s}
.pin-caption.active p{opacity:1}

/* ---- full-bleed cinematic image break with parallax ---- */
.cine{position:relative;height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.cine img{position:absolute;inset:0;width:100%;height:120%;object-fit:cover;object-position:center;will-change:transform}
.cine::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,13,12,.15) 0%,rgba(10,13,12,.05) 40%,rgba(10,13,12,.9) 100%)}
.cine-content{position:relative;z-index:2;padding:4rem 2rem 5rem;width:100%}

/* ---- image cards (lineup / product grids) ---- */
.lineup-card{position:relative;border-radius:22px;overflow:hidden;aspect-ratio:3/4;background:#121613;transform-style:preserve-3d;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.lineup-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.16,1,.3,1)}
.lineup-card:hover img{transform:scale(1.08)}
.lineup-card .overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(10,13,12,.94) 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.75rem}
.lineup-card .shine{position:absolute;inset:0;z-index:3;background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.14) 48%,transparent 62%);transform:translateX(-120%);transition:transform .8s cubic-bezier(.16,1,.3,1);pointer-events:none}
.lineup-card:hover .shine{transform:translateX(120%)}

.no-scrollbar::-webkit-scrollbar{display:none}
.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}
.snap-x-mand{scroll-snap-type:x mandatory}.snap-start{scroll-snap-align:start}

/* ---- animated counter band ---- */
.statband{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
@media(min-width:768px){.statband{grid-template-columns:repeat(4,1fr)}}
.statcell{background:#0A0D0C;padding:2.6rem 1.5rem;text-align:center;position:relative;overflow:hidden}
.statcell::before{content:'';position:absolute;top:0;left:0;height:2px;width:0;background:linear-gradient(90deg,#8FD1AA,#479D6E);transition:width 1.1s cubic-bezier(.16,1,.3,1)}
.statcell.in::before{width:100%}
.statnum{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(2rem,4.4vw,3rem);letter-spacing:-.02em;line-height:1;background:linear-gradient(120deg,#EFF3F0,#8FD1AA);-webkit-background-clip:text;background-clip:text;color:transparent}
.statlbl{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(239,243,240,.5);margin-top:.7rem}

/* ---- exploded-part label reveal + tether pulse ---- */
.part-label{opacity:0;transform:translateY(10px) scale(.96);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1)}
.part-label.in{opacity:1;transform:none}
.part-label::after{content:'';position:absolute;width:7px;height:7px;border-radius:99px;background:#8FD1AA;box-shadow:0 0 0 0 rgba(143,209,170,.6);animation:tether 2.4s ease-out infinite}
@keyframes tether{0%{box-shadow:0 0 0 0 rgba(143,209,170,.55)}70%{box-shadow:0 0 0 10px rgba(143,209,170,0)}100%{box-shadow:0 0 0 0 rgba(143,209,170,0)}}
.part-label.pl-a::after{right:-3px;top:50%}.part-label.pl-b::after{left:-3px;top:50%}

/* ---- mobile scroll-story ---- */
.m-fig{position:relative;isolation:isolate}
.m-img{will-change:transform;transform:translateY(0) scale(1.06)}
.m-curtain{position:absolute;inset:0;z-index:3;background:linear-gradient(180deg,#0A0D0C,#10160f);transform:translateY(0);transition:transform 1.05s cubic-bezier(.76,0,.24,1)}
.m-curtain::after{content:'';position:absolute;left:0;right:0;bottom:0;height:2px;background:linear-gradient(90deg,#8FD1AA,#479D6E);box-shadow:0 0 14px rgba(143,209,170,.7)}
.mchapter.in .m-curtain{transform:translateY(-101%)}
.m-copy > *{opacity:0;transform:translateY(22px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.mchapter.in .m-num{opacity:1;transform:none;transition-delay:.2s}
.mchapter.in .m-h{opacity:1;transform:none;transition-delay:.32s}
.mchapter.in .m-p{opacity:1;transform:none;transition-delay:.46s}
@media(prefers-reduced-motion:reduce){.m-curtain{display:none}.m-copy>*{opacity:1;transform:none}.m-img{transform:none}}

/* ---- ambient aurora ---- */
.aurora{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.aurora span{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;background:radial-gradient(circle,rgba(71,157,110,.5),transparent 70%)}
.aurora .a1{width:46vw;height:46vw;left:-10vw;top:-12vw;animation:drift1 18s ease-in-out infinite}
.aurora .a2{width:38vw;height:38vw;right:-8vw;bottom:-10vw;background:radial-gradient(circle,rgba(143,209,170,.4),transparent 70%);animation:drift2 22s ease-in-out infinite}
@keyframes drift1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(6vw,4vw) scale(1.15)}}
@keyframes drift2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-5vw,-3vw) scale(1.1)}}

/* ---- marquee ---- */
.marquee{display:flex;overflow:hidden;white-space:nowrap;-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:3.5rem;padding-right:3.5rem;animation:scrollx 26s linear infinite;flex-shrink:0}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes scrollx{to{transform:translateX(-100%)}}
.mq-item{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(1.4rem,3.4vw,2.2rem);letter-spacing:-.01em;color:rgba(239,243,240,.28);display:inline-flex;align-items:center;gap:3.5rem}
.mq-item::before{content:'';width:7px;height:7px;border-radius:99px;background:#479D6E;flex-shrink:0}

/* ---- scroll progress rail ---- */
#scrollbar{position:fixed;top:0;left:0;height:2px;z-index:60;width:0;background:linear-gradient(90deg,#8FD1AA,#479D6E);box-shadow:0 0 10px rgba(71,157,110,.6)}

/* ============ SITE NAV (injected by theme.js) ============ */
#site-header{position:fixed;top:0;inset-inline:0;z-index:50;transition:background .4s ease,backdrop-filter .4s,border-color .4s;border-bottom:1px solid transparent}
#site-header.scrolled{background:rgba(10,13,12,.78);backdrop-filter:blur(16px);border-bottom-color:var(--line)}
#site-header .nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.5rem}
@media(min-width:1024px){#site-header .nav-inner{padding:1.15rem 2.5rem}}
#site-header a.brand{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.15rem;color:#fff;letter-spacing:-.01em}
#site-header .navlinks{display:none;gap:2rem}
@media(min-width:1024px){#site-header .navlinks{display:flex}}
#site-header .navlinks a{font-size:.9rem;font-weight:500;color:var(--ink2);transition:color .2s;position:relative}
#site-header .navlinks a:hover,#site-header .navlinks a[aria-current]{color:#fff}
#site-header .navlinks a[aria-current]::after{content:'';position:absolute;left:0;right:0;bottom:-6px;height:1.5px;background:var(--green)}
#site-header .navright{display:flex;align-items:center;gap:1rem}
.nav-icon{color:var(--ink2);transition:color .2s}.nav-icon:hover{color:#fff}
#burger{display:inline-flex;color:#fff}@media(min-width:1024px){#burger{display:none}}
/* mobile drawer */
#mobile-menu{position:fixed;inset:0;z-index:49;background:rgba(10,13,12,.97);backdrop-filter:blur(10px);transform:translateY(-100%);transition:transform .5s cubic-bezier(.76,0,.24,1);display:flex;flex-direction:column;justify-content:center;padding:2rem;gap:.25rem}
#mobile-menu.open{transform:translateY(0)}
#mobile-menu a{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:2rem;color:#fff;padding:.6rem 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
#mobile-menu a .idx{font-family:'JetBrains Mono',monospace;font-size:.8rem;color:var(--green)}

/* ============ SITE FOOTER (injected by theme.js) ============ */
#site-footer{border-top:1px solid var(--line);background:#080B0A;position:relative;z-index:2}
#site-footer .foot-top{max-width:1400px;margin:0 auto;padding:4rem 1.5rem 2.5rem;display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
@media(min-width:768px){#site-footer .foot-top{grid-template-columns:2fr 1fr 1fr 1fr 1fr;padding:5rem 2.5rem 3rem}}
#site-footer .foot-brand{grid-column:1/-1}
@media(min-width:768px){#site-footer .foot-brand{grid-column:auto}}
#site-footer .foot-brand .bw{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.4rem;color:#fff}
#site-footer h4{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);margin-bottom:1rem}
#site-footer ul{display:flex;flex-direction:column;gap:.6rem}
#site-footer ul a{color:var(--ink2);font-size:.92rem;transition:color .2s}#site-footer ul a:hover{color:#fff}
#site-footer .foot-bottom{max-width:1400px;margin:0 auto;padding:1.5rem;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;color:var(--mute);font-size:.8rem}
@media(min-width:768px){#site-footer .foot-bottom{padding:1.5rem 2.5rem}}

/* ---- custom precision cursor (desktop only) ---- */
@media (hover:hover) and (pointer:fine){
  body{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='7' fill='none' stroke='white' stroke-width='3' opacity='.9'/%3E%3Cline x1='12' y1='1' x2='12' y2='6' stroke='white' stroke-width='3'/%3E%3Cline x1='12' y1='18' x2='12' y2='23' stroke='white' stroke-width='3'/%3E%3Cline x1='1' y1='12' x2='6' y2='12' stroke='white' stroke-width='3'/%3E%3Cline x1='18' y1='12' x2='23' y2='12' stroke='white' stroke-width='3'/%3E%3Ccircle cx='12' cy='12' r='7' fill='none' stroke='%23479D6E' stroke-width='1.5'/%3E%3Cline x1='12' y1='1' x2='12' y2='6' stroke='%23479D6E' stroke-width='1.5'/%3E%3Cline x1='12' y1='18' x2='12' y2='23' stroke='%23479D6E' stroke-width='1.5'/%3E%3Cline x1='1' y1='12' x2='6' y2='12' stroke='%23479D6E' stroke-width='1.5'/%3E%3Cline x1='18' y1='12' x2='23' y2='12' stroke='%23479D6E' stroke-width='1.5'/%3E%3Ccircle cx='12' cy='12' r='1.5' fill='%23479D6E'/%3E%3C/svg%3E") 12 12,auto}
  a,button,.magnetic,.btn,[role="button"]{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'%3E%3Ccircle cx='14' cy='14' r='8' fill='none' stroke='white' stroke-width='3' opacity='.9'/%3E%3Cpath d='M2 8 L2 2 L8 2' stroke='white' stroke-width='2.6' fill='none'/%3E%3Cpath d='M20 2 L26 2 L26 8' stroke='white' stroke-width='2.6' fill='none'/%3E%3Cpath d='M2 20 L2 26 L8 26' stroke='white' stroke-width='2.6' fill='none'/%3E%3Cpath d='M20 26 L26 26 L26 20' stroke='white' stroke-width='2.6' fill='none'/%3E%3Ccircle cx='14' cy='14' r='8' fill='none' stroke='%232F6949' stroke-width='1.6'/%3E%3Cpath d='M2 8 L2 2 L8 2' stroke='%232F6949' stroke-width='1.3' fill='none'/%3E%3Cpath d='M20 2 L26 2 L26 8' stroke='%232F6949' stroke-width='1.3' fill='none'/%3E%3Cpath d='M2 20 L2 26 L8 26' stroke='%232F6949' stroke-width='1.3' fill='none'/%3E%3Cpath d='M20 26 L26 26 L26 20' stroke='%232F6949' stroke-width='1.3' fill='none'/%3E%3Ccircle cx='14' cy='14' r='3' fill='%23479D6E'/%3E%3C/svg%3E") 14 14,pointer}
}
