/* ============================================================
   MY INDIA NOW — design system v2
   Warm luxury + real product UI · serif display · depth & color
   ============================================================ */

/* ---------- self-hosted fonts (latin subset, variable) ---------- */
@font-face{
  font-family:'Fraunces';
  font-style:normal;
  font-weight:100 900;
  font-display:swap;
  src:url('fonts/fraunces-latin-wght-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Fraunces';
  font-style:italic;
  font-weight:100 900;
  font-display:swap;
  src:url('fonts/fraunces-latin-wght-italic.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Inter';
  font-style:normal;
  font-weight:100 900;
  font-display:swap;
  src:url('fonts/inter-latin-wght-normal.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

:root{
  --paper:#faf8f3;
  --paper-2:#f2efe6;
  --card:#ffffff;
  --ink:#191713;
  --ink-2:#5b564b;
  --ink-3:#938d7e;
  --hairline:#e7e2d5;
  --hairline-2:#d8d2c2;
  --accent:#c4552e;
  --accent-deep:#a44523;
  --accent-soft:#f7e3d8;
  --sage:#dfe7dc;
  --sage-deep:#39543e;
  --gold:#e0a458;
  --gold-soft:#f6ead4;
  --night:#171512;
  --night-2:#211e19;
  --night-line:rgba(250,248,243,.12);
  --serif:'Fraunces', Georgia, serif;
  --sans:'Inter', -apple-system, 'Helvetica Neue', Arial, sans-serif;
  --w:1240px;
  --gutter:clamp(20px, 4.5vw, 56px);
  --r:22px;
  --shadow-s:0 1px 2px rgba(25,23,19,.04), 0 4px 14px rgba(25,23,19,.05);
  --shadow-m:0 2px 6px rgba(25,23,19,.05), 0 14px 40px -8px rgba(25,23,19,.12);
  --shadow-l:0 4px 12px rgba(25,23,19,.06), 0 32px 80px -16px rgba(25,23,19,.22);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* film grain */
body::after{
  content:"";position:fixed;inset:0;z-index:200;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0.1 0 0 0 0 0.09 0 0 0 0 0.07 0 0 0 0.03 0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:rgba(196,85,46,.18)}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
h1,h2,h3{text-wrap:balance}

/* scroll progress */
#progress{
  position:fixed;top:0;left:0;height:3px;width:0;z-index:300;
  background:linear-gradient(90deg,var(--accent),var(--gold));
  border-radius:0 3px 3px 0;transition:width .1s linear;
}

/* ---------- luxe entrance ---------- */
#loader{
  position:fixed;inset:0;z-index:400;background:var(--paper);
  display:grid;place-items:center;
  transition:transform .95s cubic-bezier(.75,0,.2,1);
}
#loader.up{transform:translateY(-101%)}
#loader .lw{
  font-family:var(--serif);font-size:clamp(32px,5.5vw,60px);
  font-weight:420;letter-spacing:-.02em;opacity:0;
  animation:lw-in 1.05s cubic-bezier(.2,.7,.2,1) .15s forwards;
}
#loader .lw span{color:var(--accent)}
#loader .lsub{
  position:absolute;bottom:46px;left:0;right:0;text-align:center;
  font-size:10px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--ink-3);
  opacity:0;animation:lw-in .8s ease .6s forwards;
}
#loader .bar{
  position:absolute;bottom:0;left:0;height:3px;width:0;
  background:linear-gradient(90deg,var(--accent),var(--gold));
  animation:lbar 1.35s cubic-bezier(.4,0,.2,1) .15s forwards;
}
@keyframes lw-in{from{opacity:0;transform:translateY(26px);letter-spacing:.1em}to{opacity:1;transform:none;letter-spacing:-.02em}}
@keyframes lbar{to{width:100%}}

/* ---------- cursor ring ---------- */
#cring{
  position:fixed;top:0;left:0;width:34px;height:34px;
  border:1.2px solid rgba(196,85,46,.55);border-radius:50%;
  pointer-events:none;z-index:350;opacity:0;
  transition:width .25s,height .25s,background .25s,opacity .4s,border-color .25s;
}
body.cursor-on #cring{opacity:1}
#cring.big{width:58px;height:58px;background:rgba(196,85,46,.07);border-color:rgba(196,85,46,.8)}
@media(pointer:coarse){#cring{display:none}}

/* ---------- metallic shimmer on accent words ---------- */
.display em,.headline em{
  background:linear-gradient(105deg,var(--accent) 25%,#f0bf7c 42%,var(--accent-deep) 58%,var(--accent) 80%);
  background-size:220% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:sheen 5.5s ease-in-out infinite;
}
.intel .headline em,.band-dark .headline em{
  background:linear-gradient(105deg,var(--gold) 25%,#fbe4b8 45%,#c58538 60%,var(--gold) 80%);
  background-size:220% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
@keyframes sheen{0%,100%{background-position:0% 0}50%{background-position:100% 0}}

/* phone tilt smoothing + magnetic buttons */
.phone{transition:transform .3s ease-out;will-change:transform}
.btn,.nav-cta{will-change:transform}

.wrap{max-width:var(--w);margin:0 auto;padding:0 var(--gutter)}

/* ---------- type ---------- */
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ink-3);
}
.kicker::before{content:"";width:26px;height:1px;background:var(--accent)}
.display{
  font-family:var(--serif);font-weight:380;
  font-size:clamp(46px, 7.4vw, 104px);
  line-height:1.0;letter-spacing:-.022em;
  font-variation-settings:"opsz" 110;
}
.display em,.headline em{font-style:italic;font-weight:330;color:var(--accent)}
.headline{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(32px, 4.2vw, 56px);
  line-height:1.06;letter-spacing:-.018em;
  font-variation-settings:"opsz" 80;
}
.sub{font-size:clamp(16px,1.5vw,18.5px);color:var(--ink-2);max-width:54ch}
.body-l{font-size:clamp(21px,2.6vw,32px);line-height:1.4;font-family:var(--serif);font-weight:380;letter-spacing:-.012em}

/* ---------- nav ---------- */
header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(250,248,243,.85);
  -webkit-backdrop-filter:blur(16px) saturate(1.2);backdrop-filter:blur(16px) saturate(1.2);
  border-bottom:1px solid transparent;transition:border-color .4s;
}
header.on{border-bottom-color:var(--hairline)}
.nav{
  max-width:var(--w);margin:0 auto;padding:0 var(--gutter);
  height:74px;display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.wordmark{font-family:var(--serif);font-size:19px;font-weight:500;letter-spacing:-.01em;white-space:nowrap;line-height:1.15}
.wordmark span{color:var(--accent)}
.wordmark small{
  display:block;font-family:var(--sans);font-size:8.5px;font-weight:600;
  letter-spacing:.3em;text-transform:uppercase;color:var(--ink-3);
}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:14px;font-weight:480;color:var(--ink-2);padding:6px 0;position:relative;transition:color .25s}
.nav-links a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;
  background:var(--accent);transition:right .3s cubic-bezier(.2,.7,.2,1);
}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{right:0}
.nav-links a[aria-current]{color:var(--ink)}
.nav-links a[aria-current]::after{right:0}
.nav-cta{
  font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--paper)!important;background:var(--ink);
  padding:13px 26px;border-radius:8px;position:relative;overflow:hidden;
  transition:color .3s;white-space:nowrap;isolation:isolate;
}
.nav-cta::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(135deg,#d0613a,var(--accent-deep));
  transform:translateY(101%);transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.nav-cta:hover::before{transform:translateY(0)}
.nav-cta::after{display:none}
.menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--ink);width:44px;height:44px;place-items:center}

/* mobile menu — scrollable, clears fixed header and bottom CTA bar */
.m-menu{
  position:fixed;inset:0;z-index:99;background:var(--paper);display:none;
  flex-direction:column;justify-content:flex-start;
  padding:96px var(--gutter) 130px;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
}
.m-menu.open{display:flex}
.m-menu a{
  font-family:var(--serif);font-size:clamp(24px,6.5vw,40px);font-weight:400;
  letter-spacing:-.02em;padding:14px 0;border-bottom:1px solid var(--hairline);
  display:flex;justify-content:space-between;align-items:center;flex:none;
}
.m-menu a[aria-current]{color:var(--accent)}
.m-menu .m-contact{border:none;margin-top:26px;font-family:var(--sans);font-size:15px;color:var(--ink-2)}

/* ---------- layout ---------- */
main{padding-top:74px}
section{padding:clamp(72px,9vw,130px) 0;position:relative}
.rule{border:none;border-top:1px solid var(--hairline);margin:0}
.section-head{margin-bottom:clamp(40px,5vw,68px)}
.section-head .kicker{margin-bottom:20px}

/* ---------- HERO ---------- */
.hero{
  position:relative;overflow:hidden;
  padding:clamp(48px,6vw,96px) 0 clamp(64px,8vw,120px);
}
.hero::before{
  content:"";position:absolute;top:-30%;right:-12%;width:60vw;height:60vw;max-width:900px;max-height:900px;
  background:radial-gradient(circle, rgba(224,164,88,.18), rgba(196,85,46,.08) 45%, transparent 68%);
  border-radius:50%;pointer-events:none;
}
.hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,72px);
  align-items:center;position:relative;
}
.hero-copy .kicker{margin-bottom:28px}
.hero-copy .sub{margin-top:34px}
.hero-actions{margin-top:42px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-proof{
  margin-top:46px;display:flex;gap:34px;flex-wrap:wrap;
  padding-top:30px;border-top:1px solid var(--hairline);
}
.hero-proof div b{font-family:var(--serif);font-size:24px;font-weight:450;letter-spacing:-.02em;display:block;line-height:1.1}
.hero-proof div span{font-size:12px;color:var(--ink-3);letter-spacing:.04em}

/* hero visual composition */
.hero-visual{position:relative;display:grid;place-items:center;min-height:560px}
.blob{
  position:absolute;inset:6% 2%;border-radius:44% 56% 52% 48% / 46% 44% 56% 54%;
  background:linear-gradient(150deg, var(--sage) 0%, var(--gold-soft) 55%, var(--accent-soft) 100%);
}

/* rotating hero word */
.rotator{display:inline-block;transition:opacity .35s, transform .35s;min-width:5.2ch}
.rotator.fade{opacity:0;transform:translateY(14px)}

/* phone */
.phone{
  position:relative;width:min(300px,78vw);border-radius:44px;
  background:#0b0a08;padding:10px;box-shadow:var(--shadow-l), 0 0 0 1px rgba(25,23,19,.1);
  transform:rotate(-2deg);
}
.phone-screen{
  border-radius:36px;overflow:hidden;
  background:linear-gradient(178deg,#1b1915 0%,#100f0c 60%,#0c0b09 100%);
  display:flex;flex-direction:column;min-height:568px;position:relative;color:#f5f2ea;
}
/* phone v2 — dark AI-first UI */
.p2-head{display:flex;justify-content:space-between;align-items:center;padding:52px 20px 12px}
.p2-head .hi{font-size:10.5px;color:rgba(245,242,234,.45);font-weight:500}
.p2-head .nm{font-family:var(--serif);font-size:18px;font-weight:450;letter-spacing:-.01em}
.p2-ava{
  width:34px;height:34px;border-radius:50%;flex:none;
  background:linear-gradient(135deg,var(--gold),var(--accent));
  display:grid;place-items:center;font-weight:600;font-size:13px;color:#fff;
}
.p2-card{
  margin:8px 18px 0;border-radius:20px;padding:18px;position:relative;overflow:hidden;
  background:linear-gradient(130deg,#d0613a 0%,#a4431f 55%,#7e3315 100%);
  box-shadow:0 14px 34px -10px rgba(196,85,46,.55);
}
.p2-card::before{
  content:"";position:absolute;top:-70%;right:-25%;width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle, rgba(255,224,180,.4), transparent 65%);
}
.p2-card .lbl{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,246,238,.65);font-weight:600}
.p2-card .amt{font-family:var(--serif);font-size:35px;font-weight:430;letter-spacing:-.015em;margin-top:4px;position:relative}
.p2-card .c-row{display:flex;justify-content:space-between;align-items:center;margin-top:16px;position:relative}
.p2-card .c-num{font-size:11.5px;letter-spacing:.22em;color:rgba(255,246,238,.75);font-weight:500}
.p2-card .c-row svg{width:22px;height:22px;opacity:.85}
.p2-acts{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:16px 18px 6px}
.p2-act{text-align:center;font-size:9px;color:rgba(245,242,234,.55);font-weight:520}
.p2-act i{
  display:grid;place-items:center;width:44px;height:44px;margin:0 auto 5px;border-radius:15px;
  background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.09);font-style:normal;color:#f0ead9;
}
.p2-act i svg{width:17px;height:17px}
.p2-ai2{
  margin:12px 18px 0;border-radius:16px;padding:13px 14px;
  background:linear-gradient(160deg, rgba(224,164,88,.14), rgba(224,164,88,.05));
  border:1px solid rgba(224,164,88,.3);
}
.p2-ai2 .tag{
  display:inline-flex;align-items:center;gap:6px;font-size:8.5px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:7px;
}
.p2-ai2 .tag svg{width:11px;height:11px}
.p2-ai2 p{font-size:11.5px;line-height:1.5;color:rgba(245,242,234,.85)}
.p2-ai2 .btns{display:flex;gap:8px;margin-top:10px}
.p2-ai2 .btns b{
  font-size:10px;font-weight:600;padding:7px 15px;border-radius:100px;
  background:linear-gradient(135deg,var(--gold),#c58538);color:#1a1408;
}
.p2-ai2 .btns span{
  font-size:10px;font-weight:550;padding:7px 15px;border-radius:100px;
  border:1px solid rgba(245,242,234,.25);color:rgba(245,242,234,.7);
}
.p2-graph{
  margin:12px 18px 0;display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:13px 15px;border-radius:16px;
  background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08);
}
.p2-graph .gl{font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(245,242,234,.45);font-weight:600}
.p2-graph .gv{font-family:var(--serif);font-size:17px;margin-top:2px}
.p2-graph .gv em{font-style:normal;font-size:11px;font-weight:600;color:#7fe3ab;margin-left:7px}
.p2-graph svg{width:92px;height:38px;flex:none}
.p2-nav{
  margin-top:auto;display:flex;justify-content:space-around;align-items:center;
  padding:12px 20px 18px;border-top:1px solid rgba(255,255,255,.07);
}
.p2-nav > i{font-style:normal;color:rgba(245,242,234,.4);display:grid}
.p2-nav > i svg{width:19px;height:19px}
.p2-nav > i.on{color:var(--gold)}
.ai-orb{
  width:46px;height:46px;border-radius:50%;flex:none;margin-top:-28px;
  background:linear-gradient(135deg,var(--gold),var(--accent));
  display:grid;place-items:center;border:3px solid #12100d;
  box-shadow:0 0 26px rgba(224,164,88,.55);animation:orb 3s ease-in-out infinite;
}
.ai-orb svg{width:20px;height:20px}
@keyframes orb{0%,100%{box-shadow:0 0 18px rgba(224,164,88,.4)}50%{box-shadow:0 0 34px rgba(224,164,88,.75)}}
.p-island{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:86px;height:24px;border-radius:100px;background:var(--night);z-index:3}
.p-head{padding:52px 20px 16px;background:linear-gradient(180deg,#f6f1e7,#fdfcf9)}
.p-hello{font-size:11.5px;color:var(--ink-3);font-weight:500}
.p-name{font-family:var(--serif);font-size:21px;font-weight:450;letter-spacing:-.01em}
.p-balance{
  margin:12px 20px 0;border-radius:18px;padding:18px;color:#faf8f3;
  background:linear-gradient(140deg,#22201b,#3a352c);box-shadow:var(--shadow-m);
}
.p-balance .lbl{font-size:10px;letter-spacing:.18em;text-transform:uppercase;opacity:.55;font-weight:550}
.p-balance .amt{font-family:var(--serif);font-size:29px;font-weight:420;letter-spacing:-.01em;margin-top:4px}
.p-balance .dlt{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:550;color:#8fd8a8;margin-top:8px;background:rgba(143,216,168,.12);padding:3px 9px;border-radius:100px}
.p-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:16px 20px 4px}
.p-act{text-align:center;font-size:9.5px;color:var(--ink-2);font-weight:520}
.p-act i{
  display:grid;place-items:center;width:44px;height:44px;margin:0 auto 5px;
  border-radius:15px;background:var(--paper-2);color:var(--ink);font-style:normal;
}
.p-act i svg{width:17px;height:17px}
.p-act:first-child i{background:var(--accent);color:#fff}
.p-list{padding:12px 20px;display:flex;flex-direction:column;gap:4px}
.p-row{display:flex;align-items:center;gap:11px;padding:9px 0;border-bottom:1px solid #f0ece1}
.p-row:last-child{border:none}
.p-row i{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;font-style:normal;flex:none}
.p-row i svg{width:15px;height:15px}
.p-row .t{flex:1;min-width:0}
.p-row .t b{font-size:12px;font-weight:550;display:block;line-height:1.3}
.p-row .t span{font-size:10px;color:var(--ink-3)}
.p-row .v{font-size:12px;font-weight:600}
.p-row .v.plus{color:#2c7a4b}
.p-ai{
  margin:auto 20px 18px;display:flex;gap:9px;align-items:flex-start;
  background:var(--accent-soft);border:1px solid #efd3c4;border-radius:14px;padding:11px 13px;
}
.p-ai i{width:24px;height:24px;border-radius:8px;background:var(--accent);display:grid;place-items:center;flex:none;font-style:normal}
.p-ai i svg{width:13px;height:13px}
.p-ai p{font-size:10.5px;line-height:1.45;color:#7c3c22;font-weight:480}

/* floating cards */
.float{
  position:absolute;background:var(--card);border-radius:16px;padding:14px 17px;
  box-shadow:var(--shadow-m);border:1px solid rgba(25,23,19,.05);
  display:flex;gap:11px;align-items:center;
  animation:hover-float 5.5s ease-in-out infinite;
}
.float i{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;font-style:normal;flex:none}
.float i svg{width:16px;height:16px}
.float b{font-size:13px;font-weight:600;display:block;line-height:1.25;letter-spacing:-.01em}
.float span{font-size:11px;color:var(--ink-3)}
.float.fa{top:9%;left:-4%;animation-delay:0s}
.float.fb{bottom:14%;right:-6%;animation-delay:1.6s}
.float.fc{bottom:-2%;left:2%;animation-delay:3s}
@keyframes hover-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ---------- marquee ---------- */
.marquee-band{
  border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);
  overflow:hidden;padding:18px 0;background:var(--card);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.marquee{display:flex;width:max-content;animation:mq 40s linear infinite}
.mq-item{
  font-family:var(--serif);font-size:15px;color:var(--ink-2);
  padding:0 28px;white-space:nowrap;display:flex;align-items:center;gap:56px;
}
.mq-item::after{content:"✦";color:var(--gold);font-size:11px}
@keyframes mq{to{transform:translateX(-50%)}}

/* ---------- numbers (dark band) ---------- */
.band-dark{
  background:var(--night);color:var(--paper);
  border-radius:clamp(20px,3vw,36px);
  padding:clamp(44px,6vw,84px) clamp(28px,5vw,72px);
  position:relative;overflow:hidden;
}
.band-dark::before{
  content:"";position:absolute;top:-40%;right:-10%;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle, rgba(224,164,88,.16), transparent 65%);
}
.band-dark .kicker{color:rgba(250,248,243,.5)}
.numbers{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.numbers .n{padding:10px 32px 10px 0}
.numbers .n + .n{border-left:1px solid var(--night-line);padding-left:32px}
.numbers .n b{
  font-family:var(--serif);font-weight:380;font-size:clamp(40px,4.6vw,64px);
  letter-spacing:-.025em;display:block;line-height:1;
}
.numbers .n b sup{font-size:.4em;color:var(--gold);font-weight:450;top:-.8em}
.numbers .n span{font-size:13px;color:rgba(250,248,243,.55);display:block;margin-top:12px}

/* ---------- discipline cards ---------- */
.disc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.disc{
  border-radius:var(--r);padding:clamp(28px,3vw,40px);min-height:380px;
  display:flex;flex-direction:column;position:relative;overflow:hidden;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s;
  box-shadow:var(--shadow-s);
}
.disc:hover{transform:translateY(-6px);box-shadow:var(--shadow-m)}
.disc.t-sage{background:linear-gradient(165deg,#e6ecdf,#d8e2d2)}
.disc.t-sand{background:linear-gradient(165deg,#f5ecda,#eddfc4)}
.disc.t-clay{background:linear-gradient(165deg,#f6e2d6,#eccfbc)}
.disc .idx{font-size:11px;font-weight:600;letter-spacing:.2em;color:var(--ink-3)}
.disc h3{font-family:var(--serif);font-weight:430;font-size:clamp(24px,2.4vw,31px);letter-spacing:-.015em;margin:14px 0 10px}
.disc p{font-size:14.5px;color:var(--ink-2);max-width:40ch}
.disc .art{margin-top:auto;padding-top:28px;display:flex;justify-content:flex-end}
.disc .art svg{width:clamp(96px,9vw,130px);height:auto;opacity:.9}
.disc .go{
  position:absolute;top:24px;right:24px;width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.6);display:grid;place-items:center;color:var(--ink);
  transition:.3s;backdrop-filter:blur(4px);
}
.disc:hover .go{background:var(--ink);color:var(--paper);transform:rotate(-45deg)}

/* ---------- app tiles ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tile{
  background:var(--card);border-radius:var(--r);padding:clamp(24px,2.6vw,34px);
  border:1px solid rgba(25,23,19,.05);box-shadow:var(--shadow-s);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s;
  position:relative;
}
.tile:hover{transform:translateY(-6px);box-shadow:var(--shadow-m)}
.tile .glyph{
  width:54px;height:54px;border-radius:17px;display:grid;place-items:center;margin-bottom:22px;
  box-shadow:var(--shadow-s);
}
.tile .glyph svg{width:24px;height:24px}
.tile .idx{font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);display:block;margin-bottom:8px}
.tile h3{font-family:var(--serif);font-weight:430;font-size:23px;letter-spacing:-.015em;margin-bottom:10px}
.tile p{font-size:14px;color:var(--ink-2)}
.tile .meta{
  margin-top:28px;padding-top:18px;border-top:1px solid var(--hairline);
  display:flex;justify-content:space-between;align-items:baseline;
}
.tile .meta b{font-family:var(--serif);font-weight:450;font-size:25px;letter-spacing:-.02em}
.tile .meta b small{font-family:var(--sans);font-size:11px;font-weight:480;color:var(--ink-3);margin-left:6px}
.tile .meta .stars{font-size:12px;font-weight:600;color:var(--gold);letter-spacing:.02em}

/* ---------- portfolio explorer ---------- */
/* ---------- rows (index lists) ---------- */
.rows{border-top:1px solid var(--hairline)}
.row{
  display:grid;grid-template-columns:80px 1.1fr 1.3fr 56px;gap:28px;align-items:center;
  padding:clamp(26px,3.4vw,40px) 0;border-bottom:1px solid var(--hairline);
  transition:padding-left .35s cubic-bezier(.2,.7,.2,1);
}
.row:hover{padding-left:16px}
.row .idx{font-size:12px;font-weight:560;letter-spacing:.18em;color:var(--accent)}
.row h3{font-family:var(--serif);font-weight:420;font-size:clamp(22px,2.4vw,30px);letter-spacing:-.015em;line-height:1.15}
.row p{font-size:14.5px;color:var(--ink-2);max-width:46ch}
.row .arrow{
  width:44px;height:44px;border:1px solid var(--hairline-2);border-radius:50%;
  display:grid;place-items:center;color:var(--ink-2);flex:none;transition:.3s;
}
.row:hover .arrow{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(-45deg)}

/* ---------- intelligence band (dark, home) ---------- */
.intel{
  background:var(--night);color:var(--paper);position:relative;overflow:hidden;
  border-radius:clamp(20px,3vw,36px);padding:clamp(40px,6vw,84px) clamp(28px,5vw,72px);
}
.intel::before{
  content:"";position:absolute;bottom:-45%;left:-10%;width:640px;height:640px;border-radius:50%;
  background:radial-gradient(circle, rgba(196,85,46,.22), transparent 65%);
}
.intel .kicker{color:rgba(250,248,243,.5)}
.intel .headline{color:var(--paper)}
.intel .headline em{color:var(--gold)}
.intel .sub{color:rgba(250,248,243,.62)}
.intel-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);align-items:center;position:relative}
.intel-feats{display:flex;flex-direction:column;gap:0;margin-top:38px}
.intel-feat{
  display:flex;gap:16px;align-items:flex-start;padding:20px 0;
  border-top:1px solid var(--night-line);
}
.intel-feat i{
  width:38px;height:38px;border-radius:12px;background:rgba(250,248,243,.06);
  border:1px solid var(--night-line);display:grid;place-items:center;font-style:normal;flex:none;color:var(--gold);
}
.intel-feat i svg{width:17px;height:17px}
.intel-feat b{font-size:15px;font-weight:550;display:block;letter-spacing:-.01em}
.intel-feat span{font-size:13.5px;color:rgba(250,248,243,.55);line-height:1.55;display:block;margin-top:3px}

/* intelligence visual: guard console */
.console{
  background:var(--night-2);border:1px solid var(--night-line);border-radius:20px;
  overflow:hidden;box-shadow:0 24px 64px -16px rgba(0,0,0,.5);position:relative;
}
.console-bar{
  display:flex;align-items:center;gap:8px;padding:13px 18px;
  border-bottom:1px solid var(--night-line);font-size:11px;color:rgba(250,248,243,.4);
  letter-spacing:.14em;text-transform:uppercase;font-weight:550;
}
.console-bar i{width:8px;height:8px;border-radius:50%;background:#4cd88a;font-style:normal;box-shadow:0 0 10px rgba(76,216,138,.8);animation:blink 2.2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}
.console-body{padding:20px 18px;display:flex;flex-direction:column;gap:10px}
.c-line{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  background:rgba(250,248,243,.035);border:1px solid var(--night-line);
  border-radius:12px;padding:12px 15px;font-size:12px;
}
.c-line .l{display:flex;align-items:center;gap:10px;color:rgba(250,248,243,.75);font-weight:480}
.c-line .l i{width:7px;height:7px;border-radius:50%;font-style:normal;flex:none}
.c-line .tag{font-size:10px;font-weight:600;letter-spacing:.08em;padding:4px 10px;border-radius:100px}
.tag.ok{background:rgba(76,216,138,.12);color:#7fe3ab}
.tag.block{background:rgba(255,107,74,.14);color:#ff9c82}
.tag.watch{background:rgba(224,164,88,.14);color:#eec387}
.c-foot{
  padding:14px 18px;border-top:1px solid var(--night-line);
  font-size:11.5px;color:rgba(250,248,243,.45);display:flex;justify-content:space-between;
}
.c-foot b{color:#7fe3ab;font-weight:550}

/* ---------- eco split ---------- */
.eco-split{
  display:grid;grid-template-columns:1fr 1fr;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-m);border:1px solid rgba(25,23,19,.05);
}
.eco-half{padding:clamp(32px,4vw,56px);position:relative;min-height:340px;display:flex;flex-direction:column}
.eco-half.a{background:linear-gradient(160deg,#eef2e8,#dde7d6)}
.eco-half.b{background:linear-gradient(160deg,#f8ede2,#f0dcc8)}
.eco-half .idx{font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3)}
.eco-half h3{font-family:var(--serif);font-weight:420;font-size:clamp(26px,3vw,38px);letter-spacing:-.018em;margin:14px 0 12px}
.eco-half p{font-size:14.5px;color:var(--ink-2);max-width:40ch}
.eco-half .stat{margin-top:auto;padding-top:30px;font-family:var(--serif);font-size:clamp(30px,3.4vw,44px);font-weight:400;letter-spacing:-.02em}
.eco-half .stat small{font-family:var(--sans);font-size:12px;color:var(--ink-3);display:block;letter-spacing:.04em;margin-top:2px}

/* ---------- CTA panel ---------- */
.cta-panel{
  background:linear-gradient(150deg,var(--accent) 0%,#a4431f 70%);
  color:#fdf6f0;border-radius:clamp(20px,3vw,36px);
  padding:clamp(52px,7vw,104px) clamp(28px,5vw,80px);
  text-align:center;position:relative;overflow:hidden;
}
.cta-panel::before{
  content:"";position:absolute;top:-55%;left:50%;transform:translateX(-50%);
  width:820px;height:820px;border-radius:50%;
  background:radial-gradient(circle, rgba(255,220,180,.28), transparent 62%);
}
.cta-panel::after{
  content:"";position:absolute;bottom:-42%;right:-12%;width:560px;height:560px;border-radius:50%;
  border:1.5px solid rgba(255,220,180,.28);
  box-shadow:0 0 0 60px rgba(255,220,180,.06), 0 0 0 130px rgba(255,220,180,.045), 0 0 0 210px rgba(255,220,180,.03);
  pointer-events:none;
}
.cta-panel h2{
  font-family:var(--serif);font-weight:380;font-size:clamp(38px,5.6vw,80px);
  line-height:1.02;letter-spacing:-.025em;max-width:18ch;margin:0 auto;position:relative;
}
.cta-panel h2 em{font-style:italic;color:#ffd9a8}
.cta-panel p{font-size:16.5px;color:rgba(253,246,240,.8);max-width:50ch;margin:22px auto 40px;position:relative}
.cta-panel .btn-fill{background:#fdf6f0;color:var(--accent-deep);border-color:#fdf6f0}
.cta-panel .btn-fill:hover{background:#fff;transform:translateY(-2px);box-shadow:0 16px 40px -12px rgba(0,0,0,.35)}
.cta-panel .btn-line{border-color:rgba(253,246,240,.5);color:#fdf6f0}
.cta-panel .btn-line:hover{background:rgba(253,246,240,.12)}
.cta-panel .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-size:15px;font-weight:520;padding:15px 30px;border-radius:100px;
  border:1.5px solid var(--ink);transition:.28s;cursor:pointer;font-family:var(--sans);
}
.btn svg{transition:transform .25s}
.btn:hover svg{transform:translateX(3px)}
.btn-fill{
  background:linear-gradient(135deg,#d0613a,var(--accent-deep));color:#fff;border-color:transparent;
  box-shadow:0 6px 20px -6px rgba(196,85,46,.5), inset 0 1px 0 rgba(255,255,255,.2);
}
.btn-fill:hover{
  transform:translateY(-2px);filter:brightness(1.06);
  box-shadow:0 12px 32px -8px rgba(196,85,46,.6), inset 0 1px 0 rgba(255,255,255,.2);
}
.btn-fill:active{transform:translateY(0) scale(.98)}
.btn-line{background:transparent;color:var(--ink)}
.btn-line:hover{background:var(--ink);border-color:var(--ink);color:var(--paper)}

/* ---------- big link ---------- */
.cta-link{
  display:inline-flex;align-items:center;gap:22px;margin-top:34px;
  font-family:var(--serif);font-size:clamp(24px,3vw,40px);font-weight:400;letter-spacing:-.02em;
}
.cta-link .ring{
  width:clamp(52px,5.6vw,68px);height:clamp(52px,5.6vw,68px);border-radius:50%;
  border:1.5px solid var(--ink);display:grid;place-items:center;flex:none;
  transition:.35s cubic-bezier(.2,.7,.2,1);
}
.cta-link:hover .ring{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(-45deg) scale(1.06)}

/* ---------- page hero (inner pages) ---------- */
.page-hero{padding:clamp(70px,9vw,130px) 0 clamp(48px,6vw,90px)}
.page-hero .kicker{margin-bottom:28px}
.page-hero .sub{margin-top:32px}

/* ---------- editorial ---------- */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,90px);align-items:start}
.duo .sticky{position:sticky;top:110px}

/* ---------- timeline ---------- */
.timeline{position:relative;border-left:1.5px solid var(--hairline-2);margin-left:8px}
.t-row{position:relative;padding:0 0 clamp(34px,4vw,52px) clamp(28px,4vw,52px)}
.t-row::before{
  content:"";position:absolute;left:-7px;top:8px;width:12px;height:12px;border-radius:50%;
  background:var(--paper);border:2.5px solid var(--accent);
}
.t-row .year{font-family:var(--serif);font-size:24px;font-weight:450;letter-spacing:-.01em;color:var(--accent);display:block;margin-bottom:8px}
.t-row h4{font-size:16.5px;font-weight:560;margin-bottom:6px}
.t-row p{font-size:14.5px;color:var(--ink-2);max-width:58ch}

/* ---------- principles ---------- */
.plist{border-top:1px solid var(--hairline);counter-reset:p}
.p-item{
  display:grid;grid-template-columns:72px 1fr;gap:28px;
  padding:clamp(28px,3.6vw,44px) 0;border-bottom:1px solid var(--hairline);
  transition:padding-left .3s;
}
.p-item:hover{padding-left:12px}
.p-item::before{
  counter-increment:p;content:"0" counter(p);
  font-size:12px;font-weight:560;letter-spacing:.18em;color:var(--accent);padding-top:8px;
}
.p-item h3{font-family:var(--serif);font-weight:420;font-size:clamp(22px,2.4vw,30px);letter-spacing:-.015em;margin-bottom:10px}
.p-item p{font-size:15px;color:var(--ink-2);max-width:60ch}

/* ---------- contact ---------- */
.contact-mail{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(24px,4.4vw,54px);letter-spacing:-.02em;
  border-bottom:2px solid var(--ink);padding-bottom:6px;display:inline-block;
  transition:.3s;line-height:1.15;
}
.contact-mail:hover{color:var(--accent);border-color:var(--accent)}
.c-details{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:clamp(44px,5vw,72px)}
.c-cell{
  background:var(--card);border-radius:var(--r);padding:30px;
  border:1px solid rgba(25,23,19,.05);box-shadow:var(--shadow-s);
}
.c-cell h5{font-size:10.5px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-3);margin-bottom:14px}
.c-cell a,.c-cell p{font-size:16px;color:var(--ink);display:block;line-height:1.9}
.c-cell a:hover{color:var(--accent)}

/* ---------- form ---------- */
.form{
  margin-top:clamp(40px,5vw,64px);max-width:760px;background:var(--card);
  border-radius:var(--r);padding:clamp(28px,4vw,52px);
  border:1px solid rgba(25,23,19,.05);box-shadow:var(--shadow-s);
}
.form label{display:block;font-size:10.5px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-3);margin:30px 0 6px}
.form label:first-child{margin-top:0}
.form input,.form textarea{
  width:100%;background:transparent;border:none;border-bottom:1.5px solid var(--hairline-2);
  font-family:var(--serif);font-size:clamp(19px,2vw,26px);color:var(--ink);
  padding:10px 0;outline:none;transition:border-color .3s;resize:vertical;
}
.form input:focus,.form textarea:focus{border-bottom-color:var(--accent)}
.form .btn{margin-top:40px}

/* ---------- footer ---------- */
footer{
  background:var(--night);color:var(--paper);
  padding:clamp(56px,7vw,96px) 0 40px;margin-top:clamp(40px,6vw,80px);
  position:relative;overflow:hidden;
}
footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--gold),var(--accent));
}
footer::after{
  content:"";position:absolute;top:-45%;right:-8%;width:640px;height:640px;border-radius:50%;
  background:radial-gradient(circle, rgba(196,85,46,.16), transparent 62%);
  pointer-events:none;
}
.f-mark{
  position:absolute;bottom:-.28em;left:0;right:0;z-index:0;pointer-events:none;
  font-family:var(--serif);font-weight:400;font-size:clamp(90px,14.5vw,220px);
  letter-spacing:-.03em;line-height:1;white-space:nowrap;text-align:center;
  color:rgba(250,248,243,.045);user-select:none;
}
footer .wrap{position:relative;z-index:2}
.f-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:44px;padding-bottom:clamp(44px,5vw,72px)}
.f-word{font-family:var(--serif);font-size:clamp(28px,3vw,40px);font-weight:400;letter-spacing:-.02em;line-height:1.1}
.f-word span{color:var(--gold)}
.f-top .tag{font-size:13.5px;color:rgba(250,248,243,.5);margin-top:14px;max-width:30ch}
.f-col h5{font-size:10.5px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:rgba(250,248,243,.4);margin-bottom:20px}
.f-col a{display:block;font-size:14.5px;color:rgba(250,248,243,.7);margin-bottom:12px;transition:color .2s}
.f-col a:hover{color:var(--paper)}
.f-bottom{
  border-top:1px solid var(--night-line);padding-top:26px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
}
.f-bottom p{font-size:12.5px;color:rgba(250,248,243,.4)}
.f-bottom .links{display:flex;gap:24px}
.f-bottom .links a{font-size:12.5px;color:rgba(250,248,243,.5);transition:color .2s}
.f-bottom .links a:hover{color:var(--paper)}

/* ---------- reveal ---------- */
/* reveal is opt-in: content stays visible unless the reveal script is confirmed running */
html.js .rv{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
html.js .rv.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:1060px){
  .hero-grid{grid-template-columns:1fr;gap:56px}
  .hero-visual{min-height:600px}
  .intel-grid{grid-template-columns:1fr}
}
@media(max-width:840px){
  .nav-links{display:none}
  .menu-btn{display:grid}
  .numbers{grid-template-columns:1fr 1fr;gap:28px}
  .numbers .n + .n{border-left:none;padding-left:0}
  .numbers .n:nth-child(even){border-left:1px solid var(--night-line);padding-left:28px}
  .disc-grid,.grid-3,.c-details{grid-template-columns:1fr}
  .duo{grid-template-columns:1fr}
  .duo .sticky{position:static}
  .eco-split{grid-template-columns:1fr}
  .row{grid-template-columns:1fr;gap:10px}
  .row .arrow{display:none}
  .f-top{grid-template-columns:1fr 1fr}
  .float.fa{left:0}
  .float.fb{right:0}
}
@media(max-width:560px){
  .numbers{grid-template-columns:1fr;gap:24px}
  .numbers .n:nth-child(even){border-left:none;padding-left:0}
  .f-top{grid-template-columns:1fr}
  .p-item{grid-template-columns:1fr;gap:6px}
  .hero-proof{gap:22px}
  .float.fc{display:none}
  /* thumb-friendly full-width actions */
  .hero-actions,.cta-panel .actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn,.cta-panel .actions .btn{justify-content:center}
  .nl form{flex-direction:column;align-items:stretch}
  .nl form .btn{justify-content:center}
  .nl input{min-width:0;width:100%}
  .display{font-size:clamp(40px,11.5vw,52px)}
  section{padding:64px 0}
  .contact-mail{font-size:clamp(20px,6.4vw,30px);word-break:break-all}
}
/* ---------- business platform ---------- */
.biz-teaser{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);align-items:center}
.code-card{
  background:var(--night-2);border-radius:20px;overflow:hidden;
  box-shadow:var(--shadow-l);border:1px solid rgba(0,0,0,.35);
  font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;
}
.code-bar{display:flex;align-items:center;gap:7px;padding:14px 18px;border-bottom:1px solid var(--night-line)}
.code-bar i{width:11px;height:11px;border-radius:50%;font-style:normal}
.code-bar span{margin-left:10px;font-size:11px;color:rgba(250,248,243,.4);letter-spacing:.1em}
.code-body{padding:22px 24px;font-size:12.5px;line-height:2.05;color:#cfcaba;overflow-x:auto;white-space:pre}
.code-body .c1{color:#847f6f}
.code-body .c2{color:#e0a458}
.code-body .c3{color:#8fd8a8}
.code-body .c4{color:#ff9c82}
.code-body .c5{color:#9fc6e8}
.check-list{margin-top:32px;border-bottom:1px solid var(--hairline)}
.check{display:flex;gap:13px;align-items:flex-start;padding:14px 0;border-top:1px solid var(--hairline);font-size:15px;color:var(--ink-2)}
.check i{font-style:normal;color:var(--accent);flex:none;padding-top:3px}
.check b{color:var(--ink);font-weight:550}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;counter-reset:s}
.step{
  background:var(--card);border-radius:var(--r);padding:clamp(28px,3vw,38px);
  border:1px solid rgba(25,23,19,.05);box-shadow:var(--shadow-s);position:relative;overflow:hidden;
}
.step::before{
  counter-increment:s;content:"0" counter(s);
  position:absolute;top:14px;right:20px;
  font-family:var(--serif);font-size:64px;font-weight:380;line-height:1;
  color:var(--paper-2);
}
.step h3{font-family:var(--serif);font-weight:430;font-size:24px;letter-spacing:-.015em;margin-bottom:10px;position:relative}
.step p{font-size:14.5px;color:var(--ink-2);position:relative;max-width:36ch}
.step .s-ic{
  width:48px;height:48px;border-radius:15px;display:grid;place-items:center;margin-bottom:20px;
  background:var(--accent-soft);color:var(--accent);position:relative;
}
.step .s-ic svg{width:21px;height:21px}

/* testimonials */
.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.quote{
  background:var(--card);border-radius:var(--r);padding:clamp(26px,3vw,36px);
  border:1px solid rgba(25,23,19,.05);box-shadow:var(--shadow-s);
  display:flex;flex-direction:column;transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s;
}
.quote:hover{transform:translateY(-6px);box-shadow:var(--shadow-m)}
.quote .qmark{font-family:var(--serif);font-size:56px;line-height:.6;color:var(--accent);margin-bottom:18px}
.quote p{font-family:var(--serif);font-size:18.5px;line-height:1.5;letter-spacing:-.008em}
.quote .who{margin-top:auto;padding-top:26px;display:flex;gap:13px;align-items:center}
.quote .who i{
  width:42px;height:42px;border-radius:50%;font-style:normal;flex:none;
  display:grid;place-items:center;font-weight:600;color:#fff;font-size:13.5px;letter-spacing:.02em;
}
.quote .who b{font-size:14px;font-weight:560;display:block;line-height:1.3}
.quote .who span{font-size:12px;color:var(--ink-3)}

/* newsletter */
.nl{
  background:linear-gradient(150deg,var(--gold-soft),#f1ddb8);
  border-radius:clamp(20px,3vw,32px);
  padding:clamp(32px,4.5vw,56px) clamp(24px,4vw,64px);
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:28px;
}
.nl h3{font-family:var(--serif);font-weight:420;font-size:clamp(24px,3vw,36px);letter-spacing:-.018em}
.nl p{font-size:14.5px;color:var(--ink-2);margin-top:6px;max-width:44ch}
.nl form{display:flex;gap:10px;flex-wrap:wrap}
.nl input{
  background:#fff;border:1px solid rgba(25,23,19,.12);border-radius:100px;
  padding:14px 24px;font-size:15px;font-family:var(--sans);min-width:min(300px,70vw);
  outline:none;transition:border-color .25s;color:var(--ink);
}
.nl input:focus{border-color:var(--accent)}
.nl .done{font-size:16px;font-weight:550;color:var(--sage-deep);display:flex;align-items:center;gap:10px}

/* faq */
.faq{border-top:1px solid var(--hairline);max-width:860px}
.faq details{border-bottom:1px solid var(--hairline)}
.faq summary{
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:clamp(20px,2.6vw,28px) 0;
  font-family:var(--serif);font-weight:420;font-size:clamp(19px,2.1vw,25px);letter-spacing:-.012em;
}
.faq summary::-webkit-details-marker{display:none}
.faq .pm{
  width:36px;height:36px;border:1.5px solid var(--hairline-2);border-radius:50%;
  display:grid;place-items:center;transition:.3s;flex:none;color:var(--ink-2);
}
.faq details[open] .pm{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(45deg)}
.faq .a{padding:0 0 28px;color:var(--ink-2);font-size:15px;max-width:62ch}

/* offering tiles keep .tile; wide variant */
.tile .feat-list{margin-top:18px}
.tile .feat-list li{
  list-style:none;font-size:13.5px;color:var(--ink-2);padding:7px 0 7px 24px;position:relative;
}
.tile .feat-list li::before{
  content:"";position:absolute;left:2px;top:14px;width:10px;height:6px;
  border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(-45deg);
}

/* ---------- live tools ---------- */
.tools-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.tool{
  background:var(--card);border-radius:var(--r);padding:clamp(26px,3vw,40px);
  border:1px solid rgba(25,23,19,.06);box-shadow:var(--shadow-s);
  display:flex;flex-direction:column;
}
.tool .t-kick{
  display:inline-flex;align-items:center;gap:9px;
  font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);
}
.tool .t-kick i{width:7px;height:7px;border-radius:50%;background:#2bd869;box-shadow:0 0 9px #2bd869;animation:blink 2s infinite;font-style:normal}
.tool h3{font-family:var(--serif);font-weight:430;font-size:clamp(22px,2.4vw,27px);letter-spacing:-.015em;margin:12px 0 4px}
.tool .t-sub{font-size:13.5px;color:var(--ink-3);margin-bottom:10px}
.tool label{font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);display:block;margin:20px 0 9px}
.opts{display:flex;flex-wrap:wrap;gap:8px}
.opt{
  font-size:13px;font-weight:500;padding:9px 16px;border-radius:100px;
  border:1px solid var(--hairline-2);cursor:pointer;transition:.2s;
  background:transparent;color:var(--ink-2);font-family:var(--sans);
}
.opt:hover{border-color:var(--ink);color:var(--ink)}
.opt.sel{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.tool input[type=range]{width:100%;accent-color:var(--accent);margin:8px 0 2px;cursor:pointer}
.range-val{font-family:var(--serif);font-size:21px;letter-spacing:-.01em}
.t-result{
  margin-top:24px;background:var(--paper-2);border-radius:14px;padding:18px 22px;
  display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;
}
.t-result .r-l span{font-size:10.5px;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-3);font-weight:600;display:block;margin-bottom:2px}
.t-result .r-l b{font-family:var(--serif);font-size:clamp(24px,2.6vw,32px);font-weight:450;letter-spacing:-.018em;color:var(--accent)}
.t-result .r-r{font-size:12px;color:var(--ink-3);max-width:18ch;text-align:right}
.tool .btn{margin-top:22px;justify-content:center}

/* online chip */
.online-chip{
  display:inline-flex;align-items:center;gap:10px;padding:10px 18px;
  border:1px solid var(--hairline);border-radius:100px;background:var(--card);
  font-size:13.5px;font-weight:500;color:var(--ink-2);box-shadow:var(--shadow-s);
}
.online-chip i{width:8px;height:8px;border-radius:50%;background:#2bd869;box-shadow:0 0 10px #2bd869;animation:blink 2s infinite;font-style:normal;flex:none}
.online-chip.off i{background:var(--gold);box-shadow:0 0 8px var(--gold)}

/* clickable phone AI button */
.p2-ai2 .btns b{cursor:pointer;transition:.2s}
.p2-ai2 .btns b:hover{filter:brightness(1.1);transform:translateY(-1px)}

/* ---------- versus (vibe coding vs MIN method) ---------- */
.versus{position:relative;display:grid;grid-template-columns:1fr 1fr;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-m)}
.vs-col{padding:clamp(28px,4vw,52px)}
.vs-col.bad{background:var(--paper-2)}
.vs-col.good{background:linear-gradient(165deg,var(--night),#2e2820);color:var(--paper)}
.vs-col .vs-k{font-size:10.5px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-3);display:block;margin-bottom:10px}
.vs-col.good .vs-k{color:var(--gold)}
.vs-col h3{font-family:var(--serif);font-size:clamp(22px,2.4vw,30px);font-weight:420;letter-spacing:-.015em;margin-bottom:4px}
.vs-col .sub-l{font-size:13.5px;color:var(--ink-3);margin-bottom:24px}
.vs-col.good .sub-l{color:rgba(250,248,243,.5)}
.vs-item{display:flex;gap:12px;padding:12px 0;border-top:1px solid var(--hairline);font-size:14.5px;color:var(--ink-2);align-items:flex-start;line-height:1.5}
.vs-col.good .vs-item{border-top-color:var(--night-line);color:rgba(250,248,243,.8)}
.vs-item i{font-style:normal;flex:none;font-weight:700;padding-top:1px}
.vs-col.bad .vs-item i{color:#b3562f}
.vs-col.good .vs-item i{color:var(--gold)}
.vs-badge{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,#d0613a,var(--accent-deep));color:#fff;
  display:grid;place-items:center;font-family:var(--serif);font-style:italic;font-size:16px;
  box-shadow:0 8px 24px -6px rgba(196,85,46,.6), 0 0 0 6px var(--paper);z-index:2;
}
.global-note{
  display:flex;align-items:center;justify-content:center;gap:12px;
  margin-top:30px;font-size:13.5px;color:var(--ink-3);text-align:center;
}
.global-note::before,.global-note::after{content:"";width:44px;height:1px;background:var(--hairline-2)}

/* ---------- whatsapp ---------- */
.wa-btn{
  position:fixed;right:22px;bottom:22px;z-index:150;
  width:58px;height:58px;border-radius:50%;
  background:linear-gradient(140deg,#2bd869,#1faf53);
  display:grid;place-items:center;
  box-shadow:0 10px 30px -6px rgba(37,211,102,.55), inset 0 1px 0 rgba(255,255,255,.25);
  transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s;
}
.wa-btn:hover{transform:scale(1.1) rotate(6deg);box-shadow:0 16px 40px -8px rgba(37,211,102,.65)}
.wa-btn svg{width:30px;height:30px;fill:#fff}
.wa-btn::after{
  content:"Chat with us";position:absolute;right:70px;top:50%;transform:translateY(-50%);
  background:var(--night);color:var(--paper);font-size:12.5px;font-weight:500;
  padding:8px 14px;border-radius:10px;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .25s;
}
.wa-btn:hover::after{opacity:1}

/* ---------- plans ---------- */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.plan{
  background:var(--card);border-radius:var(--r);padding:clamp(28px,3.2vw,40px);
  border:1px solid rgba(25,23,19,.06);box-shadow:var(--shadow-s);
  display:flex;flex-direction:column;position:relative;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s;
}
.plan:hover{transform:translateY(-6px);box-shadow:var(--shadow-m)}
.plan.hot{
  background:linear-gradient(170deg,var(--night),#2b2620);color:var(--paper);
  box-shadow:var(--shadow-l);border-color:transparent;
}
.plan .p-badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,#d0613a,var(--accent-deep));color:#fff;
  font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  padding:7px 16px;border-radius:100px;white-space:nowrap;
  box-shadow:0 6px 18px -4px rgba(196,85,46,.5);
}
.plan .p-name{font-family:var(--serif);font-weight:430;font-size:27px;letter-spacing:-.015em}
.plan .p-for{font-size:13.5px;color:var(--ink-3);margin-top:4px}
.plan.hot .p-for{color:rgba(250,248,243,.55)}
.plan .p-line{
  font-family:var(--serif);font-size:17.5px;font-style:italic;color:var(--accent);
  margin:18px 0 6px;
}
.plan.hot .p-line{color:var(--gold)}
.plan ul{list-style:none;margin:14px 0 28px}
.plan li{
  font-size:14px;color:var(--ink-2);padding:8px 0 8px 26px;position:relative;
  border-bottom:1px solid var(--hairline);
}
.plan.hot li{color:rgba(250,248,243,.75);border-bottom-color:var(--night-line)}
.plan li:last-child{border-bottom:none}
.plan li::before{
  content:"";position:absolute;left:2px;top:16px;width:11px;height:6px;
  border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(-45deg);
}
.plan.hot li::before{border-color:var(--gold)}
.plan .btn{margin-top:auto;justify-content:center}
.plan.hot .btn-line{border-color:rgba(250,248,243,.45);color:var(--paper)}
.plan.hot .btn-line:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

/* ---------- industries ---------- */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.ind{
  display:flex;gap:15px;align-items:center;
  background:var(--card);border:1px solid rgba(25,23,19,.05);border-radius:18px;
  padding:20px 22px;box-shadow:var(--shadow-s);
  transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s;
}
.ind:hover{transform:translateY(-4px);box-shadow:var(--shadow-m)}
.ind i{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;font-style:normal;flex:none}
.ind i svg{width:21px;height:21px}
.ind b{font-size:15px;font-weight:560;display:block;line-height:1.3}
.ind span{font-size:12.5px;color:var(--ink-3);display:block;margin-top:2px}

/* ---------- promo band ---------- */
.promo{
  background:linear-gradient(150deg,var(--night),#2e2820);color:var(--paper);
  border-radius:clamp(20px,3vw,32px);
  padding:clamp(32px,4.5vw,56px) clamp(24px,4vw,64px);
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:32px;
  position:relative;overflow:hidden;
}
.promo::before{
  content:"";position:absolute;top:-60%;right:8%;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle, rgba(224,164,88,.22), transparent 62%);
}
.promo .p-kick{
  display:inline-flex;align-items:center;gap:9px;
  font-size:10.5px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);
  margin-bottom:14px;
}
.promo .p-kick i{width:7px;height:7px;border-radius:50%;background:var(--gold);font-style:normal;box-shadow:0 0 10px var(--gold);animation:blink 2s infinite}
.promo h3{font-family:var(--serif);font-weight:410;font-size:clamp(25px,3.2vw,40px);letter-spacing:-.018em;position:relative}
.promo h3 em{font-style:italic;color:var(--gold)}
.promo p{font-size:14.5px;color:rgba(250,248,243,.6);margin-top:10px;max-width:52ch;position:relative}
.promo .btn{position:relative}

@media(max-width:840px){
  .biz-teaser{grid-template-columns:1fr}
  .steps,.quote-grid{grid-template-columns:1fr}
  .nl,.promo{grid-template-columns:1fr}
  .plans{grid-template-columns:1fr;gap:28px}
  .ind-grid{grid-template-columns:1fr}
  .wa-btn{right:16px;bottom:16px;width:54px;height:54px}
  .wa-btn::after{display:none}
}
@media(min-width:841px) and (max-width:1060px){
  .ind-grid{grid-template-columns:1fr 1fr}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}

/* ---------- language switcher ---------- */
.lang-wrap{position:relative;margin-left:4px}
.lang-btn{
  display:inline-flex;align-items:center;gap:7px;padding:10px 13px;
  border:1px solid var(--hairline-2);border-radius:9px;background:transparent;cursor:pointer;
  font-size:12px;font-weight:600;letter-spacing:.08em;color:var(--ink-2);
  font-family:var(--sans);text-transform:uppercase;transition:.2s;
}
.lang-btn:hover{border-color:var(--ink);color:var(--ink)}
.lang-btn svg{width:15px;height:15px}
.lang-menu{
  position:absolute;top:calc(100% + 10px);right:0;z-index:210;
  background:var(--card);border:1px solid var(--hairline);border-radius:14px;
  box-shadow:var(--shadow-m);padding:8px;min-width:176px;display:none;
}
.lang-menu.open{display:block}
.lang-menu button{
  display:flex;justify-content:space-between;align-items:center;width:100%;
  padding:9px 13px;border:none;background:none;font-size:14px;color:var(--ink-2);
  cursor:pointer;border-radius:8px;font-family:var(--sans);transition:.15s;
}
.lang-menu button:hover{background:var(--paper-2);color:var(--ink)}
.lang-menu button.cur{color:var(--accent);font-weight:600}
.lang-menu button small{font-size:10.5px;color:var(--ink-3);letter-spacing:.08em}
.m-langs{display:flex;flex-wrap:wrap;gap:8px;margin-top:26px}
.m-langs button{
  font-size:13px;font-weight:500;padding:9px 15px;border-radius:100px;
  border:1px solid var(--hairline-2);background:none;color:var(--ink-2);cursor:pointer;font-family:var(--sans);
}
.m-langs button.cur{background:var(--ink);color:var(--paper);border-color:var(--ink)}
/* google translate engine cleanup */
#gt_container{display:none}
body{top:0!important;position:static!important}
.skiptranslate,.goog-te-banner-frame{display:none!important}
font{background:transparent!important;box-shadow:none!important}

/* ---------- sticky mobile CTA bar ---------- */
.m-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:140;display:none;
  grid-template-columns:1fr 1fr;gap:1px;background:var(--hairline-2);
  border-top:1px solid var(--hairline-2);
  padding-bottom:env(safe-area-inset-bottom);
  box-shadow:0 -10px 34px rgba(25,23,19,.12);
}
.m-bar a{
  display:flex;align-items:center;justify-content:center;gap:9px;
  padding:16px 10px;font-size:14.5px;font-weight:600;
}
.m-bar a svg{width:17px;height:17px;flex:none}
.m-bar .mb-quote{background:var(--ink);color:var(--paper)}
.m-bar .mb-wa{background:#1faf53;color:#fff}
@media(max-width:840px){
  .m-bar{display:grid}
  .wa-btn{display:none}
  body{padding-bottom:56px}
}

/* ---------- case studies ---------- */
.case{
  display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(28px,4vw,64px);
  padding:clamp(36px,5vw,64px) 0;border-bottom:1px solid var(--hairline);align-items:center;
}
.case:first-of-type{border-top:1px solid var(--hairline)}
.case .tagline{font-size:10.5px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}
.case h3{font-family:var(--serif);font-weight:430;font-size:clamp(24px,3vw,36px);letter-spacing:-.018em;margin:14px 0}
.case p{font-size:15px;color:var(--ink-2);max-width:56ch;margin-bottom:12px}
.case p b{color:var(--ink);font-weight:560}
.case-stats{display:flex;flex-direction:column;gap:14px}
.case-stat{
  background:var(--card);border:1px solid rgba(25,23,19,.05);border-radius:16px;
  padding:18px 24px;box-shadow:var(--shadow-s);
}
.case-stat b{font-family:var(--serif);font-weight:450;font-size:clamp(26px,3vw,38px);letter-spacing:-.02em;color:var(--accent);display:block;line-height:1.15}
.case-stat span{font-size:12.5px;color:var(--ink-3)}
@media(max-width:840px){.case{grid-template-columns:1fr}}

/* ---------- legal / doc pages ---------- */
.legal{max-width:820px;padding-top:clamp(40px,5vw,64px)}
.legal .updated{color:var(--ink-3);font-size:14px;margin-bottom:6px}
.legal h2{font-family:var(--serif);font-weight:500;font-size:clamp(22px,2.6vw,30px);line-height:1.22;letter-spacing:-.012em;margin:clamp(36px,4.5vw,56px) 0 14px}
.legal h2:first-of-type{margin-top:clamp(28px,3.5vw,44px)}
.legal h3{font-size:17px;font-weight:600;color:var(--ink);margin:26px 0 8px}
.legal p{color:var(--ink-2);margin-bottom:16px;max-width:72ch}
.legal ul{color:var(--ink-2);margin:0 0 18px 20px;max-width:72ch}
.legal li{margin-bottom:9px}
.legal a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.legal .note{background:var(--paper-2);border:1px solid var(--hairline);border-radius:14px;padding:15px 18px;font-size:13.5px;color:var(--ink-2);margin:6px 0 8px;max-width:72ch}

/* ============================================================
   PRESTIGE UPGRADE — theme, refinements, new components
   ============================================================ */

/* ---------- Midnight dark theme ---------- */
html[data-theme="dark"]{
  color-scheme:dark;
  /* warm, not pitch-black; cards sit ABOVE the page, dark bands sit BELOW it */
  --paper:#1a1611;
  --paper-2:#221d16;
  --card:#252019;
  --ink:#f3efe7;
  --ink-2:#bcb5a6;
  --ink-3:#928b7c;
  --hairline:rgba(245,240,232,.11);
  --hairline-2:rgba(245,240,232,.19);
  --accent:#e07a4e;        /* a touch brighter so it pops on dark */
  --accent-soft:#33211a;
  --sage:#1d281f;
  --gold-soft:#2b2417;
  --night:#100d09;
  --night-2:#171310;
  --night-line:rgba(250,248,243,.14);
  --shadow-s:0 1px 2px rgba(0,0,0,.4), 0 6px 18px rgba(0,0,0,.35);
  --shadow-m:0 2px 8px rgba(0,0,0,.4), 0 18px 46px -10px rgba(0,0,0,.6);
  --shadow-l:0 6px 16px rgba(0,0,0,.45), 0 36px 90px -18px rgba(0,0,0,.7);
}
html[data-theme="dark"] body{background:var(--paper);color:var(--ink)}
html[data-theme="dark"] header{background:rgba(26,22,17,.82)}
html[data-theme="dark"] body::after{opacity:.3}
html[data-theme="dark"] .glyph svg{filter:none}

/* lifted panels get a hairline so they read on dark */
html[data-theme="dark"] .tile,
html[data-theme="dark"] .case-stat,
html[data-theme="dark"] .quote,
html[data-theme="dark"] .plan,
html[data-theme="dark"] .tool,
html[data-theme="dark"] .member,
html[data-theme="dark"] .chart-card,
html[data-theme="dark"] .press-asset,
html[data-theme="dark"] .px-card,
html[data-theme="dark"] .float,
html[data-theme="dark"] .code-card,
html[data-theme="dark"] .console{border-color:var(--hairline)}

/* fix panels that had hard-coded LIGHT backgrounds (text was going invisible) */
html[data-theme="dark"] .disc.t-clay{background:linear-gradient(165deg,#2d1e15,#241812)}
html[data-theme="dark"] .disc.t-sand{background:linear-gradient(165deg,#2b2417,#221c12)}
html[data-theme="dark"] .disc.t-sage{background:linear-gradient(165deg,#1e2920,#172019)}
html[data-theme="dark"] .eco-half.a{background:linear-gradient(160deg,#1f2b21,#18221a)}
html[data-theme="dark"] .eco-half.b{background:linear-gradient(160deg,#2d1f16,#241811)}
html[data-theme="dark"] .p-head{background:linear-gradient(180deg,#231e17,#191510)}
html[data-theme="dark"] .nl{background:linear-gradient(150deg,#2b2417,#211a12);border:1px solid var(--hairline)}
html[data-theme="dark"] .nl input{background:#14110c;border-color:var(--hairline-2);color:var(--ink)}
html[data-theme="dark"] .disc,
html[data-theme="dark"] .eco-half{border:1px solid var(--hairline)}

/* give the dark bands a faint edge so they separate from the page */
html[data-theme="dark"] .band-dark,
html[data-theme="dark"] .intel,
html[data-theme="dark"] .promo,
html[data-theme="dark"] footer{border:1px solid rgba(250,248,243,.06)}
html[data-theme="dark"] footer{border-width:1px 0 0}

/* CRITICAL: these sections are ALWAYS dark and paint their text with var(--paper).
   In dark mode --paper is dark, so their headings went invisible. Remap --paper
   back to a light value locally so light-text-on-dark is restored. */
html[data-theme="dark"] .band-dark,
html[data-theme="dark"] .intel,
html[data-theme="dark"] .promo,
html[data-theme="dark"] .cta-panel,
html[data-theme="dark"] .vs-col.good,
html[data-theme="dark"] .kpi-live,
html[data-theme="dark"] footer{--paper:#f4f0e8}
/* the highlighted plan swaps paper/ink on hover, so give it both */
html[data-theme="dark"] .plan.hot{--paper:#f4f0e8;--ink:#171310}
/* stray light-on-dark chips */
html[data-theme="dark"] .wa-btn::after,
html[data-theme="dark"] .member .ava{color:#f4f0e8}
/* discipline-card arrow: keep it visible on dark */
html[data-theme="dark"] .disc .go{background:rgba(255,255,255,.1)}

/* smooth token cross-fade on toggle */
body,header{transition:background-color .5s ease, color .5s ease}

/* ---------- theme toggle ---------- */
.theme-btn{
  width:38px;height:38px;border-radius:10px;border:1px solid var(--hairline-2);
  background:none;color:var(--ink-2);display:grid;place-items:center;cursor:pointer;flex:none;
  transition:color .25s,border-color .25s,transform .25s;
}
.theme-btn:hover{color:var(--ink);border-color:var(--ink);transform:translateY(-1px)}
.theme-btn svg{width:17px;height:17px}
.theme-btn .t-moon{display:none}
html[data-theme="dark"] .theme-btn .t-sun{display:none}
html[data-theme="dark"] .theme-btn .t-moon{display:block}
@media(max-width:840px){.lang-wrap{display:none}}

/* ---------- skip link (a11y) ---------- */
.skip-link{
  position:fixed;top:-60px;left:16px;z-index:600;background:var(--ink);color:var(--paper);
  padding:10px 16px;border-radius:8px;font-size:13px;font-weight:600;transition:top .2s;
}
.skip-link:focus{top:14px}

/* ---------- prestige typographic detail ---------- */
.numbers .n b,.hero-proof b,.stat,.case-stat b,.kpi b,.metric b{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
.drop-cap::first-letter{
  font-family:var(--serif);float:left;font-size:3.9em;line-height:.82;font-weight:420;
  padding:6px 12px 0 0;color:var(--accent);
}
.pull-quote{
  font-family:var(--serif);font-weight:360;font-style:italic;
  font-size:clamp(24px,3.6vw,42px);line-height:1.28;letter-spacing:-.015em;
  max-width:20ch;margin:clamp(30px,4vw,52px) 0;color:var(--ink);
}
.pull-quote em{color:var(--accent);font-style:italic}

/* ---------- trust logo wall ---------- */
.logos-band{border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);padding:clamp(30px,4vw,48px) 0}
.logos-lead{font-size:11px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-3);text-align:center;margin-bottom:26px}
.logos{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;
  gap:clamp(22px,4vw,60px);
}
.logos .logo{
  display:flex;align-items:center;gap:9px;color:var(--ink-2);opacity:.72;
  font-weight:600;font-size:15px;letter-spacing:-.01em;transition:opacity .3s,color .3s;
}
.logos .logo:hover{opacity:1;color:var(--ink)}
.logos .logo svg{width:22px;height:22px;flex:none}

/* ---------- traction / charts ---------- */
.chart-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(20px,3vw,32px)}
.chart-card{
  background:var(--card);border:1px solid rgba(25,23,19,.06);border-radius:var(--r);
  padding:clamp(24px,3vw,36px);box-shadow:var(--shadow-s);
}
.chart-card .ch-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:8px}
.chart-card .ch-k{font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3)}
.chart-card .ch-v{font-family:var(--serif);font-weight:450;font-size:clamp(28px,3.4vw,42px);letter-spacing:-.02em;line-height:1.1;margin-top:6px}
.chart-card .ch-v em{font-style:normal;font-size:.5em;color:#2c7a4b;font-family:var(--sans);font-weight:600;margin-left:8px}
.line-chart{width:100%;height:auto;display:block;margin-top:10px;overflow:visible}
.line-chart .lc-line{fill:none;stroke:url(#lcg);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:1;stroke-dashoffset:1;transition:stroke-dashoffset 1.8s cubic-bezier(.6,0,.2,1)}
.line-chart.in .lc-line{stroke-dashoffset:0}
.line-chart .lc-fill{opacity:0;transition:opacity 1.4s ease .3s}
.line-chart.in .lc-fill{opacity:1}
.line-chart .lc-dot{opacity:0;transition:opacity .4s ease 1.5s}
.line-chart.in .lc-dot{opacity:1}
.bars{display:flex;align-items:flex-end;gap:clamp(8px,1.6vw,16px);height:180px;margin-top:18px}
.bars .bar{flex:1;background:linear-gradient(180deg,var(--gold),var(--accent));border-radius:7px 7px 0 0;
  height:0;transition:height 1.1s cubic-bezier(.6,0,.2,1);position:relative;min-height:3px}
.bars.in .bar{height:var(--h)}
.bars .bar span{position:absolute;top:-22px;left:0;right:0;text-align:center;font-size:11px;font-weight:600;color:var(--ink-3)}
.bars .bar small{position:absolute;bottom:-24px;left:0;right:0;text-align:center;font-size:10.5px;color:var(--ink-3);letter-spacing:.04em}
.bars-wrap{padding:0 0 26px}

/* ---------- live KPI strip ---------- */
.kpi-live{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--night-line);
  border:1px solid var(--night-line);border-radius:18px;overflow:hidden;
}
.kpi-live .kpi{background:var(--night-2);padding:clamp(22px,3vw,34px)}
.kpi-live .kpi b{display:block;font-family:var(--serif);font-weight:450;font-size:clamp(26px,3.4vw,44px);color:var(--paper);letter-spacing:-.02em;line-height:1.05}
.kpi-live .kpi .kl{font-size:12px;color:rgba(250,248,243,.55);margin-top:8px;display:block}
.kpi-live .kpi .kd{font-size:10.5px;color:#7fe3ab;margin-top:10px;display:flex;align-items:center;gap:6px}
.kpi-live .kpi .kd i{width:6px;height:6px;border-radius:50%;background:#7fe3ab;box-shadow:0 0 8px #7fe3ab;animation:blink 1.8s infinite;font-style:normal}
@media(max-width:840px){.kpi-live{grid-template-columns:1fr 1fr}.chart-grid{grid-template-columns:1fr}}

/* ---------- leadership ---------- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,30px)}
.member{
  background:var(--card);border:1px solid rgba(25,23,19,.06);border-radius:var(--r);
  padding:clamp(24px,3vw,32px);box-shadow:var(--shadow-s);transition:transform .4s,box-shadow .4s;
}
.member:hover{transform:translateY(-4px);box-shadow:var(--shadow-m)}
.member .ava{
  width:60px;height:60px;border-radius:16px;display:grid;place-items:center;
  font-family:var(--serif);font-size:24px;color:var(--paper);margin-bottom:20px;
}
.member h3{font-family:var(--serif);font-weight:460;font-size:22px;letter-spacing:-.01em}
.member .role{font-size:12.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin:4px 0 14px}
.member p{font-size:14px;color:var(--ink-2);line-height:1.6}
@media(max-width:840px){.team-grid{grid-template-columns:1fr}}

/* ---------- founder letter ---------- */
.letter{
  max-width:760px;margin:0 auto;background:var(--card);border:1px solid var(--hairline);
  border-radius:var(--r);padding:clamp(34px,5vw,72px);box-shadow:var(--shadow-m);position:relative;
}
.letter p{font-size:clamp(16px,1.5vw,18.5px);line-height:1.8;color:var(--ink-2);margin-bottom:22px}
.letter p:first-of-type{color:var(--ink)}
.letter .sign{margin-top:34px}
.letter .sign b{font-family:var(--serif);font-size:26px;font-weight:420;color:var(--ink);display:block}
.letter .sign span{font-size:13px;color:var(--ink-3)}

/* ---------- press kit ---------- */
.press-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.5vw,26px)}
.press-asset{
  background:var(--card);border:1px solid rgba(25,23,19,.06);border-radius:18px;
  padding:26px;box-shadow:var(--shadow-s);
}
.press-asset h4{font-size:15px;font-weight:600;margin-bottom:6px}
.press-asset p{font-size:13px;color:var(--ink-3);margin-bottom:16px}
.press-swatches{display:flex;gap:10px;flex-wrap:wrap}
.swatch{width:44px;height:44px;border-radius:10px;border:1px solid var(--hairline);position:relative}
.swatch span{position:absolute;bottom:-18px;left:0;font-size:9.5px;color:var(--ink-3)}
.fact-table{width:100%;border-collapse:collapse;margin-top:8px}
.fact-table td{padding:13px 0;border-bottom:1px solid var(--hairline);font-size:14.5px;vertical-align:top}
.fact-table td:first-child{color:var(--ink-3);width:34%;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding-right:20px}
.fact-table td:last-child{color:var(--ink)}
@media(max-width:840px){.press-grid{grid-template-columns:1fr}}

/* ---------- portfolio explorer ---------- */
.px-controls{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:clamp(28px,3.5vw,44px)}
.px-chip{
  border:1px solid var(--hairline-2);background:none;color:var(--ink-2);cursor:pointer;
  padding:9px 18px;border-radius:100px;font-size:13px;font-weight:500;font-family:var(--sans);
  transition:all .25s;
}
.px-chip:hover{border-color:var(--ink);color:var(--ink)}
.px-chip.sel{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.px-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px)}
.px-card{
  background:var(--card);border:1px solid rgba(25,23,19,.06);border-radius:var(--r);padding:26px;
  box-shadow:var(--shadow-s);transition:transform .4s,box-shadow .4s,opacity .35s;
}
.px-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-m)}
.px-card.hide{display:none}
.px-card .glyph{width:46px;height:46px;border-radius:13px;margin-bottom:18px}
.px-card h3{font-family:var(--serif);font-weight:450;font-size:21px;letter-spacing:-.01em}
.px-card .idx{font-size:10.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);display:block;margin-bottom:12px}
.px-card p{font-size:14px;color:var(--ink-2);margin:8px 0 16px;line-height:1.6}
.px-card .meta{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--hairline);padding-top:14px}
.px-card .meta b{font-family:var(--serif);font-size:22px;font-weight:450;color:var(--ink)}
.px-card .meta b small{font-size:11px;color:var(--ink-3);font-family:var(--sans);margin-left:4px}
.px-card .meta .stars{color:var(--gold);font-size:13.5px;font-weight:600}
.px-empty{grid-column:1/-1;text-align:center;color:var(--ink-3);padding:40px 0;font-size:15px}
@media(max-width:900px){.px-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.px-grid{grid-template-columns:1fr}}

/* ---------- 404 ---------- */
.nf{min-height:72vh;display:grid;place-items:center;text-align:center;padding:120px var(--gutter) 80px}
.nf .big{font-family:var(--serif);font-weight:420;font-size:clamp(90px,20vw,220px);line-height:.9;letter-spacing:-.04em;background:linear-gradient(135deg,var(--accent),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nf p{font-size:18px;color:var(--ink-2);margin:18px 0 30px;max-width:44ch}

/* ---------- investor CTA pill ---------- */
.ir-note{
  display:inline-flex;align-items:center;gap:10px;margin-top:26px;
  font-size:13px;color:var(--ink-3);
}
.ir-note a{color:var(--accent);font-weight:600;text-decoration:underline;text-underline-offset:2px}

/* ---------- view transitions ---------- */
@view-transition{navigation:auto}
::view-transition-old(root),::view-transition-new(root){animation-duration:.42s}
@media(prefers-reduced-motion:reduce){
  ::view-transition-old(root),::view-transition-new(root){animation:none}
}

/* ---------- mobile menu editorial enhancements ---------- */
.m-menu .m-close{
  position:absolute;top:22px;right:var(--gutter);width:44px;height:44px;border:none;background:none;
  color:var(--ink);cursor:pointer;display:grid;place-items:center;
}
html.menu-open,html.menu-open body{overflow:hidden}
.m-menu a{opacity:0;transform:translateY(14px)}
.m-menu.open a{opacity:1;transform:none;transition:opacity .5s ease,transform .5s cubic-bezier(.2,.7,.2,1)}
.m-menu.open a:nth-of-type(1){transition-delay:.05s}
.m-menu.open a:nth-of-type(2){transition-delay:.1s}
.m-menu.open a:nth-of-type(3){transition-delay:.14s}
.m-menu.open a:nth-of-type(4){transition-delay:.18s}
.m-menu.open a:nth-of-type(5){transition-delay:.22s}
.m-menu.open a:nth-of-type(6){transition-delay:.26s}
.m-menu.open a:nth-of-type(7){transition-delay:.3s}
.m-menu.open a:nth-of-type(8){transition-delay:.34s}
@media(prefers-reduced-motion:reduce){.m-menu a{opacity:1;transform:none}}

/* ---------- print (press kit / one-pager) ---------- */
@media print{
  header,footer,.wa-btn,.m-bar,.lang-wrap,.theme-btn,.skip-link,.menu-btn,.marquee-band,#progress,#cring,.no-print{display:none!important}
  body{background:#fff;color:#000;padding:0}
  body::after{display:none}
  main{padding-top:0}
  .press-asset,.chart-card,.member{box-shadow:none;border:1px solid #ddd;break-inside:avoid}
  a{color:#000;text-decoration:none}
  .wrap{max-width:none;padding:0 24px}
}
