/* Fetcher LLC — Enterprise & Government theme
   Pneumatic-mailroom system, dialed to enterprise/government gravitas. */
:root{
  --manila:#F6F0DE; --paper:#FBF9F0; --manila-deep:#EEE4CB;
  --ink:#1F2635; --ink-soft:#414856; --ink-mute:#636975;
  --stamp:#CC361E; --stamp-deep:#A52110;
  --ledger:#206749; --ledger-soft:#D7EFE2;
  --kraft-line:#B8A17A; --kraft:#D5C29C;
  --sans:"Bricolage Grotesque",system-ui,-apple-system,Segoe UI,sans-serif;
  --mono:"Fragment Mono",ui-monospace,Menlo,Consolas,monospace;
  --maxw:1140px;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
html:not(.reduce){scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.6;font-size:17px;font-weight:400;overflow-x:hidden}
h1,h2,h3{font-weight:800;line-height:1.08;letter-spacing:-.02em;margin:0}
p{margin:0 0 1em}
a{color:inherit}
img{max-width:100%;height:auto}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.mono{font-family:var(--mono);font-weight:400}
.eyebrow{font-family:var(--mono);font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--stamp);margin:0 0 14px;display:flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--stamp);display:inline-block}
.eyebrow.center{justify-content:center}
.btn{position:relative;display:inline-flex;align-items:center;gap:.5em;font-family:var(--sans);font-weight:700;font-size:15.5px;text-decoration:none;padding:.85em 1.5em;border-radius:4px;border:1.5px solid transparent;cursor:pointer;transition:transform .25s var(--ease),background .2s,color .2s,box-shadow .25s;will-change:transform}
.btn-primary{background:var(--stamp);color:#fff;border-color:var(--stamp);box-shadow:0 6px 20px rgba(204,54,30,.22)}
.btn-primary:hover{background:var(--stamp-deep);border-color:var(--stamp-deep);box-shadow:0 10px 30px rgba(204,54,30,.35)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-ghost-light{background:transparent;color:var(--paper);border-color:rgba(251,249,240,.45)}
.btn-ghost-light:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

/* scroll progress */
.progress{position:fixed;top:0;left:0;height:3px;width:100%;transform:scaleX(0);transform-origin:0 50%;background:var(--stamp);z-index:100}
html.reduce .progress,html.no-js .progress{display:none}

/* header */
header.site{position:sticky;top:0;z-index:60;background:rgba(251,249,240,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--kraft-line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;font-weight:800;font-size:21px;letter-spacing:-.02em;color:var(--ink)}
.brand .seal{width:30px;height:30px;flex:0 0 auto;transition:transform .6s var(--ease)}
.brand:hover .seal{transform:rotate(150deg)}
.brand small{font-family:var(--mono);font-weight:400;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);display:block;line-height:1;margin-top:3px}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{position:relative;font-size:15px;text-decoration:none;color:var(--ink-soft);font-weight:600}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--stamp);transform:scaleX(0);transform-origin:0;transition:transform .3s var(--ease)}
.nav-links a:hover{color:var(--stamp)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{display:flex;align-items:center;gap:14px}
.menu-toggle{display:none;background:none;border:1.5px solid var(--ink);border-radius:4px;padding:6px 10px;font-family:var(--mono);font-size:12px;cursor:pointer}

/* hero */
.hero{position:relative;background:var(--ink);color:var(--paper);overflow:hidden;border-bottom:3px solid var(--stamp)}
#zk-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block}
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(circle at 22% 50%,rgba(31,38,53,.72),transparent 55%)}
.hero .wrap{position:relative;z-index:2;padding:96px 24px 86px;display:grid;grid-template-columns:1.35fr .9fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(34px,4.6vw,60px);color:var(--paper)}
.hero h1 .hl{color:var(--stamp)}
.hero h1 .line{display:block;overflow:hidden}
.hero .lede{font-size:clamp(17px,1.4vw,20px);color:#D9DBE0;max-width:36ch;margin:22px 0 30px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.trust-chips{display:flex;flex-wrap:wrap;gap:8px 10px}
.chip{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:#cdd0d6;border:1px solid rgba(251,249,240,.22);border-radius:3px;padding:6px 10px;display:inline-flex;gap:7px;align-items:center;background:rgba(23,29,41,.4)}
.chip b{color:var(--ledger-soft);font-weight:400}
.scrollcue{position:absolute;left:50%;bottom:18px;z-index:2;transform:translateX(-50%);font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:rgba(251,249,240,.5);display:flex;flex-direction:column;align-items:center;gap:7px}
.scrollcue .dot{width:5px;height:5px;border-radius:50%;background:var(--stamp)}
html:not(.reduce) .scrollcue .dot{animation:cue 1.7s var(--ease) infinite}
@keyframes cue{0%{transform:translateY(-5px);opacity:0}40%{opacity:1}100%{transform:translateY(7px);opacity:0}}

/* hero glass status card */
.seal-card{justify-self:center;width:100%;max-width:330px;background:rgba(23,29,41,.55);backdrop-filter:blur(7px);border:1px solid rgba(251,249,240,.18);border-radius:12px;padding:28px;box-shadow:0 26px 70px rgba(0,0,0,.4)}
.seal-card .lab{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute)}
.seal-card .val{font-size:15px;color:var(--paper);font-weight:700;margin:2px 0 14px;display:flex;align-items:center;gap:8px}
.seal-card .val:last-child{margin-bottom:0}
.seal-card .pulse{width:7px;height:7px;border-radius:50%;background:var(--ledger)}
html:not(.reduce) .seal-card .pulse{animation:dot 2s ease-in-out infinite}
@keyframes dot{0%,100%{box-shadow:0 0 0 0 rgba(32,103,73,.5)}50%{box-shadow:0 0 0 6px rgba(32,103,73,0)}}
.seal-card .rule{height:1px;background:rgba(251,249,240,.14);margin:0 0 16px}
.seal-card .cardhead{display:flex;align-items:center;gap:10px;margin-bottom:16px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ledger-soft)}

/* marquee */
.marquee{background:var(--stamp);color:var(--paper);overflow:hidden;border-bottom:1px solid var(--stamp-deep);white-space:nowrap}
.marquee .track{display:inline-flex;gap:0;padding:11px 0;font-family:var(--mono);font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;will-change:transform}
html:not(.reduce) .marquee .track{animation:marq 38s linear infinite}
.marquee span{padding:0 26px;position:relative}
.marquee span::after{content:"●";position:absolute;right:-4px;opacity:.5;font-size:8px;top:50%;transform:translateY(-50%)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* sections */
section{padding:88px 0;position:relative}
.sec-head{max-width:660px;margin-bottom:48px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(27px,3.2vw,40px)}
.sec-head p{font-size:18px;color:var(--ink-soft);margin-top:16px}
.bg-manila{background:var(--manila)}
.bg-ink{background:var(--ink);color:var(--paper)}
.bg-ink h2{color:var(--paper)}.bg-ink .sec-head p{color:#c9ccd3}

/* reveal — only active when JS+motion present */
html.anim [data-reveal]{opacity:0;transform:translateY(28px)}
html.anim [data-reveal=fade]{transform:none}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--kraft-line);border:1px solid var(--kraft-line);border-radius:12px;overflow:hidden}
.stat{background:var(--paper);padding:34px 24px;text-align:center}
.stat .num{font-size:clamp(38px,5vw,56px);font-weight:800;letter-spacing:-.03em;line-height:1;color:var(--ink)}
.stat .num .u{color:var(--stamp)}
.stat .lab{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--ink-mute);margin-top:12px;text-transform:uppercase}

/* problem */
.prob-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.prob-list{list-style:none;margin:0;padding:0;display:grid;gap:18px}
.prob-list li{display:flex;gap:14px;font-size:16.5px;color:var(--ink-soft)}
.prob-list .x{color:var(--stamp);font-family:var(--mono);font-weight:700;flex:0 0 auto}
.statement{background:var(--ink);color:var(--paper);border-radius:12px;padding:34px 32px;font-size:21px;font-weight:700;line-height:1.35;letter-spacing:-.01em}
.statement .mono{display:block;color:var(--ledger-soft);font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:14px;font-weight:400}

/* zk steps */
.zk-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:zk}
.zk-step{background:var(--paper);border:1px solid var(--kraft-line);border-radius:12px;padding:28px 24px;position:relative;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.zk-step:hover{transform:translateY(-4px);box-shadow:0 16px 34px rgba(31,38,53,.1)}
.zk-step::before{counter-increment:zk;content:"0" counter(zk);font-family:var(--mono);font-size:13px;color:var(--stamp);letter-spacing:.1em}
.zk-step h3{font-size:19px;margin:10px 0 8px}
.zk-step p{font-size:15px;color:var(--ink-soft);margin:0}
.zk-note{margin-top:34px;border-left:3px solid var(--ledger);background:var(--ledger-soft);border-radius:0 8px 8px 0;padding:20px 24px;font-size:15px;color:#13402b}
.zk-note b{color:var(--ledger)}

/* cap grid */
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--kraft-line);border:1px solid var(--kraft-line);border-radius:12px;overflow:hidden}
.cap{background:var(--paper);padding:30px 26px;transition:background .3s}
.cap:hover{background:var(--manila)}
.cap .ic{width:30px;height:30px;color:var(--stamp);margin-bottom:14px}
.cap h3{font-size:18px;margin-bottom:8px}
.cap p{font-size:14.5px;color:var(--ink-soft);margin:0}

/* deployment */
.deploy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.deploy{border:1px solid rgba(251,249,240,.18);border-radius:12px;padding:28px 26px;background:rgba(251,249,240,.03);transition:transform .3s var(--ease),border-color .3s}
.deploy:hover{transform:translateY(-4px);border-color:rgba(215,239,226,.4)}
.deploy .tag{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ledger-soft)}
.deploy h3{color:var(--paper);font-size:20px;margin:8px 0 10px}
.deploy p{color:#c9ccd3;font-size:14.5px;margin:0}

/* audiences */
.aud-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.aud{text-align:center;padding:26px 14px;border:1px solid var(--kraft-line);border-radius:12px;background:var(--paper);transition:transform .3s var(--ease),box-shadow .3s}
.aud:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(31,38,53,.1)}
.aud .ic{width:28px;height:28px;color:var(--ink);margin:0 auto 12px}
.aud h3{font-size:15.5px;letter-spacing:-.01em}

/* tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start}
.tier{background:var(--paper);border:1px solid var(--kraft-line);border-radius:14px;padding:32px 28px;display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s}
.tier:hover{transform:translateY(-5px);box-shadow:0 20px 44px rgba(31,38,53,.12)}
.tier.feature{border:2px solid var(--ink);box-shadow:0 18px 40px rgba(31,38,53,.12)}
.tier .name{font-family:var(--mono);font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--stamp)}
.tier h3{font-size:24px;margin:8px 0 4px}
.tier .price{font-size:15px;color:var(--ink-mute);font-family:var(--mono);margin-bottom:6px}
.tier .who{font-size:14.5px;color:var(--ink-soft);min-height:42px;margin-bottom:18px}
.tier ul{list-style:none;margin:0 0 24px;padding:0;display:grid;gap:11px;font-size:14.5px}
.tier li{display:flex;gap:10px;color:var(--ink-soft)}
.tier li .tick{color:var(--ledger);flex:0 0 auto;font-weight:700}
.tier .btn{margin-top:auto;justify-content:center}
.tier-note{text-align:center;font-size:14px;color:var(--ink-mute);margin-top:22px;font-family:var(--mono)}

/* compliance */
.comp-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.comp-list{list-style:none;margin:0;padding:0;display:grid;gap:16px}
.comp-list li{display:flex;gap:13px;font-size:15.5px;color:var(--ink-soft)}
.comp-list .tick{color:var(--ledger);flex:0 0 auto;font-weight:700}
.honest{border:1px dashed var(--kraft-line);border-radius:12px;padding:24px;background:var(--manila);font-size:14.5px;color:var(--ink-soft)}
.honest h3{font-size:15px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink);margin-bottom:10px}

/* engagement */
.eng{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:eng}
.eng-step{position:relative;padding-top:22px}
.eng-step::before{counter-increment:eng;content:counter(eng);position:absolute;top:0;left:0;font-family:var(--mono);font-size:13px;color:var(--paper);background:var(--stamp);width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-weight:700}
.eng-step h3{font-size:16.5px;margin:14px 0 6px}
.eng-step p{font-size:14px;color:var(--ink-soft);margin:0}

/* cta/form */
.cta{background:var(--ink);color:var(--paper)}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.cta h2{color:var(--paper);font-size:clamp(28px,3.4vw,42px)}
.cta .lede{color:#c9ccd3;font-size:17px;margin-top:16px}
.cta-contacts{margin-top:26px;display:grid;gap:12px;font-size:15px}
.cta-contacts a{color:var(--ledger-soft);text-decoration:none;font-family:var(--mono);font-size:14px}
form.demo,.demo--plugin{background:rgba(251,249,240,.04);border:1px solid rgba(251,249,240,.16);border-radius:14px;padding:28px}
form.demo label{display:block;font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:#aeb2bb;margin:0 0 6px}
form.demo .field{margin-bottom:16px}
form.demo input,form.demo select,form.demo textarea{width:100%;font-family:var(--sans);font-size:15px;padding:11px 13px;border-radius:6px;border:1px solid rgba(251,249,240,.22);background:#171d29;color:var(--paper);transition:border-color .2s,box-shadow .2s}
form.demo input:focus,form.demo select:focus,form.demo textarea:focus{outline:none;border-color:var(--stamp);box-shadow:0 0 0 3px rgba(204,54,30,.18)}
form.demo input::placeholder,form.demo textarea::placeholder{color:#737884}
form.demo .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
form.demo .btn{width:100%;justify-content:center;margin-top:6px}
form.demo .fineprint{font-size:12px;color:#878c96;margin:12px 0 0;font-family:var(--mono);line-height:1.5}

/* FluentForms ([fluentform id="3"]) restyled to match the dark glass form.
   Scoped to .demo--plugin (the wrapper fetcher_llc_demo_form() outputs).
   !important is used on key paint props to override FluentForms' own CSS. */
.demo--plugin .fluentform,
.demo--plugin .frm-fluent-form,
.demo--plugin form{background:none!important;border:0!important;padding:0!important;margin:0!important;box-shadow:none!important}
.demo--plugin .ff-el-group{margin-bottom:16px}
.demo--plugin .ff-el-input--label label,
.demo--plugin .ff-el-input--label{font-family:var(--mono)!important;font-size:11.5px!important;letter-spacing:.1em;text-transform:uppercase;color:#aeb2bb!important;margin:0 0 6px;font-weight:400!important}
.demo--plugin .ff-el-input--label .ff-el-is-required,
.demo--plugin .text-danger{color:var(--stamp)!important}
.demo--plugin .ff-el-form-control,
.demo--plugin input[type=text],
.demo--plugin input[type=email],
.demo--plugin input[type=tel],
.demo--plugin input[type=number],
.demo--plugin input[type=url],
.demo--plugin select,
.demo--plugin textarea{
  width:100%;font-family:var(--sans)!important;font-size:15px!important;
  padding:11px 13px!important;border-radius:6px!important;
  border:1px solid rgba(251,249,240,.22)!important;background:#171d29!important;color:var(--paper)!important;
  box-shadow:none!important;transition:border-color .2s,box-shadow .2s}
.demo--plugin .ff-el-form-control:focus,
.demo--plugin input:focus,
.demo--plugin select:focus,
.demo--plugin textarea:focus{outline:none!important;border-color:var(--stamp)!important;box-shadow:0 0 0 3px rgba(204,54,30,.18)!important}
.demo--plugin .ff-el-form-control::placeholder,
.demo--plugin textarea::placeholder{color:#737884!important}
.demo--plugin select option{color:#1f2635;background:#fff}
.demo--plugin .ff-el-is-error .ff-el-form-control,
.demo--plugin .ff-el-form-control.error{border-color:var(--stamp)!important}
.demo--plugin .error,
.demo--plugin .ff-el-help-message,
.demo--plugin .ff-description{color:#9aa0aa!important;font-family:var(--mono)!important;font-size:12px!important}
.demo--plugin .ff-message-success{color:var(--ledger-soft)!important;background:rgba(32,103,73,.18)!important;border:1px solid rgba(73,163,125,.4)!important;border-radius:8px;padding:12px 14px}
.demo--plugin .ff-btn-submit,
.demo--plugin button[type=submit]{
  background:var(--stamp)!important;color:#fff!important;border:1.5px solid var(--stamp)!important;
  border-radius:4px!important;font-family:var(--sans)!important;font-weight:700!important;font-size:15.5px!important;
  padding:.85em 1.5em!important;width:100%;cursor:pointer;box-shadow:0 6px 20px rgba(204,54,30,.22);
  transition:transform .25s var(--ease),background .2s}
.demo--plugin .ff-btn-submit:hover,
.demo--plugin button[type=submit]:hover{background:var(--stamp-deep)!important;transform:translateY(-1px)}

/* footer */
footer.site{background:#161b26;color:#aeb2bb;padding:54px 0 34px;font-size:14px}
.foot-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;border-bottom:1px solid rgba(251,249,240,.12);padding-bottom:28px;margin-bottom:24px}
.foot-brand{max-width:320px}
.foot-brand .brand{color:var(--paper);margin-bottom:12px}
.foot-cols{display:flex;gap:56px;flex-wrap:wrap}
.foot-col h4{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:#737884;margin:0 0 12px;font-weight:400}
.foot-col a{display:block;color:#aeb2bb;text-decoration:none;margin-bottom:9px}
.foot-col a:hover{color:var(--paper)}
.foot-legal{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:12.5px;color:#737884;font-family:var(--mono)}

/* secondary pages / blog (page.php, index.php) */
.page-wrap{padding:72px 24px 96px;max-width:820px}
.page-head{margin-bottom:32px}
.page-title{font-size:clamp(28px,3.4vw,42px)}
.page-content,.post-excerpt{font-size:17px;color:var(--ink-soft)}
.page-content h2{font-size:26px;margin:1.4em 0 .5em}
.page-content h3{font-size:20px;margin:1.3em 0 .4em}
.page-content a{color:var(--stamp-deep);text-underline-offset:2px}
.post-list{display:grid;gap:24px}
.post-card{border:1px solid var(--kraft-line);border-radius:12px;padding:26px 28px;background:var(--paper)}
.post-card-title{font-size:22px;margin-bottom:6px}
.post-card-title a{text-decoration:none}
.post-meta{font-size:12px;color:var(--ink-mute);margin-bottom:10px}
.pagination{margin-top:36px}
.pagination .page-numbers{font-family:var(--mono);font-size:14px;padding:6px 11px;border:1px solid var(--kraft-line);border-radius:5px;text-decoration:none;margin-right:6px}
.pagination .current{background:var(--ink);color:var(--paper);border-color:var(--ink)}

@media(max-width:920px){
  .hero .wrap{grid-template-columns:1fr;gap:40px;padding:64px 24px 72px}
  .seal-card{order:-1;max-width:300px}
  .prob-grid,.comp-grid,.cta-grid{grid-template-columns:1fr;gap:32px}
  .zk-steps,.cap-grid,.deploy-grid,.tiers{grid-template-columns:1fr}
  .cap-grid{gap:1px}
  .aud-grid{grid-template-columns:repeat(2,1fr)}
  .eng,.stats{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .menu-toggle{display:inline-block}
  .nav-links.open{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;background:var(--paper);border-bottom:1px solid var(--kraft-line);padding:18px 24px;gap:16px}
}
@media(max-width:520px){
  .aud-grid,.eng,.stats,form.demo .row{grid-template-columns:1fr}
  section{padding:62px 0}
  .nav-cta .btn-ghost{display:none}
}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
