/* Crux Snapshot — Crux Works brand styling.
   Tokens, header/nav, footer, buttons, .mono eyebrow, .spec corner-bracket card, callouts and
   pills are ported from crux-works.com (assets/css/styles.css) so the tool reads as one product.
   Score/exposure bands map to the brand palette (rust→gold→moss→slate), not traffic-light red/green.
   Logic, questions, and data flow are unchanged — this file is visual only. */

:root{
  --ink:#15120c; --ink2:#211c14;
  --bone:#f4efe4; --bone2:#ece4d4;
  --rust:#bc5a2e; --rust-d:#9a4621; --rust-t:#f1e0d6;
  --slate:#3c5a70; --slate-d:#2b4254; --slate-t:#dde4ea;
  --moss:#6f7a43; --moss-d:#535d31; --moss-t:#e6e9d7;
  --gold:#bb8a23; --gold-d:#8c6510; --gold-t:#f1e7cc;
  --gray:#8a8276;
  --text:#221d15; --muted:rgba(34,29,21,.62); --line:rgba(34,29,21,.16);
  --cream:#f4efe4; --cream-muted:rgba(244,239,228,.66); --cream-line:rgba(244,239,228,.16);
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bone);color:var(--text);
  font-family:"IBM Plex Sans",system-ui,-apple-system,"Segoe UI",sans-serif;
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:600;line-height:1.08;letter-spacing:-.01em;margin:0}
p{margin:0}
a{color:var(--slate-d);text-decoration:none}
a:hover{color:var(--rust-d)}
img{max-width:100%;display:block}
.mono{font-family:"IBM Plex Mono",monospace;text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;font-weight:500}

/* ---------- content column ---------- */
.snap-wrap{width:min(880px,calc(100% - 2.4rem));margin-inline:auto;padding:2.4rem 0 4.5rem}

/* ---------- header / nav (from crux-works.com) ---------- */
.site-header{background:var(--ink);color:var(--cream);border-bottom:1px solid var(--cream-line)}
.site-header .wrap{width:min(var(--maxw),calc(100% - 3rem));margin-inline:auto;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:14px 0}
.site-header .logo{height:54px;width:auto}
.nav{display:flex;gap:.2rem;flex-wrap:wrap;align-items:center}
.nav a{font-family:"IBM Plex Mono",monospace;text-transform:uppercase;letter-spacing:.13em;font-size:.7rem;
  color:var(--cream-muted);padding:.5rem .7rem;border-radius:6px;border:1px solid transparent;
  transition:color .15s,background .15s,border-color .15s}
.nav a:hover{color:var(--cream);background:rgba(244,239,228,.06)}
.nav a.active{color:var(--cream);background:rgba(188,90,46,.16);border-color:rgba(188,90,46,.4)}
.nav a.ext{color:var(--cream);border-color:var(--cream-line)}
.nav a.ext:hover{border-color:var(--rust);color:var(--rust)}
.nav a.snap{background:var(--rust);color:var(--cream);border-color:var(--rust)}
.nav a.snap:hover{background:var(--rust-d);border-color:var(--rust-d);color:var(--cream)}
.nav a.snap.active{background:var(--rust);border-color:var(--rust);color:var(--cream)}
.nav-toggle{display:none;font-family:"IBM Plex Mono",monospace;letter-spacing:.14em;font-size:.72rem;
  background:rgba(244,239,228,.08);border:1px solid var(--cream-line);color:var(--cream);padding:.5rem .8rem;border-radius:8px;cursor:pointer}
@media(max-width:860px){
  .nav-toggle{display:inline-flex}
  .nav{display:none;width:100%;flex-direction:column;align-items:stretch;gap:.25rem;padding-bottom:.6rem}
  .nav.open{display:flex}
  .site-header .wrap{flex-wrap:wrap}
  .nav a{padding:.7rem .8rem}
}

/* ---------- footer (from crux-works.com) ---------- */
.site-footer{background:var(--ink);color:var(--cream);padding:3rem 0 2.4rem;border-top:1px solid var(--cream-line)}
.site-footer .wrap{width:min(var(--maxw),calc(100% - 3rem));margin-inline:auto;
  display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:flex-start}
.site-footer .logo{height:40px;margin-bottom:.8rem}
.site-footer .tl{color:var(--cream-muted);font-size:.9rem;max-width:34ch}
.site-footer .cols{display:flex;gap:.3rem;flex-wrap:wrap}
.site-footer .cols a{font-family:"IBM Plex Mono",monospace;text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;color:var(--cream-muted);padding:.3rem .5rem}
.site-footer .cols a:hover{color:var(--rust)}
.site-footer .cr{color:var(--cream-muted);font-size:.78rem;margin-top:1.3rem;width:100%}

/* ---------- buttons ---------- */
.btn,#go,.report-actions .action-btn{display:inline-flex;align-items:center;gap:.5rem;
  font-family:"IBM Plex Sans",sans-serif;font-weight:600;font-size:.96rem;padding:.8rem 1.25rem;
  border-radius:9px;border:1px solid transparent;cursor:pointer;transition:transform .12s ease,background .15s,border-color .15s}
.btn.primary,#go,.report-actions .action-btn.primary{background:var(--rust);color:var(--cream);border-color:var(--rust)}
.btn.primary:hover,#go:hover,.report-actions .action-btn.primary:hover{background:var(--rust-d);border-color:var(--rust-d)}
#go::after{content:"\2192";transition:transform .15s}
#go:hover::after{transform:translateX(3px)}
.report-actions .action-btn{background:transparent;color:var(--text);border-color:var(--line)}
.report-actions .action-btn:hover{border-color:var(--text)}
.report-actions .action-btn:disabled{opacity:.5;cursor:default}

/* ---------- page head / intro ---------- */
.page-eyebrow{color:var(--rust-d);margin-bottom:.8rem}
#survey-view h1{font-size:clamp(2rem,4.4vw,3rem);margin-bottom:.2rem}
.intro{margin-top:1.1rem;color:var(--muted);font-size:1.06rem;max-width:64ch}
.intro p{margin:.7rem 0}

/* ---------- survey cards ---------- */
fieldset{border:1px solid var(--line);border-radius:12px;margin:1.1rem 0;padding:1.2rem 1.3rem;background:var(--bone)}
legend{font-family:"Fraunces",Georgia,serif;font-weight:600;font-size:1.2rem;padding:0 .4rem;color:var(--text)}
.covers{color:var(--muted);font-size:.86rem;line-height:1.5}
.score-def{font-size:.86rem;color:var(--text);margin-top:.5rem;min-height:1.1em}

/* chip-style answer buttons (scores / budget / deep-dive / concerns / ranks) */
.scorebtns,.budgetbtns{display:flex;flex-wrap:wrap;gap:6px;margin-top:.6rem}
.scorebtns button,.budgetbtns button,.dd-opt,.concern-card,.rank-btns button{
  font-family:"IBM Plex Sans",sans-serif;background:var(--bone2);color:var(--text);
  border:1px solid var(--line);border-radius:8px;cursor:pointer;transition:border-color .12s,background .12s,color .12s}
.scorebtns button,.budgetbtns button{padding:8px 13px;font-size:.9rem}
.scorebtns button:hover,.budgetbtns button:hover,.dd-opt:hover,.concern-card:hover{border-color:var(--rust)}
.scorebtns button[aria-pressed="true"],.budgetbtns button[aria-pressed="true"],
.dd-opt[aria-pressed="true"],.concern-card[aria-pressed="true"]{
  background:var(--rust-t);border-color:var(--rust);color:var(--rust-d);font-weight:600}

/* eyebrow on survey + report */
.brand{font-family:"IBM Plex Mono",monospace;text-transform:uppercase;letter-spacing:.16em;
  font-size:.72rem;font-weight:500;color:var(--rust-d)}

/* per-domain context boxes → brand callouts (gold = caution/hazard, slate = info/assumption) */
.context-box{border:1px solid var(--line);border-left:4px solid var(--gray);border-radius:0 10px 10px 0;
  padding:.7rem .95rem;margin:.7rem 0 0;font-size:.9rem}
.context-box.assume{border-left-color:var(--slate);background:var(--slate-t);color:var(--text)}
.context-box.hazard{border-left-color:var(--gold);background:var(--gold-t);color:var(--text);font-weight:500}
.ctx-field{display:inline-block;margin-top:.5rem}
.ctx-field input{width:6rem}
.ctx-insul{color:var(--muted);font-size:.82rem;margin-top:.35rem}

/* deep-dive expanders */
.deepdive{margin-top:.9rem;border-top:1px solid var(--line);padding-top:.7rem}
.deepdive>summary{cursor:pointer;font-family:"IBM Plex Mono",monospace;text-transform:uppercase;
  letter-spacing:.13em;font-size:.7rem;font-weight:500;color:var(--rust-d)}
.dd-item{margin:.9rem 0}
.dd-q{font-size:.92rem;font-weight:600;margin-bottom:.4rem;color:var(--text)}
.dd-q.dd-sub{font-weight:500;color:var(--muted);margin-top:.4rem}
.dd-zone{font-size:.82rem;color:var(--muted);margin-top:.35rem}
.dd-btns{display:flex;flex-wrap:wrap;gap:6px}
.dd-opt{padding:6px 10px;font-size:.85rem}
.dd-secondary,.dd-indent{margin-left:1rem;padding-left:.7rem;border-left:2px solid var(--line)}
.dd-indent{margin-top:.2rem}
.dd-fuel-row{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:6px 0}
.dd-fuel-name{flex:0 0 5.5rem;font-size:.85rem;font-weight:600}
.dd-inline-label{font-size:.8rem;color:var(--muted);align-self:center}
.dd-fire-only{display:none}

/* preamble + inputs */
input,select{font-family:"IBM Plex Sans",sans-serif;font-size:.95rem;padding:.6rem .7rem;
  border:1px solid var(--line);border-radius:9px;background:var(--bone);color:var(--text)}
input:focus,select:focus{outline:none;border-color:var(--rust)}
input::placeholder{color:var(--gray)}
.preamble label{display:inline-block;margin:.4rem .7rem .4rem 0}
.preamble input[type="number"]{width:5rem}
.household{margin-top:.5rem}
.prepop-context{font-size:.88rem;margin:.6rem 0;padding:.7rem .95rem;border:1px solid var(--line);
  border-left:4px solid var(--gray);border-radius:0 10px 10px 0}
.prepop-context.found{border-left-color:var(--slate);background:var(--slate-t)}
.prepop-context.missing{border-left-color:var(--gold);background:var(--gold-t)}
.prepop-context.invalid{border-left-color:var(--rust);background:var(--rust-t);color:var(--rust-d);font-weight:600}

/* concern pick-and-rank */
.concern-counter{font-weight:600;margin:.5rem 0;color:var(--rust-d)}
.concern-cards{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.concern-card{text-align:left;padding:9px 11px}
.concern-card:disabled{opacity:.4;cursor:not-allowed}
.concern-card-label{font-weight:600;margin-bottom:2px}
.concern-ranks{margin-top:1rem}
.concern-rank-head{font-weight:600;margin-bottom:.5rem}
.rank-row{display:flex;align-items:center;gap:8px;margin:6px 0;flex-wrap:wrap}
.rank-label{flex:1 1 9rem}
.rank-btns button{width:2.2rem;padding:7px 0;margin-right:4px}
.rank-btns button[aria-pressed="true"]{background:var(--rust);border-color:var(--rust);color:var(--cream);font-weight:700}
@media(max-width:480px){.concern-cards{grid-template-columns:1fr}}

.err,.email-msg.err{color:var(--rust-d);font-weight:600}

/* return banner */
.return-banner{background:var(--slate-t);border:1px solid var(--line);border-left:4px solid var(--slate);
  border-radius:0 10px 10px 0;padding:.9rem 1.05rem;margin-bottom:1.2rem;font-size:.94rem}
.return-actions{margin-top:.6rem;display:flex;gap:8px;flex-wrap:wrap}
.return-actions .action-btn{font-family:"IBM Plex Sans",sans-serif;font-weight:600;font-size:.92rem;
  padding:.55rem 1rem;border-radius:9px;border:1px solid var(--line);background:transparent;color:var(--text);cursor:pointer}
.return-actions .action-btn.primary{background:var(--rust);color:var(--cream);border-color:var(--rust)}

/* =================== REPORT =================== */
.report-header{padding-bottom:1rem;margin-bottom:1.2rem;border-bottom:1px solid var(--line)}
.report-header h1{font-size:clamp(2rem,4.4vw,3rem);margin-top:.5rem}
.report-meta{color:var(--muted);font-size:.9rem;margin-top:.5rem;font-family:"IBM Plex Mono",monospace;letter-spacing:.04em}
.report-section{margin:2.2rem 0}
.report-section>h2{font-size:clamp(1.5rem,3vw,1.9rem);margin-bottom:.8rem;padding-bottom:.4rem;border-bottom:1px solid var(--line)}
.summary-text{font-size:1.1rem;color:var(--text)}

/* overall score — the signature corner-bracket instrument panel (.spec motif) */
.overall-score{position:relative;text-align:center;margin:1.4rem 0 1.8rem;
  border:1px solid var(--line);border-radius:14px;background:var(--bone2);padding:1.9rem 1.4rem}
.overall-score:before,.overall-score:after{content:"";position:absolute;width:12px;height:12px;border:1.5px solid var(--rust);opacity:.85}
.overall-score:before{top:11px;left:11px;border-right:0;border-bottom:0}
.overall-score:after{bottom:11px;right:11px;border-left:0;border-top:0}
.score-caption{font-family:"IBM Plex Mono",monospace;text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--muted)}
.score-value{display:flex;align-items:baseline;justify-content:center;gap:.8rem;margin-top:.45rem;flex-wrap:wrap}
.score-pct{font-family:"Fraunces",Georgia,serif;font-size:4.2rem;font-weight:640;line-height:1}
.score-grade{font-family:"IBM Plex Mono",monospace;text-transform:uppercase;letter-spacing:.1em;
  font-size:.95rem;font-weight:500;padding:7px 16px;border-radius:999px}

/* wheel */
.wheel{width:100%;max-width:380px;display:block;margin:.4rem auto}
.wheel-label{font-size:11px;fill:var(--muted)}
.wheel-scale{font-size:10px;fill:var(--text);font-weight:600}

/* readiness bars */
.bars{display:flex;flex-direction:column;gap:7px}
.bar-row{display:grid;grid-template-columns:9rem 1fr 7rem;align-items:center;gap:9px;font-size:.9rem}
.bar-name{color:var(--text)}
.bar-track{background:var(--bone2);border:1px solid var(--line);border-radius:5px;height:18px;overflow:hidden}
.bar-fill{height:100%}
.bar-band{color:var(--muted);font-family:"IBM Plex Mono",monospace;font-size:.72rem;letter-spacing:.04em}

/* regional / estimates */
.region-intro{border:1px solid var(--line);border-left:4px solid var(--slate);background:var(--slate-t);
  padding:.75rem .95rem;border-radius:0 10px 10px 0;margin:0 0 .8rem;color:var(--text)}
.region-intro strong{color:var(--text)}
.estimate-note{color:var(--muted);font-size:.8rem;font-style:italic;margin:0 0 .5rem}
.estimates{margin:0;padding-left:1.1rem}
.estimates li{margin-bottom:.6rem}
.estimate-pending{color:var(--muted)}

.align-block{margin-bottom:.9rem}
.align-concern{font-weight:600;color:var(--text)}
.align-systems{color:var(--muted);font-size:.92rem}

/* project recommendation cards */
.projects-framing{color:var(--muted);font-size:.92rem;margin-bottom:.5rem}
.project{border:1px solid var(--line);border-left:3px solid var(--rust);border-radius:12px;
  background:var(--bone);padding:1rem 1.1rem;margin-bottom:.8rem;transition:border-color .15s,transform .15s}
.project:hover{transform:translateY(-2px)}
.project-head{display:flex;align-items:baseline;gap:.6rem;flex-wrap:wrap}
.project-num{background:var(--rust);color:var(--cream);border-radius:50%;width:1.6rem;height:1.6rem;
  display:inline-flex;align-items:center;justify-content:center;font-family:"IBM Plex Mono",monospace;font-size:.82rem;font-weight:500;flex:none}
.project-action{font-family:"Fraunces",Georgia,serif;font-weight:600;font-size:1.12rem;color:var(--text)}
.project-domain{font-family:"IBM Plex Mono",monospace;text-transform:uppercase;letter-spacing:.1em;font-size:.62rem;
  color:var(--rust-d);border:1px solid rgba(188,90,46,.4);background:var(--rust-t);border-radius:999px;padding:.18rem .5rem}
.project-meta{color:var(--muted);font-size:.84rem;margin-top:.45rem;font-family:"IBM Plex Mono",monospace;letter-spacing:.02em}
.project-affirm{margin-top:.4rem;font-size:.85rem;color:var(--moss-d);font-weight:600}

/* report actions / email */
.report-actions .covers{margin-bottom:.7rem}
.email-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:.7rem}
.email-input{flex:1 1 13rem;min-width:11rem}
.optin{display:block;font-size:.82rem;color:var(--muted);margin-top:.6rem}
.email-msg{margin-top:.6rem;font-size:.9rem;min-height:1.1em}
.email-msg.ok{color:var(--moss-d);font-weight:600}

/* whats-next + footer credits */
.whats-next p{margin:.6rem 0}
.report-footer{border-top:1px solid var(--line);margin-top:1.8rem;padding-top:.9rem;
  font-family:"IBM Plex Mono",monospace;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--rust-d)}
.report-credits{color:var(--muted);font-weight:400;font-size:.7rem;letter-spacing:.02em;margin-top:.4rem;text-transform:none}

/* =================== PRINT / PDF =================== */
@media print{
  .site-header,.site-footer,#survey-view,.report-actions,.return-banner{display:none !important}
  body{background:#fff}
  .snap-wrap{width:100%;padding:0}
  .project{break-inside:avoid}
}
body.print-export .site-header,body.print-export .site-footer,
body.print-export #survey-view,body.print-export .report-actions,
body.print-export .return-banner{display:none !important}
body.print-export{background:#fff}
