/* =====================================================
   App & Design — main.css  ·  v2 "modern dark"
   Amber #f5a400 on deep black · glass, gradient borders,
   spotlight cards, scroll reveals
   ===================================================== */

/* ---- self-hosted fonts (no external request, faster mobile) ---- */
/* Inter — body */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/inter-v20-latin-regular.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/inter-v20-latin-500.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/inter-v20-latin-600.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/inter-v20-latin-700.woff2') format('woff2')}
/* Instrument Serif — display. Only a normal face exists; the browser
   synthesizes the italic slant (font-synthesis) for em/italic display type. */
@font-face{font-family:'Instrument Serif';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/instrument-serif-v5-latin-regular.woff2') format('woff2')}
/* JetBrains Mono — labels */
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/jetbrains-mono-v24-latin-regular.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/jetbrains-mono-v24-latin-500.woff2') format('woff2')}

:root{
  --ink:#060605;
  --surface:#0b0a08;
  --glass:rgba(255,255,255,.025);
  --glass-strong:rgba(255,255,255,.045);
  --line:rgba(255,255,255,.08);
  --line-soft:rgba(255,255,255,.055);
  --amber:#f5a400;
  --amber-2:#ffc14d;
  --amber-soft:rgba(245,164,0,.10);
  --amber-glow:rgba(245,164,0,.32);
  --text:#f2eee4;
  --muted:#a39d91;
  --faint:#8a8474;
  --green:#5fb878;
  --r-lg:20px;
  --r-md:14px;
  --font-display:'Instrument Serif',Georgia,serif;
  --font-body:'Inter',-apple-system,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--text);
  font-family:var(--font-body);
  font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* ambient grid + vignette */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 90% 60% at 50% 0%,#000 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 90% 60% at 50% 0%,#000 30%,transparent 75%);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-3;pointer-events:none;
  background:
    radial-gradient(900px 500px at 80% -10%,rgba(245,164,0,.06),transparent 60%),
    radial-gradient(700px 500px at 10% 10%,rgba(245,164,0,.03),transparent 60%);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--amber);color:var(--ink)}
:focus-visible{outline:2px solid var(--amber);outline-offset:3px;border-radius:6px}

.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.wrap-narrow{max-width:820px;margin:0 auto;padding:0 24px}
section{padding:110px 0;position:relative}

/* ---------- type ---------- */
.eyebrow{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--amber);letter-spacing:.08em;text-transform:lowercase;display:inline-flex;align-items:center;gap:10px;margin-bottom:20px;padding:7px 14px;border:1px solid rgba(245,164,0,.25);border-radius:99px;background:var(--amber-soft)}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--amber);box-shadow:0 0 10px var(--amber)}
.eyebrow.center{margin-left:auto;margin-right:auto}

.grad{
  background:linear-gradient(115deg,var(--amber) 20%,var(--amber-2) 55%,#fff3d6 90%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
h1.page-title{font-family:var(--font-display);font-weight:400;font-size:clamp(42px,5.6vw,68px);line-height:1.04;letter-spacing:-.015em}
h1.page-title em,h2 em,.hero h1 em{font-style:italic;
  background:linear-gradient(115deg,var(--amber) 20%,var(--amber-2) 60%,#ffe9bd 95%);
  -webkit-background-clip:text;background-clip:text;color:transparent}
h2{font-family:var(--font-display);font-weight:400;font-size:clamp(34px,4.4vw,54px);line-height:1.07;letter-spacing:-.01em}
.lede{color:var(--muted);font-size:17.5px;max-width:560px;margin-top:22px}

.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:60px;flex-wrap:wrap}
.section-head p{color:var(--muted);max-width:420px;font-size:15.5px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14.5px;padding:12px 24px;border-radius:99px;transition:transform .18s,box-shadow .18s,border-color .18s,color .18s,background .18s;cursor:pointer;border:none;font-family:var(--font-body);position:relative}
.btn-amber{
  background:linear-gradient(180deg,#ffb627,var(--amber));color:#1a1100;
  box-shadow:0 1px 0 rgba(255,255,255,.35) inset,0 6px 22px rgba(245,164,0,.25);
}
.btn-amber:hover{transform:translateY(-2px);box-shadow:0 1px 0 rgba(255,255,255,.4) inset,0 12px 36px var(--amber-glow)}
.btn-ghost{border:1px solid var(--line);color:var(--text);background:var(--glass);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.btn-ghost:hover{border-color:rgba(245,164,0,.55);color:var(--amber-2);background:var(--amber-soft)}
.btn-sm{font-size:13.5px;padding:9px 18px}

/* ---------- floating glass nav ---------- */
.nav{position:sticky;top:14px;z-index:50;pointer-events:none}
.nav-in{
  pointer-events:auto;
  display:flex;align-items:center;justify-content:space-between;
  height:62px;padding:0 10px 0 20px;
  max-width:1180px;margin:0 auto;
  background:rgba(12,11,9,.72);
  backdrop-filter:blur(18px) saturate(1.4);-webkit-backdrop-filter:blur(18px) saturate(1.4);
  border:1px solid var(--line-soft);
  border-radius:99px;
  box-shadow:0 12px 40px rgba(0,0,0,.45);
}
@media(min-width:1240px){.nav-in{margin:0 auto}}
.nav{padding:0 16px}
.logo{display:flex;align-items:center;gap:11px;font-weight:700;font-size:16.5px;letter-spacing:-.02em}
.logo-img{height:32px;width:auto;display:block;filter:drop-shadow(0 0 10px rgba(245,164,0,.25));transition:filter .2s}
.logo:hover .logo-img{filter:drop-shadow(0 0 16px rgba(245,164,0,.5))}
footer .logo-img{height:36px}
.logo-mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(180deg,#ffb627,var(--amber));color:#1a1100;display:grid;place-items:center;font-family:var(--font-display);font-style:italic;font-size:19px;line-height:1;box-shadow:0 0 18px rgba(245,164,0,.35)}
.nav-links{display:flex;gap:4px;font-size:14px;color:var(--muted)}
.nav-links a{padding:8px 14px;border-radius:99px;transition:color .15s,background .15s}
.nav-links a:hover{color:var(--text);background:var(--glass-strong)}
.nav-links a.active{color:var(--amber-2);background:var(--amber-soft)}
.nav-contact-mobile{display:none}
.nav-tools{position:relative}
.nav-tools-btn{display:flex;align-items:center;gap:7px;font-family:var(--font-body);font-size:14px;color:var(--muted);background:none;border:none;cursor:pointer;padding:8px 14px;border-radius:99px;transition:color .15s,background .15s}
.nav-tools-btn:hover,.nav-tools.open .nav-tools-btn{color:var(--text);background:var(--glass-strong)}
.nav-tools-badge{font-family:var(--font-mono);font-size:9.5px;color:var(--amber-2);background:var(--amber-soft);border:1px solid rgba(245,164,0,.3);border-radius:99px;padding:2px 7px;letter-spacing:.04em}
.nav-tools-menu{position:absolute;top:calc(100% + 12px);right:0;min-width:248px;background:rgba(12,11,9,.96);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid var(--line);border-radius:16px;padding:8px;box-shadow:0 18px 50px rgba(0,0,0,.5);opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s,transform .18s,visibility .18s}
.nav-tools.open .nav-tools-menu{opacity:1;visibility:visible;transform:none}
.nav-tools-menu a{display:block;padding:12px 14px;border-radius:11px;transition:background .15s}
.nav-tools-menu a:hover{background:var(--amber-soft)}
.nav-tools-menu b{display:block;font-size:14px;font-weight:600;color:var(--text);margin-bottom:1px}
.nav-tools-menu span{font-family:var(--font-mono);font-size:11.5px;color:var(--faint)}
.nav-actions{display:flex;gap:10px;align-items:center}
.nav .btn{padding:9px 18px;font-size:13.5px}
.nav-toggle{display:none;background:none;border:none;color:var(--text);font-size:30px;line-height:1;cursor:pointer;padding:6px 12px}

/* ---------- page hero (subpages) ---------- */
.page-hero{padding:96px 0 72px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:-200px;right:-120px;width:560px;height:560px;background:radial-gradient(circle,rgba(245,164,0,.08),transparent 62%);pointer-events:none;filter:blur(10px)}

/* ---------- home hero (centered, ambient tiles) ---------- */
.hero{padding:120px 0 96px;position:relative;overflow:hidden;text-align:center}
.hero::before{content:"";position:absolute;top:-260px;left:50%;transform:translateX(-50%);width:900px;height:700px;background:radial-gradient(circle,rgba(245,164,0,.10),transparent 60%);pointer-events:none;filter:blur(14px)}
.hero-bg{position:absolute;inset:-20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(34px,1fr));grid-auto-rows:34px;gap:5px;pointer-events:none;
  mask-image:radial-gradient(ellipse 75% 72% at 50% 38%,#000 8%,transparent 72%);
  -webkit-mask-image:radial-gradient(ellipse 75% 72% at 50% 38%,#000 8%,transparent 72%);
  opacity:.6}
.hero-bg i{border-radius:4px;background:rgba(255,255,255,.022);transition:background 1.2s,box-shadow 1.2s}
.hero-bg i.lit{background:rgba(245,164,0,.45);box-shadow:0 0 14px rgba(245,164,0,.45)}
.hero-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}
.hero h1{font-family:var(--font-display);font-weight:400;font-size:clamp(46px,6.4vw,86px);line-height:1.04;letter-spacing:-.018em;margin-bottom:28px;max-width:980px}
.hero-sub{color:var(--muted);font-size:17.5px;max-width:560px;margin:0 auto 38px}
.hero-sub strong{color:var(--text);font-weight:600}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-bottom:56px}
.hero-proof{
  display:flex;font-family:var(--font-mono);
  background:linear-gradient(180deg,var(--glass-strong),var(--glass));
  border:1px solid var(--line-soft);border-radius:18px;
  padding:22px 10px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 18px 50px rgba(0,0,0,.4);
  margin-bottom:40px}
.proof{padding:0 34px;border-right:1px solid var(--line-soft);text-align:center}
.proof:last-child{border-right:none}
.proof b{display:block;font-size:24px;font-weight:500;color:var(--text)}
.proof span{font-size:11.5px;color:var(--faint)}
.hero-clients{font-family:var(--font-mono);font-size:12px;color:var(--faint);letter-spacing:.04em;display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center}
.hero-clients span{color:var(--amber);text-transform:lowercase;margin-right:4px}
.hero-clients i{font-style:normal;color:rgba(245,164,0,.4);font-size:8px}

/* ---------- glass card base + gradient border ---------- */
.card{
  position:relative;border-radius:var(--r-lg);
  background:linear-gradient(180deg,var(--glass-strong),var(--glass));
  border:1px solid var(--line-soft);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transition:transform .25s,border-color .25s,box-shadow .25s;
}
.card::before{ /* spotlight */
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),rgba(245,164,0,.08),transparent 45%);
  opacity:0;transition:opacity .3s;
}
.card:hover{border-color:rgba(245,164,0,.35);transform:translateY(-3px);box-shadow:0 18px 50px rgba(0,0,0,.45)}
.card:hover::before{opacity:1}

/* ---------- ribbon ---------- */
.ribbon{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);padding:18px 0;overflow:hidden;background:rgba(255,255,255,.012);
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.ribbon-track{display:flex;gap:52px;white-space:nowrap;font-family:var(--font-mono);font-size:13px;color:var(--faint);animation:scroll 36s linear infinite;width:max-content}
.ribbon-track span b{color:var(--amber);font-weight:500;margin-right:6px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- services bento ---------- */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{padding:34px 32px;display:flex;flex-direction:column}
.svc.featured{grid-column:span 2;background:
  linear-gradient(180deg,rgba(245,164,0,.07),rgba(245,164,0,.015)),
  linear-gradient(180deg,var(--glass-strong),var(--glass))}
.svc h3{font-size:20px;font-weight:600;margin-bottom:10px;letter-spacing:-.01em}
.svc.featured h3{font-size:24px}
.svc p{color:var(--muted);font-size:14.5px;margin-bottom:22px;flex:1}
.svc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:8px}
.svc-price{font-family:var(--font-mono);font-size:12.5px;color:var(--amber-2);background:var(--amber-soft);border:1px solid rgba(245,164,0,.25);padding:5px 12px;border-radius:99px;white-space:nowrap}
.svc-icon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--amber-soft);border:1px solid rgba(245,164,0,.2);color:var(--amber);font-size:18px;margin-bottom:18px}
.tags{display:flex;gap:8px;flex-wrap:wrap}
.tags span{font-family:var(--font-mono);font-size:11.5px;color:var(--muted);border:1px solid var(--line-soft);border-radius:99px;padding:4px 11px;background:var(--glass)}

/* ---------- service detail (services page) ---------- */
.svc-overview{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:48px}
.svc-pill{padding:20px 18px;display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.svc-pill-icon{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:var(--amber-soft);border:1px solid rgba(245,164,0,.2);color:var(--amber);font-size:15px}
.svc-pill b{font-size:14px;font-weight:600;line-height:1.3;letter-spacing:-.01em}
.svc-pill-price{font-family:var(--font-mono);font-size:11.5px;color:var(--amber-2)}
.svc-layout{display:grid;grid-template-columns:212px 1fr;gap:56px;align-items:start}
.svc-rail{position:sticky;top:96px;display:flex;flex-direction:column;gap:2px}
.svc-rail h4,.svc-rail .rail-label{font-family:var(--font-mono);font-size:11.5px;font-weight:500;color:var(--faint);letter-spacing:.07em;text-transform:uppercase;margin-bottom:12px}
.svc-rail a:not(.rail-cta){font-size:13.5px;color:var(--muted);padding:9px 14px;border-left:2px solid var(--line-soft);transition:color .15s,border-color .15s,background .15s}
.svc-rail a:not(.rail-cta):hover{color:var(--text)}
.svc-rail a.rail-on{color:var(--amber-2);border-left-color:var(--amber);background:linear-gradient(90deg,var(--amber-soft),transparent)}
.rail-cta{margin-top:18px;justify-content:center}
.svc-detail{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;padding:64px 0;border-bottom:1px solid var(--line-soft);align-items:start;scroll-margin-top:96px}
.svc-detail:first-child{padding-top:0}
.svc-detail:last-child{border-bottom:none}
.svc-detail-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.svc-detail-num{font-family:var(--font-mono);font-size:12px;color:var(--faint)}
.svc-detail h2{font-size:clamp(27px,3.2vw,38px);margin-bottom:14px}
.svc-detail .svc-detail-price{font-family:var(--font-mono);font-size:13px;color:var(--amber-2);background:var(--amber-soft);border:1px solid rgba(245,164,0,.25);padding:6px 14px;border-radius:99px;margin-bottom:20px;display:inline-block}
.svc-detail p{color:var(--muted);font-size:15.5px;margin-bottom:24px}
.svc-detail-ctas{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}
.includes{padding:30px 32px;position:sticky;top:96px}
.includes h4{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--faint);letter-spacing:.07em;text-transform:uppercase;margin-bottom:18px}
.includes ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.includes li{display:flex;gap:12px;font-size:14.5px;color:var(--muted)}
.includes li::before{content:"◆";color:var(--amber);font-size:10px;padding-top:5px;text-shadow:0 0 8px rgba(245,164,0,.5)}
.perk-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.perk{padding:28px 26px;display:flex;flex-direction:column;gap:10px}
.perk i{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-style:normal;background:var(--amber-soft);border:1px solid rgba(245,164,0,.2);color:var(--amber);font-family:var(--font-mono);font-size:15px;margin-bottom:6px}
.perk b{font-size:15.5px;font-weight:600;letter-spacing:-.01em}
.perk span{color:var(--muted);font-size:13.5px}

/* ---------- work / portfolio ---------- */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.proj{padding:26px 26px 30px;display:flex;flex-direction:column;gap:13px}
.proj-kind{font-family:var(--font-mono);font-size:12px;color:var(--faint);letter-spacing:.04em}
.proj h3,.proj .proj-name{font-family:var(--font-display);font-weight:400;font-size:28px;letter-spacing:-.01em}
.proj p{color:var(--muted);font-size:14.5px;flex:1}
.proj-stat{font-family:var(--font-mono);font-size:13px;color:var(--amber-2);border-top:1px solid var(--line-soft);padding-top:16px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.proj-stat a{color:var(--muted);transition:color .15s}
.proj-stat a:hover{color:var(--text)}
.proj-stat .dim{color:var(--faint)}

/* CSS-drawn project previews */
.proj-visual{
  position:relative;border-radius:13px;overflow:hidden;
  border:1px solid var(--line-soft);
  background:linear-gradient(180deg,#0d0c0a,#080807);
  height:190px;margin-bottom:10px;flex-shrink:0;
  transition:border-color .25s}
.proj:hover .proj-visual{border-color:rgba(245,164,0,.3)}
.proj-visual .lit{background:linear-gradient(180deg,#ffb627,var(--amber))!important;opacity:.85;box-shadow:0 0 10px rgba(245,164,0,.35)}
/* web: browser */
.vz-bar{display:flex;align-items:center;gap:6px;padding:11px 14px;border-bottom:1px solid var(--line-soft)}
.vz-bar i{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.1)}
.vz-bar i:first-child{background:rgba(245,164,0,.5)}
.vz-url{flex:1;max-width:46%;height:9px;border-radius:99px;background:rgba(255,255,255,.05);margin-left:8px}
.vz-body{padding:16px 18px}
.vz-h{width:42%;height:13px;border-radius:5px;background:rgba(255,255,255,.12);margin-bottom:10px}
.vz-line{width:70%;height:7px;border-radius:99px;background:rgba(255,255,255,.05);margin-bottom:7px}
.vz-line.short{width:48%}
.vz-tiles{display:grid;grid-template-columns:repeat(6,1fr);gap:7px;margin-top:14px}
.vz-tiles i{aspect-ratio:1.6;border-radius:4px;background:rgba(255,255,255,.045)}
/* ios: phone */
.viz-ios{display:grid;place-items:center}
.vz-phone{
  width:118px;height:158px;border-radius:22px 22px 0 0;border:1.5px solid var(--line);border-bottom:none;
  background:linear-gradient(180deg,#11100d,#0a0908);position:relative;padding:24px 13px 0;
  box-shadow:0 -8px 40px rgba(245,164,0,.06)}
.vz-notch{position:absolute;top:9px;left:50%;transform:translateX(-50%);width:38px;height:7px;border-radius:99px;background:rgba(255,255,255,.1)}
.vz-approw{height:17px;border-radius:7px;background:rgba(255,255,255,.055);margin-bottom:9px}
.vz-approw.short{width:62%}
.vz-fab{position:absolute;bottom:12px;right:12px;width:26px;height:26px;border-radius:50%;background:linear-gradient(180deg,#ffb627,var(--amber));box-shadow:0 0 14px rgba(245,164,0,.4)}
/* saas: dashboard */
.viz-saas{display:flex}
.vz-side{width:54px;border-right:1px solid var(--line-soft);padding:16px 12px;display:flex;flex-direction:column;gap:10px}
.vz-side i{height:9px;border-radius:99px;background:rgba(255,255,255,.06)}
.vz-main{flex:1;padding:16px 18px;display:flex;flex-direction:column}
.vz-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.vz-kpis i{height:30px;border-radius:7px;background:rgba(255,255,255,.05)}
.vz-chart{flex:1;display:flex;align-items:flex-end;gap:8px}
.vz-chart i{flex:1;border-radius:4px 4px 0 0;background:rgba(255,255,255,.07)}
.filter-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:42px}
.filter-row button{font-family:var(--font-mono);font-size:13px;color:var(--muted);background:var(--glass);border:1px solid var(--line-soft);border-radius:99px;padding:9px 20px;cursor:pointer;transition:all .15s;backdrop-filter:blur(6px)}
.filter-row button:hover{border-color:rgba(245,164,0,.45);color:var(--amber-2)}
.filter-row button.on{background:linear-gradient(180deg,#ffb627,var(--amber));border-color:transparent;color:#1a1100;font-weight:500}

/* editorial rows (portfolio) */
.rowp-list{display:flex;flex-direction:column}
.rowp{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:58px 0;border-bottom:1px solid var(--line-soft)}
.rowp:last-child{border-bottom:none}
.rowp:nth-child(even) .rowp-vis{order:2}
.rowp-vis{height:290px}
.rowp-vis .proj-visual{height:100%;margin:0;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.rowp-vis .vz-tiles{grid-template-columns:repeat(8,1fr)}
.rowp:hover .proj-visual{border-color:rgba(245,164,0,.35)}
.rowp-idx{font-family:var(--font-mono);font-size:12px;color:var(--amber);margin-bottom:16px;display:block;letter-spacing:.04em}
.rowp h3{font-family:var(--font-display);font-weight:400;font-size:clamp(30px,3.6vw,44px);letter-spacing:-.012em;margin-bottom:12px}
.rowp h3 em{font-style:italic;background:linear-gradient(115deg,var(--amber) 20%,var(--amber-2) 60%,#ffe9bd 95%);-webkit-background-clip:text;background-clip:text;color:transparent}
.rowp p{color:var(--muted);font-size:15px;margin-bottom:20px;max-width:430px}
.rowp-metric{font-family:var(--font-mono);font-size:13px;color:var(--amber-2);margin-bottom:22px}
.rowp-link{font-family:var(--font-mono);font-size:13px;color:var(--text);border-bottom:1px solid var(--amber);padding-bottom:3px;transition:color .15s}
.rowp-link:hover{color:var(--amber-2)}
.rowp-link.dim{color:var(--faint);border-bottom-color:var(--line)}
.rowp-empty{display:grid;place-items:center;border-style:dashed!important;border-color:rgba(245,164,0,.3)!important;background:linear-gradient(180deg,rgba(245,164,0,.04),transparent)!important}
.rowp-empty span{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;border:1px dashed rgba(245,164,0,.45);color:var(--amber);font-size:30px;font-family:var(--font-mono)}
.rowp-cta:hover .rowp-empty{border-color:rgba(245,164,0,.6)!important}

/* ---------- case studies ---------- */
.case{padding:92px 0;border-bottom:1px solid var(--line-soft)}
.case:last-of-type{border-bottom:none}
.case-top{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:40px;flex-wrap:wrap}
.case-top .proj-kind{margin-bottom:12px;display:block}
.case-top h2{margin-bottom:12px}
.case-metric{text-align:right;flex-shrink:0}
.case-metric b{display:block;font-family:var(--font-display);font-weight:400;font-size:clamp(40px,5vw,62px);line-height:1;letter-spacing:-.01em}
.case-metric span{font-family:var(--font-mono);font-size:12px;color:var(--faint)}
.case-metric-text{font-size:14px!important;color:var(--amber-2)!important;border:1px solid rgba(245,164,0,.25);background:var(--amber-soft);border-radius:99px;padding:7px 16px;display:inline-block}
.case-link{font-family:var(--font-mono);font-size:13px;color:var(--amber-2)}
.case-link:hover{text-decoration:underline}
.case-link.dim{color:var(--faint)}
.case-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.case-block{padding:30px}
.case-block h4{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--amber);letter-spacing:.07em;text-transform:uppercase;margin-bottom:14px}
.case-block p{color:var(--muted);font-size:15px}
.case-results{padding:32px;display:grid;grid-template-columns:2fr 1fr;gap:40px;align-items:center;background:
  linear-gradient(180deg,rgba(245,164,0,.06),rgba(245,164,0,.01)),
  linear-gradient(180deg,var(--glass-strong),var(--glass))}
.case-results ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.case-results li{display:flex;gap:12px;font-size:15px;color:var(--text)}
.case-results li::before{content:"→";color:var(--amber)}
.case-stack{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.case-stack h4{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--faint);letter-spacing:.07em;text-transform:uppercase;margin-bottom:6px}

/* ---------- band ---------- */
.band{padding:80px 0}
.band-in{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.band h2{font-size:clamp(30px,3.6vw,46px)}
.band-points{display:flex;flex-direction:column}
.band-point{display:flex;gap:18px;padding:24px 0;border-bottom:1px solid var(--line-soft)}
.band-point:last-child{border-bottom:none}
.band-point i{font-family:var(--font-mono);font-style:normal;color:var(--amber);font-size:13px;padding-top:3px;text-shadow:0 0 10px rgba(245,164,0,.4)}
.band-point div b{display:block;font-weight:600;font-size:15.5px;margin-bottom:3px}
.band-point div span{color:var(--muted);font-size:14px}

/* ---------- process ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{padding:26px 26px 30px;border-radius:var(--r-md);background:var(--glass);border:1px solid var(--line-soft);position:relative;overflow:hidden;transition:border-color .25s,transform .25s}
.step::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--amber),transparent);opacity:.35;transition:opacity .25s}
.step:hover{border-color:rgba(245,164,0,.3);transform:translateY(-3px)}
.step:hover::before{opacity:1}
.step-meta{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:12px;color:var(--faint);margin-bottom:16px}
.step-meta b{color:var(--amber-2);font-weight:500}
.step h3{font-size:17px;font-weight:600;margin-bottom:8px}
.step p{color:var(--muted);font-size:14px}

/* ---------- quotes ---------- */
.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.quote{padding:30px 28px;display:flex;flex-direction:column;gap:18px}
.stars{color:var(--amber);letter-spacing:3px;font-size:13px;text-shadow:0 0 12px rgba(245,164,0,.4)}
.quote blockquote{font-family:var(--font-display);font-size:19.5px;line-height:1.45;flex:1}
.quote-who b{display:block;font-size:14px;font-weight:600}
.quote-who span{font-family:var(--font-mono);font-size:12px;color:var(--faint)}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:start}
.about-grid .prose p{color:var(--muted);font-size:16px;margin-bottom:20px}
.about-grid .prose p strong{color:var(--text)}
.pull-quote{
  font-family:var(--font-display);font-size:23px;line-height:1.4;color:var(--text);
  border-left:2px solid var(--amber);padding:6px 0 6px 24px;margin:30px 0;
  text-shadow:0 0 30px rgba(245,164,0,.12)}
.founder-col{display:flex;flex-direction:column;gap:18px;position:sticky;top:96px}
.founder-card{padding:34px 32px;text-align:center;background:
  linear-gradient(180deg,rgba(245,164,0,.07),rgba(245,164,0,.015)),
  linear-gradient(180deg,var(--glass-strong),var(--glass))}
.founder-avatar{
  width:84px;height:84px;border-radius:26px;margin:0 auto 20px;
  display:grid;place-items:center;
  background:linear-gradient(180deg,#ffb627,var(--amber));color:#1a1100;
  font-family:var(--font-display);font-style:italic;font-size:34px;
  box-shadow:0 0 40px rgba(245,164,0,.35),0 1px 0 rgba(255,255,255,.4) inset}
.founder-card h3,.founder-card .founder-name{font-size:21px;font-weight:600;letter-spacing:-.01em;margin-bottom:4px}
.founder-role{font-family:var(--font-mono);font-size:12px;color:var(--amber-2);display:block;margin-bottom:20px}
.founder-facts{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:26px}
.founder-facts li{font-family:var(--font-mono);font-size:12.5px;color:var(--muted)}
.founder-facts li::before{content:"◆ ";color:var(--amber);font-size:9px}
.founder-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.num-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.num-card{padding:32px 26px;text-align:center}
.num-card b{display:block;font-family:var(--font-display);font-weight:400;font-size:clamp(34px,3.4vw,46px);line-height:1;margin-bottom:12px;letter-spacing:-.01em}
.num-card span{font-family:var(--font-mono);font-size:12px;color:var(--faint)}
.infra-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.infra-card{padding:32px}
.infra-num{font-family:var(--font-mono);font-size:12px;color:var(--amber);display:inline-block;border:1px solid rgba(245,164,0,.3);background:var(--amber-soft);border-radius:8px;padding:4px 10px;margin-bottom:18px}
.infra-card h3{font-size:18px;font-weight:600;margin-bottom:8px;letter-spacing:-.01em}
.infra-card p{color:var(--muted);font-size:14.5px}
.stack-card{padding:30px}
.stack-card h4,.stack-card h3{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--faint);letter-spacing:.07em;text-transform:uppercase;margin-bottom:18px}
.stack-list{display:flex;flex-direction:column;gap:14px}
.stack-list div{display:flex;justify-content:space-between;gap:16px;font-size:14px;border-bottom:1px solid var(--line-soft);padding-bottom:14px}
.stack-list div:last-child{border-bottom:none;padding-bottom:0}
.stack-list b{font-weight:600}
.stack-list span{color:var(--faint);font-family:var(--font-mono);font-size:12.5px;text-align:right}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:72px}
.value{padding:28px}
.value h3{font-size:17px;font-weight:600;margin-bottom:8px}
.value p{color:var(--muted);font-size:14.5px}

/* ---------- recommendation tool ---------- */
.rec-form{padding:34px;display:flex;flex-direction:column;gap:18px}
.field .opt{color:var(--faint);font-weight:400;text-transform:none;letter-spacing:0}
.rec-why{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.rec-why-item{padding:4px 2px}
.rec-why-item b{display:block;font-size:14.5px;font-weight:600;margin-bottom:5px}
.rec-why-item b::before{content:"◆ ";color:var(--amber);font-size:9px;vertical-align:2px}
.rec-why-item span{color:var(--muted);font-size:13.5px}
.rec-head{display:flex;gap:44px;align-items:center;margin-bottom:44px;flex-wrap:wrap}
.rec-tags{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0 16px}
.rec-tags span{font-family:var(--font-mono);font-size:11.5px;color:var(--amber-2);background:var(--amber-soft);border:1px solid rgba(245,164,0,.25);border-radius:99px;padding:5px 13px}
.rec-list{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}
.rec-item{display:flex;gap:22px;padding:26px 30px;align-items:flex-start}
.rec-num{font-family:var(--font-display);font-size:34px;color:var(--amber);opacity:.5;line-height:1;flex-shrink:0;min-width:42px}
.rec-body{flex:1}
.rec-item-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:8px;flex-wrap:wrap}
.rec-item-head h3{font-size:18.5px;font-family:var(--font-body);font-weight:600;letter-spacing:-.01em}
.rec-pri{font-family:var(--font-mono);font-size:11px;border-radius:99px;padding:4px 11px;white-space:nowrap}
.rec-high{color:#e08080;background:rgba(220,80,80,.1);border:1px solid rgba(220,80,80,.3)}
.rec-med{color:var(--amber-2);background:var(--amber-soft);border:1px solid rgba(245,164,0,.3)}
.rec-low{color:var(--muted);background:var(--glass);border:1px solid var(--line-soft)}
.rec-body p{color:var(--muted);font-size:14.5px;margin-bottom:10px}
.rec-src{font-family:var(--font-mono);font-size:11.5px;color:var(--amber)}
.rec-restart{font-family:var(--font-mono);font-size:13px;color:var(--muted)}
.rec-restart:hover{color:var(--amber-2)}

/* ---------- audit tool ---------- */
.audit-bar{display:flex;gap:8px;max-width:680px;margin:40px auto 0;border-radius:99px;padding:7px;
  background:var(--glass-strong);border:1px solid var(--line);backdrop-filter:blur(10px);
  box-shadow:0 18px 50px rgba(0,0,0,.4);flex-wrap:wrap}
.audit-bar:focus-within{border-color:rgba(245,164,0,.5);box-shadow:0 0 0 3px rgba(245,164,0,.12),0 18px 50px rgba(0,0,0,.4)}
.audit-bar input{flex:1;background:none;border:none;outline:none;color:var(--text);font-family:var(--font-body);font-size:15px;padding:10px 18px;min-width:170px}
.audit-bar input::placeholder{color:var(--faint)}
.audit-bar input[name=email]{border-left:1px solid var(--line-soft)}
.audit-err{font-family:var(--font-mono);font-size:13px;color:#e08080;margin-top:16px}
.audit-note{font-family:var(--font-mono);font-size:12px;color:var(--faint);margin-top:18px}
.audit-note a{color:var(--muted)}
.audit-head{display:flex;gap:44px;align-items:center;margin-bottom:48px;flex-wrap:wrap}
.audit-ring{position:relative;width:168px;height:168px;flex-shrink:0}
.audit-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring-bg{fill:none;stroke:rgba(255,255,255,.07);stroke-width:9}
.ring-fg{fill:none;stroke:var(--amber);stroke-width:9;stroke-linecap:round;filter:drop-shadow(0 0 10px rgba(245,164,0,.5))}
.ring-val{position:absolute;inset:0;display:grid;place-items:center;text-align:center}
.ring-val b{font-family:var(--font-display);font-weight:400;font-size:50px;line-height:1;display:block}
.ring-val span{font-family:var(--font-mono);font-size:11.5px;color:var(--faint)}
.audit-url{font-family:var(--font-mono);font-size:13px;color:var(--amber-2);margin:8px 0 14px;word-break:break-all}
.audit-summary{color:var(--muted);font-size:15.5px;max-width:560px}
.audit-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.audit-cat{padding:28px 28px 18px}
.audit-cat-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.audit-cat-head h3{font-size:18px;font-family:var(--font-body);font-weight:600}
.audit-cat-score{font-family:var(--font-mono);font-size:12.5px;color:var(--amber-2);background:var(--amber-soft);border:1px solid rgba(245,164,0,.25);border-radius:99px;padding:4px 12px}
.audit-checks{display:flex;flex-direction:column}
.audit-check{display:flex;gap:14px;padding:13px 0;border-bottom:1px solid var(--line-soft);align-items:flex-start}
.audit-check:last-child{border-bottom:none}
.audit-check i{width:24px;height:24px;border-radius:8px;display:grid;place-items:center;font-style:normal;font-family:var(--font-mono);font-size:12px;flex-shrink:0;margin-top:1px}
.audit-check.pass i{background:rgba(95,184,120,.12);border:1px solid rgba(95,184,120,.35);color:var(--green)}
.audit-check.warn i{background:var(--amber-soft);border:1px solid rgba(245,164,0,.35);color:var(--amber)}
.audit-check.fail i{background:rgba(220,80,80,.1);border:1px solid rgba(220,80,80,.35);color:#e08080}
.audit-check b{display:block;font-size:14px;font-weight:600;margin-bottom:1px}
.audit-check span{color:var(--muted);font-size:13px}
.audit-pitch{padding:38px;display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:center;background:
  linear-gradient(180deg,rgba(245,164,0,.08),rgba(245,164,0,.015)),
  linear-gradient(180deg,var(--glass-strong),var(--glass))!important}
.audit-pitch h3{font-size:clamp(24px,2.8vw,32px);margin-bottom:10px}
.audit-pitch h3 em{font-style:italic;background:linear-gradient(115deg,var(--amber),#ffe9bd);-webkit-background-clip:text;background-clip:text;color:transparent}
.audit-pitch p{color:var(--muted);font-size:14.5px}
.audit-pitch-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end}

/* ---------- blog ---------- */
.post-list{display:flex;flex-direction:column}
.post-row{display:block;padding:40px 8px;border-bottom:1px solid var(--line-soft);transition:padding .2s}
.post-row:first-child{border-top:1px solid var(--line-soft)}
.post-row:hover{padding-left:24px}
.post-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:12px}
.post-cat{font-family:var(--font-mono);font-size:11.5px;color:var(--amber-2);background:var(--amber-soft);border:1px solid rgba(245,164,0,.25);border-radius:99px;padding:4px 12px}
.mono-dim{font-family:var(--font-mono);font-size:12px;color:var(--faint)}
.post-row h3,.post-row .post-title{font-family:var(--font-display);font-weight:400;font-size:clamp(24px,3vw,34px);letter-spacing:-.012em;margin-bottom:8px;transition:color .2s}
.post-row:hover h3,.post-row:hover .post-title{color:var(--amber-2)}
.post-row p{color:var(--muted);font-size:14.5px;max-width:640px;margin-bottom:14px}
.post-go{font-family:var(--font-mono);font-size:12.5px;color:var(--amber)}
.post-body{padding:48px 24px 24px}
.post-body p{color:var(--muted);font-size:16.5px;margin-bottom:22px;line-height:1.75}
.post-body p strong{color:var(--text)}
.post-body h2{font-family:var(--font-display);font-weight:400;font-size:clamp(24px,2.8vw,32px);letter-spacing:-.01em;margin:42px 0 16px;color:var(--text)}
.post-body h2 em{font-style:italic}
.post-body a{color:var(--amber-2);border-bottom:1px solid rgba(245,164,0,.35)}
.post-body a:hover{border-bottom-color:var(--amber)}
.post-body code{font-family:var(--font-mono);font-size:14px;color:var(--amber-2);background:var(--amber-soft);border:1px solid rgba(245,164,0,.2);border-radius:6px;padding:2px 7px}
.post-body ul{padding-left:24px;margin-bottom:22px}
.post-body li{color:var(--muted);margin-bottom:8px}
.post-foot{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:32px 24px 96px;border-top:1px solid var(--line-soft);margin-top:24px}

/* ---------- start here ---------- */
.sh-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:start}
.sh-prose p{color:var(--muted);font-size:16px;margin-bottom:20px}
.sh-prose p strong{color:var(--text)}
.sh-q{font-family:var(--font-mono);font-size:13.5px;color:var(--amber-2);background:var(--amber-soft);border:1px solid rgba(245,164,0,.22);border-radius:8px;padding:2px 9px;white-space:nowrap}
.sh-math{padding:32px;position:sticky;top:96px;background:
  linear-gradient(180deg,rgba(245,164,0,.07),rgba(245,164,0,.015)),
  linear-gradient(180deg,var(--glass-strong),var(--glass))!important}
.sh-math h4,.sh-math h3{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--faint);letter-spacing:.07em;text-transform:uppercase;margin-bottom:24px}
.sh-eq{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:24px}
.sh-num{text-align:center}
.sh-num b{display:block;font-family:var(--font-display);font-weight:400;font-size:46px;line-height:1}
.sh-num span{font-family:var(--font-mono);font-size:11px;color:var(--faint)}
.sh-op{font-family:var(--font-display);font-size:30px;color:var(--amber)}
.sh-result{border-top:1px solid var(--line-soft);padding-top:22px;margin-bottom:22px}
.sh-result b{display:block;font-family:var(--font-display);font-weight:400;font-size:34px;line-height:1.1;margin-bottom:10px}
.sh-result span{color:var(--muted);font-size:13.5px;display:block}

/* ---------- faq ---------- */
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--line-soft);border-radius:var(--r-md);background:var(--glass);transition:border-color .2s;overflow:hidden}
.faq-item:hover,.faq-item[open]{border-color:rgba(245,164,0,.3)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:24px;padding:22px 26px;font-weight:600;font-size:16.5px;transition:color .15s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--amber-2)}
.faq-item summary::after{content:"+";font-family:var(--font-mono);color:var(--amber);font-size:20px;flex-shrink:0;transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .faq-a{padding:0 26px 24px;color:var(--muted);font-size:15px;max-width:720px}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:start}
.form{display:flex;flex-direction:column;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field label{display:block;font-family:var(--font-mono);font-size:12px;color:var(--faint);letter-spacing:.05em;margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;background:var(--glass);border:1px solid var(--line);border-radius:12px;padding:13px 16px;color:var(--text);font-family:var(--font-body);font-size:15px;transition:border-color .15s,box-shadow .15s;backdrop-filter:blur(6px)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(245,164,0,.12)}
.field textarea{min-height:140px;resize:vertical}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23a39d91' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.field option{background:#14120e;color:var(--text)}
.hp{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}
.form-note{font-size:13px;color:var(--faint)}
.alert{border-radius:12px;padding:16px 20px;font-size:14.5px;margin-bottom:24px;backdrop-filter:blur(6px)}
.alert-ok{background:rgba(95,184,120,.1);border:1px solid rgba(95,184,120,.35);color:var(--green)}
.alert-err{background:rgba(220,80,80,.1);border:1px solid rgba(220,80,80,.35);color:#e08080}
.contact-aside{position:sticky;top:96px;display:flex;flex-direction:column}
.ca-block{padding:28px 0;border-bottom:1px solid var(--line-soft)}
.ca-block:first-child{padding-top:6px}
.ca-block:last-child{border-bottom:none}
.ca-block h4,.ca-block .ca-h{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--faint);letter-spacing:.07em;text-transform:uppercase;margin-bottom:18px}
.ca-steps{display:flex;flex-direction:column;gap:14px}
.ca-step{display:flex;gap:14px;font-size:14px;color:var(--muted);align-items:flex-start}
.ca-step i{font-style:normal;font-family:var(--font-mono);font-size:11px;color:var(--amber);border:1px solid rgba(245,164,0,.3);background:var(--amber-soft);border-radius:7px;padding:3px 8px;flex-shrink:0;margin-top:1px}
.ca-step b{color:var(--text);font-weight:600}
.ca-link{display:block;font-size:17px;font-weight:600;letter-spacing:-.01em;margin-bottom:8px;transition:color .15s}
.ca-link:hover{color:var(--amber-2)}
.ca-hours{display:block;font-family:var(--font-mono);font-size:12px;color:var(--faint);margin-top:10px}
.ca-note{color:var(--faint);font-size:13px;margin-top:14px}

/* ---------- legal ---------- */
.legal{padding:80px 0 100px}
.legal h1{margin-bottom:18px}
.legal-meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px}
.legal-meta span{font-family:var(--font-mono);font-size:12px;color:var(--muted);border:1px solid var(--line-soft);background:var(--glass);border-radius:99px;padding:6px 14px}
.legal-toc{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:34px;padding-bottom:30px;border-bottom:1px solid var(--line-soft)}
.legal-toc h4{font-family:var(--font-mono);font-size:11.5px;font-weight:500;color:var(--faint);letter-spacing:.07em;text-transform:uppercase;margin-right:8px;width:100%;margin-bottom:6px}
.legal-toc a{font-family:var(--font-mono);font-size:12.5px;color:var(--muted);border:1px solid var(--line-soft);border-radius:99px;padding:6px 14px;transition:border-color .15s,color .15s;text-decoration:none}
.legal-toc a:hover{border-color:rgba(245,164,0,.45);color:var(--amber-2)}
.plain{padding:24px 28px;margin-bottom:30px;font-size:15.5px;color:var(--muted);
  background:linear-gradient(180deg,rgba(245,164,0,.07),rgba(245,164,0,.015)),linear-gradient(180deg,var(--glass-strong),var(--glass))!important}
.plain strong{color:var(--amber-2)}
.legal h2{font-size:23px;font-family:var(--font-body);font-weight:600;margin:48px 0 14px;scroll-margin-top:96px;display:flex;align-items:center;gap:12px}
.legal h2 i{font-family:var(--font-mono);font-style:normal;font-weight:500;font-size:12px;color:var(--amber);border:1px solid rgba(245,164,0,.3);background:var(--amber-soft);border-radius:8px;padding:4px 9px}
.legal p,.legal li{color:var(--muted);font-size:15.5px;margin-bottom:14px}
.legal p strong,.legal li strong{color:var(--text)}
.legal ul{padding-left:22px;margin-bottom:14px}
.legal li{margin-bottom:8px}
.legal a{color:var(--amber-2)}
.legal a:hover{text-decoration:underline}
.legal-contact{padding:28px 30px;margin:8px 0 24px}
.legal-contact h3{font-size:17px;font-weight:600;margin-bottom:18px}
.legal-contact-row{display:flex;gap:18px;padding:11px 0;border-bottom:1px solid var(--line-soft);font-size:14.5px}
.legal-contact-row:last-child{border-bottom:none}
.legal-contact-row b{font-family:var(--font-mono);font-size:12px;color:var(--faint);font-weight:500;width:110px;flex-shrink:0;text-transform:uppercase;letter-spacing:.05em;padding-top:2px}
.legal-contact-row span{color:var(--muted)}
.legal-note{font-size:13.5px!important;color:var(--faint)!important;border-top:1px solid var(--line-soft);padding-top:22px;margin-top:34px}

/* ---------- 404 ---------- */
.nf{min-height:62vh;display:grid;place-items:center;text-align:center;padding:96px 24px}
.nf .code{font-family:var(--font-mono);font-size:14px;color:var(--amber);margin-bottom:18px}
.nf h1{font-family:var(--font-display);font-weight:400;font-size:clamp(44px,6vw,76px);margin-bottom:16px}
.nf h1 em{font-style:italic;background:linear-gradient(115deg,var(--amber),#ffe9bd);-webkit-background-clip:text;background-clip:text;color:transparent}
.nf p{color:var(--muted);margin-bottom:32px}

/* ---------- cta (bento) ---------- */
.cta{padding:110px 0;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;bottom:-340px;left:50%;transform:translateX(-50%);width:820px;height:560px;background:radial-gradient(circle,rgba(245,164,0,.09),transparent 62%);pointer-events:none;filter:blur(10px)}
.cta-bento{display:grid;grid-template-columns:1.5fr 1fr 1fr;grid-template-rows:auto auto;gap:14px;position:relative;z-index:1}
.cta-cell{border-radius:18px;border:1px solid var(--line-soft);background:linear-gradient(180deg,var(--glass-strong),var(--glass));padding:30px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:border-color .2s,transform .2s}
.cta-cell:hover{border-color:rgba(245,164,0,.35);transform:translateY(-2px)}
.cta-cell-main{grid-row:span 2;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:40px 38px;
  background:linear-gradient(180deg,rgba(245,164,0,.08),rgba(245,164,0,.015)),linear-gradient(180deg,var(--glass-strong),var(--glass))}
.cta-cell-main h2{font-size:clamp(32px,3.6vw,46px);margin-bottom:12px}
.cta-cell-main p{color:var(--muted);font-size:15px;margin-bottom:28px;max-width:360px}
.cta-main-row{display:flex;gap:10px;flex-wrap:wrap}
.cta-stat b{display:block;font-family:var(--font-display);font-weight:400;font-size:38px;line-height:1;margin-bottom:10px;letter-spacing:-.01em}
.cta-stat span{font-family:var(--font-mono);font-size:11.5px;color:var(--faint)}
.cta-go{display:flex;flex-direction:column;justify-content:space-between;gap:18px;min-height:128px}
.cta-go b{display:block;font-size:15.5px;font-weight:600;margin-bottom:3px}
.cta-go div span{font-family:var(--font-mono);font-size:12px;color:var(--amber-2)}
.cta-arr{align-self:flex-end;width:36px;height:36px;border-radius:11px;display:grid;place-items:center;background:var(--amber-soft);border:1px solid rgba(245,164,0,.25);color:var(--amber);font-size:16px;transition:transform .2s}
.cta-go:hover .cta-arr{transform:translate(3px,-3px)}
/* compact button rows reused by 404 etc. */
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}
.cta-alt{font-family:var(--font-mono);font-size:13px;color:var(--faint)}
.cta-alt a{color:var(--amber-2)}
.cta-alt a:hover{text-decoration:underline}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line-soft);padding:68px 0 36px;background:linear-gradient(180deg,transparent,rgba(245,164,0,.018))}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr 1.2fr;gap:40px;margin-bottom:52px}
.foot-grid p{color:var(--muted);font-size:14px;max-width:300px;margin-top:14px}
footer h4,footer .foot-h{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--faint);letter-spacing:.07em;text-transform:uppercase;margin-bottom:16px}
footer ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:14px;color:var(--muted)}
footer ul a:hover{color:var(--amber-2)}
.foot-contact a{display:block;color:var(--text);font-size:14.5px;margin-bottom:8px}
.foot-contact a:hover{color:var(--amber-2)}
.foot-contact small{display:block;color:var(--faint);font-size:12.5px;margin:14px 0 16px}
.foot-bottom{border-top:1px solid var(--line-soft);padding-top:26px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--faint)}
.foot-bottom a{margin-left:20px}
.foot-bottom a:hover{color:var(--text)}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive / motion ---------- */
@media(prefers-reduced-motion:reduce){
  .ribbon-track{animation:none}
  .reveal{opacity:1;transform:none;transition:none}
  *{transition:none!important}
}
@media(max-width:980px){
  .band-in,.svc-detail,.about-grid,.contact-grid,.case-results{grid-template-columns:1fr}
  .svc-layout{grid-template-columns:1fr;gap:0}
  .sh-grid{grid-template-columns:1fr}
  .audit-grid,.audit-pitch{grid-template-columns:1fr}
  .rec-why{grid-template-columns:1fr}
  .audit-pitch-row{justify-content:flex-start}
  .audit-bar{border-radius:24px}
  .sh-math{position:static}
  .svc-rail{display:none}
  .svc-overview{grid-template-columns:repeat(2,1fr)}
  .perk-grid{grid-template-columns:repeat(2,1fr)}
  .includes{position:static}
  .contact-aside{position:static}
  .hero{padding:88px 0 72px}
  .hero-proof{flex-wrap:wrap;gap:18px 0;padding:20px 6px}
  .proof{padding:0 22px;flex:1 1 40%}
  .proof:nth-child(2){border-right:none}
  .bento{grid-template-columns:1fr}
  .svc.featured{grid-column:span 1}
  .work-grid,.case-grid{grid-template-columns:1fr}
  .case-top{align-items:flex-start}
  .case-metric{text-align:left}
  .rowp{grid-template-columns:1fr;gap:28px;padding:44px 0}
  .rowp:nth-child(even) .rowp-vis{order:0}
  .rowp-vis{height:210px}
  .steps{grid-template-columns:repeat(2,1fr)}
  .quote-grid,.values,.infra-grid{grid-template-columns:1fr}
  .cta-bento{grid-template-columns:1fr 1fr}
  .cta-cell-main{grid-column:span 2;grid-row:auto}
  .num-grid{grid-template-columns:repeat(2,1fr)}
  .founder-col{position:static}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px 40px}
  .foot-grid > div:first-child{grid-column:span 2}
  .nav-links{display:none}
  .nav-toggle{display:block}
  .nav-links.open{display:flex;position:absolute;top:74px;left:14px;right:14px;background:rgba(10,9,7,.97);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);flex-direction:column;padding:14px;border:1px solid var(--line);border-radius:22px;gap:2px;box-shadow:0 24px 60px rgba(0,0,0,.55)}
  /* uniform top-level rows */
  .nav-links.open > a,
  .nav-links.open .nav-tools-btn{display:flex;align-items:center;width:100%;font-size:17px;font-weight:500;padding:15px 16px;border-radius:13px;margin:0;line-height:1}
  .nav-links.open > a:not(:last-child){border-bottom:1px solid var(--line-soft)}
  .nav-links.open .nav-tools{border-bottom:1px solid var(--line-soft)}
  .nav-contact-btn{display:none}
  .nav-contact-mobile{display:flex!important}
  .nav-tools{width:100%}
  .nav-tools-btn{justify-content:flex-start;color:var(--muted)}
  .nav-tools-btn::after{content:"⌄";margin-left:auto;font-family:var(--font-mono);color:var(--amber);transition:transform .2s}
  .nav-tools.open .nav-tools-btn::after{transform:rotate(180deg)}
  .nav-tools-menu{position:static;min-width:0;background:none;border:none;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;padding:0;margin:0;
    max-height:0;overflow:hidden;opacity:0;visibility:hidden;transform:none;transition:max-height .25s ease,opacity .2s,padding .2s,margin .2s}
  .nav-tools.open .nav-tools-menu{max-height:200px;opacity:1;visibility:visible;padding:2px 0 8px 16px;margin-top:2px}
  .nav-tools-menu a{display:block;padding:10px 0}
  .nav-tools-menu a:hover{background:none}
  section{padding:76px 0}
}
@media(max-width:560px){
  .steps,.foot-grid,.form-row,.svc-overview,.perk-grid{grid-template-columns:1fr}
  .cta-bento{grid-template-columns:1fr}
  .cta-cell-main{grid-column:span 1}
  .proof{flex:1 1 40%;padding:8px 14px;border-right:none}
  .nav{top:8px;padding:0 10px}
}

/* a11y: retagged headings keep their styled look, not browser defaults */
.foot-h,.rail-label,.ca-h,.founder-name,.proj-name,.post-title{margin-top:0}
h2.foot-h,h2.founder-name,h2.proj-name,h2.post-title{font-weight:inherit}
.stack-card h3,.sh-math h3{margin-top:0}
