/* On Record — styles. Split out so the CSP can forbid inline styles
   (style-src 'self'), with no 'unsafe-inline'. */

:root{
  --bg:#0f172a; --card:#1e293b; --card2:#273548; --line:#33455c;
  --text:#e8eef6; --muted:#94a3b8; --accent:#38bdf8; --accent-press:#0ea5e9;
  --good:#34d399; --warn:#fbbf24; --danger:#f87171;
  --radius:16px; --tap:54px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  background:var(--bg);color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  line-height:1.45;padding-bottom:120px;-webkit-font-smoothing:antialiased;
}
.wrap{max-width:520px;margin:0 auto;padding:0 16px}

.hidden{display:none}

header{
  position:sticky;top:0;z-index:30;background:rgba(15,23,42,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
  padding:14px 16px calc(14px + env(safe-area-inset-top,0)) 16px;
}
.hrow{max-width:520px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:10px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;letter-spacing:.2px;cursor:pointer;background:none;border:none;color:inherit;font-family:inherit;padding:0}
.brand:active{opacity:.7}
.brand .taphint{font-size:11px;color:var(--muted);font-weight:600;margin-left:2px}
.logo{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--accent),#818cf8);display:grid;place-items:center}
.logo .rec{width:14px;height:14px;border-radius:50%;background:#ef4444;box-shadow:0 0 0 3px rgba(255,255,255,.85)}

/* ---- Guided breath pacer ---- */
.breath{display:flex;align-items:center;justify-content:center;gap:16px;margin:2px 0 18px}
.breath-orb{
  width:40px;height:40px;border-radius:50%;
  background:radial-gradient(circle at 50% 38%, #bae6fd, var(--accent));
  box-shadow:0 0 22px rgba(56,189,248,.55);
  animation:breath-orb 19s ease-in-out infinite;
}
.breath-label{position:relative;width:92px;height:20px;font-size:14px;font-weight:600;color:var(--text)}
.breath-label span{position:absolute;left:0;top:0;white-space:nowrap}
.bl-in  {animation:bl-in   19s ease-in-out infinite}
.bl-hold{animation:bl-hold 19s ease-in-out infinite}
.bl-out {animation:bl-out  19s ease-in-out infinite}
.bl-static{opacity:0;color:var(--muted)}
/* 4-7-8 breathing on a 19s loop: inhale 4s (0→21%, orb grows), hold 7s (21→58%, orb stays),
   exhale 8s (58→100%, orb settles). Callouts cross-fade with quiet beats between phases. */
@keyframes breath-orb{ 0%{transform:scale(.62);opacity:.85} 21%{transform:scale(1);opacity:1} 58%{transform:scale(1);opacity:1} 100%{transform:scale(.62);opacity:.85} }
@keyframes bl-in  { 0%{opacity:0} 5%{opacity:1} 17%{opacity:1} 21%{opacity:0} 100%{opacity:0} }
@keyframes bl-hold{ 0%{opacity:0} 24%{opacity:0} 28%{opacity:1} 54%{opacity:1} 58%{opacity:0} 100%{opacity:0} }
@keyframes bl-out { 0%{opacity:0} 58%{opacity:0} 62%{opacity:1} 95%{opacity:1} 100%{opacity:0} }
@media (prefers-reduced-motion:reduce){
  .breath-orb{animation:none;transform:scale(.82)}
  .bl-in,.bl-hold,.bl-out{animation:none;opacity:0}
  .bl-static{opacity:1}
}
.privacy-btn{
  display:flex;align-items:center;gap:6px;font-size:12px;color:var(--good);
  background:rgba(52,211,153,.1);border:1px solid rgba(52,211,153,.3);
  border-radius:99px;padding:6px 11px;cursor:pointer;font-weight:600;
}
.privacy-btn .dot{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 0 4px rgba(52,211,153,.15)}

.progress{max-width:520px;margin:12px auto 0;display:flex;gap:6px}
.pseg{flex:1;height:5px;border-radius:99px;background:var(--line)}
.pseg.done{background:var(--accent)}

h1{font-size:22px;margin:18px 0 4px}
.sub{color:var(--muted);font-size:14px;margin:0 0 16px}

.emergency{
  background:linear-gradient(135deg,#7f1d1d,#b91c1c);border:1px solid #ef4444;
  border-radius:var(--radius);padding:14px 16px;margin:14px 0;
}
.emergency-head{display:flex;align-items:center;gap:10px;cursor:pointer}
.emergency-head .eh-title{flex:1;font-weight:800;font-size:15px;color:#fff}
.emergency-head .chev{flex:none;font-size:13px;color:#fecaca;transition:transform .2s}
.emergency:not(.collapsed) .emergency-head .chev{transform:rotate(90deg)}
/* compact Call 911 shown next to the title only when the banner is collapsed */
.call911-mini{flex:none;display:none;align-items:center;gap:6px;background:#fff;color:#b91c1c;font-weight:800;font-size:13px;text-decoration:none;border-radius:99px;padding:7px 12px}
.emergency.collapsed .call911-mini{display:inline-flex}
.emergency-body{margin-top:10px}
.emergency.collapsed .emergency-body{display:none}
/* clean, consistent callout rows; ".key" (don't-admit-fault) leads, slightly brighter */
.emergency-tip{display:flex;gap:9px;align-items:flex-start;margin:0 0 8px;padding:10px 12px;background:rgba(255,255,255,.12);border-radius:10px;color:#fff;font-weight:600;font-size:14px;line-height:1.45}
.emergency-tip.key{background:rgba(255,255,255,.2);font-weight:700}
.emergency-tip .ti{flex:none;font-size:15px}
.call911{
  display:flex;align-items:center;justify-content:center;gap:8px;width:100%;
  height:var(--tap);margin-top:12px;background:#fff;color:#b91c1c;border:none;
  border-radius:12px;font-size:17px;font-weight:800;text-decoration:none;
}

.step{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);margin:10px 0;overflow:hidden}
.step-head{display:flex;align-items:center;gap:12px;padding:16px;cursor:pointer;user-select:none;min-height:var(--tap)}
.check{flex:none;width:30px;height:30px;border-radius:50%;border:2px solid var(--line);display:grid;place-items:center;font-size:16px;color:transparent;transition:.15s}
.step.complete .check{background:var(--good);border-color:var(--good);color:#063a26}
.step-titles{flex:1;min-width:0}
.step-title{font-weight:700;font-size:16px}
.step-meta{font-size:12.5px;color:var(--muted);margin-top:2px}
.chev{flex:none;color:var(--muted);transition:transform .2s;font-size:14px}
.step.open .chev{transform:rotate(90deg)}
.step-body{display:none;padding:0 16px 16px}
.step.open .step-body{display:block}

label{display:block;font-size:13px;color:var(--muted);margin:12px 0 5px;font-weight:600}
input,textarea,select{
  width:100%;background:var(--card2);border:1px solid var(--line);color:var(--text);
  border-radius:12px;padding:13px 14px;font-size:16px;font-family:inherit;outline:none;transition:border-color .15s;
}
input:focus,textarea:focus,select:focus{border-color:var(--accent)}
textarea{min-height:90px;resize:vertical}
.two{display:flex;gap:10px}.two>div{flex:1}
.hint{font-size:12px;color:var(--muted);margin-top:5px}

.photogrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px}
.photo-add{aspect-ratio:1;border-radius:12px;display:grid;place-items:center;background:var(--card2);border:1px dashed var(--line);cursor:pointer;color:var(--muted);font-size:12px;text-align:center;padding:6px}
.photo-thumb{aspect-ratio:1;border-radius:12px;object-fit:cover;width:100%;display:block;border:1px solid var(--line);cursor:pointer}
.photo-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.chip{font-size:12px;background:var(--card2);border:1px solid var(--line);border-radius:99px;padding:5px 10px;color:var(--muted)}

/* scene sketch pad */
.sketch-tools{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:6px 0 8px}
.sk-tool{height:38px;min-width:42px;padding:0 8px;background:var(--card2);border:1px solid var(--line);border-radius:10px;font-size:19px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.sk-tool.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.sk-color{width:28px;height:28px;border-radius:50%;border:2px solid var(--line);cursor:pointer;padding:0}
.sk-color.active{border-color:#fff;box-shadow:0 0 0 2px var(--accent)}
.sk-black{background:#111111}.sk-red{background:#e11d48}.sk-blue{background:#2563eb}
.sk-spacer{flex:1}
.sk-btn{height:34px;padding:0 12px;background:var(--card2);border:1px solid var(--line);color:var(--text);border-radius:10px;font-size:13px;font-weight:600;cursor:pointer}
.sketch-canvas{width:100%;display:block;background:#fff;border:1px solid var(--line);border-radius:12px;touch-action:none;cursor:crosshair}

.geo{display:flex;gap:10px;align-items:center;margin-top:8px}
.geo button{flex:none;height:46px;padding:0 16px;background:var(--card2);border:1px solid var(--line);color:var(--accent);border-radius:12px;font-weight:600;font-size:14px;cursor:pointer}

.actionbar{position:fixed;left:0;right:0;bottom:0;z-index:30;background:rgba(15,23,42,.94);backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:12px 16px calc(12px + env(safe-area-inset-bottom,0))}
.actionbar-inner{max-width:520px;margin:0 auto;display:flex;gap:10px}
.btn{flex:1;height:var(--tap);border:none;border-radius:14px;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-primary{background:var(--accent);color:#06283b}
.btn-primary:active{background:var(--accent-press)}
.btn-ghost{flex:none;width:var(--tap);background:var(--card2);color:var(--text);border:1px solid var(--line)}

.overlay{position:fixed;inset:0;z-index:50;background:rgba(0,0,0,.6);display:none;align-items:flex-end;justify-content:center}
.overlay.show{display:flex}
.sheet{width:100%;max-width:520px;background:var(--card);border-radius:22px 22px 0 0;padding:8px 16px calc(20px + env(safe-area-inset-bottom,0));border:1px solid var(--line);border-bottom:none;animation:up .25s ease;max-height:88vh;overflow-y:auto}
@keyframes up{from{transform:translateY(40px);opacity:.5}to{transform:translateY(0);opacity:1}}
.grab{width:40px;height:4px;border-radius:99px;background:var(--line);margin:8px auto 16px}
.sheet h2{margin:0 0 4px;font-size:20px}
.sheet p.s{color:var(--muted);font-size:14px;margin:0 0 16px}
.opt{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:var(--card2);border:1px solid var(--line);border-radius:14px;padding:14px;margin:8px 0;color:var(--text);cursor:pointer;font-size:15px}
.opt .oi{width:42px;height:42px;flex:none;border-radius:11px;display:grid;place-items:center;font-size:20px;background:var(--bg)}
.opt .ot{font-weight:700}.opt .od{font-size:12.5px;color:var(--muted)}
.opt:active{border-color:var(--accent)}
.close-sheet{width:100%;height:48px;margin-top:8px;background:transparent;border:none;color:var(--muted);font-size:15px;cursor:pointer}

/* install panel button fills the sheet */
#installBody .btn{width:100%}

/* export password prompt */
#passOverlay .btn{width:100%;margin-top:14px}
.err{color:var(--danger);font-size:13px;margin:10px 0 0}

/* Privacy panel */
.plist{list-style:none;margin:0 0 8px;padding:0}
.plist li{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.plist li:last-child{border-bottom:none}
.plist .pi{flex:none;font-size:18px;width:24px;text-align:center}
.plist b{color:var(--text)} .plist span{color:var(--muted)}
.verify{background:var(--card2);border:1px solid var(--line);border-radius:12px;padding:12px 14px;font-size:13px;color:var(--muted);margin-top:4px}
.verify b{color:var(--accent)}

.footnote{text-align:center;color:var(--muted);font-size:12px;margin:24px 0 0;opacity:.75;line-height:1.7}
.footnote a{color:var(--accent);cursor:pointer;text-decoration:none}

/* ---- Printable report (built on demand, shown only when printing) ---- */
#report{display:none}
@media print{
  @page{margin:18mm 16mm}
  body{background:#fff;color:#111;padding:0}
  header,.wrap,.actionbar,.overlay{display:none !important}
  #report{display:block;max-width:none;color:#111}
  .rep-head{border-bottom:2px solid #111;padding-bottom:10px;margin-bottom:18px}
  .rep-title{font-size:22px;font-weight:800;letter-spacing:.2px}
  .rep-sub{font-size:12px;color:#555;margin-top:3px}
  #report section{margin:0 0 16px;page-break-inside:avoid}
  #report h3{font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:#000;border-bottom:1px solid #ccc;padding-bottom:4px;margin:0 0 8px}
  #report dl{display:grid;grid-template-columns:170px 1fr;gap:4px 14px;margin:0;font-size:13px}
  #report dt{color:#555;font-weight:600}
  #report dd{margin:0;white-space:pre-wrap}
  .rep-photos{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:6px}
  .rep-photos img{width:100%;border:1px solid #ccc;border-radius:6px}
  .rep-sketch-img{width:100%;max-width:480px;border:1px solid #ccc;border-radius:6px}
  .rep-foot{margin-top:24px;padding-top:10px;border-top:1px solid #ccc;font-size:11px;color:#777}
}
