/* SEO Strategy Engine — theme.
   Derived from the Beyond Your Brand style guide. Replace this file with your
   own theme; the HTML uses semantic classes so the structure stays stable. */
:root{
  --green-900:#1f3d2b;
  --green-700:#2f6b43;
  --green-600:#3a7d4f;
  --green-500:#4a9460;
  --tan:#c8a86b;
  --tan-soft:#e3d3b0;
  --paper:#fbfaf6;
  --paper-2:#f4f1e8;
  --ink:#26302a;
  --ink-soft:#5a655d;
  --line:#e2ddd0;
  --blue:#4a78c4;
  --red:#c0533f;
  --amber:#d49a2e;
  --shadow:0 1px 2px rgba(31,61,43,.04),0 8px 24px rgba(31,61,43,.06);
  --shadow-lg:0 4px 12px rgba(31,61,43,.08),0 24px 60px rgba(31,61,43,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Spline Sans',system-ui,sans-serif;
  background:var(--paper);color:var(--ink);line-height:1.6;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(circle at 12% -5%, rgba(58,125,79,.06), transparent 40%),
    radial-gradient(circle at 90% 5%, rgba(200,168,107,.08), transparent 35%);
  background-attachment:fixed;
}
.wrap{max-width:1080px;margin:0 auto;padding:0 28px}

/* top bar */
header{position:sticky;top:0;z-index:50;background:rgba(251,250,246,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:13px}
.logo-mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(145deg,var(--green-600),var(--green-900));display:grid;place-items:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.logo-mark::after{content:"";position:absolute;width:14px;height:14px;border-radius:50%;border:2.5px solid var(--tan);left:11px;top:11px}
.logo-mark span{position:absolute;width:5px;height:5px;border-radius:50%;background:var(--tan);right:9px;bottom:9px}
.brand-txt b{font-family:'Fraunces',serif;font-weight:600;font-size:18px;letter-spacing:-.01em;display:block;line-height:1.1}
.brand-txt small{font-size:11.5px;color:var(--ink-soft);letter-spacing:.04em;text-transform:uppercase}
.byb-tag{font-size:12px;color:var(--ink-soft);display:flex;align-items:center;gap:7px}
.byb-tag .dot{width:7px;height:7px;border-radius:50%;background:var(--green-500);box-shadow:0 0 0 3px rgba(74,148,96,.18)}

/* hero */
.hero{padding:64px 0 30px;text-align:center;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--green-700);font-weight:600;background:rgba(58,125,79,.08);padding:7px 15px;border-radius:100px;border:1px solid rgba(58,125,79,.16);margin-bottom:22px}
h1{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(34px,5.2vw,52px);line-height:1.04;letter-spacing:-.02em;color:var(--green-900);max-width:780px;margin:0 auto}
h1 em{font-style:italic;color:var(--tan)}
.sub{font-size:clamp(16px,2vw,19px);color:var(--ink-soft);max-width:620px;margin:22px auto 0;line-height:1.55}
.demo-note{margin:30px auto 0;max-width:580px;font-size:13px;color:var(--ink-soft);background:var(--paper-2);border:1px dashed var(--tan);border-radius:12px;padding:13px 18px;display:flex;gap:10px;align-items:flex-start;text-align:left}
.demo-note svg{flex-shrink:0;margin-top:2px}

/* stepper */
.stepper{display:flex;justify-content:center;gap:6px;margin:42px 0 8px;flex-wrap:wrap}
.step-pill{display:flex;align-items:center;gap:9px;padding:9px 16px;border-radius:100px;font-size:13px;font-weight:500;color:var(--ink-soft);background:transparent;border:1px solid transparent;transition:.35s}
.step-pill .num{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:11.5px;font-weight:700;background:var(--paper-2);border:1px solid var(--line);transition:.35s}
.step-pill.active{color:var(--green-900);background:#fff;border-color:var(--line);box-shadow:var(--shadow)}
.step-pill.active .num{background:var(--green-700);color:#fff;border-color:var(--green-700)}
.step-pill.done .num{background:var(--green-500);color:#fff;border-color:var(--green-500)}
.step-pill.done{color:var(--green-700)}

/* panels */
main{padding:18px 0 90px}
.panel{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:38px;margin-bottom:26px;display:none;animation:rise .5s cubic-bezier(.2,.7,.3,1) both}
.panel.show{display:block}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.panel-head{margin-bottom:26px}
.panel-kicker{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--tan);font-weight:700;margin-bottom:8px}
.panel-head h2{font-family:'Fraunces',serif;font-weight:600;font-size:26px;color:var(--green-900);letter-spacing:-.01em}
.panel-head p{color:var(--ink-soft);font-size:15px;margin-top:7px;max-width:640px}

/* intake form */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:7px}
.field label .hint{font-weight:400;color:var(--ink-soft);font-size:12px}
.field input,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:11px;font-family:inherit;font-size:14px;color:var(--ink);background:var(--paper);transition:.2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--green-500);box-shadow:0 0 0 3px rgba(74,148,96,.13);background:#fff}
.field-full{grid-column:1/-1}

/* upload zones */
.uploads{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:6px}
.uz{border:1.5px dashed var(--line);border-radius:14px;padding:20px;cursor:pointer;transition:.25s;background:var(--paper);position:relative;overflow:hidden;display:block}
.uz:hover{border-color:var(--tan);background:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}
.uz.filled{border-style:solid;border-color:var(--green-500);background:rgba(74,148,96,.05)}
.uz input[type=file]{display:none}
.uz-top{display:flex;align-items:center;gap:12px}
.uz-ico{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;flex-shrink:0;font-weight:700;font-size:12px;color:#fff;letter-spacing:.02em}
.uz-ga4 .uz-ico{background:linear-gradient(140deg,#e8893a,#d4732a)}
.uz-gsc .uz-ico{background:linear-gradient(140deg,#4a78c4,#3a5fa0)}
.uz-sf  .uz-ico{background:linear-gradient(140deg,#3a7d4f,#1f3d2b)}
.uz-ah  .uz-ico{background:linear-gradient(140deg,#5b6dd4,#3d4aa0)}
.uz-meta b{display:block;font-size:14px;font-weight:600;color:var(--ink)}
.uz-meta small{font-size:12px;color:var(--ink-soft)}
.uz-state{margin-top:14px;font-size:12.5px;color:var(--ink-soft);display:flex;align-items:center;gap:7px;min-height:18px}
.uz.filled .uz-state{color:var(--green-700);font-weight:500}
.uz-check{width:16px;height:16px;border-radius:50%;background:var(--green-500);display:none;place-items:center}
.uz.filled .uz-check{display:grid}
.uz-runs{position:absolute;top:14px;right:14px;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);background:var(--paper-2);padding:3px 8px;border-radius:6px;border:1px solid var(--line)}

/* buttons */
.actions{display:flex;justify-content:space-between;align-items:center;margin-top:30px;gap:14px;flex-wrap:wrap}
.btn{font-family:inherit;font-weight:600;font-size:14.5px;cursor:pointer;border:none;padding:13px 26px;border-radius:12px;transition:.22s;display:inline-flex;align-items:center;gap:9px;text-decoration:none}
.btn-primary{background:var(--green-700);color:#fff;box-shadow:0 4px 14px rgba(47,107,67,.28)}
.btn-primary:hover{background:var(--green-900);transform:translateY(-2px);box-shadow:0 8px 22px rgba(47,107,67,.34)}
.btn-primary:disabled{background:var(--line);color:var(--ink-soft);cursor:not-allowed;box-shadow:none;transform:none}
.btn-ghost{background:transparent;color:var(--ink-soft);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--ink-soft);color:var(--ink)}
.btn-tan{background:var(--tan);color:var(--green-900)}
.btn-tan:hover{background:#bb9856;transform:translateY(-2px)}

/* processing */
.proc{text-align:center;padding:20px 0}
.proc-ring{width:64px;height:64px;margin:0 auto 8px;position:relative}
.proc-ring svg{transform:rotate(-90deg)}
.proc-ring circle{fill:none;stroke-width:5}
.proc-ring .track{stroke:var(--paper-2)}
.proc-ring .fill{stroke:var(--green-600);stroke-linecap:round;transition:stroke-dashoffset .4s}
.proc-pct{position:absolute;inset:0;display:grid;place-items:center;font-family:'Fraunces',serif;font-weight:600;font-size:17px;color:var(--green-900)}
.proc-log{max-width:520px;margin:24px auto 0;text-align:left}
.log-row{display:flex;align-items:center;gap:13px;padding:11px 16px;border-radius:11px;margin-bottom:8px;font-size:14px;color:var(--ink-soft);background:var(--paper);border:1px solid transparent;opacity:.4;transition:.4s;transform:translateX(-6px)}
.log-row.on{opacity:1;transform:none;background:#fff;border-color:var(--line);color:var(--ink);box-shadow:var(--shadow)}
.log-row.on.done{color:var(--green-700)}
.log-ico{width:24px;height:24px;flex-shrink:0;display:grid;place-items:center}
.log-spin{width:15px;height:15px;border:2px solid var(--tan-soft);border-top-color:var(--green-600);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.log-tick{width:20px;height:20px;border-radius:50%;background:var(--green-500);display:grid;place-items:center}
.log-tag{margin-left:auto;font-size:11px;font-weight:600;padding:3px 9px;border-radius:6px;text-transform:uppercase;letter-spacing:.04em}
.tag-auto{background:rgba(74,148,96,.12);color:var(--green-700)}
.tag-ai{background:rgba(200,168,107,.18);color:#9a7d3e}
.proc-error{max-width:520px;margin:18px auto 0;background:rgba(192,83,63,.08);border:1px solid rgba(192,83,63,.3);color:var(--red);border-radius:12px;padding:14px 18px;font-size:14px;display:none}

/* report preview */
.report-shell{background:var(--paper-2);border-radius:20px;padding:8px;border:1px solid var(--line)}
.report{background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-lg)}
.rep-cover{background:linear-gradient(155deg,var(--green-900),var(--green-700));color:#fff;padding:40px 44px 34px;position:relative;overflow:hidden}
.rep-cover::before{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;border:30px solid rgba(200,168,107,.14)}
.rep-cover .rc-brand{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--tan);font-weight:600;margin-bottom:18px}
.rep-cover h3{font-family:'Fraunces',serif;font-weight:600;font-size:30px;line-height:1.1;letter-spacing:-.01em}
.rep-cover .rc-sub{margin-top:10px;color:rgba(255,255,255,.78);font-size:14.5px}
.rep-cover .rc-meta{margin-top:22px;display:flex;gap:26px;flex-wrap:wrap}
.rc-meta div small{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.55)}
.rc-meta div b{font-size:15px;font-weight:600}
.rep-body{padding:36px 44px 40px}
.rep-sec{margin-bottom:34px}
.rep-sec h4{font-family:'Fraunces',serif;font-weight:600;font-size:20px;color:var(--green-900);margin-bottom:5px;display:flex;align-items:center;gap:11px;flex-wrap:wrap}
.sec-badge{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:3px 8px;border-radius:5px}
.badge-high{background:rgba(74,148,96,.13);color:var(--green-700)}
.badge-draft{background:rgba(212,154,46,.16);color:#9a7d3e}
.badge-ai{background:rgba(200,168,107,.2);color:#9a7d3e}
.badge-missing{background:rgba(192,83,63,.12);color:var(--red)}
.rep-sec>p{color:var(--ink-soft);font-size:14.5px;margin:6px 0 14px}

.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.stat{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:15px 16px}
.stat .s-val{font-family:'Fraunces',serif;font-weight:600;font-size:24px;color:var(--green-900);line-height:1}
.stat .s-val.down{color:var(--red)}
.stat .s-lab{font-size:12px;color:var(--ink-soft);margin-top:6px}
.stat .s-trend{font-size:11px;font-weight:600;margin-top:4px}
.s-trend.neg{color:var(--red)}.s-trend.pos{color:var(--green-600)}

table.rep-tbl{width:100%;border-collapse:collapse;font-size:13.5px;margin:6px 0 4px;border-radius:10px;overflow:hidden}
.rep-tbl th{background:var(--blue);color:#fff;text-align:left;padding:10px 14px;font-weight:600;font-size:12.5px}
.rep-tbl td{padding:10px 14px;border-bottom:1px solid var(--line);color:var(--ink)}
.rep-tbl tr:last-child td{border-bottom:none}
.rep-tbl tr:nth-child(even) td{background:var(--paper)}
.rep-tbl .me{color:var(--green-700);font-weight:600}
.pos-bad{color:var(--red);font-weight:600}.pos-mid{color:var(--amber);font-weight:600}.pos-good{color:var(--green-600);font-weight:600}

.insight{background:linear-gradient(120deg,rgba(200,168,107,.12),rgba(58,125,79,.07));border:1px solid var(--tan-soft);border-left:4px solid var(--tan);border-radius:12px;padding:18px 20px;margin:16px 0}
.insight .ins-tag{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#9a7d3e;margin-bottom:8px}
.insight p{font-size:14.5px;color:var(--ink);line-height:1.6;margin-bottom:8px}
.insight p:last-child{margin-bottom:0}

.flag{display:flex;gap:13px;padding:13px 16px;border-radius:11px;margin-bottom:9px;align-items:flex-start;border:1px solid var(--line);background:var(--paper)}
.flag-ico{width:26px;height:26px;border-radius:7px;flex-shrink:0;display:grid;place-items:center;font-weight:700;font-size:13px;color:#fff}
.flag.err .flag-ico{background:var(--red)}
.flag.warn .flag-ico{background:var(--amber)}
.flag.ok .flag-ico{background:var(--green-500)}
.flag-txt b{font-size:13.5px;color:var(--ink);display:block}
.flag-txt small{font-size:12.5px;color:var(--ink-soft)}

.review-band{background:var(--green-900);border-radius:14px;padding:22px 26px;margin-top:8px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.review-band .rb-txt b{color:#fff;font-family:'Fraunces',serif;font-size:17px;display:block}
.review-band .rb-txt small{color:rgba(255,255,255,.7);font-size:13px}

.confidence-key{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:22px;font-size:12.5px;color:var(--ink-soft)}
.ck{display:flex;align-items:center;gap:7px}
.ck .d{width:11px;height:11px;border-radius:3px}

.banner{border-radius:12px;padding:13px 18px;margin-bottom:18px;font-size:13.5px;display:flex;gap:10px;align-items:flex-start}
.banner-warn{background:rgba(212,154,46,.12);border:1px solid rgba(212,154,46,.4);color:#8a6a1e}

footer{border-top:1px solid var(--line);padding:30px 0;text-align:center;color:var(--ink-soft);font-size:13px}
footer b{color:var(--green-700)}

@media(max-width:760px){
  .grid2,.uploads,.stat-row{grid-template-columns:1fr}
  .stat-row{grid-template-columns:1fr 1fr}
  .panel{padding:24px}
  .rep-cover,.rep-body{padding-left:24px;padding-right:24px}
  .byb-tag{display:none}
}
