/* ============================================================
   ShipItFam — shared neo-brutalist stylesheet
   Space Grotesk · cream canvas · hard offset shadows
   ============================================================ */

:root{
  --cream:#FFFDF5;--ink:#0A0A0A;--red:#FF6B6B;--yellow:#FFD93D;--violet:#C9B6FF;
  --blue:#7CC4FF;--lime:#B8FF5C;--white:#FFFFFF;--muted:#5b5650;
  --bw:4px;--off:6px;--shadow:var(--off) var(--off) 0 var(--ink);--shadow-lg:9px 9px 0 var(--ink);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:"Space Grotesk",system-ui,-apple-system,Arial,sans-serif;background:var(--cream);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.skip-link{position:absolute;left:-9999px;top:0;z-index:100;padding:12px 20px;background:var(--yellow);color:var(--ink);font-weight:700;border:var(--bw) solid var(--ink);box-shadow:var(--shadow);text-transform:uppercase}
.skip-link:focus{left:16px;top:16px}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
a{color:inherit;text-decoration:none}
h1,h2,h3{letter-spacing:-1.5px;line-height:1;text-transform:uppercase;font-weight:700}
.mono{font-variant-numeric:tabular-nums}
a:focus-visible,button:focus-visible{outline:4px solid var(--ink);outline-offset:3px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:17px;text-transform:uppercase;letter-spacing:-.3px;padding:16px 26px;min-height:56px;border:var(--bw) solid var(--ink);box-shadow:var(--shadow);cursor:pointer;transition:transform .1s ease,box-shadow .1s ease,background .15s ease;background:var(--white);color:var(--ink)}
.btn:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-lg)}
.btn:active{transform:translate(var(--off),var(--off));box-shadow:0 0 0 var(--ink)}
.btn--cta{background:var(--red)}
.btn--yellow{background:var(--yellow)}
.btn--ink{background:var(--ink);color:var(--cream)}
.btn svg{width:20px;height:20px}

/* ---------- nav ---------- */
nav:not(.toc){position:sticky;top:0;z-index:50;background:var(--cream);border-bottom:var(--bw) solid var(--ink)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 24px;max-width:1140px;margin:0 auto}
.logo{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:22px;text-transform:uppercase;letter-spacing:-1px}
.logo .mark{width:38px;height:38px;display:grid;place-items:center;flex:none}
.logo .mark svg{width:55px;margin-top:-9px;margin-left:-13px}
.logo .lite{font-weight:500}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a.lnk{font-weight:600;font-size:15px;padding:8px 12px;text-transform:uppercase;letter-spacing:-.3px}
.nav-links a.lnk:hover{background:var(--yellow);box-shadow:3px 3px 0 var(--ink)}
.nav-links a.lnk.active{background:var(--ink);color:var(--cream)}
.nav-cta{padding:11px 18px;min-height:auto;font-size:15px}
@media(max-width:820px){
  .nav-inner{flex-wrap:wrap;gap:10px;padding:12px 16px}
  .nav-links{flex-wrap:wrap;width:100%;gap:4px}
  .nav-links a.lnk{font-size:13px;padding:6px 10px}
  .nav-cta{margin-left:auto}
}

/* ---------- hero (shared) ---------- */
.hero{padding:78px 0 58px;position:relative;border-bottom:var(--bw) solid var(--ink)}
.hero:has(.toc){border-bottom:0}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background-image:radial-gradient(var(--ink) 1.4px,transparent 1.4px);background-size:26px 26px;opacity:.07}
.hero .wrap{position:relative;z-index:1}
.badge{display:inline-flex;align-items:center;gap:11px;padding:0;font-weight:700;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;color:var(--ink);margin-bottom:22px}
.badge .dot{width:24px;height:3px;border-radius:0;background:var(--ink)}
@keyframes blink{50%{opacity:.25}}
h1{font-size:clamp(40px,7vw,76px);margin-bottom:22px}
h1 .hl{background:var(--yellow);padding:2px 10px;border:3px solid var(--ink);display:inline-block;transform:rotate(-1deg);box-decoration-break:clone;-webkit-box-decoration-break:clone}
h1 .hl2{background:var(--red);color:var(--ink);padding:2px 10px;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.lede{font-size:clamp(17px,2vw,21px);font-weight:500;max-width:620px;line-height:1.5;color:#1a1a1a;margin-bottom:0}
.lede b{font-weight:700}

/* hero — home two-column variant */
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr;gap:40px}}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:32px;margin-bottom:26px}
.hero-trust{display:flex;align-items:center;gap:10px;font-weight:600;font-size:14px;color:var(--muted)}
.hero-trust svg{width:18px;height:18px;flex:none}

/* hero — sub-page table of contents */
.toc{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.toc a{font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:-.3px;border:3px solid var(--ink);background:var(--white);padding:8px 13px;box-shadow:3px 3px 0 var(--ink);transition:transform .1s ease,box-shadow .1s ease}
.toc a:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink);background:var(--violet)}

/* phone mock (home) */
.phone{background:var(--ink);border:var(--bw) solid var(--ink);border-radius:34px;padding:12px;box-shadow:var(--shadow-lg);max-width:330px;margin:0 auto;transform:rotate(2deg)}
.phone-screen{background:var(--cream);border-radius:24px;overflow:hidden}
.phone-top{background:var(--ink);color:var(--cream);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:600}
.phone-top .live{display:inline-flex;align-items:center;gap:6px}
.phone-top .live .d{width:8px;height:8px;border-radius:50%;background:var(--lime)}
.phone-body{padding:14px}
.ptask{font-weight:700;font-size:15px;text-transform:uppercase;letter-spacing:-.5px;margin-bottom:12px}
.pstep{border:3px solid var(--ink);background:var(--white);padding:10px 12px;margin-bottom:10px;box-shadow:3px 3px 0 var(--ink)}
.pstep .lbl{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--muted);letter-spacing:.4px}
.pstep .cmd{font-size:14px;font-weight:600;margin-top:2px}
.pstep.run{background:var(--violet)}
.pstep.done{background:var(--lime)}
.pstep .row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.pcheck{width:22px;height:22px;border:3px solid var(--ink);display:grid;place-items:center;background:var(--cream);flex:none}
.pcheck svg{width:13px;height:13px}
.papprove{display:flex;gap:8px;margin-top:8px}
.papprove .b{flex:1;text-align:center;border:3px solid var(--ink);padding:9px;font-weight:700;font-size:13px;text-transform:uppercase}
.papprove .ok{background:var(--lime)}
.papprove .no{background:var(--white)}

/* ---------- marquee ---------- */
.marquee{background:var(--ink);color:var(--cream);border-bottom:var(--bw) solid var(--ink);overflow:hidden;white-space:nowrap}
.mtrack{display:inline-flex;align-items:center;padding:13px 0;animation:scroll 24s linear infinite;will-change:transform}
.mtrack span{font-weight:700;font-size:16px;text-transform:uppercase;letter-spacing:-.3px;margin:0 21px}
.mtrack .s{color:var(--yellow);margin:0 2px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- auth (login / register) ---------- */
.auth{display:flex;align-items:center;justify-content:center;min-height:calc(100dvh - 86px);padding:40px 0;border-bottom:var(--bw) solid var(--ink)}
.auth .wrap{width:100%;max-width:460px}
.auth .eyebrow{margin-bottom:16px}
.auth h1{font-size:clamp(28px,4.6vw,40px);margin-bottom:10px}
.auth .sec-intro{font-size:16px;margin-bottom:0}
.auth .form{margin-top:24px}
@media(max-width:560px){.auth{min-height:auto;padding:32px 0}}

/* ---------- sections ---------- */
section{padding:78px 0;border-bottom:var(--bw) solid var(--ink)}
h2{font-size:clamp(28px,4.8vw,48px);margin-bottom:18px}
.sec-intro{font-size:18px;font-weight:500;max-width:660px;color:#1a1a1a;margin-bottom:0}

/* eyebrow (home) + chapter (sub-pages) */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:700;text-transform:uppercase;font-size:13px;letter-spacing:.5px;background:var(--violet);border:3px solid var(--ink);padding:6px 12px;box-shadow:4px 4px 0 var(--ink);margin-bottom:22px}
.chapter{display:inline-flex;align-items:center;gap:12px;font-weight:700;text-transform:uppercase;font-size:13px;letter-spacing:.6px;margin-bottom:20px}
.chapter .cn{width:38px;height:38px;background:var(--ink);color:var(--cream);display:grid;place-items:center;border:3px solid var(--ink);font-size:15px;box-shadow:3px 3px 0 var(--red)}

/* ---------- problem (home) ---------- */
.problem{background:var(--violet)}
.prob-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px;margin-top:44px}
.prob{background:var(--cream);border:var(--bw) solid var(--ink);box-shadow:var(--shadow);padding:26px}
.prob .ic{width:52px;height:52px;border:3px solid var(--ink);background:var(--red);display:grid;place-items:center;margin-bottom:16px;box-shadow:3px 3px 0 var(--ink)}
.prob .ic svg{width:26px;height:26px}
.prob h3{font-size:20px;margin-bottom:8px;letter-spacing:-.5px}
.prob p{font-weight:500;font-size:15px;color:#1f1f1f}

/* ---------- steps (home) ---------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-top:44px}
.step{border:var(--bw) solid var(--ink);box-shadow:var(--shadow);padding:24px;position:relative}
.step:nth-child(1){background:var(--yellow)}
.step:nth-child(2){background:var(--blue)}
.step:nth-child(3){background:var(--red)}
.step:nth-child(4){background:var(--lime)}
.step:nth-child(5){background:var(--white)}
.step .n{display:inline-grid;place-items:center;width:46px;height:46px;background:var(--ink);color:var(--cream);font-weight:700;font-size:20px;border:3px solid var(--ink);margin-bottom:14px;box-shadow:3px 3px 0 rgba(255,255,255,.4)}
.step h3{font-size:17px;margin-bottom:8px;letter-spacing:-.5px}
.step p{font-weight:500;font-size:14.5px}

/* ---------- feature / generic cards ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:22px;margin-top:44px}
.feat{border:var(--bw) solid var(--ink);box-shadow:var(--shadow);padding:28px;background:var(--white);transition:transform .12s ease,box-shadow .12s ease}
.feat:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow-lg)}
.feat .ic{width:56px;height:56px;border:3px solid var(--ink);display:grid;place-items:center;margin-bottom:18px;box-shadow:4px 4px 0 var(--ink)}
.feat:nth-child(1) .ic{background:var(--red)}
.feat:nth-child(2) .ic{background:var(--yellow)}
.feat:nth-child(3) .ic{background:var(--blue)}
.feat:nth-child(4) .ic{background:var(--violet)}
.feat:nth-child(5) .ic{background:var(--lime)}
.feat:nth-child(6) .ic{background:var(--red)}
.feat .ic svg{width:28px;height:28px}
.feat h3{font-size:21px;margin-bottom:10px;letter-spacing:-.6px}
.feat p{font-weight:500;font-size:15px;color:#1f1f1f}

/* made-for dark band (home "Made for" teaser) */
.made{background:var(--ink);color:var(--cream)}
.made .eyebrow{background:var(--yellow);color:var(--ink)}
.made h2{color:var(--cream)}
.made .sec-intro{color:#d8d4cc}
.made .feat{background:#161616;border-color:var(--cream)}
.made .feat:hover{box-shadow:9px 9px 0 var(--cream)}
.made .feat h3{color:var(--cream)}
.made .feat p{color:#cfcbc3}

/* ---------- manifesto / creed bands ---------- */
.manifesto{background:var(--yellow);text-align:center}
.manifesto .wrap{max-width:880px}
.manifesto blockquote{font-size:clamp(26px,4.4vw,44px);font-weight:700;text-transform:uppercase;letter-spacing:-1.5px;line-height:1.05}
.manifesto blockquote .u{background:var(--ink);color:var(--yellow);padding:0 8px}
.manifesto .by{margin-top:24px;font-weight:600;font-size:15px;text-transform:uppercase;letter-spacing:.5px;display:inline-flex;align-items:center;gap:10px;border:3px solid var(--ink);padding:8px 16px;background:var(--cream);box-shadow:4px 4px 0 var(--ink)}
.creed{background:var(--ink);color:var(--cream);text-align:center}
.creed .wrap{max-width:880px}
.creed blockquote{font-size:clamp(26px,4.4vw,44px);font-weight:700;text-transform:uppercase;letter-spacing:-1.5px;line-height:1.05}
.creed blockquote .u{background:var(--yellow);color:var(--ink);padding:0 8px}
.creed .by{margin-top:24px;font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px;color:#a8a39a}

/* ---------- split layout (how-it-works, made-for) ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:38px}}
ul.checks{list-style:none;margin-top:24px}
ul.checks li{display:flex;gap:12px;align-items:flex-start;font-weight:500;font-size:16px;margin-bottom:14px;color:#1a1a1a}
ul.checks li svg{width:24px;height:24px;flex:none;margin-top:1px}
ul.checks li b{font-weight:700}

/* visual cards (browser / connect) */
.visual{border:var(--bw) solid var(--ink);box-shadow:var(--shadow-lg);background:var(--white);overflow:hidden}
.browser .bar{background:var(--ink);display:flex;align-items:center;gap:8px;padding:12px 14px}
.browser .bar .d{width:12px;height:12px;border-radius:50%;border:2px solid var(--cream)}
.browser .bar .d.r{background:var(--red)}.browser .bar .d.y{background:var(--yellow)}.browser .bar .d.g{background:var(--lime)}
.browser .url{flex:1;margin-left:8px;background:var(--cream);border:2px solid var(--cream);padding:5px 12px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;color:var(--ink)}
.browser .url .live{margin-left:auto;font-size:11px;font-weight:700;text-transform:uppercase;color:#1f7a1f}
.browser .page{padding:26px 22px;background:var(--cream);color:var(--ink)}
.browser .skeleton{height:18px;background:var(--violet);border:2px solid var(--ink);margin-bottom:12px}
.browser .skeleton.w70{width:70%;background:var(--yellow)}
.browser .skeleton.w40{width:40%;background:var(--blue)}
.browser .pbtn{display:inline-block;margin-top:8px;background:var(--red);border:3px solid var(--ink);box-shadow:3px 3px 0 var(--ink);padding:9px 16px;font-weight:700;font-size:13px;text-transform:uppercase}
.connect{background:var(--ink);color:var(--cream);padding:26px}
.connect .row{display:flex;align-items:center;justify-content:space-between;gap:14px;border:3px solid var(--cream);padding:14px 16px;margin-bottom:14px}
.connect .row:last-child{margin-bottom:0}
.connect .who{display:flex;align-items:center;gap:12px;font-weight:700;font-size:15px}
.connect .who .ic{width:38px;height:38px;background:var(--lime);border:3px solid var(--cream);display:grid;place-items:center;flex:none}
.connect .who .ic svg{width:20px;height:20px}
.connect .pill{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;border:3px solid var(--lime);color:var(--lime);padding:4px 10px}
.connect .pill.muted{border-color:#3a3a3a;color:#9a9a9a}
.connect .note{font-size:13px;font-weight:500;color:#a8a39a;margin-top:4px}

/* ---------- persona / audience cards ---------- */
.persona-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px;margin-top:44px}
.persona{border:var(--bw) solid var(--ink);box-shadow:var(--shadow);padding:26px;background:var(--white);transition:transform .12s ease,box-shadow .12s ease}
.persona:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow-lg)}
.persona .ic{width:54px;height:54px;border:3px solid var(--ink);display:grid;place-items:center;margin-bottom:16px;box-shadow:4px 4px 0 var(--ink)}
.persona .ic svg{width:27px;height:27px}
.persona:nth-child(1) .ic{background:var(--red)}
.persona:nth-child(2) .ic{background:var(--yellow)}
.persona:nth-child(3) .ic{background:var(--blue)}
.persona:nth-child(4) .ic{background:var(--violet)}
.persona:nth-child(5) .ic{background:var(--lime)}
.persona .role{display:inline-block;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.5px;border:2px solid var(--ink);background:var(--cream);padding:3px 9px;margin-bottom:10px}
.persona h3{font-size:21px;margin-bottom:9px;letter-spacing:-.6px}
.persona p{font-weight:500;font-size:15px;color:#1f1f1f}

/* ---------- harness goods (how-it-works) ---------- */
.goods{background:var(--yellow)}
.goods-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:22px;margin-top:44px}
.good{border:var(--bw) solid var(--ink);box-shadow:var(--shadow);padding:26px;background:var(--cream)}
.good .ic{width:54px;height:54px;border:3px solid var(--ink);background:var(--ink);display:grid;place-items:center;margin-bottom:16px;box-shadow:4px 4px 0 var(--ink)}
.good .ic svg{width:26px;height:26px;stroke:var(--yellow)}
.good h3{font-size:20px;margin-bottom:9px;letter-spacing:-.5px}
.good p{font-weight:500;font-size:15px;color:#1f1f1f}

/* ---------- dark band (how-it-works) ---------- */
.dark{background:var(--ink);color:var(--cream)}
.dark .chapter .cn{box-shadow:3px 3px 0 var(--lime)}
.dark h2{color:var(--cream)}
.dark .sec-intro{color:#d8d4cc}
.dark ul.checks li{color:#d8d4cc}

/* ---------- thesis (why-it-works) ---------- */
.thesis{background:var(--violet);text-align:center}
.thesis .wrap{max-width:880px}
.thesis .chapter{justify-content:center}
.thesis p.big{font-size:clamp(26px,4.4vw,42px);font-weight:700;text-transform:uppercase;letter-spacing:-1.2px;line-height:1.08;margin-bottom:22px}
.thesis p.big .u{background:var(--ink);color:var(--cream);padding:0 8px;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.thesis p.sub{font-size:18px;font-weight:500;max-width:660px;margin:0 auto;color:#1a1a1a}

/* ---------- comparison (why-it-works) ---------- */
.cmp-wrap{margin-top:44px;border:var(--bw) solid var(--ink);box-shadow:var(--shadow-lg);background:var(--cream);overflow:hidden}
.cmp-grid{display:grid;grid-template-columns:repeat(3,1fr)}
@media(max-width:820px){.cmp-grid{grid-template-columns:1fr}}
.cmp{border-right:var(--bw) solid var(--ink)}
.cmp:last-child{border-right:0}
@media(max-width:820px){.cmp{border-right:0;border-bottom:var(--bw) solid var(--ink)}.cmp:last-child{border-bottom:0}}
.cmp.best{background:var(--lime)}
.cmp .head{padding:22px 24px;border-bottom:var(--bw) solid var(--ink);background:var(--white)}
.cmp.best .head{background:var(--ink);color:var(--cream)}
.cmp .head .tagx{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;display:inline-block;border:2px solid currentColor;padding:3px 8px;margin-bottom:12px}
.cmp .head h3{font-size:21px;letter-spacing:-.6px}
.cmp .rows{padding:6px 24px 18px}
.cmp .r{padding:14px 0;border-bottom:2px dashed rgba(10,10,10,.18)}
.cmp .r:last-child{border-bottom:0}
.cmp .r .k{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:5px}
.cmp.best .r .k{color:#3a4d12}
.cmp .r .v{display:flex;align-items:center;gap:9px;font-weight:600;font-size:15px}
.cmp .r .v .dot{width:13px;height:13px;border:2px solid var(--ink);flex:none}
.dot.g{background:var(--lime)}.dot.b{background:var(--red)}.dot.m{background:var(--yellow)}
.cmp.best .r .v .dot.g{background:var(--white)}

/* ---------- principles (why-it-works) ---------- */
.principles{margin-top:42px;border-bottom:3px solid var(--ink)}
.principle{display:grid;grid-template-columns:96px 1fr;gap:28px;padding:32px 0;border-top:3px solid var(--ink);align-items:start}
@media(max-width:640px){.principle{grid-template-columns:1fr;gap:10px}}
.principle .pn{font-size:54px;font-weight:700;line-height:.85;letter-spacing:-2px}
.principle h3{font-size:24px;margin-bottom:11px;letter-spacing:-.7px}
.principle p{font-weight:500;font-size:16px;color:#1f1f1f;max-width:700px;line-height:1.55}
.principle p b{font-weight:700}

/* ---------- questions (why-it-works) ---------- */
.questions{background:var(--yellow)}
.qa-grid{display:grid;gap:18px;margin-top:44px;max-width:880px}
.qa{border:var(--bw) solid var(--ink);box-shadow:var(--shadow);background:var(--cream);padding:24px 26px}
.qa h3{font-size:19px;margin-bottom:11px;letter-spacing:-.4px;display:flex;gap:12px;align-items:flex-start;line-height:1.15}
.qa h3 .q{width:28px;height:28px;flex:none;background:var(--ink);color:var(--yellow);display:grid;place-items:center;font-size:15px;border:2px solid var(--ink)}
.qa p{font-weight:500;font-size:15.5px;color:#1f1f1f;line-height:1.55}
.qa p b{font-weight:700}

/* ---------- final CTA (all pages) ---------- */
.final{background:var(--red);text-align:center}
.final .eyebrow{background:var(--ink);color:var(--cream)}
.final .chapter{justify-content:center}
.final .chapter .cn{box-shadow:3px 3px 0 var(--ink)}
.final h2{font-size:clamp(32px,6vw,58px)}
.final p{font-weight:600;font-size:19px;max-width:560px;margin:16px auto 34px}
.flow{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}
.flow .chip{display:inline-flex;align-items:center;gap:10px;background:var(--cream);border:var(--bw) solid var(--ink);box-shadow:var(--shadow);padding:14px 20px;font-weight:700;font-size:16px;text-transform:uppercase;letter-spacing:-.3px}
.flow .chip .num{width:28px;height:28px;background:var(--ink);color:var(--cream);display:grid;place-items:center;font-size:14px;border:2px solid var(--ink)}
.flow .arrow{display:inline-flex;align-items:center;color:var(--ink)}
.flow .arrow svg{width:22px;height:22px}
@media(max-width:640px){.flow .arrow{transform:rotate(90deg)}}
.final-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ---------- footer ---------- */
footer{background:var(--ink);color:var(--cream);padding:46px 0}
.foot-inner{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:24px}
footer .logo .mark{box-shadow:3px 3px 0 var(--cream)}
.foot-links{display:flex;gap:40px;flex-wrap:wrap}
.foot-col h4{font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:#8a8a8a;margin-bottom:12px;font-weight:700}
.foot-col a{display:block;font-weight:500;font-size:15px;margin-bottom:8px;color:var(--cream)}
.foot-col a:hover{color:var(--yellow)}
.foot-bottom{margin-top:34px;padding-top:20px;border-top:2px solid #2a2a2a;font-size:13px;color:#8a8a8a;font-weight:500}

/* ---------- contact / forms ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:42px;margin-top:44px;align-items:start}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:32px}}
.form{border:var(--bw) solid var(--ink);box-shadow:var(--shadow-lg);background:var(--white);padding:30px}
.field{margin-bottom:20px}
.field:last-of-type{margin-bottom:24px}
.field label{display:block;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px}
.field label .req{color:var(--red);margin-left:3px}
.field input,.field textarea,.field select{width:100%;font-family:inherit;font-weight:500;font-size:16px;color:var(--ink);background:var(--cream);border:3px solid var(--ink);padding:13px 15px;box-shadow:3px 3px 0 var(--ink);transition:box-shadow .1s ease,transform .1s ease}
.field textarea{resize:vertical;min-height:130px}
.field input::placeholder,.field textarea::placeholder{color:#8a857c;font-weight:500}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;box-shadow:5px 5px 0 var(--violet);transform:translate(-2px,-2px)}
.form .btn{width:100%;justify-content:center;background:var(--lime)}
.info-stack{display:grid;gap:18px}
.info-card{border:var(--bw) solid var(--ink);box-shadow:var(--shadow);background:var(--cream);padding:24px}
.info-card .ic{width:50px;height:50px;border:3px solid var(--ink);display:grid;place-items:center;margin-bottom:14px;box-shadow:3px 3px 0 var(--ink)}
.info-card:nth-child(1) .ic{background:var(--yellow)}
.info-card:nth-child(2) .ic{background:var(--blue)}
.info-card:nth-child(3) .ic{background:var(--violet)}
.info-card .ic svg{width:24px;height:24px}
.info-card h3{font-size:18px;margin-bottom:6px;letter-spacing:-.5px}
.info-card p{font-weight:500;font-size:15px;color:#1f1f1f}
.info-card a{color:var(--ink);font-weight:700;border-bottom:3px solid var(--yellow)}

/* ---------- about ---------- */
.lead-body{max-width:760px;margin-top:26px}
.lead-body p{font-weight:500;font-size:17px;line-height:1.6;color:#1f1f1f;margin-bottom:18px}
.lead-body p b{font-weight:700}
.stats{background:var(--ink);color:var(--cream)}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:22px;margin-top:8px}
.stat{border:3px solid var(--cream);padding:26px;text-align:center}
.stat .num{font-size:clamp(38px,6vw,60px);font-weight:700;letter-spacing:-2px;line-height:1;color:var(--lime)}
.stat .lbl{margin-top:10px;font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.4px;color:#cfcbc3}

/* ---------- footer socials ---------- */
.foot-brand{max-width:330px}
.foot-tag{font-weight:500;font-size:14px;color:#a8a39a;margin-top:14px}
.socials{display:flex;gap:10px;margin-top:20px}
.socials a{width:42px;height:42px;display:grid;place-items:center;border:3px solid var(--cream);color:var(--cream);box-shadow:3px 3px 0 rgba(255,255,255,.22);transition:transform .1s ease,box-shadow .1s ease,background .15s ease,color .15s ease}
.socials a:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--yellow);background:var(--yellow);color:var(--ink)}
.socials a svg{width:20px;height:20px}
.foot-rally{font-weight:700;font-size:15px;text-transform:uppercase;letter-spacing:.5px;color:var(--cream);margin-top:16px}
.foot-rally .hl{color:var(--yellow)}

/* ---------- rally line (final section) ---------- */
.rally{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:clamp(20px,3vw,30px);text-transform:uppercase;letter-spacing:-1px;border:var(--bw) solid var(--ink);background:var(--white);box-shadow:var(--shadow);padding:12px 22px;margin-top:34px;transform:rotate(-1deg)}
.rally .hl{background:var(--yellow);padding:0 8px;border:2px solid var(--ink);box-shadow:2px 2px 0 var(--ink)}

/* ---------- pricing ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px;align-items:stretch}
@media(max-width:880px){.tiers{grid-template-columns:1fr}}
.tier{border:var(--bw) solid var(--ink);box-shadow:var(--shadow);background:var(--white);padding:30px;display:flex;flex-direction:column;transition:transform .12s ease,box-shadow .12s ease}
.tier:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow-lg)}
.tier.best{background:var(--lime)}
.tier .name{font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.4px;border:2px solid var(--ink);display:inline-block;padding:4px 10px;background:var(--cream);align-self:flex-start;margin-bottom:18px}
.tier.best .name{background:var(--ink);color:var(--cream)}
.tier .price{font-size:clamp(34px,5vw,46px);font-weight:700;letter-spacing:-2px;line-height:1}
.tier .price small{font-size:15px;font-weight:600;letter-spacing:0;color:var(--muted)}
.tier .desc{font-weight:500;font-size:14.5px;color:#1f1f1f;margin:12px 0 20px}
.tier ul{list-style:none;margin:0 0 26px;display:grid;gap:12px}
.tier ul li{display:flex;gap:10px;align-items:flex-start;font-weight:500;font-size:14.5px;color:#1a1a1a}
.tier ul li svg{width:20px;height:20px;flex:none;margin-top:1px}
.tier .btn{width:100%;justify-content:center;margin-top:auto}

/* ---------- legal prose ---------- */
.legal{max-width:760px}
.legal .updated{font-weight:600;font-size:14px;color:var(--muted);margin-bottom:30px}
.legal h2{font-size:23px;text-transform:none;letter-spacing:-.5px;line-height:1.2;margin:36px 0 12px}
.legal h2:first-of-type{margin-top:0}
.legal p{font-weight:500;font-size:16px;line-height:1.62;color:#1f1f1f;margin-bottom:14px}
.legal ul{margin:0 0 16px 22px}
.legal li{font-weight:500;font-size:16px;line-height:1.55;color:#1f1f1f;margin-bottom:8px}
.legal a{color:var(--ink);font-weight:700;border-bottom:3px solid var(--yellow)}

/* ---------- changelog / ship log ---------- */
.log{margin-top:42px;max-width:840px}
.entry{display:grid;grid-template-columns:160px 1fr;gap:30px;padding:32px 0;border-top:3px solid var(--ink)}
.entry:last-child{border-bottom:3px solid var(--ink)}
@media(max-width:640px){.entry{grid-template-columns:1fr;gap:14px}}
.entry .ver{display:inline-block;font-weight:700;font-size:14px;border:3px solid var(--ink);background:var(--yellow);padding:5px 11px;box-shadow:3px 3px 0 var(--ink)}
.entry .date{display:block;margin-top:12px;font-weight:600;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.entry h3{font-size:22px;margin-bottom:14px;letter-spacing:-.6px}
.entry ul{list-style:none;display:grid;gap:11px}
.entry li{display:flex;gap:11px;align-items:flex-start;font-weight:500;font-size:15.5px;color:#1f1f1f}
.entry li .tag{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;border:2px solid var(--ink);padding:2px 7px;flex:none;margin-top:1px}
.entry li .tag.new{background:var(--lime)}
.entry li .tag.fix{background:var(--blue)}
.entry li .tag.imp{background:var(--violet)}

/* ---------- 404 ---------- */
.notfound{background:var(--red);text-align:center;min-height:72vh;display:grid;place-items:center}
.notfound .code{font-size:clamp(110px,26vw,240px);font-weight:700;line-height:.8;letter-spacing:-8px}
.notfound h1{font-size:clamp(28px,5vw,48px);margin:6px 0 14px}
.notfound p{font-weight:600;font-size:18px;max-width:480px;margin:0 auto 32px}
.notfound .preject{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:var(--cream);border:var(--bw) solid var(--ink);box-shadow:var(--shadow);padding:10px 18px;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:-.2px;transform:rotate(-2deg);margin-bottom:30px}
.notfound .preject svg{width:18px;height:18px}

/* ---------- micro-interactions ---------- */
/* marquee pauses so you can read it */
.marquee:hover .mtrack{animation-play-state:paused}

/* cards lift on hover (match the .feat behaviour everywhere) */
.step,.prob{transition:transform .12s ease,box-shadow .12s ease}
.step:hover,.prob:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow-lg)}

/* flow chips nudge on hover */
.flow .chip{transition:transform .12s ease,box-shadow .12s ease}
.flow .chip:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-lg)}

/* hero phone: live approve loop (driven by JS, index only) */
.papprove .ok{transition:transform .12s ease,box-shadow .12s ease,background .12s ease}
.papprove .ok.tap{transform:translate(2px,2px);box-shadow:inset 0 0 0 999px rgba(10,10,10,.12)}
@keyframes stampIn{0%{transform:scale(.2) rotate(-16deg);opacity:0}55%{transform:scale(1.22) rotate(7deg);opacity:1}100%{transform:scale(1) rotate(0)}}
.pcheck.stamp{animation:stampIn .42s cubic-bezier(.2,.8,.3,1.2) both}
.phone-body .pstep{transition:background .2s ease}

/* scroll reveal — only when motion is welcome; classes are added by JS,
   so no-JS and reduced-motion users always see content normally */
@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .55s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}
}

@media (prefers-reduced-motion: reduce){*{animation:none!important;scroll-behavior:auto!important;transition:none!important}}

/* ---------- utility classes (extracted from inline styles) ---------- */
.logo--on-dark{color:var(--cream)}
.mt-6{margin-top:6px}
.mt-14{margin-top:14px}
.mt-40{margin-top:40px}
.hero-trust--split{margin-top:14px;justify-content:space-between}
.icon-18{width:18px;height:18px}
.icon-current-color{stroke:currentColor}
.ic-muted{background:#3a3a3a;border-color:#3a3a3a;color:#9a9a9a}
.page-white{background:var(--white)}
.label-upper--lg{margin-bottom:18px}
.skeleton-prompt{background:var(--cream);border-color:var(--ink);height:auto;padding:10px 12px;font-weight:600;font-size:13px;margin-bottom:10px}
.skeleton-prompt--answer{background:var(--lime);width:88%}
.token-budget{background:var(--ink);color:var(--cream);padding:28px}
.token-gauge{border:3px solid var(--cream);height:30px;display:flex;margin-bottom:10px}
.token-gauge__used{width:34%;background:var(--lime);border-right:3px solid var(--cream)}
.token-gauge__free{width:66%;background:transparent}
.token-stats{display:flex;justify-content:space-between;font-size:13px;font-weight:600;color:#a8a39a}
.token-note{margin-top:18px;border:3px solid #3a3a3a;padding:12px 14px;font-size:13px;font-weight:600;color:#cfcbc3;display:flex;align-items:center;gap:10px}
.eyebrow--lime{background:var(--lime);color:var(--ink)}
.section-heading--cream{color:var(--cream)}

