:root{
  /* Warm palette derived from the OJI logo (orange -> deep red).
     Legacy names (--blue/--teal) are kept so every rule recolours at once:
     --blue = deep red, --blue2 = orange, --teal = ember-orange. */
  --blue:#9e1409; --blue2:#e8531b; --teal:#cf4a17; --teal2:#9e1409; --orange:#ef610d;
  --ink:#3a1a12; --muted:#9c7b70; --line:#eeddd4; --frame:#e7c9bd;
  --bg:#f6efe9; --card:#fff; --fieldbg:#fdf4ef; --fieldline:#e8c4b4;
  --ok:#0a7d3c; --err:#c0392b;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink);
  -webkit-text-size-adjust:100%;line-height:1.45}
.app{max-width:760px;margin:0 auto;min-height:100vh;background:var(--card);display:flex;flex-direction:column;
  border:2px solid var(--frame);box-shadow:0 6px 40px rgba(120,30,10,.16)}
@media(min-width:800px){ .app{margin:18px auto;min-height:calc(100vh - 36px);border-radius:16px;overflow:hidden} }

/* ---- brand header (white, like the printed sheet) ---- */
.brand{display:flex;align-items:center;gap:16px;padding:16px 18px 12px;border-bottom:3px solid #f3e6df}
.logo{flex:0 0 auto;line-height:0}
.logo img{height:60px;width:auto;display:block;border-radius:8px}
.brandtxt h1{margin:0;font-size:26px;font-weight:800;color:var(--blue);letter-spacing:.3px;line-height:1}
.brandtxt .sub{margin:5px 0 0;font-size:15px;font-weight:700;color:var(--orange)}

/* progress */
.progress{height:7px;background:#f0dcd2}
.progress-bar{height:100%;width:0;background:linear-gradient(90deg,var(--orange),var(--blue));transition:width .3s}
.stepinfo{padding:9px 18px 0;font-size:12.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.stepinfo #steptitle{color:var(--blue)}

/* ---- lead + mission (step 0) ---- */
.lead{margin:14px 2px 12px;font-size:14.5px;color:#7a4a3a}
.mission{display:flex;gap:12px;align-items:flex-start;background:#fdeee6;border:1.5px solid #f4cdb7;
  border-radius:12px;padding:14px 16px;margin:0 0 8px;font-size:14px;color:#8a3b1e}
.mission b{color:var(--red,#9e1409)}
.mission-ic{font-size:26px;color:var(--orange);line-height:1;margin-top:-2px}
.autosave-note{font-size:12.5px;color:var(--muted);margin:10px 2px 0}

/* ---- section header bars (solid colored, printed-form style) ---- */
.step{padding:6px 18px 18px}
.secthead{display:flex;align-items:center;gap:12px;color:#fff;border-radius:8px;padding:11px 14px;margin:14px 0 0;
  box-shadow:0 2px 6px rgba(120,30,10,.22)}
.secthead.blue{background:linear-gradient(180deg,#b91c0e,#7d1109)}
.secthead.teal{background:linear-gradient(180deg,#f26a1b,#d0430f)}
.secthead h2{margin:0;font-size:16px;font-weight:800;text-transform:uppercase;letter-spacing:.4px}
.secnum{background:rgba(255,255,255,.92);color:#9e1409;border-radius:6px;min-width:28px;height:28px;
  display:grid;place-items:center;font-weight:800;font-size:15px}
.secthead.teal .secnum{color:#d0430f}

/* card that holds the fields, tucked under the bar */
.fields{border:1.5px solid var(--line);border-top:none;border-radius:0 0 12px 12px;padding:16px 14px 6px;background:#fff}

/* ---- fields ---- */
.field{margin:0 0 18px}
.field[hidden]{display:none}
.flabel{display:block;font-weight:700;font-size:14.5px;margin-bottom:8px;color:var(--ink)}
.qnum{display:inline-block;color:var(--blue2);margin-right:6px;font-weight:800}
.req{color:var(--err)}
.help{font-size:12.5px;color:var(--muted);margin:-3px 0 8px;font-style:italic}

/* fill-in-line style inputs */
input[type=text],input[type=tel],input[type=email],input[type=number],input[type=date]{
  width:100%;padding:10px 10px;font-size:16px;color:var(--ink);
  background:var(--fieldbg);border:1px solid transparent;border-bottom:2px solid var(--fieldline);border-radius:8px 8px 0 0}
input:focus{outline:none;border-bottom-color:var(--blue2);background:#fdece2;box-shadow:0 2px 0 -1px var(--blue2)}
textarea{width:100%;padding:10px;font-size:16px;color:var(--ink);background:var(--fieldbg);
  border:1px solid var(--line);border-bottom:2px solid var(--fieldline);border-radius:8px;resize:vertical;min-height:52px}
textarea:focus{outline:none;border-bottom-color:var(--blue2);background:#fdece2}

/* ---- square check/radio options (printed-form style) ---- */
.opts{display:flex;flex-wrap:wrap;gap:8px 10px}
.chip{position:relative;display:inline-flex;align-items:center;gap:9px;padding:8px 12px 8px 10px;
  border:1.5px solid var(--line);border-radius:9px;font-size:15px;cursor:pointer;background:#fff;user-select:none;min-height:44px}
.chip span{pointer-events:none}
.chip input{-webkit-appearance:none;appearance:none;margin:0;flex:0 0 auto;width:21px;height:21px;
  border:2px solid #e0a892;border-radius:5px;background:#fff;cursor:pointer;position:relative}
.chip input:checked{background:var(--blue2);border-color:var(--blue2)}
.chip input:checked::after{content:"";position:absolute;left:6px;top:2px;width:6px;height:11px;
  border:solid #fff;border-width:0 3px 3px 0;transform:rotate(45deg)}
.chip:has(input:checked){border-color:var(--blue2);background:#fdece2;color:var(--blue);font-weight:600}
.other-text{margin-top:8px;flex:1 1 100%}

/* percent grid */
.pct-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.pct-cell label{display:block;font-size:12.5px;color:var(--blue2);font-weight:700;margin-bottom:4px}
.pct-in{display:flex;align-items:center;gap:4px}
.pct-in input{width:100%}
.pct-in span{color:var(--muted);font-weight:700}
.pct-total{margin-top:10px;font-size:14px;color:var(--muted)}
.pct-total .pct-sum{color:var(--blue)}
.pct-total.bad .pct-sum{color:var(--err)}
.pct-total.good .pct-sum{color:var(--ok)}

/* nav */
.navbar{position:sticky;bottom:0;display:flex;gap:10px;padding:12px 18px;background:#fff;border-top:1.5px solid var(--line)}
.btn{flex:1;padding:14px;border:none;border-radius:11px;font-size:16px;font-weight:800;cursor:pointer;background:var(--blue2);color:#fff}
.btn.ghost{background:#f7e7df;color:var(--blue)}
.btn.primary{background:var(--teal)}
.btn:disabled{opacity:.4;cursor:not-allowed}

/* review */
.review .ritem{border-bottom:1px solid var(--line);padding:8px 0;font-size:14px}
.review .rq{color:var(--muted)} .review .ra{font-weight:700}
.review .rsec{margin-top:14px;color:var(--blue);font-weight:800;font-size:12.5px;text-transform:uppercase;letter-spacing:.5px}

.saved{margin:10px 18px;color:var(--ok);font-size:13px;font-weight:700}
.foot{margin-top:auto;padding:13px 18px;text-align:center;font-size:12.5px;font-weight:700;color:#fff;
  background:linear-gradient(180deg,#9e1409,#6d1410);letter-spacing:.3px}

/* validation */
.field.invalid input,.field.invalid textarea{border-color:var(--err);border-bottom-color:var(--err)}
.field.invalid .opts{outline:2px solid rgba(192,57,43,.4);outline-offset:4px;border-radius:8px}

@media(min-width:560px){ .pct-grid{grid-template-columns:repeat(4,1fr)} }

/* ---- legacy header used by admin + thank-you pages ---- */
.topbar{display:flex;align-items:center;gap:14px;padding:12px 18px;color:#fff;
  background:linear-gradient(135deg,#9e1409,#e8531b)}
.topbar .logo{flex:0 0 auto;line-height:0}
.topbar .logo img{height:48px;width:auto;display:block;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.topbar .titles h1{margin:0;font-size:20px;font-weight:800}
.topbar .titles p{margin:2px 0 0;font-size:13px;opacity:.9}
