:root{
  --ink:#1E2B45; --ink-2:#2A3A5C; --paper:#F7F6F0; --card:#FFFFFF;
  --seal:#BE3A2C; --seal-d:#A22F23; --green:#356648; --blue:#2C5F8A;
  --graphite:#5A6072; --faint:#9AA0AD; --line:#E3E0D6; --amber:#A9760F;
  --display:'Lora',Georgia,serif; --body:'Public Sans',-apple-system,Segoe UI,sans-serif;
  --mono:ui-monospace,'SF Mono',Menlo,monospace; --hand:'Caveat',cursive;
  --r:10px; --shadow:0 1px 2px rgba(30,43,69,.06),0 8px 24px -12px rgba(30,43,69,.18);
}
*{box-sizing:border-box} html{-webkit-text-size-adjust:100%}
[hidden]{display:none!important}
body{margin:0;font-family:var(--body);font-size:15.5px;line-height:1.6;color:var(--ink);background:var(--paper)}
h1,h2,h3,h4{font-family:var(--display);line-height:1.18;margin:0 0 .5em;font-weight:600;letter-spacing:-.01em}
h1{font-size:clamp(2rem,5vw,3.1rem)} h2{font-size:clamp(1.5rem,3.4vw,2.1rem)} h3{font-size:1.22rem} h4{font-size:1.02rem}
p{margin:0 0 1em} a{color:var(--ink);text-decoration-color:rgba(30,43,69,.35);text-underline-offset:3px}
a:hover{text-decoration-color:var(--seal)} img{max-width:100%}
small,.muted{color:var(--graphite);font-size:.86em}
code,.mono{font-family:var(--mono);font-size:.88em}
.i{vertical-align:-3px}

/* Airmail brand stripe */
.airstripe{height:7px;background:repeating-linear-gradient(135deg,var(--seal) 0 14px,#fff 14px 24px,var(--ink) 24px 38px,#fff 38px 48px)}

.wrap{max-width:1100px;margin:0 auto;padding:0 22px}
.narrow{max-width:760px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;border:1.5px solid var(--ink);background:var(--ink);color:#fff;
  font:600 .94rem var(--body);padding:10px 18px;border-radius:8px;cursor:pointer;text-decoration:none;transition:transform .06s,box-shadow .15s,background .15s}
.btn:hover{background:var(--ink-2);box-shadow:var(--shadow)} .btn:active{transform:translateY(1px)}
.btn.seal{background:var(--seal);border-color:var(--seal)} .btn.seal:hover{background:var(--seal-d)}
.btn.ghost{background:transparent;color:var(--ink)} .btn.ghost:hover{background:#fff}
.btn.sm{padding:6px 12px;font-size:.85rem;border-radius:7px} .btn.lg{padding:13px 24px;font-size:1.02rem}
.btn.wide{width:100%;justify-content:center}
.btn[disabled]{opacity:.55;cursor:not-allowed;box-shadow:none}
.btn .i{vertical-align:-3px}

/* Badges */
.badge{display:inline-block;padding:2.5px 9px;border-radius:99px;font:600 .72rem var(--body);letter-spacing:.04em;text-transform:uppercase;border:1px solid}
.b-green{color:var(--green);border-color:#bcd3c4;background:#eef5f0}
.b-red{color:var(--seal);border-color:#e8c4be;background:#faf0ee}
.b-blue{color:var(--blue);border-color:#c2d4e3;background:#eef4f9}
.b-amber{color:var(--amber);border-color:#e4d2ab;background:#f9f3e4}
.b-muted{color:var(--graphite);border-color:var(--line);background:#f1efe8}

/* Flash messages */
.flashes{position:fixed;top:16px;right:16px;z-index:90;display:flex;flex-direction:column;gap:8px;max-width:min(420px,90vw)}
.flash{display:flex;gap:10px;align-items:flex-start;background:var(--ink);color:#fff;padding:12px 14px;border-radius:10px;box-shadow:var(--shadow);font-size:.92rem;animation:fin .25s ease}
.flash.err{background:var(--seal)} .flash.ok{background:var(--green)}
.flash button{margin-left:auto;background:none;border:0;color:#fff;cursor:pointer;font-size:1rem;line-height:1;opacity:.8}
@keyframes fin{from{opacity:0;transform:translateY(-6px)}to{opacity:1}}

/* Forms */
.field{margin-bottom:16px}
.field label{display:block;font:600 .86rem var(--body);margin-bottom:6px;color:var(--ink)}
.field label em{color:var(--seal);font-style:normal}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:8px;background:#fff;
  padding:10px 12px;font:400 .95rem var(--body);color:var(--ink);transition:border-color .12s,box-shadow .12s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(30,43,69,.12)}
.field small{display:block;margin-top:5px;color:var(--graphite)}
.field textarea{resize:vertical;min-height:90px}
.check{display:flex;gap:9px;align-items:flex-start;font-size:.93rem;margin:8px 0;cursor:pointer}
.check input{margin-top:3px;accent-color:var(--ink);width:16px;height:16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.kpis .card,.stats .card{display:flex;flex-direction:column;justify-content:center;margin:0}
.acol{display:flex;flex-direction:column;gap:18px;min-width:0}
.acol>.card{margin:0}
.acol>.card:last-child{flex:1}
.kpis,.stats{align-items:stretch}
.howto-ov{position:fixed;inset:0;z-index:120;display:none;background:rgba(30,43,69,.45);padding:20px}
.howto-ov.open{display:grid;place-items:center}
.howto-card{position:relative;z-index:1;background:var(--card);border:1px solid var(--line);border-radius:16px;max-width:740px;width:100%;max-height:90vh;overflow:auto;padding:26px;box-shadow:0 18px 50px rgba(30,43,69,.25)}
.howto-back{position:absolute;inset:0;background:transparent;border:0;cursor:default}
.howto-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:14px;margin:16px 0}
.howto-step{display:flex;gap:12px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:14px}
.howto-n{flex:none;width:30px;height:30px;border-radius:50%;background:var(--seal);color:#fff;display:grid;place-items:center;font:700 .95rem var(--display)}
.howto-step p{margin:3px 0 0;font-size:.9rem;line-height:1.5}
.howto-step b{font-size:.96rem}
.vgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px;align-items:stretch}
.vgrid .card{margin:0;display:flex;flex-direction:column;gap:6px}
.vgrid .card p{margin:0}
.grid2 .card,.grid3 .card{margin-top:0}
@media(max-width:680px){.grid2,.grid3{grid-template-columns:1fr}}
.fr{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.hp{position:absolute;left:-6000px;top:-6000px}

/* Cards & panels */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:0 1px 2px rgba(30,43,69,.04)}
.card+.card{margin-top:18px}
.card h3{display:flex;align-items:center;gap:9px}
.panel-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}

/* Tables */
.tbl{width:100%;border-collapse:collapse;font-size:.92rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.tbl th{font:600 .76rem var(--body);letter-spacing:.05em;text-transform:uppercase;color:var(--graphite);text-align:left;padding:11px 13px;background:#FBFAF6;border-bottom:1px solid var(--line)}
.tbl td{padding:11px 13px;border-bottom:1px solid #EFEDE5;vertical-align:middle}
.tbl tr:last-child td{border-bottom:0}
.tbl tr:hover td{background:#FBFAF6}
.tbl-wrap{overflow-x:auto;border-radius:var(--r)}
.tbl .actions{white-space:nowrap;text-align:right}
.empty{padding:42px 20px;text-align:center;color:var(--graphite)}
.empty .postmark{color:#cfccc0;margin-bottom:8px}

/* ===================== MARKETING ===================== */
.mk-head{position:sticky;top:0;background:var(--paper);border-bottom:1px solid var(--line);z-index:50}
.mk-nav{display:flex;align-items:center;gap:26px;height:64px}
.logo{display:flex;align-items:center;gap:10px;font:700 1.18rem var(--display);text-decoration:none;letter-spacing:-.01em}
.logo .seal-dot{width:26px;height:26px;border-radius:50%;background:var(--seal);display:grid;place-items:center;color:#fff;flex:none}
.logo .seal-dot svg{width:15px;height:15px}
.mk-links{display:flex;gap:22px;margin-left:auto;align-items:center}
.mk-links a{text-decoration:none;font-weight:500;font-size:.94rem}
.mk-burger{display:none;margin-left:auto;background:none;border:0;cursor:pointer;color:var(--ink)}
@media(max-width:760px){
  .mk-links{display:none;position:absolute;top:64px;left:0;right:0;background:var(--paper);border-bottom:1px solid var(--line);flex-direction:column;padding:18px;gap:14px}
  .mk-links.open{display:flex}.mk-burger{display:block}
}
.hero{padding:72px 0 64px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
@media(max-width:860px){.hero-grid{grid-template-columns:1fr}}
.kicker{font:600 .78rem var(--body);letter-spacing:.14em;text-transform:uppercase;color:var(--seal);margin-bottom:14px;display:flex;gap:8px;align-items:center}
.kicker:before{content:"";width:26px;height:2px;background:var(--seal)}
.hero p.lede{font-size:1.13rem;color:var(--graphite);max-width:46ch}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.hero-note{margin-top:14px;font-size:.86rem;color:var(--graphite)}
/* envelope visual */
.envelope{position:relative;max-width:430px;margin:0 auto;filter:drop-shadow(0 18px 30px rgba(30,43,69,.18))}
.env-letter{background:#fff;border:1px solid var(--line);border-radius:6px;padding:26px 24px 20px;font-family:Georgia,serif;font-size:.82rem;line-height:1.7;color:var(--ink);
  transform:translateY(34px) rotate(-1.2deg);animation:rise 1.1s .25s cubic-bezier(.2,.8,.3,1) both}
.env-letter .el-head{font:700 .68rem var(--body);letter-spacing:.1em;text-transform:uppercase;border-top:5px solid var(--ink);padding-top:10px;margin-bottom:12px;display:flex;justify-content:space-between;color:var(--graphite)}
.env-letter .el-line{height:7px;background:#EDEBE2;border-radius:4px;margin:9px 0}
.env-letter .el-line.w60{width:60%}.env-letter .el-line.w85{width:85%}.env-letter .el-line.w72{width:72%}
.env-letter .el-sign{font-family:var(--hand);font-size:1.5rem;color:var(--ink);margin-top:14px}
.env-body{position:relative;margin-top:-30px;background:linear-gradient(180deg,#fff, #F4F2EA);border:1px solid var(--line);border-radius:8px;height:118px;
  -webkit-mask:linear-gradient(#000,#000)}
.env-body:before{content:"";position:absolute;inset:0;border-radius:8px;background:repeating-linear-gradient(135deg,var(--seal) 0 12px,transparent 12px 22px,var(--ink) 22px 34px,transparent 34px 44px);
  -webkit-mask:linear-gradient(#000,#000) top/100% 7px no-repeat;mask:linear-gradient(#000,#000) top/100% 7px no-repeat}
.env-stamp{position:absolute;right:18px;top:20px;width:58px;height:68px;background:#fff;border:1px solid var(--line);border-radius:4px;
  box-shadow:0 0 0 5px #fff,0 0 0 6px var(--line);display:grid;place-items:center;color:var(--seal);transform:rotate(3deg)}
.env-mark{position:absolute;left:16px;top:12px;color:rgba(30,43,69,.5)}
@keyframes rise{from{transform:translateY(112px) rotate(-1.2deg);opacity:.2}to{transform:translateY(34px) rotate(-1.2deg);opacity:1}}
.trustline{display:flex;gap:26px;flex-wrap:wrap;border-top:1px solid var(--line);padding:22px 0;color:var(--graphite);font-size:.9rem;align-items:center}
.trustline strong{color:var(--ink)}

.sec{padding:64px 0}
.sec.alt{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-head{max-width:640px;margin-bottom:40px}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:s}
@media(max-width:820px){.steps{grid-template-columns:1fr}}
.step{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:26px 22px 22px}
.step:before{counter-increment:s;content:counter(s,decimal-leading-zero);font:700 .8rem var(--mono);color:var(--seal);letter-spacing:.1em}
.step h3{margin-top:10px}
.delivery{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:820px){.delivery{grid-template-columns:1fr}}
.dcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px;position:relative;overflow:hidden}
.dcard .di{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;background:var(--paper);border:1px solid var(--line);margin-bottom:14px;color:var(--ink)}
.dcard.hot{border-color:var(--seal)}
.dcard.hot:after{content:none}
.hand-demo{font-family:var(--hand);font-size:1.35rem;color:var(--ink);background:#fff;border:1px dashed var(--line);border-radius:8px;padding:10px 14px;margin-top:12px;transform:rotate(-.6deg)}
.featgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px}
.feat{display:flex;gap:13px}
.feat .fi{flex:none;width:36px;height:36px;border-radius:9px;background:var(--ink);color:#fff;display:grid;place-items:center}
.feat h3{margin-bottom:3px;font-size:1.05rem}.feat p{font-size:.9rem;color:var(--graphite);margin:0}

/* Pricing */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
@media(max-width:860px){.plans{grid-template-columns:1fr}}
.plan{background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:28px 24px;display:flex;flex-direction:column}
.plan.hot{border-color:var(--ink);box-shadow:var(--shadow);position:relative}
.plan.hot .pop{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;font:700 .68rem var(--body);letter-spacing:.08em;padding:4px 12px;border-radius:99px}
.plan .price{font:600 2.3rem var(--display);margin:8px 0 2px}
.plan .price span{font:500 .95rem var(--body);color:var(--graphite)}
.plan ul{list-style:none;padding:0;margin:18px 0 22px;flex:1}
.plan li{padding:6px 0;font-size:.93rem;display:flex;gap:9px;align-items:flex-start}
.plan li .i{color:var(--green);flex:none;margin-top:2px}
.faq{max-width:740px}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{font:600 1rem var(--body);padding:12px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:14px}
.faq summary:after{content:"+";font-family:var(--display);color:var(--seal);font-size:1.2rem}
.faq details[open] summary:after{content:"–"}
.faq p{color:var(--graphite);padding-bottom:12px}
.cta-band{background:var(--ink);color:#fff;border-radius:16px;padding:46px 38px;display:flex;justify-content:space-between;align-items:center;gap:26px;flex-wrap:wrap;position:relative;overflow:hidden}
.cta-band h2{color:#fff;margin:0}
.cta-band .postmark{position:absolute;right:-14px;top:-18px;color:rgba(255,255,255,.16)}
.mk-foot{border-top:1px solid var(--line);padding:36px 0;color:var(--graphite);font-size:.9rem}
.mk-foot .wrap{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}
.mk-foot .cols{display:grid;grid-template-columns:repeat(3,minmax(150px,1fr));gap:16px 30px;line-height:2.1}
.mk-foot .cols b{display:block;color:var(--ink);margin-bottom:3px;font-size:.95em}
@media(max-width:640px){.mk-foot .cols{grid-template-columns:1fr 1fr}}
.mk-foot .support-line{margin-top:14px;font-size:1em}
/* Readability: subtle only — the Aa+ control (header/footer) is the opt-in path to larger text. */
.mk-links a[aria-current="page"]{text-decoration:underline;text-underline-offset:5px;font-weight:700}
.pub .field input,.pub .field select,.pub .field textarea{font-size:1.05rem}
.step-count{font:600 .95rem var(--body);color:var(--graphite);margin:-10px 0 18px}
.consent-opt{display:flex;gap:9px;align-items:flex-start;margin:8px 0;cursor:pointer;font-size:.98em}
.consent-opt input{margin-top:3px;flex:0 0 auto}
.uniq-band{background:var(--ink);color:#EDEAE0;border-radius:var(--r);padding:24px 28px;margin-top:22px}
.uniq-band h3{color:#fff;margin:0 0 14px;font-family:var(--display)}
.uniq-band ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:14px 24px}
.uniq-band li{display:flex;gap:9px;align-items:flex-start;font-size:.95em}
.uniq-band li svg{color:#9BC4A4;flex:0 0 auto;margin-top:3px}
@media(max-width:820px){.uniq-band ul{grid-template-columns:1fr}}
.evidence{border-left:4px solid var(--seal)}
.matrix-fold{margin:26px auto 0}
.matrix-fold>summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;border:1.5px solid var(--line);border-radius:var(--r);padding:14px 22px;font:600 1rem var(--body);color:var(--ink)}
.matrix-fold>summary::-webkit-details-marker{display:none}
.matrix-fold>summary:after{content:"▾";color:var(--seal);transition:transform .15s ease}
.matrix-fold>summary:hover{border-color:var(--ink)}
.matrix-fold[open]>summary{border-radius:var(--r) var(--r) 0 0;border-bottom-color:var(--paper)}
.matrix-fold[open]>summary:after{transform:rotate(180deg)}
.matrix-fold .matrix-wrap{border:1.5px solid var(--line);border-top:0;border-radius:0 0 var(--r) var(--r);background:#fff;padding:4px 14px 14px;margin-top:0}
.ev-stat{font-family:var(--display);font-size:2.1rem;margin:4px 0 0}
.cr-rows{list-style:none;margin:12px 0 0;padding:0;display:grid;gap:10px}
.cr-rows li{display:flex;gap:10px;align-items:flex-start}
.cr-rows li svg{flex:0 0 auto;margin-top:3px;color:var(--seal)}

/* ===================== AUTH ===================== */
.auth{min-height:100vh;display:grid;place-items:center;padding:34px 16px;background:
  radial-gradient(900px 480px at 85% -10%,#fff 0%,transparent 60%),var(--paper)}
.auth-card{width:100%;max-width:430px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:34px 30px;box-shadow:var(--shadow)}
.auth-card .logo{justify-content:center;margin-bottom:8px}
.auth-card h1{font-size:1.5rem;text-align:center}
.auth-card .sub{text-align:center;color:var(--graphite);margin-bottom:22px;font-size:.93rem}
.auth-foot{text-align:center;margin-top:18px;font-size:.9rem;color:var(--graphite)}

/* ===================== APP SHELL ===================== */
.app{display:grid;grid-template-columns:236px 1fr;min-height:100vh}
.side{background:var(--ink);color:#E8EAF0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side .logo{color:#fff;padding:20px 18px 14px}
.side .logo .seal-dot{background:var(--seal)}
.side nav{padding:8px 10px;flex:1;overflow-y:auto}
.side .nv{display:flex;align-items:center;gap:11px;color:#C6CCDA;text-decoration:none;font:500 .92rem var(--body);padding:9px 12px;border-radius:8px;margin:2px 0}
.side .nv:hover{background:rgba(255,255,255,.07);color:#fff}
.side .nv.on{background:rgba(255,255,255,.12);color:#fff}
.side .nv .i{opacity:.85}
.side .grp{font:700 .66rem var(--body);letter-spacing:.12em;text-transform:uppercase;color:#7C86A0;padding:16px 12px 6px}
.side .sfoot{padding:14px;border-top:1px solid rgba(255,255,255,.1);font-size:.84rem}
.side .sfoot .who{color:#fff;font-weight:600}
.side .sfoot a{color:#C6CCDA}
.credits-pill{margin:10px 12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:10px;padding:10px 12px;font-size:.83rem;color:#C6CCDA}
.credits-pill b{color:#fff;font-size:1.05rem}
.main{min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:14px;padding:14px 26px;border-bottom:1px solid var(--line);background:var(--paper);position:sticky;top:0;z-index:30}
.topbar h1{font-size:1.3rem;margin:0}
.topbar .sp{margin-left:auto;display:flex;gap:10px;align-items:center}
.content{padding:26px;max-width:1280px;width:100%;margin:0 auto}
.imp-banner{background:var(--seal);color:#fff;padding:9px 26px;font-size:.9rem;display:flex;gap:12px;align-items:center}
.imp-banner a{color:#fff;font-weight:700}
.menu-btn{display:none;background:none;border:0;color:var(--ink);cursor:pointer}
@media(max-width:900px){
  .app{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;bottom:0;width:248px;z-index:80;transform:translateX(-100%);transition:transform .2s;height:100dvh}
  .side.open{transform:none;box-shadow:0 0 0 100vmax rgba(20,28,46,.45)}
  .menu-btn{display:block}
  .content{padding:18px 16px}
  .topbar{padding:12px 16px}
}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:22px}
.stat{display:flex;gap:13px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px}
.stat-i{width:38px;height:38px;flex:none;border-radius:9px;background:var(--paper);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink)}
.stat-v{font:600 1.5rem var(--display);line-height:1.1}
.stat-l{font-size:.8rem;color:var(--graphite);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.stat-s{font-size:.8rem;color:var(--graphite);margin-top:2px}
.tabs{display:flex;gap:4px;border-bottom:1.5px solid var(--line);margin-bottom:20px;overflow-x:auto}
.tabs a{padding:9px 14px;text-decoration:none;font:600 .9rem var(--body);color:var(--graphite);border-bottom:2.5px solid transparent;margin-bottom:-1.5px;white-space:nowrap}
.tabs a.on{color:var(--ink);border-color:var(--seal)}
.checklist li{list-style:none;display:flex;gap:10px;padding:7px 0;align-items:flex-start;font-size:.93rem}
.checklist{padding:0;margin:0}
.checklist .ok{color:var(--green)} .checklist .no{color:var(--faint)}
.copyrow{display:flex;gap:8px}
.copyrow input{flex:1;font-family:var(--mono);font-size:.85rem}

/* ===================== PUBLIC CAMPAIGN ===================== */
.pub{min-height:100vh;display:flex;flex-direction:column}
.pub-head{border-bottom:1px solid var(--line);background:#fff}
.pub-head .wrap{display:flex;align-items:center;gap:14px;height:60px}
.pub-org{min-width:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:560px){.pub-head .wrap{height:auto;min-height:56px;flex-wrap:wrap;padding:8px 0;row-gap:2px}.pub-pow{flex-basis:100%;margin-left:0;order:9}}
.pub-org{font:600 1rem var(--display)}
.pub-pow{margin-left:auto;font-size:.85rem;color:var(--graphite);text-decoration:none}
.pub-main{flex:1;padding:34px 0 64px}
.pub-grid{display:grid;grid-template-columns:1fr 380px;gap:34px;align-items:start}
@media(max-width:900px){.pub-grid{grid-template-columns:1fr}}
.stepper{display:flex;gap:6px;margin:18px 0 26px;flex-wrap:wrap}
.stepper .st{display:flex;align-items:center;gap:8px;font:600 .8rem var(--body);color:var(--graphite);padding:7px 13px;border:1.5px solid var(--line);border-radius:99px;background:#fff}
.stepper .st .n{width:19px;height:19px;border-radius:50%;background:var(--line);color:var(--graphite);display:grid;place-items:center;font-size:.68rem}
.stepper .st.on{border-color:var(--ink);color:var(--ink)}
.stepper .st.on .n{background:var(--ink);color:#fff}
.stepper .st.done{color:var(--green);border-color:#bcd3c4}
.stepper .st.done .n{background:var(--green);color:#fff}
.camp-title h1{font-size:clamp(1.6rem,4vw,2.4rem)}
.camp-bg{color:var(--graphite);font-size:1.02rem;max-width:60ch}
.points{margin:14px 0;padding:0;list-style:none}
.points li{display:flex;gap:10px;padding:5px 0;font-size:.95rem}
.points li .i{color:var(--seal);flex:none;margin-top:3px}
.rep-card{display:flex;gap:14px;background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:16px;cursor:pointer;transition:border-color .12s,box-shadow .12s;width:100%;text-align:left;font:inherit;color:inherit;align-items:center}
.rep-card:hover{border-color:var(--ink)} .rep-card.sel{border-color:var(--seal);box-shadow:0 0 0 3px rgba(190,58,44,.14)}
.rep-card+.rep-card{margin-top:10px}
.rep-av{position:relative;width:46px;height:46px;flex:none;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font:600 1rem var(--display);overflow:hidden}
.rep-av img,.rep-av .rep-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:var(--ink)}
.rep-meta{min-width:0}.rep-meta b{display:block}.rep-meta span{font-size:.85rem;color:var(--graphite)}
.tone-row{display:flex;gap:9px;flex-wrap:wrap;margin:6px 0 14px}
.tone{border:1.5px solid var(--line);background:#fff;border-radius:99px;padding:7px 15px;font:600 .87rem var(--body);cursor:pointer;color:var(--graphite)}
.tone.sel{border-color:var(--ink);color:var(--ink);background:var(--paper)}
.meth{display:flex;gap:12px;flex-wrap:wrap}
.meth label{flex:1;min-width:150px;border:1.5px solid var(--line);border-radius:12px;background:#fff;padding:14px;cursor:pointer;display:block}
.meth label.sel{border-color:var(--seal);box-shadow:0 0 0 3px rgba(190,58,44,.12)}
.meth input{position:absolute;opacity:0}
.meth b{display:flex;gap:8px;align-items:center}
.meth small{display:block;margin-top:4px}
.meth .cost{font:600 .72rem var(--mono);color:var(--seal);margin-top:6px;display:block}

/* Letter paper preview */
.letter-sheet{background:#fff;border:1px solid var(--line);border-radius:4px;box-shadow:0 2px 4px rgba(30,43,69,.07),0 16px 40px -18px rgba(30,43,69,.3);
  padding:34px 36px;font-family:Georgia,'Times New Roman',serif;font-size:.96rem;line-height:1.7;position:relative}
.letter-sheet:before{content:"";position:absolute;top:10px;right:12px;width:44px;height:52px;border:1px dashed var(--line);border-radius:3px;opacity:.6}
.letter-head{display:flex;justify-content:space-between;align-items:baseline;padding-top:12px;margin-bottom:26px;gap:14px}
.letter-org{font:700 .74rem var(--body);letter-spacing:.09em;text-transform:uppercase}
.letter-date{color:var(--graphite);font-size:.83rem}
.letter-to{margin-bottom:22px}
.letter-body p{margin:0 0 13px}
.letter-from{margin-top:24px}
.letter-foot{margin-top:34px;padding-top:9px;border-top:1px solid var(--line);color:var(--faint);font:400 .72rem var(--body)}
.letter-sheet.hand .letter-body{font-family:var(--hand);font-size:1.34rem;line-height:1.55}
.letter-edit textarea{font-family:Georgia,serif;font-size:.98rem;line-height:1.65;min-height:340px;background:#fff}
.gen-wait{display:none;text-align:center;padding:46px 20px;color:var(--graphite)}
.gen-wait .postmark{color:var(--seal);animation:spin 7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.busy .gen-wait{display:block}.busy .gen-hide{display:none}
.share-box{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.success-mark{color:var(--green);margin:0 auto 14px;display:block;width:fit-content}
.pub-side .card{position:sticky;top:20px}
.counter{font:600 2rem var(--display)}
.progressbar{height:8px;background:var(--line);border-radius:99px;overflow:hidden;margin:10px 0 4px}
.progressbar i{display:block;height:100%;background:linear-gradient(90deg,var(--seal),var(--ink));border-radius:99px}

/* Setup wizard */
.wiz{max-width:640px;margin:40px auto;padding:0 18px}
.wiz-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:34px;box-shadow:var(--shadow)}
.wiz-steps{display:flex;gap:6px;margin-bottom:26px}
.wiz-steps i{height:5px;flex:1;border-radius:99px;background:var(--line)}
.wiz-steps i.on{background:var(--seal)}
.req{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid #EFEDE5;font-size:.93rem}

@media print{
  .side,.topbar,.btn,.flashes,.stepper,.no-print{display:none!important}
  body{background:#fff}.app{display:block}.content{padding:0;max-width:none}
  .letter-sheet{border:0;box-shadow:none}
}
@media(prefers-reduced-motion:reduce){
  *,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
/* ------------------------------ v2: tabs, switches, review UI, a11y ----- */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;border-radius:0 0 10px 0;z-index:300;font:600 .9rem var(--body);text-decoration:none}
.skip-link:focus{left:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip{position:absolute;left:-9999px;top:10px;z-index:200;background:var(--ink);color:#fff;padding:10px 18px;border-radius:10px;font:600 .9rem var(--body);text-decoration:none}
.skip:focus{left:10px}
.sec[id]{scroll-margin-top:80px}
mark{background:#FFE08A;color:inherit;padding:0 3px;border-radius:4px}
.hero h1,.sec-head h2,.cta-band h2{text-wrap:balance}
.hero .lede{max-width:60ch}
.sec-head>.muted{max-width:68ch}
.delivery{align-items:stretch}
.dcard{display:flex;flex-direction:column}
.dcard>.mono{margin-top:auto;padding-top:12px}
.featgrid{gap:20px 24px}
.feat{align-items:flex-start}
.trustline{margin-top:36px}
.cta-band{gap:22px}
:focus-visible{outline:3px solid var(--seal);outline-offset:2px}
.btn:focus-visible,.tab:focus-visible{outline-offset:3px}
.btn{min-height:40px}
.btn.sm{min-height:34px}
.tabs{display:flex;flex-wrap:wrap;gap:8px;margin:2px 0 16px}
.tab{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border:1.5px solid var(--line);border-radius:999px;background:#fff;color:var(--graphite);font:600 .86rem var(--body);text-decoration:none;min-height:40px}
.tab:hover{border-color:var(--ink);color:var(--ink)}
.tab.on{background:var(--ink);border-color:var(--ink);color:#fff}
.tabs{border-bottom:0}
.tabs a{margin-bottom:0;border-bottom:0}
.tabs a.on{color:#fff;border-color:var(--ink)}
.choice .pv-theme{font-size:.78rem;margin-top:6px;display:inline-block;color:var(--seal);text-decoration:underline;position:relative;z-index:2}
.check.switchy{align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px dashed var(--line)}
.check.switchy:last-of-type{border-bottom:0}
.check.switchy input{appearance:none;-webkit-appearance:none;width:42px;height:24px;flex:none;background:var(--line);border-radius:999px;position:relative;cursor:pointer;margin-top:1px;transition:background .15s ease}
.check.switchy input:checked{background:var(--green)}
.check.switchy input:before{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 2px rgba(30,43,69,.3);transition:left .15s ease}
.check.switchy input:checked:before{left:21px}
.navnum{display:inline-block;min-width:20px;text-align:center;background:var(--seal);color:#fff;border-radius:999px;font-size:.7rem;font-weight:700;padding:1px 6px;margin-left:6px;vertical-align:1px}
.letter-readonly{border:1.5px solid var(--line);border-radius:10px;background:#fff;margin-top:12px;overflow:hidden}
.lr-subject{font:700 1rem var(--body);padding:12px 16px;border-bottom:1px solid var(--line);color:var(--ink);background:#FBFAF7}
.lr-body{white-space:pre-wrap;font-family:Georgia,'Times New Roman',serif;font-size:.97rem;line-height:1.62;padding:14px 16px;color:var(--ink);max-height:340px;overflow:auto}
.card.approval{margin-bottom:18px}
input[type=color]{border:1.5px solid var(--line);border-radius:8px;background:#fff}
input[type=date]{font-family:var(--body)}
@media (prefers-contrast: more){.muted{color:#414856}.tab{border-color:var(--graphite)}}

/* --------------------- hosted campaign pages: themes, blocks, embeds ---- */
.camp-hero{margin:-4px 0 18px;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:0 10px 26px rgba(30,43,69,.10)}
.camp-hero img{display:block;width:100%;max-height:330px;object-fit:cover}
.camp-blocks{margin:4px 0 22px}
.camp-blocks h2{font-family:var(--display);font-size:1.45rem;margin:18px 0 8px;color:var(--ink)}
.camp-blocks h3{font-size:1.05rem;margin:14px 0 6px;color:var(--ink)}
.camp-blocks p{color:var(--graphite);margin:0 0 12px;line-height:1.65}
.camp-blocks blockquote{border-left:4px solid var(--seal);background:#fff;padding:12px 16px;border-radius:0 10px 10px 0;font-family:var(--display);font-style:italic;font-size:1.05rem;color:var(--ink);margin:14px 0}
.camp-blocks figure{margin:8px 0 16px}
.camp-blocks img{max-width:100%;border-radius:12px;border:1px solid var(--line);display:block}
.camp-blocks figcaption{font-size:.82rem;color:var(--graphite);margin-top:6px}
.camp-blocks hr{border:0;border-top:1px dashed var(--line);margin:18px 0}
.pub.theme-ink .pub-head{background:var(--ink)}
.pub.theme-ink .pub-org{color:#fff}
.pub.theme-ink .pub-pow{color:#C6CCDA}
.pub.theme-bold .pub-head{background:var(--seal)}
.pub.theme-bold .pub-org{color:#fff}
.pub.theme-bold .pub-pow{color:rgba(255,255,255,.85)}
.pub.theme-white .pub-main,.pub.theme-transparent .pub-main{background:transparent}
.pub.theme-transparent .card{box-shadow:none}
.pub.embed-mode .pub-main{padding:8px 0 4px}
.pub.embed-mode .pub-grid{grid-template-columns:1fr}
.pub.embed-mode .wrap{padding-left:8px;padding-right:8px;max-width:760px}
.emb-pow{text-align:right;padding:2px 10px 8px;font-size:.72rem}
.emb-pow a{color:var(--graphite);text-decoration:none}
.emb-pow a:hover{color:var(--seal)}

/* coming-soon delivery tiles + contact-list chips */
.meth label{position:relative;overflow:hidden}
.meth label.soon{cursor:not-allowed;border-style:dashed;opacity:.9}
.meth label.soon input{pointer-events:none}
.meth label.soon b,.meth label.soon small,.meth label.soon .cost{opacity:.55}
.ribbon{position:absolute;top:20px;right:-46px;transform:rotate(35deg);background:var(--seal);color:#fff;font:700 .55rem var(--body);letter-spacing:.06em;text-transform:uppercase;padding:4px 56px;box-shadow:0 2px 6px rgba(30,43,69,.25);pointer-events:none;white-space:nowrap}
.tag-chip{display:inline-flex;align-items:center;gap:6px;border:1.5px solid var(--line);border-radius:999px;padding:6px 12px;font:600 .82rem var(--body);background:#fff;margin:0 6px 8px 0;color:var(--ink)}
input[type=file]{border:1.5px dashed var(--line);border-radius:10px;padding:10px;background:#fff;width:100%;font:500 .9rem var(--body)}
/* v3 polish — institutional finish */
.field .hint{display:none}
.field:focus-within .hint{display:block}
.field>label{font-weight:600}
details.card>summary{list-style:none}
details.card>summary::-webkit-details-marker{display:none}
details.card>summary:before{content:'\25B8  ';color:var(--seal)}
details[open].card>summary:before{content:'\25BE  '}
.ccbar{position:fixed;left:0;right:0;bottom:0;z-index:140;background:var(--paper);border-top:2px solid var(--ink);box-shadow:0 -10px 30px -12px rgba(30,43,69,.35);padding:14px 0 calc(14px + env(safe-area-inset-bottom))}
.ccbar-in{max-width:1100px;margin:0 auto;padding:0 18px;display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.cctext{flex:1 1 380px;font-size:.92rem;color:var(--graphite)}
.cctext b{color:var(--ink)}
.ccacts{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.ccoverlay{position:fixed;inset:0;background:rgba(20,28,46,.5);z-index:150}
.ccmodal{position:fixed;z-index:160;left:50%;top:50%;transform:translate(-50%,-50%);width:min(520px,calc(100vw - 28px));max-height:min(86vh,640px);overflow:auto;background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;box-shadow:0 30px 80px -20px rgba(20,28,46,.5)}
.ccrow{display:flex;gap:14px;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding:13px 0}
.ccrow p{margin:3px 0 0;font-size:.85rem;color:var(--graphite)}
.ccon{font:700 .68rem var(--body);letter-spacing:.06em;background:#EDEAF1;color:var(--ink);border-radius:99px;padding:5px 10px;white-space:nowrap}
.ccsw{position:relative;display:inline-block;flex:0 0 auto}
.ccsw input{position:absolute;opacity:0;width:46px;height:26px;margin:0;cursor:pointer}
.ccsw i{display:block;width:46px;height:26px;border-radius:99px;background:#CFCBC0;transition:background .15s;position:relative}
.ccsw i:after{content:'';position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:left .15s;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.ccsw input:checked+i{background:var(--green)}
.ccsw input:checked+i:after{left:23px}
.ccsw input:focus-visible+i{outline:2px solid var(--seal);outline-offset:2px}
@media(max-width:640px){.ccacts{width:100%}.ccacts .btn{flex:1;justify-content:center}.ccmodal{padding:18px 16px}}
.proof{font-size:.86rem;color:var(--ink);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.proof .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(53,102,72,.5);animation:proofpulse 2.2s infinite}
@keyframes proofpulse{0%{box-shadow:0 0 0 0 rgba(53,102,72,.45)}70%{box-shadow:0 0 0 7px rgba(53,102,72,0)}100%{box-shadow:0 0 0 0 rgba(53,102,72,0)}}
li.cap{display:flex;gap:8px;align-items:flex-start;color:var(--graphite);font-size:.92rem;margin:6px 0}
html.a11y-lg{font-size:115%}
html.a11y-dys body, html.a11y-dys input, html.a11y-dys textarea, html.a11y-dys select, html.a11y-dys button{font-family:'Atkinson Hyperlegible',var(--body)!important;letter-spacing:.01em;word-spacing:.06em}
html.a11y-dys .letter-body, html.a11y-dys .dletter{font-family:'Atkinson Hyperlegible',Georgia,serif!important;line-height:1.75}
html.a11y-dys body{font-family:'Atkinson Hyperlegible',var(--body);letter-spacing:.01em;word-spacing:.06em;line-height:1.65}
html.a11y-dys .letter-body,html.a11y-dys h1,html.a11y-dys h2,html.a11y-dys h3{font-family:'Atkinson Hyperlegible',sans-serif}
.a11y-ctl{display:inline-flex;gap:6px;align-items:center}
.a11y-ctl button[aria-pressed="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}
/* landing demo */
.demo-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:0 18px 50px -18px rgba(30,43,69,.35);position:relative}
.demo-chip{position:absolute;top:-12px;right:14px;background:var(--ink);color:#fff;font:600 .68rem/1 var(--body);letter-spacing:.08em;padding:6px 10px;border-radius:99px;display:flex;gap:6px;align-items:center}
.demo-chip .ddot{width:7px;height:7px;border-radius:50%;background:#F0B429;animation:proofpulse 2.2s infinite}
.dlabel{display:block;font:600 .8rem var(--body);color:var(--graphite);margin:10px 0 6px}.dlabel small{font-weight:500}
.drow{display:flex;gap:8px;flex-wrap:wrap}.drow input{flex:1;min-width:140px}
.dhint{font-size:.78rem;color:var(--graphite);margin:8px 0 0}
.drep{display:flex;gap:10px;align-items:center;background:#FBFAF6;border:1px solid var(--line);border-radius:10px;padding:10px 12px}
.dava{width:38px;height:38px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font:700 .85rem var(--body)}
.dtag{margin-left:auto;font:700 .62rem var(--body);letter-spacing:.1em;color:var(--green);border:1px solid var(--green);border-radius:99px;padding:3px 8px}
.dtones{display:flex;gap:6px;flex-wrap:wrap}
.dtone{border:1px solid var(--line);background:#fff;border-radius:99px;padding:7px 12px;font:600 .8rem var(--body);cursor:pointer}
.dtone.sel{background:var(--ink);color:#fff;border-color:var(--ink)}
#dm-note{width:100%;margin-bottom:10px}
.dwriting{text-align:center;padding:26px 8px}
.dring{display:inline-flex;width:54px;height:54px;border-radius:50%;border:2px dashed var(--seal);color:var(--seal);align-items:center;justify-content:center;font:700 .9rem Georgia,serif;animation:dspin 1.4s linear infinite}
@keyframes dspin{to{transform:rotate(360deg)}}
.demo-sheet{padding:18px;max-height:300px;overflow:auto}
.dsub{font:600 .8rem var(--body);color:var(--graphite);border-bottom:1px solid var(--line);padding-bottom:8px;margin-bottom:10px}
.dletter{font-family:Georgia,serif;font-size:.92rem;line-height:1.6;white-space:pre-wrap}
.dletter .caret{display:inline-block;width:2px;height:1em;background:var(--ink);vertical-align:-2px;animation:dblink .8s steps(1) infinite}
@keyframes dblink{50%{opacity:0}}
.ddone{text-align:center;padding:6px 4px}.ddone h3{margin:10px 0 6px}
@media(prefers-reduced-motion:reduce){.dring,.demo-chip .ddot,.dletter .caret{animation:none}}
/* pricing matrix */
.matrix-wrap{overflow:auto;margin-top:26px;border:1px solid var(--line);border-radius:12px;background:#fff}
table.matrix{width:100%;border-collapse:collapse;min-width:640px}
.matrix th,.matrix td{padding:11px 14px;border-bottom:1px solid var(--line);text-align:center;font-size:.92rem}
.matrix td:first-child,.matrix th:first-child{text-align:left}
.matrix thead th{font:700 .8rem var(--body);letter-spacing:.04em;text-transform:uppercase;color:var(--graphite);background:#FBFAF6}
.matrix .pop{position:relative}
.matrix .pop .badge-pop{position:absolute;top:-1px;left:50%;transform:translate(-50%,-100%);background:var(--seal);color:#fff;font:700 .6rem var(--body);letter-spacing:.1em;padding:4px 9px;border-radius:99px 99px 0 0}
.matrix .yes{color:var(--green)}.matrix .no{color:#C8C4B8}
.matrix tbody tr:last-child td{border-bottom:0}
.tbl th{font:700 .7rem/1.2 var(--body);letter-spacing:.07em;text-transform:uppercase;color:var(--graphite);background:#FBFAF6;border-bottom:2px solid var(--line);padding:10px 12px;text-align:left}
.tbl td{padding:11px 12px;vertical-align:top}
.tbl tr:nth-child(even) td{background:#FCFBF8}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:18px}
.kpis .stat .n,.mono{font-variant-numeric:tabular-nums}
table.bars{width:100%;border-collapse:collapse}
table.bars td{padding:5px 6px;font-size:.86rem;color:var(--graphite)}
.bar{height:10px;background:var(--line);border-radius:99px;overflow:hidden}
.bar i{display:block;height:100%;background:var(--ink);border-radius:99px;min-width:2px}
.bar i.alt{background:var(--green)}
.btn{letter-spacing:.01em}
:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:4px}
.card h3{font-size:1rem}
.lang-chip{display:inline-block;border:1.5px solid var(--line);border-radius:999px;padding:5px 12px;font:700 .76rem var(--body);color:var(--ink);text-decoration:none;background:#fff}
.lang-chip:hover{border-color:var(--seal);color:var(--seal)}

/* ===================== v4 — GUIDED CAMPAIGN WIZARD ===================== */
.wz{max-width:920px}
.wz-track{display:flex;gap:6px;list-style:none;padding:0;margin:0 0 20px;flex-wrap:wrap}
.wz-track li{flex:1;min-width:110px;display:flex;align-items:center;gap:9px;padding:10px 12px;border:1.5px solid var(--line);border-radius:11px;background:#fff;font:600 .82rem var(--body);color:var(--graphite)}
.wz-track li i{width:26px;height:26px;flex:none;border-radius:50%;background:var(--line);color:var(--graphite);display:grid;place-items:center;font-style:normal;font-size:.78rem;font-weight:700;transition:background .15s}
.wz-track li.on{border-color:var(--ink);color:var(--ink);box-shadow:0 3px 10px rgba(30,43,69,.09)}
.wz-track li.on i{background:var(--ink);color:#fff}
.wz-track li.done{border-color:#bcd3c4;color:var(--green);cursor:pointer}
.wz-track li.done:hover{border-color:var(--green)}
.wz-track li.done i{background:var(--green);color:#fff}
@media(max-width:820px){.wz-track li span{display:none}.wz-track li{min-width:0;justify-content:center;padding:9px 6px}}
.wz-step{display:none;animation:fin .22s ease}
.wz-step.on{display:block}
.wz-step>.card>h3{font-size:1.3rem;margin-bottom:4px}
.wz-lede{color:var(--graphite);font-size:.98rem;margin:0 0 18px;max-width:62ch}
.wz .field input,.wz .field select,.wz .field textarea{font-size:1.03rem;padding:12px 14px}
.wz .field label{font-size:.95rem}
.wz .field small{font-size:.86rem;line-height:1.5}
.wz-nav{display:flex;gap:14px;align-items:center;justify-content:space-between;margin-top:18px;padding:13px 16px;background:#fff;border:1px solid var(--line);border-radius:13px;position:sticky;bottom:12px;box-shadow:0 8px 26px -10px rgba(30,43,69,.28);z-index:8}
.wz-count{font:600 .9rem var(--body);color:var(--graphite);text-align:center}
.wz-err{display:none;background:#FAF0EE;border:1.5px solid #E8C4BE;color:#8E2A1F;border-radius:10px;padding:12px 15px;margin:0 0 14px;font-weight:600;font-size:.95rem}
.wz-err.show{display:flex;gap:9px;align-items:flex-start}
.choices{display:grid;grid-template-columns:repeat(auto-fit,minmax(215px,1fr));gap:12px;margin:6px 0 6px}
.choices.two{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.choice{position:relative;display:block;border:1.5px solid var(--line);border-radius:13px;background:#fff;padding:16px 16px 15px;cursor:pointer;transition:border-color .12s,box-shadow .12s,transform .06s}
.choice:hover{border-color:var(--ink)}
.choice:active{transform:translateY(1px)}
.choice input{position:absolute;opacity:0;pointer-events:none}
.choice b{display:flex;gap:9px;align-items:center;font-size:1.02rem;padding-right:26px}
.choice small{display:block;color:var(--graphite);margin-top:6px;font-size:.87rem;line-height:1.5}
.choice .tick{position:absolute;top:11px;right:11px;width:23px;height:23px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;color:#fff;background:#fff;transition:background .12s}
.choice.sel{border-color:var(--seal);box-shadow:0 0 0 3px rgba(190,58,44,.13)}
.choice.sel .tick{background:var(--green);border-color:var(--green)}
.choice.dis{opacity:.62;cursor:not-allowed}
.choice.dis:hover{border-color:var(--line)}
.choice .swatch{height:36px;border-radius:8px;margin-bottom:10px;border:1px solid var(--line)}
.pt-list{display:flex;flex-direction:column;gap:9px;margin:4px 0 10px}
.pt-row{display:flex;gap:9px;align-items:center}
.pt-row .pt-n{width:28px;height:28px;flex:none;border-radius:50%;background:var(--paper);border:1px solid var(--line);display:grid;place-items:center;font:700 .8rem var(--mono);color:var(--seal)}
.pt-row input{flex:1;border:1.5px solid var(--line);border-radius:9px;padding:12px 13px;font:400 1.02rem var(--body);min-width:0}
.pt-row input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(30,43,69,.12)}
.pt-row .pt-x{flex:none;border:1.5px solid var(--line);background:#fff;color:var(--graphite);width:38px;height:38px;border-radius:9px;cursor:pointer;font-size:1.15rem;line-height:1}
.pt-row .pt-x:hover{color:var(--seal);border-color:var(--seal)}
.wz-ai{border:1.5px dashed #C9B8A4;border-radius:13px;padding:16px 18px;background:linear-gradient(135deg,#FDFBF5,#FAF6EC);margin-bottom:18px}
.wz-ai b{display:flex;gap:8px;align-items:center}
.wz-ai .drow{margin-top:10px}
.wz-restore{background:#EEF4F9;border:1.5px solid #C2D4E3;border-radius:11px;padding:12px 15px;margin-bottom:14px;display:flex;gap:12px;align-items:center;flex-wrap:wrap;font-size:.93rem}
.wz-review .rv{display:flex;gap:14px;padding:11px 0;border-bottom:1px dashed var(--line);font-size:.96rem;align-items:baseline}
.wz-review .rv:last-child{border-bottom:0}
.wz-review .rv>b{flex:none;width:158px;font-weight:600}
.wz-review .rv>span{flex:1;color:var(--ink);overflow-wrap:anywhere}
.wz-review .rv>a{flex:none;font-size:.85rem;color:var(--blue)}
.rv-ok{color:var(--green);font-weight:600} .rv-no{color:var(--seal);font-weight:600}
.wz-preview{background:#fff;border:1px solid var(--line);border-radius:6px;box-shadow:0 2px 4px rgba(30,43,69,.07),0 16px 40px -18px rgba(30,43,69,.3);padding:26px 28px;position:relative}
.wz-preview:before{content:"";position:absolute;top:9px;right:11px;width:38px;height:46px;border:1px dashed var(--line);border-radius:3px;opacity:.6}
.wz-preview .pv-org{font:700 .7rem var(--body);letter-spacing:.09em;text-transform:uppercase;border-top:5px solid var(--ink);padding-top:9px;margin-bottom:12px;color:var(--graphite)}
.wz-preview h4{font-size:1.15rem;margin:0 0 8px}
.wz-preview .pv-bg{color:var(--graphite);font-size:.9rem}
.wz-preview ul{margin:10px 0;padding:0;list-style:none}
.wz-preview li{display:flex;gap:8px;padding:3px 0;font-size:.88rem}
.wz-preview li:before{content:"✓";color:var(--seal);font-weight:700}
.wz-preview .pv-ask{font-weight:600;font-size:.92rem;border-left:3px solid var(--seal);padding-left:10px;margin-top:10px}
.wz-skip{text-align:center;margin-top:10px}
.wz-skip a{color:var(--graphite);font-size:.88rem}
@media(max-width:680px){.wz-nav{position:static;flex-wrap:wrap}.wz-nav .btn{flex:1;justify-content:center}.wz-count{width:100%;order:-1}.wz-review .rv{flex-wrap:wrap}.wz-review .rv>b{width:100%}}

/* ===================== v4 — FRIENDLY DASHBOARD ===================== */
.dash-hero{background:linear-gradient(135deg,#FFFFFF 0%,#FBFAF4 100%);border:1px solid var(--line);border-radius:16px;padding:26px 28px 24px;display:flex;gap:24px;align-items:center;flex-wrap:wrap;box-shadow:var(--shadow);position:relative;overflow:hidden;margin-bottom:18px}
.dash-hero:before{content:"";position:absolute;inset:0 0 auto 0;height:7px;background:repeating-linear-gradient(135deg,var(--seal) 0 14px,#fff 14px 24px,var(--ink) 24px 38px,#fff 38px 48px)}
.dash-hero h2{margin:4px 0 4px;font-size:1.7rem}
.dash-hero .postmark{color:#D8D4C6;flex:none}
.dash-hero p{margin:0;color:var(--graphite)}
.dash-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.dash-cta .btn.lg{font-size:1.05rem}
.onb-row{display:flex;gap:15px;align-items:center;padding:14px 0;border-bottom:1px dashed var(--line)}
.onb-row:last-child{border-bottom:0;padding-bottom:4px}
.onb-row:first-of-type{padding-top:4px}
.onb-n{width:36px;height:36px;flex:none;border-radius:50%;border:2px solid var(--line);display:grid;place-items:center;font:700 1rem var(--display);color:var(--graphite);background:#fff}
.onb-row.done .onb-n{background:var(--green);border-color:var(--green);color:#fff}
.onb-row.next .onb-n{border-color:var(--seal);color:var(--seal)}
.onb-row.done .onb-t{color:var(--graphite);text-decoration:line-through}
.onb-t{font-weight:600;font-size:1.02rem}
.onb-row p{margin:2px 0 0;font-size:.88rem;color:var(--graphite)}
.onb-row .btn{margin-left:auto;flex:none}
.campcards{display:grid;grid-template-columns:repeat(auto-fit,minmax(265px,1fr));gap:14px}
.campcard{background:#fff;border:1px solid var(--line);border-radius:13px;padding:18px;display:flex;flex-direction:column;gap:9px;transition:box-shadow .15s,border-color .15s}
.campcard:hover{border-color:var(--ink);box-shadow:var(--shadow)}
.campcard h4{margin:0;font-size:1.06rem;display:flex;gap:8px;align-items:baseline;justify-content:space-between}
.campcard .cc-meta{display:flex;gap:14px;color:var(--graphite);font-size:.86rem;flex-wrap:wrap}
.campcard .cc-meta b{color:var(--ink)}
.campcard .cc-act{display:flex;gap:8px;margin-top:auto;padding-top:6px;flex-wrap:wrap}
.dash-help{display:flex;gap:14px;align-items:center;flex-wrap:wrap;background:var(--ink);color:#E8EAF0;border-radius:14px;padding:18px 22px;margin-top:18px}
.dash-help b{color:#fff}
.dash-help a{color:#fff}
.dash-help .btn.ghost{color:#fff;border-color:rgba(255,255,255,.5)}
.dash-help .btn.ghost:hover{background:rgba(255,255,255,.1)}
@media(max-width:680px){.onb-row{flex-wrap:wrap}.onb-row .btn{margin-left:51px}.dash-hero .postmark{display:none}}
/* v4 — two-step signup */
.su-steps{display:flex;gap:6px;margin:0 0 18px}
.su-steps i{height:6px;flex:1;border-radius:99px;background:var(--line);transition:background .2s}
.su-steps i.on{background:var(--seal)}
.auth-card .btn.lg{font-size:1.04rem}
.auth-card .field input,.auth-card .field select{font-size:1.03rem;padding:12px 14px}
/* v4 — receipts */
.rcpt-sheet{background:#fff;border:1px solid var(--line);border-radius:6px;box-shadow:0 2px 4px rgba(30,43,69,.07),0 16px 40px -18px rgba(30,43,69,.3);padding:36px 40px;max-width:640px;margin:0 auto;font-size:.95rem}
.rcpt-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;border-bottom:2px solid var(--ink);padding-bottom:14px;margin-bottom:18px}
.rcpt-head h2{margin:0;font-size:1.4rem}
.rcpt-meta{font-size:.85rem;color:var(--graphite);text-align:right}
.rcpt-rows{width:100%;border-collapse:collapse;margin:14px 0}
.rcpt-rows td{padding:9px 4px;border-bottom:1px solid #EFEDE5}
.rcpt-rows td:last-child{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
.rcpt-rows tr.total td{border-top:2px solid var(--ink);border-bottom:0;font-weight:700;font-size:1.05rem}
.rcpt-foot{margin-top:18px;padding-top:12px;border-top:1px solid var(--line);font-size:.8rem;color:var(--graphite)}
@media print{.rcpt-sheet{box-shadow:none;border:0;max-width:none;padding:0}}
/* ============== v4 — supporter campaign page polish (all themes) ============== */
.pub-head .wrap{height:64px}
.pub-org{font-size:1.06rem;display:flex;align-items:center;gap:9px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pub-main{padding:38px 0 72px}
.camp-title h1{font-size:clamp(1.7rem,4.2vw,2.6rem);margin-bottom:10px;letter-spacing:-.015em}
.camp-bg{font-size:1.06rem;line-height:1.7;max-width:62ch}
.points li{font-size:1rem;padding:6px 0}
.stepper{gap:8px;margin:20px 0 28px}
.stepper .st{font-size:.84rem;padding:8px 15px;min-height:38px}
.pub .card{padding:24px;border-radius:14px;box-shadow:0 1px 2px rgba(30,43,69,.05),0 10px 30px -18px rgba(30,43,69,.18)}
.pub .field input,.pub .field select,.pub .field textarea{font-size:1.03rem;padding:12px 14px}
.pub .btn.lg{font-size:1.05rem}
.pub .btn{min-height:44px}
.pub .btn.sm{min-height:36px}
.rep-card{padding:18px;border-radius:14px}
.rep-card:focus-within,.tone:focus-within,.meth label:focus-within{outline:3px solid var(--blue);outline-offset:2px}
.tone{min-height:40px;display:inline-flex;align-items:center}
.meth label{min-height:96px;border-radius:14px}
.counter{font-size:2.2rem}
.progressbar{height:10px}
.camp-hero{border-radius:16px}
.camp-hero img{max-height:360px}
.pub.theme-craft .pub-main{background:linear-gradient(180deg,rgba(231,216,188,.38),rgba(231,216,188,0) 260px)}
.pub.theme-white .card{border-color:#ECEAE2}
@media(max-width:640px){.pub .card{padding:18px}.pub .btn.lg{width:100%;justify-content:center}.share-box .btn{flex:1 1 40%;justify-content:center}.pub-main{padding:24px 0 56px}}
/* ====================================================================
   patch-cleanup v2 — density + mobile layer
   ==================================================================== */

/* ---- belt-and-suspenders for older mains (harmless on v3.1.6+) ---- */
.mk-foot .mono{display:none}

/* ---- global density pass: same design, less dead air -------------- */
.hero{padding:40px 0 18px}
.sec{padding:36px 0}
.sec-head{margin-bottom:22px}
.sec-head h2{line-height:1.12}
.sec-head p.muted{margin-top:8px}
.trustline{padding:10px 0 14px;gap:12px 20px;font-size:.85rem}
.steps,.delivery{gap:16px}
.step{padding:20px 18px 18px}
.dcard{padding:20px}
.featgrid{gap:14px}
.plans{gap:18px}
.plan{padding:24px 22px}
.cta-band{padding:34px 30px;gap:20px}
.mk-foot{padding:24px 0 calc(24px + env(safe-area-inset-bottom))}
.mk-foot .wrap{gap:10px 18px}
.stepper{margin:14px 0 18px}
.kicker{margin-bottom:10px}
img{max-width:100%}
.matrix-wrap th,.matrix-wrap td{padding:9px 12px}
.matrix-wrap{margin-top:20px}

/* ---- ≤860px: tablet ------------------------------------------------ */
@media(max-width:860px){
  .hero{padding:38px 0 34px}
  .hero-grid{gap:26px}
  .lede{font-size:1.05rem}
  .sec{padding:38px 0}
  .pub-side .card{position:static}          /* layout is stacked — unstick */
  .pub-grid{gap:22px}
  .content{padding:18px 16px}
}

/* ---- ≤760px: forms + nav ------------------------------------------- */
@media(max-width:760px){
  input,select,textarea,
  .field input,.field select,.field textarea{font-size:16px!important}  /* no iOS zoom */
  .btn{min-height:44px}
  .btn.sm{min-height:38px}
  .mk-nav{height:56px}
  .mk-links{top:56px;padding:14px 18px;gap:4px}
  .mk-links a{display:block;padding:11px 4px;width:100%}
  .mk-links .btn{justify-content:center;margin-top:8px}
}

/* ---- ≤640px: phones ------------------------------------------------- */
@media(max-width:640px){
  .wrap{padding:0 16px}
  .hero{padding:28px 0 26px}
  .hero-note{margin-top:10px;font-size:.84rem}
  .hero-cta{display:flex;flex-direction:column;align-items:stretch;gap:10px}
  .hero-cta .btn{justify-content:center}
  .sec{padding:32px 0}
  .sec-head{margin-bottom:18px}
  .steps,.delivery,.plans,.featgrid{gap:12px}
  .card{padding:18px 16px}
  .plan{padding:20px 16px}
  .cta-band{padding:24px 18px;flex-direction:column;align-items:flex-start;text-align:left}
  .cta-band .btn{width:100%;justify-content:center}
  .letter-sheet{padding:20px 16px}
  .demo-sheet{max-height:260px}
  .demo-card{padding:14px}
  .drow{flex-wrap:wrap}
  .drow input{flex:1 1 160px;min-width:0}
  .drow .btn{flex:1 1 auto;justify-content:center}
  .dtones .dtone{flex:1 1 30%;text-align:center}
  .matrix-wrap{font-size:.84rem}
  .matrix-wrap th,.matrix-wrap td{padding:7px 8px;white-space:nowrap}
  .stepper{gap:4px;font-size:.78rem}
  .tbl{font-size:.86rem}
  .copyrow{flex-wrap:wrap}
  .copyrow input{flex:1 1 100%;min-width:0}
  .pub-grid{gap:16px}
  .points li{margin:8px 0}
  .mk-foot{font-size:.84rem;text-align:center}
  .mk-foot .wrap{flex-direction:column;align-items:center}
}

/* ---- ≤440px: small phones ------------------------------------------- */
@media(max-width:440px){
  body{font-size:15px}
  h1{font-size:1.85rem}
  .hero{padding:22px 0 20px}
  .kicker{font-size:.7rem;letter-spacing:.1em}
  .cta-band .postmark{display:none}          /* reclaim a whole band of space */
  .hand-demo{font-size:1.12rem}
  .kpis{grid-template-columns:repeat(2,1fr);gap:10px}
  .btn.lg{padding:12px 16px;font-size:.96rem}
  .demo-chip{font-size:.66rem}
  .drep{padding:8px 10px;gap:8px}
  .plan .price{font-size:1.9rem}
}