/* Fox River Audit Suite — dark theme (mastersat-style layout, Fox River palette) */
:root{
  --bg:#0b1320; --bg2:#0f1a2a; --panel:#142339; --panel2:#192a42;
  --panel-soft:#16263c; --line:rgba(255,255,255,.09); --line2:rgba(255,255,255,.06);
  --cream:#f3ece0; --white:#ffffff; --ash:#90a0b4; --ash2:#6c7b8f;
  --terra:#d2734f; --terra-d:#b85f3d; --terra-soft:rgba(210,115,79,.14);
  --gold:#e2b552; --navy:#14253c;
  --green:#4f9d6a; --amber:#d2a23c; --red:#cf5b48;
  --shadow:0 30px 70px -40px rgba(0,0,0,.8);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--cream);line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
.wrap{max-width:1080px;margin:0 auto;padding:0 22px}
.display{font-family:Fraunces,Georgia,serif}
.t{color:var(--terra)}

/* header */
header.top{background:rgba(11,19,32,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line2);position:sticky;top:0;z-index:30}
header.top .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:13px 22px}
.brand{display:flex;align-items:center;gap:10px;font-family:Fraunces;font-weight:700;font-size:19px;color:var(--white)}
.brand .dot{width:30px;height:30px;border-radius:8px;background:var(--terra);display:grid;place-items:center;color:#fff;font-family:Fraunces;font-weight:700}
.brand small{display:block;font-family:Inter;font-weight:600;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
nav.menu{display:flex;align-items:center;gap:24px;font-size:14px;font-weight:500;color:var(--ash)}
nav.menu a:hover{color:var(--white)}
nav.menu .btn{background:var(--terra);color:#fff;font-weight:600;padding:9px 18px;border-radius:10px}
nav.menu .btn:hover{background:var(--terra-d)}
.linkback{font-size:13px;color:var(--ash)}
.linkback:hover{color:var(--white)}
@media(max-width:720px){.hidem{display:none}}

/* hero */
.hero{padding:74px 0 30px;text-align:center;position:relative}
.hero::after{content:"";position:absolute;inset:0 0 auto 0;height:520px;background:radial-gradient(680px 320px at 50% -40px,rgba(210,115,79,.16),transparent 70%);z-index:-1}
.eyebrow{font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--terra)}
.hero h1{font-size:clamp(34px,5.4vw,58px);font-weight:600;line-height:1.04;letter-spacing:-.6px;color:var(--white);margin-top:14px}
.hero p.sub{font-size:clamp(16px,2.1vw,20px);color:var(--ash);max-width:660px;margin:20px auto 0}
.feat{margin:22px auto 0;display:flex;flex-wrap:wrap;gap:6px 20px;justify-content:center;color:var(--ash);font-size:13px;font-weight:500}
.feat span{display:inline-flex;align-items:center;gap:7px}
.feat span::before{content:"✓";color:var(--terra);font-weight:800}

/* input bar */
form.audit{margin:32px auto 0;max-width:660px;display:flex;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:15px;padding:9px;box-shadow:var(--shadow)}
form.audit input{flex:1;border:0;outline:0;font-size:16px;padding:14px;background:transparent;color:var(--white)}
form.audit input::placeholder{color:var(--ash2)}
form.audit button{border:0;cursor:pointer;background:var(--terra);color:#fff;font-weight:700;font-size:15px;padding:0 24px;border-radius:10px;transition:.15s;white-space:nowrap}
form.audit button:hover{background:var(--terra-d)}
form.audit button:disabled{opacity:.6;cursor:wait}
.microcopy{margin:14px auto 0;color:var(--ash2);font-size:12.5px}
.cats{margin:24px auto 0;display:flex;flex-wrap:wrap;gap:8px 18px;justify-content:center;color:var(--ash);font-size:13px;font-weight:500}
.cats b{color:var(--cream)}

/* section heads */
.kicker{font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--terra)}
.s-title{font-family:Fraunces;font-size:clamp(26px,3.4vw,36px);font-weight:600;color:var(--white);margin:8px 0 0}
.s-sub{color:var(--ash);margin-top:10px;max-width:620px}
.block{padding:54px 0}
.center{text-align:center}

/* tool / cover cards grid */
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:30px}
.grid .spacer{display:none}
@media(min-width:901px){.grid .spacer{display:block}}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:600px){.grid{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:24px;display:flex;flex-direction:column;transition:.18s;position:relative;overflow:hidden}
.card.live:hover{transform:translateY(-3px);border-color:var(--terra);box-shadow:var(--shadow)}
.card .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:22px;background:var(--terra-soft);margin-bottom:14px}
.card h3{font-family:Fraunces;font-size:20px;font-weight:600;color:var(--white)}
.card p{color:var(--ash);font-size:14px;margin-top:7px;flex:1}
.card .meta{margin-top:15px;display:flex;justify-content:space-between;align-items:center;font-size:12px;font-weight:700;color:var(--terra);letter-spacing:.03em}
.badge{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px;border-radius:99px}
.badge.free{background:rgba(79,157,106,.16);color:#7fc593}
.stripe{position:absolute;top:0;left:0;right:0;height:3px;background:var(--terra)}

/* how it works */
.steps3{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:30px}
.step{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:24px}
.step .n{font-family:Fraunces;font-size:34px;font-weight:700;color:var(--terra);line-height:1}
.step h4{font-family:Fraunces;font-size:18px;color:var(--white);font-weight:600;margin:10px 0 5px}
.step p{color:var(--ash);font-size:14px}

/* loading / error */
#load{display:none;text-align:center;padding:48px 0}#load.on{display:block}
.spin{width:46px;height:46px;border-radius:50%;border:4px solid var(--panel);border-top-color:var(--terra);margin:0 auto 18px;animation:s 1s linear infinite}
@keyframes s{to{transform:rotate(360deg)}}
#load .steps{color:var(--ash);font-size:14px}
.err{display:none;background:var(--panel);border:1px solid var(--red);border-left:4px solid var(--red);border-radius:12px;padding:16px;color:#e89a8c;font-weight:600;margin-top:22px}.err.on{display:block}

/* report */
#report{display:none;padding:18px 0 80px}#report.on{display:block}
.toolbar{display:flex;gap:10px;justify-content:flex-end;margin-bottom:16px}
.toolbar button{background:var(--panel);border:1px solid var(--line);color:var(--cream);font-weight:600;font-size:13px;padding:8px 16px;border-radius:9px;cursor:pointer}
.toolbar button:hover{border-color:var(--terra)}
.scorecard,.head{background:linear-gradient(160deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:20px;padding:32px;display:flex;gap:32px;align-items:center;flex-wrap:wrap;box-shadow:var(--shadow)}
.gauge{position:relative;flex:0 0 160px;width:160px;height:160px}
.head .gauge{flex:0 0 128px;width:128px;height:128px}
.gauge svg{transform:rotate(-90deg)}
.gauge .num{position:absolute;inset:0;display:grid;place-content:center;text-align:center}
.gauge .num b{font-family:Fraunces;font-size:46px;font-weight:700;line-height:1;display:block;color:var(--white)}
.head .gauge .num b{font-size:38px}
.gauge .num small{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}
.scoremeta,.head .meta{flex:1;min-width:240px}
.scoremeta .url,.head .meta .url{font-size:13px;color:var(--gold);word-break:break-all;font-weight:600}
.scoremeta h2,.head .meta h2{font-family:Fraunces;font-size:25px;font-weight:600;margin:6px 0 5px;color:var(--white)}
.scoremeta p,.head .meta p{color:var(--ash);font-size:14px}
.gradechip{display:inline-block;font-family:Fraunces;font-weight:700;font-size:15px;padding:3px 14px;border-radius:999px;margin-top:12px;color:#fff}

.bars{margin:30px 0 8px;display:grid;grid-template-columns:1fr 1fr;gap:16px 30px}
@media(max-width:680px){.bars{grid-template-columns:1fr}.scorecard,.head{padding:24px}}
.bar .row{display:flex;justify-content:space-between;align-items:baseline;font-size:14px;font-weight:600;color:var(--cream)}
.bar .row .w{color:var(--ash2);font-weight:600;font-size:12px}
.bar .track{height:9px;background:var(--bg);border:1px solid var(--line2);border-radius:99px;margin-top:7px;overflow:hidden}
.bar .fill{height:100%;border-radius:99px;transition:width .9s cubic-bezier(.2,.8,.2,1)}
.bar .note{font-size:12.5px;color:var(--ash2);margin-top:4px}

.sectionhead{display:flex;align-items:center;gap:12px;margin:42px 0 14px}
.sectionhead h3,.sec h3{font-family:Fraunces;font-size:22px;font-weight:600;color:var(--white)}
.sectionhead .pill{font-size:12px;font-weight:700;color:#fff;border-radius:99px;padding:3px 11px}
.sec{margin-top:38px}.sec h3{margin-bottom:14px}

.find{background:var(--panel);border:1px solid var(--line);border-left-width:4px;border-radius:12px;padding:14px 16px;margin-bottom:10px}
.find .l{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--white);font-size:15px}
.find .ico{width:20px;height:20px;border-radius:50%;flex:0 0 20px;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:800}
.find .detail{color:var(--ash);font-size:13.5px;margin:4px 0 0 30px}
.find .fix{color:var(--cream);font-size:13.5px;margin:6px 0 0 30px;padding-left:10px;border-left:2px solid var(--terra)}
.find .fix b{color:var(--terra)}
.pass{border-left-color:var(--green)} .pass .ico{background:var(--green)}
.warn{border-left-color:var(--amber)} .warn .ico{background:var(--amber)}
.fail{border-left-color:var(--red)} .fail .ico{background:var(--red)}

.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:14px}
.meta-grid .m{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:13px 15px}
.meta-grid .m b{display:block;font-family:Fraunces;font-size:20px;color:var(--white)}
.meta-grid .m span{font-size:12px;color:var(--ash2);font-weight:600}

/* AI report section types */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px}
.c{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 18px;border-top:3px solid var(--terra)}
.c .tag{display:inline-block;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--terra);background:var(--terra-soft);padding:2px 9px;border-radius:99px;margin-bottom:8px}
.c h4{font-family:Fraunces;font-size:17px;color:var(--white);font-weight:600;line-height:1.25}
.c p{font-size:13.5px;color:var(--ash);margin-top:6px}
.list .li{background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--terra);border-radius:12px;padding:13px 16px;margin-bottom:9px}
.list .li b{color:var(--white);font-size:15px}
.list .li p{color:var(--ash);font-size:13.5px;margin-top:3px}
table{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;font-size:13.5px}
thead{background:var(--bg2);color:var(--white)}
th,td{text-align:left;padding:10px 13px;border-bottom:1px solid var(--line2);vertical-align:top;color:var(--cream)}
tbody tr:nth-child(even){background:rgba(255,255,255,.02)}

/* CTA */
.cta{margin-top:46px;background:linear-gradient(120deg,var(--terra),var(--terra-d));color:#fff;border-radius:20px;padding:34px;text-align:center}
.cta h3{font-family:Fraunces;font-size:25px;font-weight:600;margin-bottom:8px}
.cta p{opacity:.94;max-width:540px;margin:0 auto 18px}
.cta a{display:inline-block;background:#fff;color:var(--terra-d);font-weight:700;padding:13px 28px;border-radius:11px}

footer{border-top:1px solid var(--line2);color:var(--ash2);padding:28px 0;text-align:center;font-size:13px}
footer a{color:var(--gold)}

@media print{
  body{background:#fff;color:#111}
  header.top,form.audit,.toolbar,.hero p.sub,.feat,.cats,.cta a{display:none!important}
  .scorecard,.head,.find,.c,.card,table,.list .li,.meta-grid .m{background:#fff!important;color:#111!important;border-color:#ddd!important}
  .scoremeta h2,.head .meta h2,.sec h3,.sectionhead h3,.c h4,.find .l,.gauge .num b{color:#14253c!important}
}

/* 90-day plan email gate */
.gate{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px}
.gaterow{display:flex;gap:10px;flex-wrap:wrap}
.gaterow input{flex:1;min-width:220px;border:1px solid var(--line);background:var(--bg2);color:var(--white);border-radius:10px;padding:13px 14px;font-size:15px;outline:0}
.gaterow input:focus{border-color:var(--terra)}
.gaterow button{border:0;cursor:pointer;background:var(--terra);color:#fff;font-weight:700;font-size:15px;padding:0 22px;border-radius:10px;white-space:nowrap}
.gaterow button:hover{background:var(--terra-d)}
.gaterow button:disabled{opacity:.6;cursor:default}
.gcheck{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:13px;color:var(--ash)}
.gcheck input{accent-color:var(--terra)}
