/* ================================================================
   AUTUMN'S BREEZE — PREMIUM EDITION (v2.0)
   Design thesis: a 7 AM room with windows open — linen light,
   one ribbon of breeze-blue, a copper leaf drift, cinematic quiet.
   ================================================================ */

/* ------------------ TOKENS ------------------ */
:root{
  /* Warm linen palette */
  --linen:        #FBF7EE;
  --linen-2:      #F4EAD5;
  --linen-3:      #E9E1CF;
  --ivory:        #FFFEFA;
  --navy:         #0B2F5C;
  --navy-ink:     #07213F;
  --ink:          #0F1A2B;
  --ink-soft:     #5A6472;
  --hair:         #E3DED2;
  --rule:         #E3DED2;

  /* Accents */
  --breeze:       #2BA8E0;
  --breeze-2:     #7FCDEA;
  --breeze-3:     #BCE0F2;
  --leaf:         #C76A3A;
  --leaf-2:       #E4B79A;
  --ember:        #A84222;
  --gold:         #C9A86A;
  --accent:       var(--breeze);
  --accent-2:     var(--leaf);

  /* Core */
  --bg:           var(--linen);
  --bg-alt:       var(--ivory);
  --bg-deep:      #F0E6CF;
  --on-bg:        var(--ink);
  --glass:        color-mix(in srgb, var(--bg) 72%, transparent);

  /* Type */
  --ff-display:   'Fraunces', ui-serif, Georgia, serif;
  --ff-body:      'Manrope', ui-sans-serif, system-ui, -apple-system, sans-serif;
  --ff-mono:      'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;

  /* Layout */
  --maxw:         1520px;
  --gutter:       clamp(20px, 4vw, 56px);
  --rail:         clamp(48px, 8vw, 108px);
  --rail-left:    clamp(36px, 5vw, 64px);

  /* Motion */
  --e-drift:      cubic-bezier(.22,.61,.36,1);
  --e-breeze:     cubic-bezier(.16,1,.3,1);
  --e-xp:         cubic-bezier(.86,0,.07,1);
  --e-elastic:    cubic-bezier(.68,-0.4,.27,1.4);

  /* Shadows */
  --sh-soft:      0 24px 60px -30px rgba(11,47,92,.18);
  --sh-lift:      0 40px 90px -40px rgba(11,47,92,.28);
}

[data-theme="dark"]{
  --bg:        #0A1420;
  --bg-alt:    #0E1A29;
  --bg-deep:   #050B14;
  --on-bg:     #F5EFE2;
  --ink:       #F5EFE2;
  --ink-soft:  #9FAAB9;
  --hair:      #1D2B3E;
  --rule:      #1D2B3E;
  --accent:    #6EC6EC;
  --accent-2:  #E4B79A;
  --glass:     color-mix(in srgb, var(--bg) 72%, transparent);
}

/* ------------------ RESET ------------------ */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scrollbar-gutter:stable}
body{
  background:var(--bg);color:var(--on-bg);
  font:400 16.5px/1.6 var(--ff-body);
  letter-spacing:-.005em;
  overflow-x:hidden;
  transition:background-color .8s var(--e-drift),color .8s var(--e-drift);
  min-height:100vh;
}
body.is-loading{overflow:hidden;height:100vh}
body.menu-open{overflow:hidden}
img,svg,video{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:var(--bg)}
::-webkit-scrollbar{width:0;height:0}

/* ------------------ CURSOR (leaf + breeze spiral) ------------------ */
@media (hover:hover) and (pointer:fine){
  html,html *{cursor:none !important}
}
#cursor{
  position:fixed;top:0;left:0;z-index:9999;pointer-events:none;
  will-change:transform;
}
/* The leaf — the mouse tip. JS drives rotation in-place. */
#cursor .cur-dot{
  position:absolute;left:-12px;top:-12px;width:24px;height:24px;
  background:url("../svg/cursor-leaf.svg") center/contain no-repeat;
  filter:drop-shadow(0 2px 3px rgba(120,60,20,.28));
  transform-origin:50% 50%;
  transition:opacity .2s;
}
/* The old static spiral element — hidden; breeze trail is drawn by JS as one continuous SVG path. */
#cursor .cur-ring{display:none !important}
.cur-label{
  position:absolute;left:18px;top:22px;white-space:nowrap;
  font:500 9px/1 var(--ff-mono);letter-spacing:.22em;text-transform:uppercase;
  color:var(--breeze);opacity:0;transition:opacity .25s;
}
#cursor.is-hover .cur-dot{filter:drop-shadow(0 3px 5px rgba(120,60,20,.45)) brightness(1.05)}
#cursor.has-label .cur-label{opacity:1}
#cursor.is-down .cur-dot{filter:drop-shadow(0 1px 2px rgba(120,60,20,.35)) brightness(.95)}
#cursor.is-hidden{opacity:0}
#cur-trail-svg{transition:opacity .3s}
#cursor.is-hidden ~ #cur-trail-svg{opacity:0}
@media (hover:none){#cursor,#cur-trail-svg{display:none}}

/* ------------------ PRELOADER ------------------ */
#preloader{
  position:fixed;inset:0;z-index:200;background:var(--bg);
  display:grid;place-items:center;overflow:hidden;
}
.pre-grid{
  position:relative;width:min(920px,88vw);
  display:grid;gap:28px;
}
.pre-mark{
  font-family:var(--ff-display);font-weight:320;
  font-size:clamp(56px,10vw,160px);line-height:.9;letter-spacing:-.04em;
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.pre-mark .pre-word{display:inline-flex;overflow:hidden;vertical-align:bottom}
.pre-char{display:inline-block;transform:translateY(110%);transition:transform 1s var(--e-breeze)}
.pre-amp{display:inline-block;color:var(--accent);font-style:italic;margin:0 .1em;opacity:0;transition:opacity .8s .6s}
body.is-lifting .pre-char{transform:translateY(0)}
body.is-lifting .pre-amp{opacity:1}
.pre-meta{
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  font:500 11px/1 var(--ff-mono);letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-soft);
}
.pre-count{color:var(--on-bg);font-variant-numeric:tabular-nums;font-size:14px}
.pre-bar{height:1px;background:var(--rule);position:relative;overflow:hidden}
.pre-bar i{position:absolute;inset:0 100% 0 0;background:var(--accent);transition:inset .15s linear}
.pre-curtain{
  position:absolute;inset:0;background:var(--bg);pointer-events:none;
  transform:translateY(100%);transition:transform 1.2s var(--e-xp);
}
body.pre-done .pre-curtain{transform:translateY(-100%)}
body.pre-done #preloader{pointer-events:none;transition:opacity .4s .9s;opacity:0}

/* ------------------ CANVAS AMBIENT ------------------ */
#ribbon-canvas{
  position:fixed;inset:0;pointer-events:none;z-index:2;
  mix-blend-mode:multiply;opacity:.85;
}
[data-theme="dark"] #ribbon-canvas{mix-blend-mode:screen;opacity:.8}

/* ------------------ SIDE RAIL ------------------ */
.rail-left{
  position:fixed;top:0;bottom:0;left:0;width:var(--rail-left);
  z-index:40;pointer-events:none;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:86px 0 28px;
}
.rail-brand{
  pointer-events:auto;
  writing-mode:vertical-rl;transform:rotate(180deg);
  font:500 10px/1 var(--ff-mono);letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-soft);margin-inline:auto;display:inline-flex;align-items:center;gap:12px;
}
.rail-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);display:inline-block}
.rail-sections{
  pointer-events:auto;
  display:flex;flex-direction:column;gap:10px;padding-left:18px;
}
.rail-sections a{
  position:relative;display:inline-flex;align-items:center;gap:10px;
  font:500 10px/1 var(--ff-mono);letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-soft);padding:4px 0;transition:color .4s var(--e-drift),transform .4s var(--e-drift);
}
.rail-sections a i{width:18px;height:1px;background:currentColor;opacity:.4;transition:width .45s var(--e-breeze),opacity .3s}
.rail-sections a em{font-style:normal;opacity:.6}
.rail-sections a span{opacity:0;transform:translateX(-6px);transition:opacity .4s,transform .4s;font-family:var(--ff-body);letter-spacing:.1em}
.rail-sections a:hover{color:var(--on-bg);transform:translateX(4px)}
.rail-sections a:hover i{width:30px;opacity:.9}
.rail-sections a:hover span{opacity:1;transform:none}
.rail-sections a.is-active{color:var(--on-bg)}
.rail-sections a.is-active i{width:36px;background:var(--accent);opacity:1}
.rail-progress{
  width:1px;height:120px;background:var(--rule);margin-inline:auto;position:relative;overflow:hidden;
}
.rail-progress i{position:absolute;inset:0 0 auto 0;height:0;background:var(--accent);transition:height .05s linear}
@media (max-width:1100px){.rail-left{display:none}}

/* ------------------ TOPBAR ------------------ */
.topbar{
  position:fixed;inset:0 0 auto 0;z-index:60;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:28px;
  padding:22px var(--gutter);
  background:var(--glass);
  backdrop-filter:blur(16px) saturate(130%);
  -webkit-backdrop-filter:blur(16px) saturate(130%);
  border-bottom:1px solid transparent;
  transition:border-color .6s var(--e-drift),padding .4s var(--e-drift),background-color .6s var(--e-drift);
}
.topbar.is-scrolled{border-bottom-color:var(--rule);padding-top:14px;padding-bottom:14px}
.brand{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--ff-display);font-size:22px;font-weight:420;
  font-variation-settings:"opsz" 144,"SOFT" 60;letter-spacing:-.03em;
  position:relative;
}
.brand .mark{width:30px;height:30px;color:var(--on-bg);transition:transform .6s var(--e-breeze)}
.brand:hover .mark{transform:rotate(-12deg) scale(1.08)}
.brand .amp{color:var(--accent);font-style:italic;}
.brand-word{display:inline-block}

.nav{
  justify-self:center;position:relative;
  display:flex;gap:clamp(14px,2.2vw,36px);padding:8px 4px;
}
.nav a{
  position:relative;display:inline-flex;align-items:baseline;gap:8px;
  font:500 12px/1 var(--ff-body);letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-soft);padding:10px 4px;
  transition:color .35s var(--e-drift);
  overflow:hidden;
}
.nav a .idx{font:500 9px/1 var(--ff-mono);color:var(--accent);transform:translateY(-2px)}
.nav a .lbl{position:relative;display:inline-block;overflow:hidden;height:1em;vertical-align:bottom}
.nav a .lbl::before{
  content:attr(data-text);position:absolute;left:0;top:100%;
  transform:translateY(0);transition:transform .5s var(--e-breeze);color:var(--on-bg);
}
.nav a:hover{color:var(--on-bg)}
.nav a:hover .lbl{color:transparent}
.nav a:hover .lbl::before{transform:translateY(-100%)}
.nav a.is-active{color:var(--on-bg)}
#nav-leaf{
  position:absolute;left:0;top:calc(100% - 4px);width:18px;height:18px;
  color:var(--leaf);opacity:0;pointer-events:none;
  transition:opacity .4s var(--e-drift);
  will-change:transform;
}
#nav-leaf.is-visible{opacity:1}

.topright{display:flex;align-items:center;gap:18px}
.tel{
  position:relative;font-family:var(--ff-mono);font-size:12px;letter-spacing:.08em;
  color:var(--on-bg);padding:10px 0;display:inline-flex;align-items:center;gap:10px;
}
.tel i{
  width:8px;height:8px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 25%,transparent);
  animation:pulse 2.6s var(--e-drift) infinite;
}
@keyframes pulse{50%{box-shadow:0 0 0 12px transparent}}

.theme-toggle{
  width:44px;height:24px;border:1px solid var(--rule);border-radius:999px;
  position:relative;transition:border-color .3s,background-color .3s;
  overflow:hidden;
}
.theme-toggle::after{
  content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;
  background:var(--on-bg);transition:transform .55s var(--e-elastic);
}
[data-theme="dark"] .theme-toggle::after{transform:translateX(20px);background:var(--accent)}
.tt-sun,.tt-moon{position:absolute;top:5px;font-size:10px;pointer-events:none}
.tt-sun{left:6px;opacity:1}
.tt-moon{right:6px;opacity:.4}
[data-theme="dark"] .tt-sun{opacity:.4}
[data-theme="dark"] .tt-moon{opacity:1}

.menu-btn{
  display:none;width:42px;height:42px;border:1px solid var(--rule);border-radius:0;
  align-items:center;justify-content:center;gap:4px;flex-direction:column;
  transition:border-color .3s;
}
.menu-btn i{width:16px;height:1px;background:var(--on-bg);transition:transform .4s var(--e-breeze),width .3s}
.menu-btn:hover i:first-child{transform:translateX(-2px)}
.menu-btn:hover i:last-child{width:12px;transform:translateX(2px)}
@media (max-width:1100px){
  .nav{display:none}
  .menu-btn{display:inline-flex}
}

/* ------------------ OVERLAY MENU ------------------ */
#overlay-menu{
  position:fixed;inset:0;z-index:120;pointer-events:none;
  background:var(--bg-deep);
  clip-path:polygon(0 0,100% 0,100% 0,0 0);
  transition:clip-path 1s var(--e-xp);
  color:var(--on-bg);
}
body.menu-open #overlay-menu{pointer-events:auto;clip-path:polygon(0 0,100% 0,100% 100%,0 100%)}
.om-panel{
  max-width:var(--maxw);margin:0 auto;padding:28px var(--gutter);
  min-height:100vh;display:grid;grid-template-rows:auto 1fr auto;gap:clamp(20px,4vw,60px);
}
.om-head{display:flex;justify-content:space-between;align-items:center}
.om-head .eyebrow{color:var(--ink-soft)}
#menu-close{
  font:500 11px/1 var(--ff-mono);letter-spacing:.22em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;color:var(--on-bg);
}
#menu-close i{width:14px;height:14px;border:1px solid currentColor;position:relative}
#menu-close i::before,#menu-close i::after{
  content:"";position:absolute;inset:50% 2px auto 2px;height:1px;background:currentColor;
  transform:translateY(-50%) rotate(45deg);
}
#menu-close i::after{transform:translateY(-50%) rotate(-45deg)}

.om-nav{display:flex;flex-direction:column;justify-content:center}
.om-link{
  display:grid;grid-template-columns:60px 1fr auto;align-items:center;gap:clamp(18px,3vw,60px);
  padding:clamp(10px,1.4vw,22px) 0;border-bottom:1px solid var(--rule);
  font-family:var(--ff-display);font-weight:320;
  font-size:clamp(42px,8vw,120px);line-height:1;letter-spacing:-.035em;
  font-variation-settings:"opsz" 144,"SOFT" 80;
  overflow:hidden;position:relative;
  transition:color .4s;
}
.om-link em{font-style:normal;font-family:var(--ff-mono);font-size:11px;letter-spacing:.22em;color:var(--ink-soft)}
.om-link span{position:relative;display:inline-block;overflow:hidden;height:.92em}
.om-link span::before{
  content:attr(data-text);position:absolute;left:0;top:100%;color:var(--accent);font-style:italic;
  transform:translateY(0);transition:transform .7s var(--e-breeze);
}
.om-link:hover span{color:transparent}
.om-link:hover span::before{transform:translateY(-100%)}
.om-link i{font:500 11px/1 var(--ff-mono);font-style:normal;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);text-align:right;opacity:0;transform:translateX(-20px);transition:all .5s var(--e-breeze)}
.om-link:hover i{opacity:1;transform:none}

.om-foot{
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,4vw,60px);
  padding-top:24px;border-top:1px solid var(--rule);
}
.om-foot p{margin:6px 0 0;color:var(--ink-soft)}
.om-foot .eyebrow{color:var(--ink-soft)}
@media (max-width:720px){.om-foot{grid-template-columns:1fr}}

/* ------------------ TYPE ------------------ */
h1,h2,h3,h4{
  font-family:var(--ff-display);font-weight:360;letter-spacing:-.03em;line-height:1.02;margin:0;
  font-variation-settings:"opsz" 144,"SOFT" 40;
}
h1{font-size:clamp(48px,9vw,164px)}
h2{font-size:clamp(34px,5.6vw,92px)}
h3{font-size:clamp(22px,2.4vw,36px);font-weight:420;letter-spacing:-.02em}
h4{font:500 13px/1 var(--ff-body);letter-spacing:.2em;text-transform:uppercase}
p{margin:0 0 1em;max-width:62ch}
em,.ital{font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 100}
.q{color:var(--accent)}
.lede{font-family:var(--ff-display);font-size:clamp(19px,1.6vw,26px);font-weight:320;font-variation-settings:"opsz" 72,"SOFT" 60;line-height:1.4;max-width:36ch;color:var(--on-bg)}
.eyebrow{font:500 11px/1 var(--ff-mono);letter-spacing:.24em;text-transform:uppercase;color:var(--ink-soft)}
.mono{font-family:var(--ff-mono);letter-spacing:.04em}
.shell{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}

/* ------------------ REVEALS ------------------ */
.reveal,.h-reveal > span,.splt-line{opacity:0;transform:translateY(24px);transition:opacity 1s var(--e-drift),transform 1s var(--e-drift)}
.reveal.in,.h-reveal.in > span,.splt-line.in{opacity:1;transform:none}
.r-d1{transition-delay:.08s}.r-d2{transition-delay:.16s}.r-d3{transition-delay:.24s}.r-d4{transition-delay:.32s}
.h-reveal > span{display:block}
.h-reveal.in > span:nth-child(1){transition-delay:.05s}
.h-reveal.in > span:nth-child(2){transition-delay:.15s}
.h-reveal.in > span:nth-child(3){transition-delay:.25s}
.h-reveal.in > span:nth-child(4){transition-delay:.35s}

.splt{display:inline-flex;overflow:hidden;vertical-align:bottom}
.splt > span{display:inline-block;transform:translateY(108%);transition:transform 1.1s var(--e-breeze)}
.splt.in > span{transform:translateY(0)}
.splt-w{display:inline-flex;overflow:hidden;vertical-align:bottom}
.splt-w > span{display:inline-block;transform:translateY(108%);transition:transform 1.1s var(--e-breeze)}
.splt-w.in > span{transform:none}

/* ------------------ BUTTONS ------------------ */
.btn-magnet{
  position:relative;display:inline-flex;align-items:center;gap:14px;
  padding:20px 28px;border:1px solid var(--on-bg);color:var(--on-bg);
  font:500 12px/1 var(--ff-mono);letter-spacing:.22em;text-transform:uppercase;
  overflow:hidden;isolation:isolate;transition:color .4s var(--e-drift),border-color .4s;
  will-change:transform;
}
.btn-magnet .btn-liquid{
  position:absolute;inset:auto 0 -10% 0;height:0;background:var(--on-bg);
  transition:height .6s var(--e-breeze);z-index:-1;
  border-radius:50% 50% 0 0/20% 20% 0 0;
}
.btn-magnet:hover{color:var(--bg)}
.btn-magnet:hover .btn-liquid{height:140%;border-radius:0}
.btn-magnet .btn-lbl{position:relative;display:inline-block;overflow:hidden;height:1em}
.btn-magnet .btn-lbl span{display:inline-block;transition:transform .5s var(--e-breeze)}
.btn-magnet .btn-lbl span::after{
  content:attr(data-text);position:absolute;left:0;top:100%;
}
.btn-magnet:hover .btn-lbl span{transform:translateY(-100%)}
.btn-magnet .arrow{width:18px;height:10px;transition:transform .5s var(--e-breeze)}
.btn-magnet:hover .arrow{transform:translateX(6px)}
.btn-lg{padding:26px 36px;font-size:13px}

.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;padding:20px 2px;
  font:500 12px/1 var(--ff-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--on-bg);
  border-bottom:1px solid var(--on-bg);transition:color .3s,border-color .3s,padding-left .4s var(--e-breeze);
}
.btn-ghost .gm-arrow{font-style:normal;color:var(--accent);transition:transform .5s var(--e-breeze)}
.btn-ghost:hover{color:var(--accent);padding-left:12px}
.btn-ghost:hover .gm-arrow{transform:translateY(4px)}

/* ================================================================
   HERO
   ================================================================ */
.hero{
  position:relative;overflow:hidden;
  padding:calc(var(--rail)*1.7) var(--gutter) calc(var(--rail)*.9);
  padding-left:calc(var(--rail-left) + var(--gutter));
  min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;
}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;opacity:.95}
.hero-veil{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    radial-gradient(60% 80% at 80% 10%,color-mix(in srgb,var(--breeze-3) 40%,transparent) 0%,transparent 60%),
    radial-gradient(50% 60% at 10% 90%,color-mix(in srgb,var(--leaf-2) 30%,transparent) 0%,transparent 60%),
    linear-gradient(180deg,transparent 40%,color-mix(in srgb,var(--bg) 30%,transparent) 100%);
  mix-blend-mode:multiply;
}
[data-theme="dark"] .hero-veil{mix-blend-mode:screen;opacity:.7}
.hero > *{position:relative;z-index:3}

.hero-grid{
  display:grid;grid-template-columns:minmax(0,9fr) minmax(0,3fr);
  gap:clamp(24px,4vw,80px);align-items:end;
}
.hero-main{}
.hero-eyebrow{display:inline-flex;align-items:center;gap:12px;margin-bottom:clamp(24px,4vw,60px)}
.hero-eyebrow .pulse{
  width:10px;height:10px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 5px color-mix(in srgb,var(--accent) 22%,transparent);
  animation:pulse 2.6s var(--e-drift) infinite;
}
.hero-h1{position:relative;margin:0 0 clamp(24px,3vw,48px)}
.hero-h1 .line{display:block}
.hero-h1 .line .splt{margin-right:.24em}
.hero-h1 .line.pull-2{padding-left:clamp(36px,12vw,220px)}
.hero-h1 .line.pull-3{padding-left:clamp(12px,6vw,120px);display:flex;align-items:baseline;gap:.08em}
.hero-h1 .ital{font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 100;color:var(--accent)}
.hero-h1 .dot-end{
  display:inline-block;width:.15em;height:.15em;background:var(--accent);border-radius:50%;
  align-self:flex-end;margin-left:.1em;transform:translateY(-.1em);animation:pulse 3s var(--e-drift) infinite;
}

.hero-sub{
  margin-top:clamp(24px,3vw,40px);
  display:grid;grid-template-columns:1fr auto;gap:clamp(24px,4vw,72px);align-items:end;
}
.hero-ctas{display:flex;flex-wrap:wrap;gap:24px;align-items:center}

.hero-meta{
  display:flex;flex-direction:column;gap:14px;
  padding-top:22px;border-top:1px solid var(--rule);
  font:500 11px/1.5 var(--ff-mono);letter-spacing:.08em;color:var(--ink-soft);
}
.meta-line{display:flex;gap:14px;align-items:baseline}
.meta-line span:first-child{color:var(--accent);min-width:22px}
.meta-clock{display:flex;flex-direction:column;gap:6px;margin-top:16px;padding-top:16px;border-top:1px solid var(--rule)}
.clock-val{font-family:var(--ff-mono);font-size:22px;color:var(--on-bg);letter-spacing:.04em;font-variant-numeric:tabular-nums}
.meta-clock em{color:var(--on-bg);font-style:normal}

.hero-ticker{
  margin:calc(var(--rail)*.7) 0 0;padding-top:26px;border-top:1px solid var(--rule);
  display:grid;grid-template-columns:repeat(4,1fr);gap:28px;
}
.ht-item{position:relative;padding-left:14px}
.ht-item::before{content:"";position:absolute;left:0;top:8px;width:4px;height:4px;border-radius:50%;background:var(--accent)}
.ht-item dt{font:500 10px/1 var(--ff-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px}
.ht-item dd{margin:0;font-family:var(--ff-display);font-size:clamp(20px,2.1vw,30px);font-weight:380;letter-spacing:-.02em}

.scroll-hint{
  position:absolute;right:var(--gutter);bottom:28px;z-index:5;
  display:inline-flex;align-items:center;gap:14px;color:var(--ink-soft);
  writing-mode:vertical-rl;transform:rotate(180deg);
}
.scroll-hint .sh-line{width:1px;height:60px;background:var(--rule);position:relative;overflow:hidden}
.scroll-hint .sh-line i{position:absolute;inset:0 0 100% 0;background:var(--accent);animation:sh-travel 2.2s var(--e-drift) infinite}
@keyframes sh-travel{0%{inset:0 0 100% 0}50%{inset:0 0 0 0}100%{inset:100% 0 0 0}}

/* ------------------ MARQUEE ------------------ */
.breeze-bar{
  overflow:hidden;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  font-family:var(--ff-display);font-weight:320;font-size:clamp(28px,4vw,60px);
  letter-spacing:-.02em;padding:22px 0;white-space:nowrap;
  font-variation-settings:"opsz" 144,"SOFT" 40;
  background:var(--bg-alt);
}
.bb-track{
  display:inline-flex;gap:48px;align-items:center;
  animation:drift 52s linear infinite;will-change:transform;
}
.bb-track em{color:var(--accent);font-variation-settings:"opsz" 144,"SOFT" 100}
.bb-track .sep{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--accent);opacity:.8}
@keyframes drift{to{transform:translateX(-50%)}}
.breeze-bar:hover .bb-track{animation-play-state:paused}

/* ================================================================
   PRACTICE
   ================================================================ */
.section{padding:clamp(90px,11vw,180px) var(--gutter)}
.section-head{
  display:grid;grid-template-columns:minmax(140px,1fr) minmax(0,3fr);
  gap:clamp(24px,4vw,80px);align-items:end;
  padding-bottom:clamp(40px,6vw,88px);border-bottom:1px solid var(--rule);
}
.section-head .idx{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}
.section-head h2 .sub-h{display:block;margin-top:14px;font-size:.42em;font-weight:320;color:var(--ink-soft);font-style:italic}

.practice{padding-left:calc(var(--rail-left) + var(--gutter))}
.practice-list{}
.service-row{
  position:relative;display:grid;
  grid-template-columns:140px minmax(0,3fr) minmax(0,4fr) auto;
  gap:clamp(24px,4vw,72px);align-items:start;
  padding:clamp(40px,5vw,72px) 0;border-bottom:1px solid var(--rule);
  transition:padding-left .5s var(--e-breeze);
  overflow:hidden;
}
.service-row:hover{padding-left:14px}
.sr-glow{
  position:absolute;inset:0;pointer-events:none;opacity:0;
  background:radial-gradient(40% 60% at 30% 50%,color-mix(in srgb,var(--accent) 10%,transparent) 0%,transparent 70%);
  transition:opacity .6s var(--e-drift);z-index:0;
}
.service-row:hover .sr-glow{opacity:1}
.service-row > *{position:relative;z-index:1}
.sr-n{font-family:var(--ff-display);line-height:.8;font-size:clamp(58px,6.4vw,98px);font-weight:300;font-variation-settings:"opsz" 144,"SOFT" 0;color:transparent;-webkit-text-stroke:1px var(--on-bg);transition:color .5s var(--e-drift),-webkit-text-stroke .5s}
.service-row:hover .sr-n{color:var(--on-bg);-webkit-text-stroke:1px transparent}
.sr-head h3{max-width:14ch}
.sr-tags{font-size:12px;color:var(--ink-soft);margin-top:10px}
.sr-body p{color:var(--ink-soft);max-width:48ch}
.sr-list{list-style:none;margin:16px 0 0;padding:0;font:400 14px/1.9 var(--ff-mono);letter-spacing:.02em}
.sr-list li{display:flex;align-items:center;gap:10px}
.sr-list li i{width:14px;height:1px;background:var(--accent);display:inline-block}
.sr-cta{align-self:center}

/* ================================================================
   BIG TYPE + STATS
   ================================================================ */
.bigtype{
  position:relative;padding:clamp(60px,10vw,160px) 0;
  background:var(--bg-alt);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  overflow:hidden;
}
.bt-type{
  font-family:var(--ff-display);font-weight:300;font-variation-settings:"opsz" 144,"SOFT" 60;
  font-size:clamp(80px,16vw,260px);line-height:.88;letter-spacing:-.04em;
  padding:0 var(--gutter);color:var(--on-bg);
  display:flex;flex-direction:column;gap:0;
  white-space:nowrap;overflow:hidden;
}
.bt-line{display:block;will-change:transform}
.bt-line.alt{text-align:right;color:color-mix(in srgb,var(--on-bg) 16%,transparent);-webkit-text-stroke:1px var(--on-bg)}
.bt-line.alt .bt-word{color:var(--on-bg);-webkit-text-stroke:0}
.bt-line em{color:var(--accent)}

.stats{
  margin-top:clamp(60px,8vw,120px);
  display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,60px);
  padding:0 var(--gutter);
}
.stat{border-top:1px solid var(--on-bg);padding-top:24px;display:flex;flex-direction:column;gap:10px}
.stat .stat-n{font-family:var(--ff-display);font-size:clamp(48px,5.5vw,88px);font-weight:320;letter-spacing:-.035em;font-variant-numeric:tabular-nums;display:flex;align-items:baseline}
.stat .stat-n i{font-style:normal;font-size:.5em;color:var(--accent);margin-left:4px}
.stat-lbl{color:var(--ink-soft);max-width:22ch}
@media (max-width:900px){.stats{grid-template-columns:1fr 1fr}}

/* ================================================================
   EVIDENCE / DUST → DAYLIGHT
   ================================================================ */
.evidence{padding:clamp(90px,11vw,180px) 0;background:var(--bg);position:relative}
.evidence .section-head{margin-bottom:clamp(40px,6vw,80px)}
.dd-stage{display:flex;flex-direction:column;gap:clamp(60px,8vw,140px)}
.dd-row{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:clamp(24px,4vw,80px);align-items:center;
}
.dd-row.alt .dd-meta{order:1}
.dd-row.alt .dd-frame{order:2}
.dd-frame{
  position:relative;aspect-ratio:4/5;overflow:hidden;
  background:var(--navy-ink);border:1px solid var(--rule);
  box-shadow:var(--sh-lift);transition:transform .7s var(--e-breeze);
}
.dd-frame:hover{transform:translateY(-6px)}
.dd-canvas{position:absolute;inset:0;width:100%;height:100%}
.dd-label{
  position:absolute;left:18px;bottom:16px;z-index:4;
  font:500 11px/1 var(--ff-mono);letter-spacing:.22em;text-transform:uppercase;color:#fff;
  mix-blend-mode:difference;
}
.dd-ba{position:absolute;top:18px;right:18px;z-index:4;display:flex;gap:10px;font:500 10px/1 var(--ff-mono);letter-spacing:.22em;text-transform:uppercase;color:#fff;mix-blend-mode:difference}
.dd-ba i{font-style:normal;padding:6px 10px;border:1px solid rgba(255,255,255,.4);opacity:.4;transition:opacity .4s,border-color .4s}
.dd-frame.is-before .dd-before{opacity:1;border-color:#fff}
.dd-frame.is-after .dd-after{opacity:1;border-color:#fff}

.dd-meta{display:flex;flex-direction:column;gap:14px;padding:0 clamp(0,2vw,32px)}
.dd-meta .eyebrow{color:var(--accent)}
.dd-meta h3{max-width:18ch}
.dd-facts{display:grid;grid-template-columns:1fr 1fr;gap:18px 30px;margin:16px 0 0;padding-top:20px;border-top:1px solid var(--rule)}
.dd-facts dt{font:500 10px/1 var(--ff-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:6px}
.dd-facts dd{margin:0;font-family:var(--ff-display);font-size:20px;font-weight:380;letter-spacing:-.015em}

/* ================================================================
   PROCESS / HORIZONTAL PIN
   ================================================================ */
.process{position:relative;background:var(--bg-deep);color:var(--on-bg);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.process-pin{
  position:relative;height:500vh;
}
.pp-head{
  position:sticky;top:0;z-index:3;
  padding:calc(var(--rail)*.8) var(--gutter) 20px;
  display:grid;grid-template-columns:minmax(160px,1fr) minmax(0,2fr) minmax(0,1fr);gap:clamp(20px,3vw,60px);align-items:start;
  pointer-events:none;
  background:linear-gradient(180deg,var(--bg-deep) 75%,transparent);
}
.pp-head > *{pointer-events:auto}
.pp-head h2{max-width:14ch}
.pp-head .lede{max-width:32ch}
.pp-progress{display:flex;align-items:center;gap:14px;align-self:end;padding-top:20px;border-top:1px solid var(--rule);font:500 11px/1 var(--ff-mono);letter-spacing:.22em;color:var(--ink-soft);text-transform:uppercase;min-width:180px}
.pp-progress::before{content:"";display:block;flex:1;height:1px;background:var(--rule);position:relative;overflow:hidden}
#pp-bar{position:absolute;inset:0 0 auto 0;height:1px;background:var(--accent);width:0%}

.process-pin .pp-track{
  position:sticky;top:0;height:calc(100vh - 40px);margin-top:-40vh;
  display:flex;align-items:center;gap:clamp(22px,3vw,48px);
  padding:0 var(--gutter);
  will-change:transform;
}
.pp-card{
  flex:0 0 clamp(320px,38vw,520px);
  height:clamp(420px,62vh,640px);
  background:var(--bg-alt);border:1px solid var(--rule);
  padding:36px 32px;display:flex;flex-direction:column;gap:18px;
  position:relative;overflow:hidden;
  transition:transform .5s var(--e-breeze),box-shadow .5s;
  box-shadow:var(--sh-soft);
}
.pp-card:hover{transform:translateY(-8px);box-shadow:var(--sh-lift)}
.pp-num{font:500 11px/1 var(--ff-mono);letter-spacing:.22em;color:var(--accent)}
.pp-card h3{max-width:16ch}
.pp-card p{color:var(--ink-soft);max-width:34ch}
.pp-art{margin-top:auto;height:180px;border-top:1px solid var(--rule);padding-top:20px;position:relative;overflow:hidden}
.art-walk{background:
  radial-gradient(circle at 20% 80%,var(--accent) 2px,transparent 3px),
  radial-gradient(circle at 50% 60%,var(--accent) 2px,transparent 3px),
  radial-gradient(circle at 80% 40%,var(--accent) 2px,transparent 3px);
  background-size:100% 100%;animation:breathe 6s var(--e-drift) infinite;
}
.art-tools{background:repeating-linear-gradient(0deg,transparent 0 14px,var(--ink-soft) 14px 15px);opacity:.4}
.art-topdown{background:linear-gradient(180deg,var(--accent) 0%,transparent 100%);opacity:.4}
.art-detail{background:radial-gradient(circle at center,var(--accent) 0,transparent 50%);opacity:.25}
.art-air{background:repeating-linear-gradient(90deg,transparent 0 3px,color-mix(in srgb,var(--accent) 30%,transparent) 3px 4px)}
.art-log{background:repeating-linear-gradient(180deg,transparent 0 16px,var(--ink-soft) 16px 17px);opacity:.35}
@keyframes breathe{50%{opacity:.5}}

/* ================================================================
   QUOTE BIG
   ================================================================ */
.quote-big{padding:clamp(120px,16vw,260px) 0;padding-left:calc(var(--rail-left) + 0px);position:relative;overflow:hidden}
.quote-big .shell{position:relative}
.quote-big .idx{display:block;margin-bottom:32px}
.qbig{
  margin:0;font-family:var(--ff-display);font-weight:300;font-variation-settings:"opsz" 144,"SOFT" 70;
  font-size:clamp(34px,5.4vw,82px);line-height:1.08;letter-spacing:-.025em;max-width:20ch;
}
.qbig .splt-line{display:block}
.qbig .splt-line:first-of-type::before{content:"“";color:var(--accent);font-style:italic}
.qbig cite,.quote-big cite{display:block;margin-top:40px;font:500 11px/1 var(--ff-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);font-style:normal}

/* ================================================================
   VOICES / TESTIMONIALS
   ================================================================ */
.voices{padding:clamp(80px,10vw,160px) 0;background:var(--bg-alt);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.voices-stage{
  position:relative;margin-top:clamp(40px,6vw,80px);padding:0 var(--gutter);
  display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;
}
.vx-nav{
  width:56px;height:56px;border:1px solid var(--on-bg);border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--ff-mono);font-size:18px;color:var(--on-bg);
  transition:background-color .4s,color .4s,transform .4s var(--e-breeze);
}
.vx-nav:hover{background:var(--on-bg);color:var(--bg);transform:scale(1.06)}
.vx-deck{position:relative;height:clamp(320px,44vw,440px);perspective:1400px}
.vx-card{
  position:absolute;inset:0;margin:auto;max-width:860px;padding:clamp(30px,4vw,56px);
  background:var(--bg);border:1px solid var(--rule);box-shadow:var(--sh-lift);
  display:flex;flex-direction:column;gap:22px;justify-content:space-between;
  transform-origin:center 60%;
  transition:transform .8s var(--e-breeze),opacity .6s,filter .6s;
  opacity:0;transform:translateY(60px) scale(.92) rotateX(10deg);filter:blur(4px);
}
.vx-card.is-active{opacity:1;transform:none;filter:none;z-index:3}
.vx-card.is-prev{opacity:.35;transform:translate(-60px,30px) rotateZ(-4deg) scale(.9);z-index:2;filter:blur(2px)}
.vx-card.is-next{opacity:.35;transform:translate(60px,30px) rotateZ(4deg) scale(.9);z-index:2;filter:blur(2px)}
.vx-card blockquote{margin:0;font-family:var(--ff-display);font-size:clamp(22px,2.6vw,40px);font-weight:320;line-height:1.25;letter-spacing:-.02em;color:var(--on-bg)}
.vx-card footer{display:flex;flex-direction:column;gap:4px;padding-top:20px;border-top:1px solid var(--rule);font:500 12px/1 var(--ff-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.vx-card footer strong{color:var(--on-bg);font-family:var(--ff-display);font-weight:420;font-size:18px;letter-spacing:-.01em;text-transform:none}
.vx-bars{grid-column:1/-1;display:flex;gap:8px;justify-content:center;margin-top:24px}
.vx-bars i{width:34px;height:2px;background:var(--rule);display:block;transition:background-color .4s,width .4s var(--e-breeze);cursor:pointer}
.vx-bars i.is-active{background:var(--accent);width:60px}

/* ================================================================
   JOURNAL
   ================================================================ */
.journal{padding:clamp(90px,11vw,180px) 0;position:relative}
.blog-row{
  display:grid;grid-template-columns:140px minmax(0,1fr) minmax(0,2fr) minmax(auto,160px) 24px;
  gap:clamp(20px,3vw,60px);align-items:center;
  padding:clamp(28px,4vw,52px) 0;border-bottom:1px solid var(--rule);
  transition:padding-left .5s var(--e-breeze);position:relative;
}
.blog-row:first-child{border-top:1px solid var(--rule)}
.blog-row:hover{padding-left:14px}
.blog-row .date{font-size:11px;letter-spacing:.14em;color:var(--ink-soft)}
.br-body h3{font-size:clamp(22px,2.4vw,36px);max-width:20ch;overflow:hidden;line-height:1.15}
.br-body h3 span{display:inline-block;transition:transform .5s var(--e-breeze)}
.blog-row:hover .br-body h3 span{transform:translateY(-4px);color:var(--accent)}
.br-body p{color:var(--ink-soft);max-width:52ch;margin:8px 0 0;font-size:15px}
.br-tag{font-size:11px;color:var(--ink-soft);letter-spacing:.12em;text-transform:uppercase}
.br-arrow{font-family:var(--ff-mono);color:var(--accent);transform:translateX(0);transition:transform .5s var(--e-breeze)}
.blog-row:hover .br-arrow{transform:translateX(10px)}

/* ================================================================
   CTA BLOCK
   ================================================================ */
.cta-block{padding:clamp(100px,12vw,200px) 0;border-top:1px solid var(--rule);position:relative}
.cta-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:clamp(24px,4vw,80px);align-items:end}
.cta-grid h2{max-width:18ch;font-size:clamp(44px,6.8vw,112px)}
.cta-grid h2 span{display:block}
.cta-right{display:flex;flex-direction:column;gap:24px;align-items:flex-start}
.cta-meta{display:flex;flex-direction:column;gap:4px;padding-top:20px;border-top:1px solid var(--rule);width:100%;font-family:var(--ff-display);font-size:20px;font-weight:380;letter-spacing:-.01em}
.cta-meta a:hover{color:var(--accent)}
@media (max-width:900px){.cta-grid{grid-template-columns:1fr}}

/* ================================================================
   FOOTER
   ================================================================ */
.site-foot{padding:clamp(70px,9vw,130px) 0 28px;border-top:1px solid var(--rule);background:var(--bg);position:relative;overflow:hidden}
.sf-grid{
  display:grid;grid-template-columns:minmax(0,2fr) repeat(3,minmax(0,1fr));
  gap:clamp(24px,4vw,64px);padding:0 var(--gutter);
}
.sf-main .lede{max-width:32ch;font-size:20px;margin:14px 0 22px}
.sf-sub{display:flex;flex-direction:column;gap:10px}
.sf-field{display:flex;gap:0;align-items:center;border-bottom:1px solid var(--on-bg)}
.sf-field input{flex:1;border:0;background:transparent;color:var(--on-bg);padding:14px 2px;font:400 16px/1 var(--ff-body);outline:none}
.sf-field input::placeholder{color:var(--ink-soft)}
.sf-field button{padding:14px 4px;font:500 11px/1 var(--ff-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--on-bg);display:inline-flex;align-items:center;gap:10px}
.sf-field button i{font-style:normal;color:var(--accent);transition:transform .4s var(--e-breeze)}
.sf-field button:hover i{transform:translateX(4px)}
.sf-ok{opacity:0;transform:translateY(4px);transition:all .4s var(--e-drift);font-size:12px;color:var(--accent)}
.sf-ok.on{opacity:1;transform:none}
.site-foot h4{color:var(--ink-soft);margin-bottom:14px}
.site-foot ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:14px}
.site-foot ul a:hover{color:var(--accent)}

.sf-wordmark{
  padding:clamp(40px,6vw,90px) var(--gutter) 0;
  font-family:var(--ff-display);font-weight:300;
  font-size:clamp(22vw,24vw,30vw);line-height:.84;letter-spacing:-.05em;
  font-variation-settings:"opsz" 144,"SOFT" 90;color:var(--on-bg);
  overflow:hidden;
}
.sfw-line{display:block;position:relative;will-change:transform}
.sfw-line em{color:var(--accent);font-style:italic}
.sfw-line:last-child{text-align:right}
.sfw-dot{display:inline-block;width:.18em;height:.18em;border-radius:50%;background:var(--accent);vertical-align:baseline;margin-left:.1em}
.sf-base{
  padding:22px var(--gutter) 0;margin-top:clamp(20px,3vw,40px);
  border-top:1px solid var(--rule);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  font:500 11px/1 var(--ff-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);
}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width:1200px){
  .hero-grid{grid-template-columns:1fr}
  .hero-meta{order:2;border-top:1px solid var(--rule);padding-top:22px}
  .service-row{grid-template-columns:90px minmax(0,2fr) minmax(0,3fr) auto}
}
@media (max-width:900px){
  .hero{padding-left:var(--gutter)}
  .practice{padding-left:var(--gutter)}
  .quote-big{padding-left:0}
  .hero-sub{grid-template-columns:1fr}
  .hero-ticker{grid-template-columns:1fr 1fr}
  .section-head{grid-template-columns:1fr}
  .service-row{grid-template-columns:60px 1fr;gap:20px}
  .sr-body{grid-column:1/-1}
  .sr-cta{grid-column:1/-1;justify-self:start;margin-top:20px}
  .dd-row,.dd-row.alt{grid-template-columns:1fr}
  .dd-row.alt .dd-meta,.dd-row.alt .dd-frame{order:unset}
  .blog-row{grid-template-columns:1fr;gap:8px}
  .blog-row .br-tag,.blog-row .br-arrow,.blog-row .date{font-size:11px}
  .sf-grid{grid-template-columns:1fr 1fr}
  .pp-head{grid-template-columns:1fr}
  .pp-progress{display:none}
}
@media (max-width:640px){
  .topbar{grid-template-columns:auto 1fr;padding:14px var(--gutter)}
  .tel{display:none}
  .theme-toggle{display:none}
  .hero-h1 .line.pull-2,.hero-h1 .line.pull-3{padding-left:0}
  .sf-grid{grid-template-columns:1fr}
  .scroll-hint{display:none}
}

/* ------------------ MOTION PREF ------------------ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
  .reveal,.h-reveal > span,.splt-line{opacity:1;transform:none}
  .splt > span,.splt-w > span{transform:none}
  #ribbon-canvas,#hero-canvas{display:none}
  .pre-curtain{transform:translateY(-100%)}
}
