/* ===== TOKENS ===== */
:root{
  --bg:#08090b;
  --bg-2:#0e1014;
  --bg-3:#13161b;
  --ink:#f0ece3;
  --ink-2:#b8b4ab;
  --ink-3:#6a6860;
  --gold:#c9a44c;
  --gold-2:#e4c878;
  --gold-dim:rgba(201,164,76,.12);
  --line:rgba(240,236,227,.07);
  --line-2:rgba(240,236,227,.13);
  --r:16px;
  --max:1260px;
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-in-out:cubic-bezier(.87,0,.13,1);
}

/* LIGHT */
body.light{
  --bg:#f8f6f1;
  --bg-2:#eeebe4;
  --bg-3:#e5e1d8;
  --ink:#0a0b0d;
  --ink-2:#4a4844;
  --ink-3:#8a8880;
  --gold:#b8902e;
  --gold-2:#8a6a18;
  --gold-dim:rgba(184,144,46,.08);
  --line:rgba(10,11,13,.08);
  --line-2:rgba(10,11,13,.16);
}

*{margin:0;padding:0;box-sizing:border-box}
html{overflow-x:hidden}
body{
  background:var(--bg);color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  font-size:16px;font-weight:300;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .5s,color .5s;
}
::selection{background:var(--gold);color:#000}
a{color:inherit;text-decoration:none}
em{font-style:italic}

/* ===== UTILITIES ===== */
.eyebrow{
  font-size:11px;letter-spacing:.38em;text-transform:uppercase;
  color:var(--ink-3);font-weight:500;display:block;margin-bottom:20px;
}
body.light .eyebrow{color:var(--ink-3)}

/* ===== ATMOSPHERE ===== */
.grain{
  position:fixed;inset:0;z-index:999;pointer-events:none;
  opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.scroll-progress{
  position:fixed;top:0;left:0;height:1.5px;width:0;z-index:1000;
  background:linear-gradient(90deg,var(--gold),var(--gold-2));
  transition:none;
}

/* ===== CUSTOM CURSOR ===== */
.cursor{
  position:fixed;top:0;left:0;width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(201,164,76,.5);pointer-events:none;z-index:998;
  transform:translate(-50%,-50%);transition:transform .08s,width .35s var(--ease-out),height .35s var(--ease-out),border-color .35s,background .35s;
  mix-blend-mode:difference;
}
.cursor span{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:4px;height:4px;border-radius:50%;background:var(--gold);
  transition:width .3s,height .3s;
}
.cursor.active{width:64px;height:64px;border-color:var(--gold);background:rgba(201,164,76,.08)}
body.light .cursor{border-color:rgba(10,11,13,.4)}

/* ===== NAV ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:28px 44px;
  transition:padding .5s var(--ease-out),background .5s,border-color .5s;
}
.nav.scrolled{
  padding:16px 44px;
  background:rgba(8,9,11,.7);
  backdrop-filter:blur(20px) saturate(1.4);
  border-bottom:1px solid var(--line);
}
body.light .nav.scrolled{background:rgba(248,246,241,.8)}

.nav__brand{
  font-family:'Cormorant Garamond',serif;
  font-size:1.35rem;font-weight:600;letter-spacing:.08em;
  display:flex;align-items:center;gap:5px;
}
.nav__mg{
  background:linear-gradient(135deg,var(--gold-2),var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
body.light .nav__mg{background:none;color:var(--ink)}
.nav__dot{color:var(--gold);margin:0 2px}
body.light .nav__dot{color:var(--ink-2)}
.nav__tresor{color:var(--ink);font-weight:300;letter-spacing:.3em;font-size:1.1rem;font-family:'Inter'}

.nav__mid{display:flex;gap:36px}
.nav__mid a{
  font-size:.85rem;letter-spacing:.06em;color:var(--ink-2);
  position:relative;transition:color .3s;
}
.nav__mid a::after{
  content:"";position:absolute;bottom:-4px;left:0;height:1px;width:0;
  background:var(--gold);transition:width .4s var(--ease-out);
}
body.light .nav__mid a::after{background:var(--ink)}
.nav__mid a:hover{color:var(--ink)}
.nav__mid a:hover::after{width:100%}

.nav__right{display:flex;align-items:center;gap:20px}

/* theme toggle */
.themetoggle{
  display:flex;align-items:center;gap:9px;
  background:none;border:1px solid var(--line-2);border-radius:100px;
  padding:7px 14px;cursor:pointer;color:var(--ink-2);font-size:.78rem;
  letter-spacing:.06em;transition:border-color .3s,background .3s;
}
.themetoggle:hover{border-color:var(--gold);background:var(--gold-dim)}
body.light .themetoggle:hover{border-color:var(--ink);background:rgba(10,11,13,.05)}
.tt-track{
  position:relative;width:36px;height:18px;border-radius:100px;
  background:var(--line-2);transition:background .4s;
}
body.light .tt-track{background:rgba(10,11,13,.2)}
.tt-thumb{
  position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;
  background:var(--gold);transition:transform .4s var(--ease-out);
}
body.light .tt-thumb{transform:translateX(18px);background:var(--ink)}
.tt-label{font-size:.78rem;letter-spacing:.06em;transition:opacity .3s}
.tt-label--d{opacity:1}
.tt-label--l{opacity:0;position:absolute}
body.light .tt-label--d{opacity:0}
body.light .tt-label--l{opacity:1;position:static}

.nav__cta{
  display:flex;align-items:center;gap:9px;
  font-size:.85rem;font-weight:500;letter-spacing:.04em;
  padding:11px 22px;border:1px solid var(--line-2);border-radius:100px;
  transition:border-color .35s,background .35s;
}
.nav__cta:hover{border-color:var(--gold);background:var(--gold-dim)}
body.light .nav__cta:hover{border-color:var(--ink);background:rgba(10,11,13,.05)}
.nav__cta-dot{
  width:7px;height:7px;border-radius:50%;background:var(--gold);
  animation:blink 2s ease infinite;
  flex-shrink:0;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* ===== HAMBURGER (mobile only) ===== */
.navburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:38px;height:38px;padding:0;background:none;border:none;cursor:pointer;
  flex-shrink:0;
}
.navburger span{
  display:block;width:100%;height:1px;background:var(--ink);
  transition:transform .4s var(--ease-out),opacity .3s,background .4s;
}
.navburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.navburger.open span:nth-child(2){opacity:0}
.navburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ===== MOBILE MENU PANEL ===== */
.mobilemenu{
  position:fixed;inset:0;z-index:95;
  background:var(--bg);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:48px;
  opacity:0;visibility:hidden;transform:translateY(-12px);
  transition:opacity .45s var(--ease-out),transform .45s var(--ease-out),visibility 0s .45s;
}
.mobilemenu.open{
  opacity:1;visibility:visible;transform:translateY(0);
  transition:opacity .45s var(--ease-out),transform .45s var(--ease-out),visibility 0s;
}
.mobilemenu__links{display:flex;flex-direction:column;align-items:center;gap:28px}
.mobilemenu__links a{
  font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:300;
  color:var(--ink);letter-spacing:.02em;
}
.mobilemenu__cta{
  display:flex;align-items:center;gap:10px;
  font-size:1rem;letter-spacing:.04em;color:var(--ink-2);
  border:1px solid var(--line-2);padding:14px 28px;border-radius:100px;
}
body.menu-open{overflow:hidden}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 32px;border-radius:100px;font-size:.92rem;font-weight:500;
  letter-spacing:.04em;transition:transform .5s var(--ease-out),box-shadow .5s,background .4s,border-color .4s;
  position:relative;overflow:hidden;will-change:transform;
}
.btn::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:rgba(255,255,255,.08);opacity:0;transition:opacity .4s;
}
.btn:hover::after{opacity:1}
.btn--primary{
  background:linear-gradient(135deg,var(--gold-2),var(--gold));
  color:#1a1200;box-shadow:0 8px 32px -8px rgba(201,164,76,.5);
}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 16px 44px -10px rgba(201,164,76,.55)}
body.light .btn--primary{background:#0a0b0d;color:#fff;box-shadow:0 8px 28px -8px rgba(0,0,0,.4)}
body.light .btn--primary:hover{box-shadow:0 14px 40px -10px rgba(0,0,0,.45)}
.btn--line{
  border:1px solid var(--line-2);color:var(--ink-2);
}
.btn--line:hover{border-color:var(--gold);color:var(--ink);transform:translateY(-2px)}
body.light .btn--line:hover{border-color:var(--ink)}
.btn--lg{padding:20px 42px;font-size:1rem}
.btn__arr{transition:transform .4s}
.btn--line:hover .btn__arr{transform:translateY(4px)}

/* ===== HERO — disciplined grid: kicker+title | seal, under-row, ticker ===== */
.hero{
  min-height:100vh;display:flex;flex-direction:column;
  justify-content:center;
  padding:150px 84px 140px;   /* bottom reserves space for the ticker */
  position:relative;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;top:-25%;left:50%;transform:translateX(-50%);
  width:1100px;height:1100px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,164,76,.1),transparent 62%);
  filter:blur(70px);pointer-events:none;
}
body.light .hero::before{background:radial-gradient(circle,rgba(201,164,76,.08),transparent 62%)}

/* inset luxury frame */
.hero__frame{
  position:absolute;inset:24px;border:1px solid var(--line);
  pointer-events:none;border-radius:4px;
}
.hero__frame::before,.hero__frame::after{
  content:"";position:absolute;width:10px;height:10px;
  border:1px solid var(--gold);opacity:.5;
}
.hero__frame::before{top:-1px;left:-1px;border-right:none;border-bottom:none}
.hero__frame::after{bottom:-1px;right:-1px;border-left:none;border-top:none}

/* vertical edge labels — quiet, in the frame margins */
.hero__edge{
  position:absolute;top:50%;
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--ink-3);
  writing-mode:vertical-rl;
}
.hero__edge--l{left:44px;transform:translateY(-50%)}
.hero__edge--r{right:44px;transform:translateY(-50%) rotate(180deg)}

/* center: title left, seal right — one grid, one axis */
.hero__center{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr auto;
  align-items:center;gap:clamp(40px,6vw,90px);
}
.hero__main{min-width:0}
.hero__kicker{
  display:inline-flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-2);
  border:1px solid var(--line);padding:9px 18px;border-radius:100px;
  margin-bottom:44px;
}
.hero__kicker-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold)}
body.light .hero__kicker-dot{box-shadow:none}

.hero__title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,8.2vw,7.6rem);font-weight:300;
  line-height:1.02;letter-spacing:-.02em;
}
.hero__line{display:block;overflow:hidden;white-space:nowrap}
.hero__line--2{padding-left:clamp(1.5rem,4.5vw,4.5rem)}  /* one deliberate echelon */
.hero__word{display:inline-block;margin-right:.22em}
.hero__word--serif{font-style:italic;color:var(--gold);font-weight:400}
body.light .hero__word--serif{color:var(--gold)}

/* rotating seal — placed, not floating */
.hero__seal{
  position:relative;
  width:clamp(150px,16vw,220px);aspect-ratio:1;
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
}
.seal{position:absolute;inset:0;width:100%;height:100%;animation:spin-slow 32s linear infinite}
@keyframes spin-slow{to{transform:rotate(360deg)}}
.seal__text{
  font-size:11px;letter-spacing:.32em;font-weight:500;
  fill:var(--gold);text-transform:uppercase;
}
.seal__core{
  position:relative;display:flex;flex-direction:column;align-items:center;
  width:46%;height:46%;border-radius:50%;
  border:1px solid var(--line-2);justify-content:center;
}
.seal__core::before{
  content:"";position:absolute;inset:6px;border-radius:50%;
  border:1px solid rgba(201,164,76,.25);
}
.seal__est{font-size:9px;letter-spacing:.3em;color:var(--ink-3)}
.seal__year{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--gold);line-height:1}
body.light .seal__year{color:var(--gold)}

/* under-row: hairline, copy left, actions right */
.hero__under{
  position:relative;z-index:2;
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:48px;flex-wrap:wrap;
  margin-top:clamp(40px,6vh,72px);
  padding-top:36px;border-top:1px solid var(--line);
}
.hero__sub{max-width:44ch;color:var(--ink-2);font-size:1.02rem;line-height:1.7}
.hero__ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* ticker: its own zone at the frame's bottom edge — nothing overlaps it */
.hero__ticker{
  position:absolute;left:25px;right:25px;bottom:25px;
  overflow:hidden;padding:18px 0;
  border-top:1px solid var(--line);
}
.ticker__inner{
  display:flex;gap:48px;white-space:nowrap;
  font-size:.74rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-3);
  animation:ticker 24s linear infinite;
}
.bull{color:var(--gold);opacity:.6}
@keyframes ticker{to{transform:translateX(-50%)}}

@keyframes scrolldrop{
  0%{transform:scaleY(0);transform-origin:top;opacity:1}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom;opacity:0}
}

/* ===== STATS BAR ===== */
.statsbar{
  padding:56px 44px;
  border-bottom:1px solid var(--line);
  background:var(--bg-2);
}
.statsbar__inner{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:30px;
}
.statitem{display:flex;flex-direction:column;gap:6px}
.statitem__n{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,4vw,3.6rem);font-weight:300;line-height:1;
  color:var(--ink);
}
.statitem__n small{font-size:60%;color:var(--gold)}
body.light .statitem__n small{color:var(--gold)}
.statitem__l{font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.statitem__div{width:1px;height:56px;background:var(--line-2)}

/* ===== VAULT (GSAP-pinned) ===== */
.vault{position:relative;z-index:2}
.vault__sticky{
  position:relative;height:100vh;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.vault__bg-text{
  position:absolute;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(8rem,22vw,20rem);font-weight:700;
  letter-spacing:.2em;color:var(--ink);
  opacity:.03;pointer-events:none;user-select:none;
  transform:translateY(20px);
}
body.light .vault__bg-text{opacity:.04}

.vault__stage{
  position:relative;display:flex;align-items:center;justify-content:center;
  width:100%;height:100%;perspective:2000px;
}
.vaultdoor{
  position:relative;
  width:min(72vh,500px);height:min(72vh,500px);
  transform-style:preserve-3d;
}
.vaultdoor__interior{
  position:absolute;inset:0;border-radius:24px;overflow:hidden;
  background:radial-gradient(circle at 50% 35%,#1e1a10,#0c0a06 70%);
  border:1px solid rgba(201,164,76,.2);
  box-shadow:inset 0 0 100px rgba(0,0,0,.95);
}
body.light .vaultdoor__interior{
  background:radial-gradient(circle at 50% 35%,#1e1a10,#0c0a06 70%);
  border-color:rgba(201,164,76,.3);
}
.interior__glow{
  position:absolute;inset:0;
  background:radial-gradient(circle at 50% 25%,rgba(201,164,76,.4),transparent 55%);
  opacity:0;transition:opacity .8s .1s;
}
.vaultdoor.open .interior__glow{opacity:1}
.interior__content{
  position:relative;padding:38px;
  opacity:0;transform:translateY(16px);
  transition:opacity .7s .3s,transform .7s .3s;
}
.vaultdoor.open .interior__content{opacity:1;transform:none}
.interior__content h2{
  font-family:'Cormorant Garamond',serif;font-size:clamp(1.5rem,3vw,2.2rem);
  font-weight:300;line-height:1.08;margin-bottom:26px;color:#f0ece3;
}
.interior__content h2 em{color:var(--gold);font-style:italic}
.vaultlist{list-style:none;display:flex;flex-direction:column;gap:14px}
.vaultlist li{
  font-size:.93rem;color:rgba(240,236,227,.65);
  padding-left:18px;position:relative;
}
.vaultlist li::before{
  content:"";position:absolute;left:0;top:8px;
  width:6px;height:6px;border-radius:50%;background:var(--gold);
}
.vaultlist li b{color:#f0ece3;font-weight:500}

/* door */
.vaultdoor__door{
  position:absolute;inset:0;transform-origin:left center;
  transform-style:preserve-3d;transition:filter .3s;
}
.vaultdoor__steel{
  position:absolute;inset:0;border-radius:24px;overflow:hidden;
  background:linear-gradient(160deg,#2e3340 0%,#1e2229 40%,#12151a 100%);
  border:1px solid rgba(255,255,255,.05);
  box-shadow:
    inset 2px 2px 20px rgba(255,255,255,.04),
    inset -4px -8px 30px rgba(0,0,0,.6),
    0 50px 100px -20px rgba(0,0,0,.8),
    4px 0 40px -10px rgba(0,0,0,.5);
}
body.light .vaultdoor__steel{
  background:linear-gradient(160deg,#d8d5ce 0%,#c8c4bc 40%,#b0ada5 100%);
  border-color:rgba(255,255,255,.4);
  box-shadow:inset 2px 2px 20px rgba(255,255,255,.5),inset -4px -8px 20px rgba(0,0,0,.15),0 40px 80px -20px rgba(0,0,0,.25);
}
.vaultdoor__steel::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.05) 50%,transparent 65%);
  animation:sheen 5s ease infinite;
}
@keyframes sheen{0%,100%{opacity:0}50%{opacity:1}}

.vd__ring{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  border-radius:50%;border:1px solid;pointer-events:none;
}
.vd__ring--1{width:87%;height:87%;border-color:rgba(255,255,255,.04)}
.vd__ring--2{width:66%;height:66%;border-color:rgba(201,164,76,.12)}
.vd__ring--3{width:45%;height:45%;border-color:rgba(255,255,255,.04)}
body.light .vd__ring--1{border-color:rgba(0,0,0,.07)}
body.light .vd__ring--2{border-color:rgba(0,0,0,.1)}
body.light .vd__ring--3{border-color:rgba(0,0,0,.06)}

.bolts{position:absolute;inset:0;pointer-events:none}
.bolts span{
  position:absolute;width:15px;height:15px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#4a5060,#1a1d24);
  box-shadow:inset 0 1px 2px rgba(255,255,255,.2),0 1px 3px rgba(0,0,0,.6);
}
body.light .bolts span{
  background:radial-gradient(circle at 35% 30%,#e8e4dc,#b0ada5);
  box-shadow:inset 0 1px 2px rgba(255,255,255,.8),0 1px 2px rgba(0,0,0,.2);
}
.bolts span:nth-child(1){top:16px;left:16px}
.bolts span:nth-child(2){top:16px;right:16px}
.bolts span:nth-child(3){bottom:16px;left:16px}
.bolts span:nth-child(4){bottom:16px;right:16px}
.bolts span:nth-child(5){top:50%;left:12px;margin-top:-7px}
.bolts span:nth-child(6){top:50%;right:12px;margin-top:-7px}
.bolts span:nth-child(7){top:12px;left:50%;margin-left:-7px}
.bolts span:nth-child(8){bottom:12px;left:50%;margin-left:-7px}

.dial{
  position:absolute;top:50%;left:50%;
  width:34%;height:34%;transform:translate(-50%,-50%);
}
.dial__outer{
  position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 40% 35%,#3a4050,#151820);
  box-shadow:0 0 0 6px #1a1d24,0 0 0 8px rgba(255,255,255,.04),inset 0 4px 12px rgba(0,0,0,.7);
}
body.light .dial__outer{
  background:radial-gradient(circle at 40% 35%,#d8d5ce,#b8b4ac);
  box-shadow:0 0 0 6px #c4c0b8,0 0 0 8px rgba(255,255,255,.6),inset 0 4px 10px rgba(0,0,0,.12);
}
.dial__ticks{
  position:absolute;inset:8%;border-radius:50%;
  background:repeating-conic-gradient(from 0deg,rgba(255,255,255,.2) 0deg 1.5deg,transparent 1.5deg 9deg);
  -webkit-mask:radial-gradient(circle,transparent 58%,#000 60%);
  mask:radial-gradient(circle,transparent 58%,#000 60%);
}
body.light .dial__ticks{background:repeating-conic-gradient(from 0deg,rgba(0,0,0,.25) 0deg 1.5deg,transparent 1.5deg 9deg)}
.dial__knob{
  position:absolute;top:50%;left:50%;
  width:50%;height:50%;transform:translate(-50%,-50%);
  border-radius:50%;
  background:radial-gradient(circle at 38% 32%,var(--gold-2),#7a5c18);
  box-shadow:inset 0 2px 6px rgba(255,255,255,.4),0 4px 12px rgba(0,0,0,.6);
}
.dial__line{
  position:absolute;top:50%;left:50%;
  width:60%;height:3px;border-radius:2px;
  transform:translate(-50%,-50%);
  background:#1a1200;opacity:.7;
}

.handle{
  position:absolute;top:50%;right:8%;
  width:11%;height:38%;transform:translateY(-50%);
}
.handle__bar{
  position:absolute;left:50%;top:50%;
  width:8px;height:100%;transform:translate(-50%,-50%);
  border-radius:6px;
  background:linear-gradient(180deg,#4a5060,#1e2229);
  box-shadow:inset 1px 0 2px rgba(255,255,255,.15);
}
body.light .handle__bar{background:linear-gradient(180deg,#d0ccc4,#909088)}
.handle__base{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:20px;height:20px;border-radius:50%;
  background:radial-gradient(circle at 38% 32%,#4a5060,#1e2229);
  box-shadow:inset 0 1px 3px rgba(255,255,255,.15);
}
body.light .handle__base{background:radial-gradient(circle at 38% 32%,#d8d4cc,#a8a49c)}

.vd__brand{
  position:absolute;bottom:10%;left:50%;transform:translateX(-50%);
  font-family:'Cormorant Garamond',serif;font-size:.72rem;letter-spacing:.5em;
  color:rgba(201,164,76,.5);white-space:nowrap;
}
.vd__serial{
  position:absolute;top:10%;left:50%;transform:translateX(-50%);
  font-size:.6rem;letter-spacing:.3em;color:rgba(255,255,255,.12);
}
body.light .vd__serial{color:rgba(0,0,0,.15)}

.vault__hint{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:12px;
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-3);
  transition:opacity .4s;
}
.vault__hint-bar{
  width:1px;height:48px;
  background:linear-gradient(var(--gold),transparent);
  animation:scrolldrop 2s ease infinite;
}

/* ===== SECTIONS ===== */
.section{padding:140px 44px;max-width:calc(var(--max) + 88px);margin:0 auto}

/* ===== WHY ===== */
.why{display:grid;grid-template-columns:1fr 2fr;gap:100px;align-items:start}
.why__head,.why__grid{min-width:0}
.why__title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.4rem,5vw,4rem);font-weight:300;line-height:1.06;
  margin-bottom:0;
}
.why__title em{font-style:italic;color:var(--gold)}
body.light .why__title em{color:var(--gold)}
.why__grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.whycard{
  padding:40px 34px;border:1px solid var(--line);
  background:var(--bg-2);
  display:flex;flex-direction:column;gap:20px;
  transition:background .4s,border-color .4s;
  position:relative;overflow:hidden;
}
.whycard::before{
  content:"";position:absolute;bottom:-60px;right:-60px;
  width:120px;height:120px;border-radius:50%;
  background:var(--gold-dim);filter:blur(30px);
  opacity:0;transition:opacity .5s;
}
.whycard:hover{background:var(--bg-3);border-color:var(--line-2)}
.whycard:hover::before{opacity:1}
.whycard__num{
  font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:300;
  color:var(--ink-3);line-height:1;opacity:.4;
}
body.light .whycard__num{opacity:.25}
.whycard h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.8rem;font-weight:300;line-height:1.05;color:var(--ink);
}
.whycard p{font-size:.9rem;color:var(--ink-2);line-height:1.7}
.whycard__foot{
  margin-top:auto;font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--ink-3);padding-top:20px;border-top:1px solid var(--line);
}

/* ===== MARQUEE ===== */
.marquee-wrap{
  overflow:hidden;padding:22px 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--bg-2);
}
.marquee__inner{
  display:flex;gap:52px;white-space:nowrap;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.1rem,2vw,1.6rem);font-weight:300;font-style:italic;
  color:var(--ink-2);
  animation:marquee 28s linear infinite;
}
.mark{color:var(--gold);font-style:normal}
body.light .mark{color:var(--gold)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ===== ADVANTAGES ===== */
.advantages{max-width:100%;padding:140px 0}
.adv-head{padding:0 44px;max-width:calc(var(--max) + 88px);margin:0 auto 80px}
.adv-head h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.6rem,6vw,5rem);font-weight:300;line-height:1.04;
}
.adv-head h2 em{font-style:italic;color:var(--gold)}
body.light .adv-head h2 em{color:var(--gold)}
.adv-panels{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}
.advpanel{
  padding:48px 36px;border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:18px;
  transition:background .4s;
  min-width:0;
}
.advpanel:last-child{border-right:none}
.advpanel:hover{background:var(--bg-2)}
.advpanel__icon{
  font-size:1.4rem;color:var(--gold);
  transition:transform .4s var(--ease-out);
}
.advpanel:hover .advpanel__icon{transform:translateX(6px)}
body.light .advpanel__icon{color:var(--gold)}
.advpanel h3{
  font-family:'Cormorant Garamond',serif;font-weight:300;
  font-size:1.6rem;line-height:1.1;color:var(--ink);
}
.advpanel p{font-size:.9rem;color:var(--ink-2);line-height:1.7}

/* ===== STANDORT ===== */
.standort{
  padding:160px 44px;
  background:var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;
}
.standort__bg{position:absolute;inset:0;pointer-events:none}
.standort__lines{
  position:absolute;inset:0;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at 60% 50%,#000,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at 60% 50%,#000,transparent 70%);
}
.standort__inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.1fr 0.9fr;gap:100px;align-items:center;
  position:relative;z-index:1;
}
.standort__left,.standort__visual{min-width:0}
.standort__left h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,6vw,5.2rem);font-weight:300;line-height:1.02;
  margin-bottom:28px;
}
.standort__copy{font-size:1rem;color:var(--ink-2);line-height:1.75;max-width:48ch;margin-bottom:52px}
.five-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.five-item{
  padding:20px 22px;border:1px solid var(--line);border-radius:var(--r);
  display:flex;align-items:flex-start;gap:14px;
  transition:border-color .4s,background .4s;
}
.five-item:hover{border-color:var(--line-2);background:var(--bg-3)}
.five-item span{
  font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;
  color:var(--gold);line-height:1;
}
body.light .five-item span{color:var(--gold)}
.five-item p{font-size:.85rem;color:var(--ink-2);padding-top:6px;line-height:1.4}

.map-card{
  border:1px solid var(--line-2);border-radius:24px;overflow:hidden;
  background:var(--bg-3);position:relative;
}
.map-card__inner{padding:40px}
.lake-svg{width:100%;max-width:340px;display:block;margin:0 auto}
.lake{fill:rgba(201,164,76,.12);stroke:var(--gold);stroke-width:.5}
body.light .lake{fill:rgba(184,144,46,.1)}
.loc-dot{fill:var(--gold)}
.loc-dot--ring{fill:none;stroke:var(--gold);stroke-width:.8;opacity:.4;animation:ring-pulse 2.5s ease infinite}
@keyframes ring-pulse{0%,100%{r:20;opacity:.4}50%{r:28;opacity:0}}
.loc-label{fill:var(--ink);font-family:'Inter';font-size:8px;font-weight:600;letter-spacing:.15em;text-anchor:middle;text-transform:uppercase}
.loc-sub{fill:var(--ink-2);font-family:'Inter';font-size:7px;text-anchor:middle;letter-spacing:.08em}
.map-card__tag{
  padding:14px 24px;border-top:1px solid var(--line);
  font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);
}

/* ===== SECURITY ===== */
.security{border-top:1px solid var(--line)}
.security__inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr 1.4fr;gap:120px;align-items:center;
}
.security__visual,.security__text{min-width:0}
.lv-ring{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  border-radius:50%;border:1px solid;
}
.lock-visual{position:relative;width:240px;height:240px}
.lv-ring--1{width:240px;height:240px;border-color:var(--line-2);animation:spin 18s linear infinite}
.lv-ring--2{width:180px;height:180px;border-color:rgba(201,164,76,.2)}
.lv-core{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:120px;height:120px;border-radius:50%;
  background:var(--bg-2);border:1px solid var(--line-2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
}
.lv-num{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:300;color:var(--gold);line-height:1}
body.light .lv-num{color:var(--gold)}
.lv-sub{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-3)}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}

.security__text h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.4rem,5vw,4rem);font-weight:300;line-height:1.06;
  margin-bottom:28px;
}
.security__text h2 em{font-style:italic;color:var(--gold)}
body.light .security__text h2 em{color:var(--gold)}
.security__text p{font-size:.97rem;color:var(--ink-2);line-height:1.75;margin-bottom:18px}

/* ===== PRICES ===== */
.prices{border-top:1px solid var(--line)}
.prices__head{max-width:var(--max);margin:0 auto 64px}
.prices__head h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.6rem,6vw,5rem);font-weight:300;line-height:1.04;
  margin-bottom:16px;
}
.prices__sub{font-size:.88rem;color:var(--ink-3);margin-top:20px;letter-spacing:.04em}
.price-list{max-width:var(--max);margin:0 auto;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.price-list__head,.prow{
  display:grid;grid-template-columns:90px 1fr 1.6fr 1fr;gap:20px;
  padding:18px 28px;align-items:center;
}
.price-list__head{
  background:var(--bg-2);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}
.prow{border-top:1px solid var(--line);font-size:.95rem;color:var(--ink-2);transition:background .3s}
.prow:hover{background:var(--bg-2)}
.prow b{
  font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:300;
  color:var(--gold);text-align:right;
}
body.light .prow b{color:var(--gold)}
.prow--box{background:var(--gold-dim)}
.pricenote{max-width:var(--max);margin:24px auto 0;font-size:.82rem;color:var(--ink-3);letter-spacing:.04em}

/* ===== CHUBB ===== */
.chubb-strip{
  padding:52px 44px;
  display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap;
  background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.chubb-strip__label{font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-3)}
.chubb-strip__name{
  font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:300;
  border:1px solid var(--line-2);padding:10px 28px;border-radius:8px;
  color:var(--gold);letter-spacing:.3em;
}
body.light .chubb-strip__name{color:var(--gold)}
.chubb-strip__desc{font-size:.88rem;color:var(--ink-2);max-width:50ch;text-align:center}

/* ===== CTA ===== */
.cta{
  padding:180px 44px;text-align:center;
  position:relative;overflow:hidden;
}
.cta__glow{
  position:absolute;bottom:-30%;left:50%;transform:translateX(-50%);
  width:800px;height:800px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,164,76,.1),transparent 60%);
  filter:blur(40px);pointer-events:none;
}
body.light .cta__glow{background:radial-gradient(circle,rgba(201,164,76,.07),transparent 60%)}
.cta__inner{position:relative;z-index:1;max-width:700px;margin:0 auto}
.cta__title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,7vw,6rem);font-weight:300;line-height:.98;
  margin-bottom:24px;
}
.cta__sub{font-size:1.05rem;color:var(--ink-2);margin-bottom:48px;max-width:48ch;margin-left:auto;margin-right:auto}
.cta__btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta__addr{margin-top:48px;font-size:.82rem;color:var(--ink-3);letter-spacing:.1em}

/* ===== FOOTER ===== */
.footer{
  padding:48px 44px;
  border-top:1px solid var(--line);
  background:var(--bg-2);
}
.footer__top{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:32px;gap:24px;flex-wrap:wrap;
}
.footer__brand{
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem;font-weight:300;letter-spacing:.2em;color:var(--ink-2);
}
.footer__dot{color:var(--gold);margin:0 4px}
body.light .footer__dot{color:var(--gold)}
.footer__nav{display:flex;gap:28px;flex-wrap:wrap}
.footer__nav a{font-size:.84rem;color:var(--ink-3);letter-spacing:.05em;transition:color .3s}
.footer__nav a:hover{color:var(--ink)}
.footer__bottom{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  padding-top:24px;border-top:1px solid var(--line);
  font-size:.78rem;color:var(--ink-3);
}

/* ===== SPLIT LINES (GSAP target) ===== */
.split-lines .line{overflow:hidden;display:block}
.split-lines .line-inner{display:block;transform:translateY(110%)}

/* ===== REVEAL CLASSES ===== */
.reveal-fade{opacity:0;transition:none}
.reveal-up{opacity:0;transform:translateY(48px);transition:none}
.reveal-left{opacity:0;transform:translateX(-32px);transition:none}

/* ===== MAGNETIC ===== */
[data-magnetic]{transition:transform .5s var(--ease-out)}

/* ===== RESPONSIVE ===== */
@media(max-width:1100px){
  .why{grid-template-columns:1fr;gap:60px}
  .why__grid{grid-template-columns:1fr 1fr}
  .adv-panels{grid-template-columns:1fr 1fr}
  .advpanel{border-bottom:1px solid var(--line)}
  .security__inner{grid-template-columns:1fr;gap:60px}
  .standort__inner{grid-template-columns:1fr;gap:60px}
  .five-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .nav{padding:16px 20px}
  .nav.scrolled{padding:12px 20px}
  .nav__mid{display:none}
  .nav__brand{font-size:1.15rem}
  .nav__tresor{font-size:.92rem;letter-spacing:.22em}
  .nav__right{gap:10px}
  .themetoggle{padding:0;border:none;width:38px;height:38px;justify-content:center}
  .themetoggle:hover{background:none}
  .tt-label{display:none}
  .tt-track{width:34px;height:18px;margin:0}
  .nav__cta{padding:0;border:none;width:38px;height:38px;justify-content:center;border-radius:50%}
  .nav__cta:hover{background:none}
  .nav__cta-text{display:none}
  .nav__cta-dot{width:9px;height:9px}
  .navburger{display:flex}

  .hero{padding:110px 24px 100px}
  .hero__seal{display:none}
  .hero__edge{display:none}
  .hero__frame{inset:12px}
  .hero__center{grid-template-columns:1fr}
  .hero__title{font-size:clamp(2.3rem,11vw,3.4rem)}
  .hero__line--2{padding-left:.8rem}
  .hero__under{margin-top:32px;padding-top:24px;flex-direction:column;align-items:flex-start;gap:24px}
  .hero__ticker{left:12px;right:12px;bottom:12px;padding:12px 0}
  .ticker__inner{gap:32px;font-size:.66rem}

  .statsbar{padding:32px 24px}
  .statsbar__inner{flex-wrap:wrap;gap:24px 0}
  .statitem__div{display:none}
  .statitem{flex:1;min-width:45%}
  .section{padding:80px 24px}
  .why__grid{grid-template-columns:1fr}
  .adv-panels{grid-template-columns:1fr}
  .advpanel{border-right:none}
  .standort{padding:80px 24px}
  .five-grid{grid-template-columns:1fr 1fr}
  .lock-visual{width:200px;height:200px}

  .prices{padding:80px 24px}
  .price-list__head{display:none}
  .price-list{border:none;border-radius:0}
  .prow{
    display:flex;flex-wrap:wrap;gap:10px 18px;
    padding:20px 22px;border:1px solid var(--line);border-radius:var(--r);
    margin-bottom:12px;
  }
  .prow:last-child{margin-bottom:0}
  .prow > *{
    display:flex;flex-direction:column;gap:3px;
    font-size:.95rem;color:var(--ink);
  }
  .prow > *::before{
    content:attr(data-label);
    font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);
  }
  .prow b{text-align:left}
  .prow > *:first-child{flex:0 0 auto;min-width:52px}
  .prow > *:nth-child(3){flex:1 1 100%}

  .cta{padding:110px 24px}
  .footer{padding:32px 24px}
  .footer__top{flex-direction:column;align-items:flex-start;gap:24px}
  .chubb-strip{padding:32px 24px;gap:20px;flex-direction:column;text-align:center}
}
@media(max-width:380px){
  .hero__title{font-size:clamp(2rem,10.5vw,2.8rem)}
  .five-grid{grid-template-columns:1fr}
  .statitem{min-width:100%}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .split-lines .line-inner{transform:none!important}
  .reveal-fade,.reveal-up,.reveal-left{opacity:1!important;transform:none!important}
}
