/* ————————————————————————————————————————————————
   WARRANT design system — “the official document”
   paper · serif display · mono ledger · rubber stamps
   ———————————————————————————————————————————————— */
:root,[data-theme="light"]{
  color-scheme:light;
  --paper:#f6f2e9; --paper2:#efe9dc; --card:#fbf8f1;
  --ink:#181510; --ink2:#4a443a; --faint:#8a8270;
  --rule:#d8d0bf; --rule2:#c4bba6;
  --green:#1c6e46; --red:#a33327; --amber:#9a6b1a; --blue:#1f4e8c;
  /* semantic surfaces that must NOT simply invert */
  --plate-bg:#181510; --plate-ink:#e9e2d2;
  --footer-bg:#181510; --footer-ink:#b9b09a; --footer-link:#e9e2d2; --footer-rule:#5a5346;
  --hover-tint:rgba(24,21,16,.05); --hl-bg:rgba(28,110,70,.07);
  --shadow-btn:rgba(24,21,16,.22); --shadow-btn-h:rgba(24,21,16,.25);
  --shadow-card:rgba(24,21,16,.13); --shadow-plate:rgba(24,21,16,.15);
  --stamp-blend:multiply;
  --serif:Georgia,'Times New Roman',ui-serif,serif;
  --mono:ui-monospace,Consolas,'Cascadia Mono',Menlo,monospace;
}
[data-theme="dark"]{
  color-scheme:dark;
  --paper:#14120d; --paper2:#1b1812; --card:#1c1912;
  /* brighter, cleaner text so body copy reads crisp on the dark paper (not muddy/dull) */
  --ink:#f3ede0; --ink2:#d8cfbb; --faint:#a89e88;
  --rule:#322d22; --rule2:#473f31;
  --green:#63cf95; --red:#ef9587; --amber:#e2b566; --blue:#8fbcf0;
  --plate-bg:#0d0b07; --plate-ink:#e9e2d2;
  --footer-bg:#0d0b07; --footer-ink:#b7af9c; --footer-link:#f1eadc; --footer-rule:#3a352a;
  --hover-tint:rgba(255,255,255,.06); --hl-bg:rgba(92,193,140,.12);
  --shadow-btn:rgba(0,0,0,.55); --shadow-btn-h:rgba(0,0,0,.62);
  --shadow-card:rgba(0,0,0,.5); --shadow-plate:rgba(0,0,0,.5);
  --stamp-blend:screen;
}
html{transition:background-color .25s ease}
body{transition:background-color .25s ease,color .25s ease}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);
     font:16px/1.65 var(--serif);-webkit-font-smoothing:antialiased}
::selection{background:var(--green);color:var(--paper)}
a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--rule2);
  text-underline-offset:3px;transition:text-decoration-color .15s}
a:hover{text-decoration-color:var(--ink)}
a:focus-visible,button:focus-visible{outline:2px solid var(--green);outline-offset:3px}
.mono{font-family:var(--mono)}
.doc{max-width:1020px;margin:0 auto;padding:0 28px}

/* ————— form-header / nav ————— */
.formbar{border-bottom:2px solid var(--ink);background:var(--paper);
         position:sticky;top:0;z-index:50}
.formbar .doc{display:flex;justify-content:space-between;align-items:center;gap:16px;
              padding-top:13px;padding-bottom:13px;flex-wrap:wrap}
.formbar .id{font-family:var(--mono);font-size:11px;letter-spacing:.16em;
             color:var(--ink2);text-transform:uppercase}
.formbar .id a{text-decoration:none}
.formbar .id b{color:var(--ink);font-weight:700;font-size:13px;letter-spacing:.2em}
nav{display:flex;gap:20px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;flex-wrap:wrap}
nav a{text-decoration:none;border-bottom:2px solid transparent;padding-bottom:2px}
nav a:hover{border-bottom-color:var(--rule2)}
nav a.active{border-bottom-color:var(--green);color:var(--green);font-weight:700}
.themetoggle{background:none;border:1.5px solid var(--rule2);border-radius:6px;cursor:pointer;
             font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink2);
             padding:5px 10px;line-height:1;display:inline-flex;align-items:center;gap:6px;
             transition:border-color .15s,color .15s}
.themetoggle:hover{border-color:var(--ink);color:var(--ink)}
.themetoggle .ico{font-size:12px}
.themetoggle .lbl-d,[data-theme="dark"] .themetoggle .lbl-l{display:inline}
.themetoggle .lbl-l,[data-theme="dark"] .themetoggle .lbl-d{display:none}

/* ————— heroes ————— */
.hero{border-bottom:1px solid var(--rule);overflow:hidden}
.hero .doc{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;
           padding-top:80px;padding-bottom:80px}
.hero h1{font-size:clamp(40px,5.6vw,64px);line-height:1.04;margin:0 0 22px;font-weight:700;
         letter-spacing:-.015em}
.hero h1 em,.pagehero h1 em{font-style:italic;color:var(--green)}
.lede{font-size:18.5px;line-height:1.6;color:var(--ink2);max-width:34em;margin:0 0 14px}
.lede b{color:var(--ink)}
.kicker{font-family:var(--mono);font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;
        color:var(--green);margin:0 0 18px;font-weight:700}
.pagehero{border-bottom:1px solid var(--rule)}
.pagehero .doc{padding-top:64px;padding-bottom:56px}
.pagehero h1{font-size:clamp(34px,4.6vw,52px);line-height:1.08;margin:0 0 18px;letter-spacing:-.015em}
.pagehero .lede{margin-bottom:0}

/* ————— buttons ————— */
.ctas{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap;align-items:center}
.btn{display:inline-block;font-family:var(--mono);font-size:13.5px;font-weight:700;letter-spacing:.04em;
     padding:13px 22px;border:2px solid var(--ink);text-decoration:none;background:var(--ink);
     color:var(--paper);transition:transform .12s,box-shadow .12s;
     box-shadow:4px 4px 0 var(--shadow-btn)}
.btn:hover{transform:translate(-1px,-1px);box-shadow:6px 6px 0 var(--shadow-btn-h)}
.btn.ghost{background:transparent;color:var(--ink);box-shadow:none}
.btn.ghost:hover{background:var(--hover-tint);transform:none}

/* ————— certificates + stamps ————— */
.certs{position:relative;min-height:380px}
.cert{position:absolute;width:min(380px,100%);background:var(--card);border:1.5px solid var(--ink);
      padding:22px 24px 20px;box-shadow:7px 8px 0 var(--shadow-card)}
.cert::before{content:"";position:absolute;inset:5px;border:1px solid var(--rule2);pointer-events:none}
.cert.front{top:34px;left:0;z-index:2;transform:rotate(-1.2deg)}
.cert.back{top:0;right:0;z-index:1;transform:rotate(2deg);opacity:.92}
.cert .ctitle{font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;
              color:var(--ink2);text-align:center;margin-bottom:4px}
.cert .cno{font-family:var(--mono);font-size:10px;text-align:center;color:var(--faint);margin-bottom:14px}
.cert .field{display:flex;justify-content:space-between;gap:12px;font-family:var(--mono);font-size:12px;
             padding:6px 0;border-bottom:1px dotted var(--rule2)}
.cert .field .k{color:var(--faint)} .cert .field .v{font-weight:700;text-align:right}
.cert .clause{font-size:12.5px;font-style:italic;color:var(--ink2);margin-top:14px;line-height:1.5}
.stamp{position:absolute;font-family:var(--mono);font-weight:800;letter-spacing:.18em;
       border:3px double currentColor;padding:6px 14px;font-size:15px;text-transform:uppercase;
       transform:rotate(-9deg);opacity:0;mix-blend-mode:var(--stamp-blend);border-radius:3px}
.stamp.green{color:var(--green)} .stamp.red{color:var(--red)} .stamp.amber{color:var(--amber)}
.cert .stamp{right:14px;bottom:48px}
.stamp.in{animation:thud .38s cubic-bezier(.2,1.6,.4,1) forwards}
@keyframes thud{
  0%{opacity:0;transform:rotate(-9deg) scale(2.1)}
  65%{opacity:.95;transform:rotate(-9deg) scale(.96)}
  100%{opacity:.9;transform:rotate(-9deg) scale(1)}}

/* ————— trust strip ————— */
.strip{border-bottom:1px solid var(--rule);background:var(--paper2)}
.strip .doc{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
            padding-top:16px;padding-bottom:16px;font-family:var(--mono);
            font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink2)}
.strip b{color:var(--green)}

/* ————— sections / clauses ————— */
section{border-bottom:1px solid var(--rule)}
section .doc{padding-top:68px;padding-bottom:68px}
.clausehead{display:flex;align-items:baseline;gap:18px;margin-bottom:26px}
.clausehead .num{font-family:var(--mono);font-size:13px;font-weight:700;letter-spacing:.18em;
                 color:var(--green);white-space:nowrap}
.clausehead h2{font-size:clamp(26px,3.4vw,38px);margin:0;line-height:1.12;letter-spacing:-.01em}
h3.sub{font-size:21px;margin:40px 0 12px}
.prose{font-size:17.5px;line-height:1.7;color:var(--ink2);max-width:42em}
.prose b,.prose strong{color:var(--ink)}
.pull{font-size:clamp(20px,2.6vw,27px);line-height:1.45;font-style:italic;max-width:30em;
      border-left:3px solid var(--green);padding-left:22px;margin:34px 0 0;color:var(--ink)}
.next{margin-top:40px;font-family:var(--mono);font-size:13px}

/* ————— ledger tables ————— */
.ledger{width:100%;border-collapse:collapse;margin-top:30px;font-family:var(--mono);font-size:13px}
.ledger th{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);
           text-align:left;font-weight:700;padding:0 14px 10px;border-bottom:2px solid var(--ink)}
.ledger td{padding:14px;border-bottom:1px solid var(--rule);vertical-align:top}
.ledger td:first-child,.ledger th:first-child{padding-left:0}
.ledger .cond{font-weight:700}
.ledger .why{font-family:var(--serif);font-size:14.5px;color:var(--ink2);font-style:italic}
.ledger .serif{font-family:var(--serif);font-size:14.5px;color:var(--ink2)}
.ledger tr.hl td{background:var(--hl-bg);border-bottom:2px solid var(--green)}
.ledger .ok{color:var(--green);font-weight:700} .ledger .no{color:var(--red)}

/* ————— pillars ————— */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:40px;
         border-top:2px solid var(--ink)}
.pillar{padding:26px 26px 30px;border-left:1px solid var(--rule)}
.pillar:first-child{border-left:none;padding-left:0}
.pillar .pnum{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--green);
              font-weight:700;text-transform:uppercase}
.pillar h3{font-size:21px;margin:10px 0 12px;line-height:1.25}
.pillar p{font-size:14.8px;line-height:1.62;color:var(--ink2);margin:0 0 12px}
.pillar a{font-family:var(--mono);font-size:12px}

/* ————— lifecycle ————— */
.cycle{display:flex;align-items:center;gap:0;margin-top:40px;flex-wrap:wrap;font-family:var(--mono)}
.state{border:2px solid currentColor;padding:10px 18px;font-size:13px;font-weight:800;letter-spacing:.14em}
.state.p{color:var(--amber)} .state.l{color:var(--green)} .state.s{color:var(--red)}
.arrow{padding:0 14px;color:var(--faint);font-size:13px;white-space:nowrap}
.arrow small{display:block;font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;text-align:center}
.driftnote{margin-top:22px;font-family:var(--mono);font-size:12.5px;color:var(--red);
           border:1px dashed var(--red);display:inline-block;padding:10px 16px}

/* ————— code plates ————— */
.plate{background:var(--plate-bg);color:var(--plate-ink);font-family:var(--mono);font-size:13px;line-height:1.75;
       padding:24px 26px;margin-top:30px;overflow-x:auto;box-shadow:6px 6px 0 var(--shadow-plate);
       white-space:pre;border:1px solid var(--rule)}
.plate .c{color:#8a8270}.plate .g{color:#7fd4a8}.plate .r{color:#ee9c8d}.plate .y{color:#e8c87a}
.plate .b{color:#9fc1ee}

/* ————— acts ————— */
.acts{margin-top:38px;border-top:2px solid var(--ink)}
.act{display:grid;grid-template-columns:64px 240px 1fr;gap:20px;padding:24px 0;
     border-bottom:1px solid var(--rule);align-items:baseline}
.act .anum{font-family:var(--mono);font-size:26px;font-weight:800;color:var(--green)}
.act h3{font-size:19px;margin:0;line-height:1.3}
.act p{margin:0;font-size:15px;line-height:1.62;color:var(--ink2)}
.act .verdict{font-family:var(--mono);font-size:11px;font-weight:800;letter-spacing:.14em;
              text-transform:uppercase;display:inline-block;margin-top:8px;padding:3px 9px;border:1.5px solid}
.v-ok{color:var(--green)} .v-bad{color:var(--red)} .v-warn{color:var(--amber)}

/* ————— two-column tool refs ————— */
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-top:34px}
.col h3{font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;
        margin:0 0 16px;padding-bottom:10px;border-bottom:2px solid var(--ink)}
.tool{font-family:var(--mono);font-size:13px;padding:9px 0;border-bottom:1px dotted var(--rule2)}
.tool b{font-weight:700}
.tool span{display:block;font-family:var(--serif);font-size:13.5px;font-style:italic;color:var(--ink2)}

/* ————— architecture diagram ————— */
.diagram{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;margin-top:38px;align-items:stretch}
.dgroup{border:2px solid var(--ink);background:var(--card);padding:18px}
.dgroup h4{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
           color:var(--faint);margin:0 0 14px;text-align:center}
.dbox{border:1.5px solid var(--ink);background:var(--paper);padding:10px 12px;margin-bottom:10px;
      font-family:var(--mono);font-size:12px;font-weight:700;text-align:center}
.dbox small{display:block;font-family:var(--serif);font-style:italic;font-weight:400;
            font-size:12px;color:var(--ink2);margin-top:3px}
.dbox.accent{border-color:var(--green);color:var(--green)}
.dlink{display:flex;flex-direction:column;justify-content:center;gap:18px;
       font-family:var(--mono);font-size:10.5px;color:var(--faint);text-align:center;
       letter-spacing:.06em;min-width:120px}
.dlink span{border-top:1.5px dashed var(--rule2);padding-top:4px}
.dcaption{margin-top:14px;font-family:var(--mono);font-size:11.5px;color:var(--faint)}

/* ————— FAQ ————— */
.faq{margin-top:34px;border-top:2px solid var(--ink)}
.faq details{border-bottom:1px solid var(--rule)}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px;
             align-items:baseline;padding:20px 0;font-size:18px;font-weight:700}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);color:var(--green);font-size:20px;font-weight:700}
.faq details[open] summary::after{content:"–"}
.faq .a{padding:0 0 22px;font-size:15.5px;line-height:1.7;color:var(--ink2);max-width:44em}
.faq .a b{color:var(--ink)}

/* ————— steps (docs) ————— */
.step{display:grid;grid-template-columns:56px 1fr;gap:18px;margin-top:34px}
.step .n{font-family:var(--mono);font-size:22px;font-weight:800;color:var(--green);
         border-top:2px solid var(--ink);padding-top:10px}
.step .body{border-top:2px solid var(--ink);padding-top:10px}
.step h3{margin:0 0 8px;font-size:20px}
.step p{margin:0;font-size:15px;color:var(--ink2);line-height:1.65}
.step .plate{margin-top:16px}

/* ————— closing + footer ————— */
.closing{text-align:center}
.closing .doc{padding-top:84px;padding-bottom:84px}
.closing h2{font-size:clamp(28px,4vw,44px);line-height:1.15;margin:0 0 14px;letter-spacing:-.01em}
.closing p{color:var(--ink2);font-size:17px;margin:0 0 34px}
footer{background:var(--footer-bg);color:var(--footer-ink)}
footer .doc{display:flex;justify-content:space-between;gap:18px;padding-top:26px;padding-bottom:26px;
            flex-wrap:wrap;font-family:var(--mono);font-size:12px}
footer a{color:var(--footer-link);text-decoration-color:var(--footer-rule)}
footer a:hover{text-decoration-color:var(--footer-link)}

/* ————— reveal ————— */
.rv{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}
.rv.vis{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .rv{opacity:1;transform:none;transition:none}
  .stamp{opacity:.9;animation:none}
  html{scroll-behavior:auto}}

/* ————— responsive ————— */
@media (max-width:860px){
  .hero .doc{grid-template-columns:1fr;gap:40px;padding-top:52px;padding-bottom:52px}
  .certs{min-height:0;height:auto}
  .cert{position:relative;width:100%}
  .cert.front{top:0;transform:rotate(-.8deg)}
  .cert.back{display:none}
  .pillars{grid-template-columns:1fr}
  .pillar{border-left:none;padding-left:0;border-top:1px solid var(--rule)}
  .pillar:first-child{border-top:none}
  .act{grid-template-columns:48px 1fr;grid-template-rows:auto auto}
  .act p{grid-column:2}
  .twocol{grid-template-columns:1fr}
  .diagram{grid-template-columns:1fr}
  .dlink{flex-direction:row;justify-content:space-around;min-width:0;flex-wrap:wrap}
  section .doc{padding-top:48px;padding-bottom:48px}
  .step{grid-template-columns:40px 1fr}
}
