/* ====== Spectral website UI kit — component styles (Dusk) ====== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--ink-900);color:var(--cream);font-family:var(--font-sans);
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
.wrap{max-width:1200px;margin:0 auto;padding:0 40px}
.eyebrow{display:inline-flex;align-items:center;gap:13px;font-family:var(--font-mono);font-size:12px;font-weight:500;
  letter-spacing:0.2em;text-transform:uppercase;color:var(--taupe);white-space:nowrap}
.eyebrow .dash{width:28px;height:3px;border-radius:2px;background:var(--grad-dusk-h)}
.grad{background:var(--grad-dusk-h);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent}

/* ---------- buttons ---------- */
.btn{font-size:15px;font-weight:600;border:0;cursor:pointer;border-radius:var(--r-pill);
  padding:13px 24px;transition:all var(--dur) var(--ease-out);display:inline-flex;
  align-items:center;gap:9px;white-space:nowrap}
.btn-primary{background:var(--grad-dusk);color:#2a130b;box-shadow:0 8px 28px -10px rgba(253,120,80,.6)}
.btn-primary:hover{filter:brightness(1.07);transform:translateY(-1px)}
.btn-primary:active{transform:translateY(0);filter:brightness(.98)}
.btn-secondary{background:var(--glass-fill-strong);color:var(--cream);border:1px solid var(--glass-border)}
.btn-secondary:hover{border-color:var(--amber);background:var(--glass-fill)}
.btn-ghost{background:transparent;color:var(--cream);padding-left:4px;padding-right:4px}
.btn-ghost:hover{color:var(--amber)}
.btn-ghost .arr{color:var(--coral);transition:transform var(--dur) var(--ease-out)}
.btn-ghost:hover .arr{transform:translateX(4px)}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:all var(--dur) var(--ease-out)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:104px}
.nav.scrolled{background:rgba(16,11,9,0.72);backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--glass-border-soft)}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{font-size:14px;font-weight:500;color:var(--cream-dim);transition:color var(--dur)}
.nav-links a:hover{color:var(--cream)}
.brand{flex:none}

/* ---------- hero ---------- */
.hero{position:relative;padding-top:150px;padding-bottom:110px;overflow:hidden}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-glow{position:absolute;top:-220px;right:-160px;width:900px;height:900px;border-radius:50%;
  background:radial-gradient(circle,rgba(253,140,89,.30) 0%,rgba(253,97,86,.10) 38%,rgba(16,11,9,0) 70%)}
.ring{position:absolute;border-radius:50%;border:1px solid rgba(253,160,110,.16);
  right:-360px;top:120px}
.ring.r1{width:620px;height:620px}
.ring.r2{width:920px;height:920px;border-color:rgba(253,140,89,.10)}
.ring.r3{width:1240px;height:1240px;border-color:rgba(253,140,89,.055)}
.hero-grid{position:relative;display:grid;grid-template-columns:1.35fr 1fr;gap:60px;align-items:center}
.hero h1{font-family:var(--font-display);font-weight:800;font-size:64px;line-height:1.02;
  letter-spacing:-0.035em;margin:26px 0 0}
.hero .underline{position:relative;display:inline-block;padding-bottom:8px}
.hero .underline::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;
  border-radius:2px;background:var(--grad-dusk-h)}
.hero-sub{font-size:19px;line-height:1.6;color:var(--cream-dim);max-width:520px;margin:26px 0 0}
.hero-actions{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}

/* track-record panel */
.panel{position:relative;border-radius:var(--r-xl);background:var(--glass-fill-strong);
  border:1px solid var(--glass-border);box-shadow:var(--sh-panel);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:26px 30px}
.panel-h{font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--taupe);margin:0 0 18px}
.stat{display:flex;align-items:baseline;gap:18px;padding:15px 0;border-top:1px solid var(--glass-border-soft)}
.stat:first-of-type{border-top:0}
.stat .num{font-family:var(--font-display);font-size:32px;font-weight:800;letter-spacing:-0.025em;
  width:128px;flex:none}
.stat .desc{font-size:14px;color:var(--taupe);line-height:1.4}

/* ---------- section frame ---------- */
.section{position:relative;padding:96px 0}
.section-head{max-width:680px;margin-bottom:52px}
.section-head h2{font-family:var(--font-display);font-weight:700;font-size:40px;line-height:1.08;
  letter-spacing:-0.025em;margin:18px 0 0}
.section-head p{font-size:18px;line-height:1.6;color:var(--cream-dim);margin:18px 0 0}

/* ---------- service cards ---------- */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.card{position:relative;border-radius:var(--r-lg);background:var(--glass-fill);
  border:1px solid var(--glass-border-soft);padding:30px 30px 32px;
  transition:all var(--dur) var(--ease-out);overflow:hidden}
.card:hover{border-color:var(--glass-border);background:var(--glass-fill-strong);transform:translateY(-2px)}
.card .ic{width:42px;height:42px;border-radius:11px;background:var(--accent-quiet);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--amber)}
.card .ic svg{width:21px;height:21px}
.card h3{font-family:var(--font-display);font-size:20px;font-weight:700;margin:0 0 10px;letter-spacing:-0.02em}
.card p{font-size:15px;line-height:1.6;color:var(--taupe);margin:0}
.card .idx{position:absolute;top:24px;right:28px;font-family:var(--font-mono);
  font-size:12px;color:var(--taupe-dim)}

/* ---------- process ---------- */
.streams{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:32px}
.stream{border-radius:var(--r-lg);border:1px solid var(--glass-border-soft);
  background:var(--glass-fill);padding:28px 30px}
.stream .tag{font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--amber)}
.stream h3{font-family:var(--font-display);font-size:25px;font-weight:700;margin:12px 0 6px;letter-spacing:-0.025em}
.stream .role{font-size:14px;color:var(--taupe);margin:0 0 18px}
.stream ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.stream li{display:flex;gap:12px;font-size:15px;line-height:1.5;color:var(--cream-dim)}
.stream li::before{content:"";flex:none;width:18px;height:2px;border-radius:2px;
  background:var(--grad-dusk-h);margin-top:11px}
.phases{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;border-radius:var(--r-lg);
  overflow:hidden;border:1px solid var(--glass-border-soft);background:var(--glass-border-soft)}
.phase{background:var(--ink-800);padding:22px 26px}
.phase .wk{font-family:var(--font-mono);font-size:12px;color:var(--amber);letter-spacing:0.06em}
.phase .nm{font-family:var(--font-display);font-size:17px;font-weight:700;margin:8px 0 6px;letter-spacing:-0.02em}
.phase .mt{font-size:13px;color:var(--taupe);line-height:1.5}

/* ---------- case study ---------- */
.work{display:grid;grid-template-columns:1fr 1.1fr;gap:50px;align-items:center}
.work-card{border-radius:var(--r-xl);border:1px solid var(--glass-border-soft);
  background:var(--glass-fill);padding:46px;display:flex;align-items:center;
  justify-content:center;min-height:240px;position:relative;overflow:hidden}
.work-card .gl{position:absolute;inset:0;background:var(--glow-dusk);opacity:.7}
.work-card img{position:relative;max-width:230px;width:100%;height:auto;
  filter:drop-shadow(0 12px 30px rgba(0,0,0,.45))}
.work-metrics{display:flex;gap:40px;margin:24px 0 28px}
.work-metrics .m .v{font-family:var(--font-display);font-size:36px;font-weight:800;letter-spacing:-0.025em}
.work-metrics .m .l{font-size:13px;color:var(--taupe);margin-top:4px}
.quote{font-family:var(--font-sans);font-size:22px;font-weight:500;line-height:1.5;
  color:var(--cream);margin:0 0 18px;letter-spacing:-0.005em}

/* ---------- CTA ---------- */
.cta{position:relative;text-align:center;padding:110px 0;overflow:hidden}
.cta-glow{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:1000px;height:600px;background:radial-gradient(closest-side,rgba(253,120,80,.20),rgba(16,11,9,0));
  pointer-events:none}
.cta h2{position:relative;font-family:var(--font-display);font-weight:800;font-size:52px;
  line-height:1.06;letter-spacing:-0.03em;margin:0 auto;max-width:760px}
.cta .sub{position:relative;font-size:18px;color:var(--cream-dim);margin:22px auto 0;max-width:520px}
.cta-actions{position:relative;display:flex;gap:14px;justify-content:center;margin-top:38px;flex-wrap:wrap}

/* inline access form */
.access{position:relative;max-width:440px;margin:34px auto 0;display:flex;gap:10px;
  flex-direction:column}
.access.hidden{display:none}
.access .field{display:flex;gap:10px}
/* min-width:0 lets the email input shrink so the Request button never
   overflows the row on narrow phones (flex items default to min-width:auto) */
.access input{flex:1;min-width:0;background:var(--ink-800);border:1px solid var(--ink-500);
  border-radius:var(--r-md);padding:13px 15px;color:var(--cream);font-size:15px;font-family:inherit}
.access input::placeholder{color:var(--taupe-dim)}
.access input:focus{outline:none;border-color:var(--ember);box-shadow:0 0 0 3px var(--accent-quiet)}
.access .ok{font-size:14px;color:var(--amber);padding-top:6px}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--glass-border-soft);padding:56px 0 48px}
.footer-grid{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap}
.footer .contact a{display:block;color:var(--cream-dim);font-size:15px;margin-top:10px;transition:color var(--dur)}
.footer .contact a:hover{color:var(--amber)}
.footer .legal{font-size:13px;color:var(--taupe-dim);margin-top:30px}

@media(max-width:900px){
  .hero-grid,.work{grid-template-columns:1fr}
  .cards,.streams,.phases{grid-template-columns:1fr}
  .hero h1{font-size:48px}
  .nav-links{display:none}
  .wrap{padding:0 24px}
}
