/* ================================================================
   CONSPIRE LANDING PAGE — Technical Swiss / Drafting OS
   Design tokens: Swiss precision. Motion: Showroom soul.
   ================================================================ */

:root {
  --ink: #000000;
  --paper: #FFFFFF;
  --action: #FF4500;
  --select: #66FFCC;
  --warning: #FFD400;
  --error: #FF0033;
  --success: #00CC66;
  --muted-ink: rgba(0,0,0,0.60);
  --faint-ink: rgba(0,0,0,0.35);
  --grid-color: rgba(157,180,191,0.4);
  --grid-strong: rgba(0,0,0,0.16);
  --bg-secondary: #FAFAFA;
  --bg-tertiary: #F5F5F5;
  --svc-red: #FF0033;
  --svc-orange: #FF4500;
  --svc-yellow: #FFD400;
  --svc-green: #00CC66;
  --font-ui: 'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-tech: 'Space Mono',monospace;
  --ts-xs: 10px; --ts-sm: 12px; --ts-base: 15px; --ts-md: 18px;
  --ts-lg: 22px; --ts-xl: 28px; --ts-2xl: 36px;
  --ts-hero: clamp(48px,10vw,80px);
  --ts-section: clamp(32px,6vw,56px);
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:20px;
  --sp-6:24px; --sp-7:32px; --sp-8:40px; --sp-9:60px; --sp-10:80px;
  --stroke-1:1px; --stroke-2:2px; --stroke-3:3px;
  --r-0:0; --r-2:4px; --r-3:8px; --r-4:12px;
  --shadow-sm: 4px 4px 0 var(--ink);
  --shadow-md: 6px 6px 0 var(--ink);
  --shadow-lg: 8px 8px 0 var(--ink);
  --spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease: cubic-bezier(0.2,0,0.2,1);
  --ease-in: cubic-bezier(0,0,0.2,1);
  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --header-h: 64px;
  --status-h: 20px;
  --max-w: 1200px;
  --grid-sp: 17px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-ui);font-size:var(--ts-base);line-height:1.5;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;overflow-x:hidden}

/* ── Drafting Grid — draws in on load ── */
body::after{content:'';position:fixed;inset:0;background-image:
  repeating-linear-gradient(0deg,transparent,transparent calc(var(--grid-sp) - 1px),var(--grid-color) calc(var(--grid-sp) - 1px),var(--grid-color) var(--grid-sp)),
  repeating-linear-gradient(90deg,transparent,transparent calc(var(--grid-sp) - 1px),var(--grid-color) calc(var(--grid-sp) - 1px),var(--grid-color) var(--grid-sp));
  pointer-events:none;z-index:0;
  background-size:0% 0%;
  animation:grid-draw-in 1s cubic-bezier(0.16,1,0.3,1) 0.2s forwards;
}
@keyframes grid-draw-in{
  0%{background-size:0% 0%}
  40%{background-size:100% 30%}
  100%{background-size:100% 100%}
}
body>*{position:relative;z-index:1}

/* ── Registration Marks — calibrate on load ── */
.reg-mark{position:fixed;width:16px;height:16px;z-index:2;pointer-events:none;opacity:0;transform:scale(0.5);animation:reg-calibrate 0.5s var(--spring) 1s forwards}
.reg-mark::before,.reg-mark::after{content:'';position:absolute;background:var(--grid-strong)}
.reg-mark::before{width:16px;height:1px;top:50%;left:0;transform:translateY(-50%)}
.reg-mark::after{width:1px;height:16px;left:50%;top:0;transform:translateX(-50%)}
.reg-tl{top:28px;left:24px;transform-origin:top left}
.reg-tr{top:28px;right:24px;transform-origin:top right;animation-delay:1.1s}
.reg-bl{bottom:24px;left:24px;transform-origin:bottom left;animation-delay:1.2s}
.reg-br{bottom:24px;right:24px;transform-origin:bottom right;animation-delay:1.3s}
@keyframes reg-calibrate{
  0%{opacity:0;transform:scale(0.5)}
  60%{opacity:1;transform:scale(1.2)}
  100%{opacity:1;transform:scale(1)}
}

/* ── Scroll Reveal — spring entrance ── */
.mono-label{font-family:var(--font-tech);font-size:var(--ts-sm);letter-spacing:2px;text-transform:uppercase;color:var(--muted-ink)}
.sec-wrap{max-width:var(--max-w);margin:0 auto;padding:0 var(--sp-8)}
@media(max-width:768px){.sec-wrap{padding:0 var(--sp-6)}}

/* Reveal with spring + blur sharpen */
.reveal{opacity:0;transform:translateY(30px);filter:blur(4px);transition:opacity 0.6s var(--ease-out-expo),transform 0.7s var(--spring),filter 0.5s ease}
.reveal.visible{opacity:1;transform:translateY(0);filter:blur(0)}

/* Eyebrow labels wipe in from left */
.reveal .mono-label{opacity:0;clip-path:inset(0 100% 0 0);transition:opacity 0.4s ease 0.2s,clip-path 0.6s var(--ease-out-expo) 0.2s}
.reveal.visible .mono-label{opacity:1;clip-path:inset(0 0% 0 0)}

/* Staggered children */
.reveal.stagger-1{transition-delay:0.08s}
.reveal.stagger-2{transition-delay:0.16s}
.reveal.stagger-3{transition-delay:0.24s}
.reveal.stagger-4{transition-delay:0.32s}

/* ═══ STATUS BAR — ambient terminal flicker ═══ */
.status-bar{position:fixed;top:0;left:0;width:100%;height:var(--status-h);z-index:101;display:flex;align-items:center;justify-content:center;background:var(--ink);font-family:var(--font-tech);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.6);overflow:hidden}

/* Scroll progress bar */
.scroll-progress{position:absolute;left:0;top:0;height:100%;width:0%;background:var(--action);opacity:0.4;transition:none;pointer-events:none}

/* Terminal flicker */
.status-bar .status-text{animation:terminal-flicker 4s ease-in-out infinite}
@keyframes terminal-flicker{
  0%,92%,96%,100%{opacity:.6}
  93%{opacity:.3}
  95%{opacity:.8}
}

/* ═══ HEADER — border solidifies on scroll ═══ */
.header{position:fixed;top:var(--status-h);left:0;width:100%;height:var(--header-h);z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-8);background:rgba(255,255,255,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:var(--stroke-1) solid var(--grid-strong);transition:border-color 0.3s ease}
.header.scrolled{border-bottom-color:var(--ink)}
.header-logo{display:flex;align-items:baseline;text-decoration:none;gap:2px}
.header-logo svg{height:24px;width:auto;fill:var(--ink)}
.logo-ai{font-family:var(--font-ui);font-size:10px;font-weight:700;color:var(--ink);vertical-align:super;line-height:1}
.header-nav{display:flex;gap:var(--sp-7);align-items:center}
.header-nav a{font-family:var(--font-tech);font-size:var(--ts-sm);letter-spacing:2px;text-transform:uppercase;color:var(--muted-ink);text-decoration:none;transition:color 0.2s ease;padding:var(--sp-2) 0}
.header-nav a:hover{color:var(--ink)}
@media(max-width:768px){.header{padding:0 var(--sp-6)}.header-nav a:not(.nav-cta){display:none}}

/* ═══ HERO — cinematic power-on entrance ═══ */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:calc(var(--header-h) + var(--status-h) + var(--sp-10)) var(--sp-8) var(--sp-10);position:relative}
.hero-inner{max-width:var(--max-w);margin:0 auto;width:100%}

/* Hero cursor spotlight */
.hero-spotlight{position:absolute;inset:0;pointer-events:none;z-index:1;opacity:0;transition:opacity 0.3s ease}
.hero:hover .hero-spotlight{opacity:1}

/* Color blocks — spring fall-in with random rotation */
.hero-blocks{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-block{position:absolute;border:var(--stroke-3) solid var(--ink);border-radius:var(--r-3);
  opacity:0;transform:translateY(-120%) rotate(-15deg) scale(0.8);
  will-change:transform,opacity}

body.loaded .hb-1{animation:block-fall 1.2s var(--spring) 0.3s forwards}
body.loaded .hb-2{animation:block-fall 1.2s var(--spring) 0.45s forwards}
body.loaded .hb-3{animation:block-fall 1.2s var(--spring) 0.6s forwards}
body.loaded .hb-4{animation:block-fall 1.2s var(--spring) 0.75s forwards}

@keyframes block-fall{
  0%{opacity:0;transform:translateY(-120%) rotate(-15deg) scale(0.8)}
  60%{opacity:1;transform:translateY(8%) rotate(3deg) scale(1.02)}
  80%{transform:translateY(-2%) rotate(-1deg) scale(0.99)}
  100%{opacity:1;transform:translateY(0) rotate(var(--rot,0deg)) scale(1)}
}

.hb-1{width:200px;height:200px;background:var(--svc-red);top:18%;right:8%;box-shadow:var(--shadow-md);--rot:2deg}
.hb-2{width:80px;height:240px;background:var(--svc-yellow);top:30%;right:24%;box-shadow:var(--shadow-sm);--rot:-1deg}
.hb-3{width:140px;height:140px;background:var(--svc-green);bottom:20%;right:5%;box-shadow:var(--shadow-md);--rot:3deg}
.hb-4{width:60px;height:60px;background:var(--svc-orange);top:24%;right:38%;box-shadow:var(--shadow-sm);--rot:-2deg}
@media(max-width:900px){.hero-block{opacity:.35!important}.hb-1{width:120px;height:120px}.hb-2{width:50px;height:140px}.hb-3{width:80px;height:80px}.hb-4{width:40px;height:40px}}

/* Hero content entrance */
.hero-content{position:relative;z-index:2;max-width:720px}
.hero-logo{margin-bottom:var(--sp-8);display:flex;align-items:baseline;gap:4px;
  opacity:0;transform:scale(0.85);filter:blur(12px)}
body.loaded .hero-logo{animation:logo-sharpen 0.8s var(--ease-out-expo) 0.6s forwards}
@keyframes logo-sharpen{
  0%{opacity:0;transform:scale(0.85);filter:blur(12px)}
  50%{filter:blur(3px)}
  100%{opacity:1;transform:scale(1);filter:blur(0)}
}

.hero-logo svg{width:100%;max-width:600px;height:auto;fill:var(--ink)}
.logo-ai-hero{font-family:var(--font-ui);font-size:clamp(16px,3vw,24px);font-weight:800;color:var(--ink);align-self:flex-start;margin-top:.1em}

.hero-tagline{font-size:var(--ts-md);font-weight:500;line-height:1.7;color:var(--muted-ink);max-width:520px;
  opacity:0;transform:translateY(25px)}
body.loaded .hero-tagline{animation:spring-up 0.7s var(--spring) 1s forwards}

.hero-tagline strong{color:var(--ink);font-weight:700}

.hero-cta{display:inline-flex;align-items:center;gap:var(--sp-2);margin-top:var(--sp-8);padding:var(--sp-3) var(--sp-6);font-family:var(--font-tech);font-size:var(--ts-sm);letter-spacing:2px;text-transform:uppercase;color:var(--paper);text-decoration:none;background:var(--action);border:var(--stroke-3) solid var(--ink);border-radius:var(--r-3);box-shadow:var(--shadow-md);min-height:52px;
  opacity:0;transform:translateY(20px) scale(0.95);
  transition:transform 0.15s ease,box-shadow 0.15s ease}
body.loaded .hero-cta{animation:cta-pop 0.6s var(--spring) 1.3s forwards}

/* Button 3D press */
.hero-cta:hover{transform:translate(3px,3px);box-shadow:3px 3px 0 var(--ink)}
.hero-cta:active{transform:translate(6px,6px) perspective(600px) rotateX(2deg);box-shadow:0 0 0 var(--ink);transition:transform 0.05s ease}

@keyframes spring-up{
  0%{opacity:0;transform:translateY(25px)}
  60%{transform:translateY(-4px)}
  100%{opacity:1;transform:translateY(0)}
}
@keyframes cta-pop{
  0%{opacity:0;transform:translateY(20px) scale(0.95)}
  50%{transform:translateY(-5px) scale(1.05)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}

.hero-company{margin-top:var(--sp-7);font-family:var(--font-tech);font-size:var(--ts-xs);letter-spacing:1px;color:var(--faint-ink)}
@media(max-width:768px){.hero{padding-left:var(--sp-6);padding-right:var(--sp-6)}}

/* ═══ COLOR STRIP — wave interaction ═══ */
.color-strip{display:flex;height:var(--sp-5);border-top:var(--stroke-1) solid var(--ink);border-bottom:var(--stroke-1) solid var(--ink)}
.color-strip>div{flex:1;transition:flex 0.4s var(--spring),transform 0.3s var(--spring)}
.color-strip>div:hover{flex:2.5;transform:scaleY(1.15)}
/* Adjacent segments compress */
.color-strip>div:hover+div{flex:0.8}

/* ═══ SERVICES — spring hover + staggered reveal ═══ */
.services{padding:var(--sp-10) 0}
.services-hdr{margin-bottom:var(--sp-9)}
.services-hdr h2{font-size:var(--ts-section);font-weight:900;line-height:1.1;letter-spacing:-.03em;text-transform:uppercase;margin-top:var(--sp-3)}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-6)}
@media(max-width:900px){.svc-grid{grid-template-columns:1fr}}

.svc-card{padding:var(--sp-6);border:var(--stroke-3) solid var(--ink);border-radius:var(--r-3);background:var(--paper);box-shadow:var(--shadow-md);cursor:pointer;
  transition:transform 0.35s var(--spring),box-shadow 0.35s var(--spring);
  overflow:hidden;position:relative}

/* Color bleed left border on hover */
.svc-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;transition:width 0.3s var(--ease-out-expo);border-radius:var(--r-3) 0 0 var(--r-3)}
.svc-card[data-color="red"]::before{background:var(--svc-red)}
.svc-card[data-color="green"]::before{background:var(--svc-green)}
.svc-card[data-color="orange"]::before{background:var(--svc-orange)}
.svc-card[data-color="yellow"]::before{background:var(--svc-yellow)}
.svc-card:hover::before{width:5px}

/* Spring lift on hover */
.svc-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:12px 12px 2px rgba(0,0,0,0.8)}
.svc-card:active{transform:translateY(-2px) scale(0.99);box-shadow:4px 4px 0 var(--ink);transition:transform 0.08s ease}
.svc-card.expanded{transform:none;box-shadow:var(--shadow-md)}
.svc-card.expanded:hover{transform:none;box-shadow:var(--shadow-md)}
.svc-card.expanded::before{width:5px}

.svc-hdr{display:flex;align-items:center;gap:var(--sp-4);margin-bottom:var(--sp-4)}
.svc-clr{width:48px;height:48px;border:var(--stroke-2) solid var(--ink);border-radius:var(--r-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:transform 0.4s var(--spring)}
.svc-card:hover .svc-clr{transform:rotate(5deg) scale(1.05)}
.svc-clr img{width:28px;height:28px}
.svc-card[data-color="red"] .svc-clr{background:var(--svc-red)}
.svc-card[data-color="green"] .svc-clr{background:var(--svc-green)}
.svc-card[data-color="orange"] .svc-clr{background:var(--svc-orange)}
.svc-card[data-color="yellow"] .svc-clr{background:var(--svc-yellow)}
.svc-title{font-size:var(--ts-lg);font-weight:900;text-transform:uppercase;letter-spacing:-.02em}
.svc-desc{font-size:var(--ts-base);line-height:1.6;color:var(--muted-ink);margin-bottom:var(--sp-4)}
.svc-trigger{font-family:var(--font-tech);font-size:var(--ts-xs);letter-spacing:2px;text-transform:uppercase;color:var(--faint-ink);transition:color 0.2s ease}
.svc-card:hover .svc-trigger{color:var(--action)}

/* TEMPO merge — spring expand with bounce */
.svc-tempo{margin-top:0;border-top:0 solid transparent;padding-top:0;max-height:0;overflow:hidden;opacity:0;
  transition:max-height 0.5s var(--ease-out-expo),opacity 0.4s ease 0.1s,margin-top 0.5s var(--ease-out-expo),padding-top 0.5s var(--ease-out-expo),border-top-width 0.5s ease}
.svc-card.expanded .svc-tempo{max-height:400px;opacity:1;margin-top:var(--sp-5);padding-top:var(--sp-5);border-top:var(--stroke-1) solid var(--grid-strong)}

.tw{border:var(--stroke-3) solid var(--ink);border-radius:var(--r-3);background:var(--bg-tertiary);overflow:hidden;
  transform:translateY(10px);opacity:0;transition:transform 0.5s var(--spring) 0.15s,opacity 0.4s ease 0.15s}
.svc-card.expanded .tw{transform:translateY(0);opacity:1}

.tw-hdr{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);background:var(--paper);border-bottom:var(--stroke-2) solid var(--ink)}
.tw-dot{width:10px;height:10px;border-radius:50%;border:var(--stroke-1) solid var(--ink)}
.tw-dot-r{background:var(--svc-red)}.tw-dot-y{background:var(--svc-yellow)}.tw-dot-g{background:var(--svc-green)}
.tw-title{margin-left:auto;font-family:var(--font-tech);font-size:var(--ts-xs);letter-spacing:2px;text-transform:uppercase;color:var(--faint-ink)}

/* TEMPO title cursor blink — alive and listening */
.tw-title::after{content:'_';animation:blink .8s step-end infinite;color:var(--action)}

.tw-body{padding:var(--sp-5);min-height:120px}

/* Message indicator bars */
.msg{display:flex;gap:var(--sp-3);margin-bottom:var(--sp-4)}
.msg:last-child{margin-bottom:0}
.msg .bar{width:4px;border-radius:2px;flex-shrink:0;align-self:stretch;transition:height 0.3s ease}
.msg.user .bar{background:var(--grid-strong)}
.msg.agent .bar{background:var(--action)}

/* Indicator bar grows with content — liquid fill */
.msg.agent .bar{transform-origin:bottom;transform:scaleY(0);transition:transform 1.5s var(--ease-out-expo)}
.svc-card.expanded .msg.agent .bar{transform:scaleY(1)}

.msg .txt{font-size:var(--ts-sm);line-height:1.6}
.msg.user .txt{color:var(--muted-ink)}
.msg.agent .txt{color:var(--ink)}
.typing-cursor{display:inline-block;width:2px;height:1em;background:var(--action);margin-left:2px;animation:blink .8s step-end infinite;vertical-align:text-bottom}
@keyframes blink{0%,50%{opacity:1}51%,100%{opacity:0}}

/* Agent bar done-glow */
@keyframes bar-glow{
  0%,100%{box-shadow:none}
  50%{box-shadow:0 0 8px var(--action)}
}

/* ═══ TRANSFORMATION — cinematic crossfade ═══ */
.transform-sec{padding:var(--sp-10) 0}
.transform-hdr{text-align:center;margin-bottom:var(--sp-9)}
.transform-hdr h2{font-size:var(--ts-section);font-weight:900;line-height:1.15;letter-spacing:-.02em;margin-top:var(--sp-3)}
.tf-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--sp-6);align-items:stretch;max-width:900px;margin:0 auto}

.tf-card{padding:var(--sp-6);border:var(--stroke-3) solid var(--ink);border-radius:var(--r-3);box-shadow:var(--shadow-md);
  transition:box-shadow 0.4s var(--spring),transform 0.4s var(--spring)}
.tf-card:hover{transform:translateY(-4px);box-shadow:10px 10px 2px rgba(0,0,0,0.7)}

/* Before card — red overlay fades away */
.tf-before{background:rgba(255,0,51,.06);position:relative;overflow:hidden}
.tf-before::after{content:'';position:absolute;inset:0;background:rgba(255,0,51,0.08);
  opacity:1;transition:opacity 0.8s ease}
.tf-before.visible::after{animation:red-fade 1.5s ease 0.3s forwards}
@keyframes red-fade{to{opacity:0}}

/* After card — green glow pulse on enter */
.tf-after{background:rgba(0,204,102,.06)}
.tf-after.visible{animation:green-glow-pulse 1.5s ease 0.5s}
@keyframes green-glow-pulse{
  0%{box-shadow:var(--shadow-md)}
  40%{box-shadow:8px 8px 0 var(--ink),0 0 20px rgba(0,204,102,0.3)}
  100%{box-shadow:var(--shadow-md)}
}

.tf-label{font-family:var(--font-tech);font-size:var(--ts-sm);letter-spacing:2px;text-transform:uppercase;margin-bottom:var(--sp-5)}
.tf-before .tf-label{color:var(--svc-red)}.tf-after .tf-label{color:var(--svc-green)}
.tf-list{list-style:none;display:flex;flex-direction:column;gap:var(--sp-3)}
.tf-list li{font-size:var(--ts-base);line-height:1.5;padding-left:var(--sp-5);position:relative}
.tf-before .tf-list li::before{content:'\2717';position:absolute;left:0;color:var(--svc-red);font-weight:700}
.tf-after .tf-list li::before{content:'\2713';position:absolute;left:0;color:var(--svc-green);font-weight:700}

/* Arrow breathes */
.tf-arrow{display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:300;color:var(--faint-ink);
  animation:arrow-breathe 2.5s ease-in-out infinite}
@keyframes arrow-breathe{
  0%,100%{transform:scale(1);opacity:0.35}
  50%{transform:scale(1.15);opacity:0.7}
}
@media(max-width:768px){.tf-grid{grid-template-columns:1fr;gap:var(--sp-4)}.tf-arrow{transform:rotate(90deg);padding:var(--sp-2) 0;font-size:28px;animation:none}}

/* ═══ MARQUEE — smooth deceleration ═══ */
.marquee-sec{padding:var(--sp-5) 0;background:var(--action);border-top:var(--stroke-2) solid var(--ink);border-bottom:var(--stroke-2) solid var(--ink);overflow:hidden}
.marquee-track{display:flex;animation:marquee 25s linear infinite;transition:animation-duration 0.8s ease}
.marquee-sec:hover .marquee-track{animation-duration:80s}
.marquee-ct{display:flex;align-items:center;gap:var(--sp-8);padding-right:var(--sp-8);white-space:nowrap}
.marquee-txt{font-size:var(--ts-lg);font-weight:700;letter-spacing:-.02em;color:var(--paper)}
.marquee-txt a{color:inherit;text-decoration:none}
.marquee-star{font-size:var(--ts-lg);color:var(--warning);transition:transform 0.3s var(--spring)}
.marquee-sec:hover .marquee-star{transform:rotate(72deg) scale(1.2)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══ WAITLIST — spring interactions ═══ */
.waitlist-sec{padding:var(--sp-10) 0}
.waitlist-inner{max-width:600px}
.waitlist-sec h2{font-size:var(--ts-section);font-weight:900;line-height:1;letter-spacing:-.04em;text-transform:uppercase;margin-bottom:var(--sp-3)}
.wl-sub{font-size:var(--ts-base);color:var(--muted-ink);margin-bottom:var(--sp-7)}
.wl-form{display:flex;gap:var(--sp-3);margin-bottom:var(--sp-5)}
.wl-input{flex:1;font-family:var(--font-ui);font-size:var(--ts-base);padding:var(--sp-3) var(--sp-4);border:var(--stroke-2) solid var(--ink);border-radius:var(--r-2);background:var(--paper);color:var(--ink);outline:none;min-height:48px;transition:border-color 0.2s ease,box-shadow 0.3s var(--spring)}
.wl-input:focus{border-color:var(--action);box-shadow:0 0 0 3px rgba(255,69,0,0.15)}
.wl-input::placeholder{color:var(--faint-ink)}

/* Submit button — 3D press + stamp success */
.wl-btn{font-family:var(--font-tech);font-size:var(--ts-sm);letter-spacing:2px;text-transform:uppercase;padding:var(--sp-3) var(--sp-6);background:var(--success);color:var(--ink);border:var(--stroke-3) solid var(--ink);border-radius:var(--r-2);box-shadow:var(--shadow-sm);cursor:pointer;min-height:48px;
  transition:transform 0.2s var(--spring),box-shadow 0.2s var(--spring),background 0.3s ease}
.wl-btn:hover{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}
.wl-btn:active{transform:translate(4px,4px) perspective(600px) rotateX(2deg);box-shadow:0 0 0 var(--ink);transition:transform 0.05s ease}

/* Stamp animation class added by JS */
.wl-btn.stamped{animation:stamp 0.4s var(--spring)}
@keyframes stamp{
  0%{transform:scale(1)}
  30%{transform:scale(0.9)}
  60%{transform:scale(1.08)}
  100%{transform:scale(1)}
}

@media(max-width:600px){.wl-form{flex-direction:column}}

/* Persistent CTA — spring entrance */
.pcta{position:fixed;bottom:var(--sp-6);right:var(--sp-6);z-index:90;opacity:0;transform:translateY(30px) scale(0.9);pointer-events:none;
  transition:opacity 0.4s ease,transform 0.5s var(--spring)}
.pcta.visible{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.pcta a{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-5);font-family:var(--font-tech);font-size:var(--ts-sm);letter-spacing:2px;text-transform:uppercase;text-decoration:none;color:var(--paper);background:var(--action);border:var(--stroke-3) solid var(--ink);border-radius:var(--r-3);box-shadow:var(--shadow-md);min-height:44px;
  transition:transform 0.2s var(--spring),box-shadow 0.2s var(--spring)}
.pcta a:hover{transform:translate(3px,3px);box-shadow:3px 3px 0 var(--ink)}
.pcta a:active{transform:translate(6px,6px) perspective(600px) rotateX(2deg);box-shadow:0 0 0 var(--ink)}

/* ═══ FOOTER ═══ */
.footer{padding:var(--sp-10) 0 var(--sp-8);border-top:var(--stroke-2) solid var(--ink);background:var(--bg-secondary)}
.footer-logo{display:flex;align-items:baseline;gap:2px;margin-bottom:var(--sp-8)}
.footer-logo svg{height:28px;width:auto;fill:var(--ink)}
.footer-hl{font-size:var(--ts-section);font-weight:900;line-height:1;letter-spacing:-.04em;margin-bottom:var(--sp-8)}
.footer-hl .pop{color:var(--action)}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--sp-7);padding-top:var(--sp-7);border-top:var(--stroke-1) solid var(--grid-strong)}
.footer-col h4{font-family:var(--font-tech);font-size:var(--ts-sm);letter-spacing:2px;text-transform:uppercase;color:var(--muted-ink);margin-bottom:var(--sp-4)}
.footer-col a{display:block;font-size:var(--ts-base);color:var(--ink);text-decoration:none;margin-bottom:var(--sp-3);transition:color 0.2s ease,transform 0.2s var(--spring)}
.footer-col a:hover{color:var(--action);transform:translateX(4px)}
.footer-man{margin-top:var(--sp-8);padding-top:var(--sp-6);border-top:var(--stroke-1) solid var(--grid-strong);font-style:italic;color:var(--muted-ink)}
.footer-copy{margin-top:var(--sp-4);font-family:var(--font-tech);font-size:var(--ts-xs);letter-spacing:1px;color:var(--faint-ink)}
.footer-addr{margin-top:var(--sp-2);font-family:var(--font-tech);font-size:var(--ts-xs);letter-spacing:1px;color:var(--faint-ink)}
@media(max-width:768px){.footer-hl{font-size:clamp(28px,6vw,40px)}}

/* ═══ LEGAL PAGES ═══ */
.legal-page{padding-top:calc(var(--header-h) + var(--status-h) + var(--sp-8));min-height:100vh}
.legal-layout{display:grid;grid-template-columns:220px 1fr;gap:var(--sp-8);max-width:var(--max-w);margin:0 auto;padding:0 var(--sp-8)}
.legal-toc{position:sticky;top:calc(var(--header-h) + var(--status-h) + var(--sp-6));align-self:start;max-height:calc(100vh - var(--header-h) - var(--status-h) - var(--sp-10));overflow-y:auto;padding-right:var(--sp-4);border-right:var(--stroke-1) solid var(--grid-strong)}
.legal-toc-title{font-family:var(--font-tech);font-size:var(--ts-xs);letter-spacing:2px;text-transform:uppercase;color:var(--faint-ink);margin-bottom:var(--sp-4)}
.legal-toc a{display:block;font-size:var(--ts-sm);color:var(--muted-ink);text-decoration:none;padding:var(--sp-2) 0 var(--sp-2) var(--sp-3);border-left:2px solid transparent;transition:color 0.2s ease,border-color 0.2s ease,transform 0.2s var(--spring)}
.legal-toc a:hover{color:var(--ink);transform:translateX(3px)}
.legal-toc a.active{color:var(--ink);font-weight:600;border-left-color:var(--action)}
.legal-content{padding-bottom:var(--sp-10)}
.legal-bc{font-family:var(--font-tech);font-size:var(--ts-xs);letter-spacing:1px;color:var(--faint-ink);margin-bottom:var(--sp-6)}
.legal-bc a{color:var(--muted-ink);text-decoration:none}.legal-bc a:hover{color:var(--action)}
.legal-title{font-size:var(--ts-2xl);font-weight:900;letter-spacing:-.02em;margin-bottom:var(--sp-3)}
.legal-meta{font-family:var(--font-tech);font-size:var(--ts-sm);color:var(--muted-ink);margin-bottom:var(--sp-8);padding-bottom:var(--sp-5);border-bottom:var(--stroke-1) solid var(--grid-strong)}
.legal-sec{margin-bottom:var(--sp-8);scroll-margin-top:calc(var(--header-h) + var(--status-h) + var(--sp-6))}
.legal-num{font-family:var(--font-tech);font-size:var(--ts-sm);color:var(--faint-ink);display:block;margin-bottom:var(--sp-1)}
.legal-sec h3{font-size:var(--ts-lg);font-weight:700;margin-bottom:var(--sp-4)}
.legal-sec p{font-size:var(--ts-base);line-height:1.7;color:var(--muted-ink);margin-bottom:var(--sp-4)}
.legal-sec ul{list-style:none;padding:0;margin-bottom:var(--sp-4)}
.legal-sec li{font-size:var(--ts-base);line-height:1.7;color:var(--muted-ink);padding-left:var(--sp-5);position:relative;margin-bottom:var(--sp-2)}
.legal-sec li::before{content:'\2022';position:absolute;left:var(--sp-2);color:var(--faint-ink)}
.legal-callout{padding:var(--sp-6);background:rgba(102,255,204,.1);border:var(--stroke-2) solid var(--select);border-radius:var(--r-3);margin:var(--sp-5) 0}
.legal-callout-title{font-family:var(--font-tech);font-size:var(--ts-sm);letter-spacing:2px;text-transform:uppercase;color:var(--ink);margin-bottom:var(--sp-3)}
.legal-callout p,.legal-callout li{color:var(--ink)}
.legal-contact{padding:var(--sp-5);background:var(--bg-tertiary);border:var(--stroke-2) solid var(--ink);border-radius:var(--r-3);box-shadow:var(--shadow-sm);margin:var(--sp-5) 0}
.legal-contact p{color:var(--ink);margin-bottom:var(--sp-2)}
.legal-contact a{color:var(--action);text-decoration:none}.legal-contact a:hover{text-decoration:underline}
@media(max-width:900px){.legal-layout{grid-template-columns:1fr;padding:0 var(--sp-6)}.legal-toc{display:none}}
