/* StrataSnap prototype — component styles.
   Consumes tokens ONLY from app.css (the StrataSnap Design System sheet).
   No raw hex here — every colour, radius and space is a var(--*). */

*{box-sizing:border-box;-webkit-font-smoothing:antialiased}

/* Tabler icons via Iconify web component */
iconify-icon{display:inline-flex;flex:0 0 auto;vertical-align:-0.15em;line-height:1}

html,body{margin:0;background:var(--ground-900)}
body{font-family:var(--font-sans);color:var(--ink-700)}

/* ── device frame ───────────────────────────────────────────── */
.stage{min-height:100vh;display:flex;flex-direction:column;align-items:center;gap:14px;
  padding:26px 16px 40px;background:radial-gradient(120% 90% at 50% 0%, #211d16, #15130f 70%)}
.device{width:min(390px,calc(100vw - 32px));height:auto;aspect-ratio:390/844;background:var(--page);border-radius:clamp(34px,10vw,44px);position:relative;
  box-shadow:0 0 0 11px #0c0b08, 0 0 0 13px #2b2720, 0 30px 70px -20px rgba(0,0,0,.7);overflow:hidden;flex:0 0 auto}
.screen{position:absolute;inset:0;display:flex;flex-direction:column;background:var(--page);overflow:hidden}

/* status bar */
.statusbar{height:46px;display:flex;align-items:flex-end;justify-content:space-between;
  padding:0 26px 7px;font-size:14px;font-weight:600;color:var(--ink-800);flex:0 0 auto;z-index:3;background:var(--page)}
.statusbar.on-dark{color:var(--ink-50);background:transparent}
.statusbar .dots{display:flex;gap:6px;opacity:.9}
.home-ind{height:5px;width:130px;background:var(--ink-300);border-radius:var(--r-pill);margin:10px auto 8px}
.home-ind.on-dark{background:rgba(255,255,255,.4)}

/* ── headers / nav ──────────────────────────────────────────── */
.nav{display:flex;align-items:center;gap:12px;padding:6px 14px 14px;flex:0 0 auto;background:var(--page)}
.iconbtn{width:44px;height:44px;border-radius:var(--r-sm);border:1px solid var(--line2);background:var(--page);
  display:flex;align-items:center;justify-content:center;color:var(--ink-800);cursor:pointer;flex:0 0 auto;padding:0}
.iconbtn:active{background:var(--raise)}
.nav .t{font-weight:600;font-size:16px;color:var(--ink-800);white-space:nowrap}
.nav .step{margin-left:auto;font-size:14px;color:var(--ink-400);white-space:nowrap;flex:0 0 auto}
.prog{height:4px;background:var(--line);border-radius:var(--r-pill);margin:0 18px;flex:0 0 auto;overflow:hidden}
.prog i{display:block;height:100%;background:var(--acc);border-radius:var(--r-pill);transition:width .3s var(--ease-out,ease)}

.scroll{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
.scroll::-webkit-scrollbar{width:0}
.pad{padding:6px 22px 24px}
.stepfade{will-change:auto}

/* ── type helpers ───────────────────────────────────────────── */
.h-title{font-family:var(--font-display);font-size:30px;font-weight:600;line-height:1.07;color:var(--ink-900);letter-spacing:-.02em;margin:0;text-wrap:balance}
.h-sub{font-size:16px;line-height:1.55;color:var(--ink-500);margin:10px 0 0;max-width:34ch}
.ey{display:inline-flex;align-items:center;gap:7px;font-size:14px;color:var(--ink-500);white-space:nowrap}
.ey svg{color:var(--acc-strong)}
.id-mono{font-family:var(--font-mono);font-size:12px;color:var(--ink-400);letter-spacing:.01em}

/* ── buttons ────────────────────────────────────────────────── */
.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;min-width:0;height:56px;border-radius:var(--r-pill);
  border:1px solid transparent;cursor:pointer;font-family:inherit;font-size:17px;font-weight:650;line-height:1;
  transition:filter .15s,background .15s,border-color .15s,box-shadow .15s;white-space:nowrap;touch-action:manipulation}
.btn:active{filter:brightness(.95)}
.btn:focus-visible{outline:0;box-shadow:var(--focus)}
.btn svg{flex:0 0 auto}
.btn-acc{background:var(--ink-btn);color:var(--white)}
.btn-acc:active{background:var(--ink-btn-press)}
.btn-dark{background:var(--ink-900);color:var(--white)}
.btn-out{background:var(--page);color:var(--ink-800);border:1px solid var(--line2)}
.btn-out:active{background:var(--raise)}
.btn-ghost{background:transparent;color:var(--ink-600)}
.btn-sm{height:44px;font-size:15px;width:auto;padding:0 16px}
.btn:disabled{opacity:.5;cursor:not-allowed}
.footer{flex:0 0 auto;padding:12px 16px calc(10px + 8px);background:var(--page);border-top:1px solid var(--line)}
.footer .row{display:flex;gap:10px}
.footer .row .btn{height:52px;font-size:16px;flex:1 1 0;padding:0 14px}
.footer .hint{font-size:13px;color:var(--ink-400);text-align:center;margin:0 0 9px;line-height:1.4}
.send-hint{font-size:13px;color:var(--ink-500);text-align:center;margin:0 0 9px;line-height:1.4}

/* ── grouped option rows ────────────────────────────────────── */
.group{margin-top:18px;background:var(--page);border:1px solid var(--line2);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-card-subtle)}
.opt{display:flex;align-items:center;gap:14px;padding:15px 16px;min-height:62px;cursor:pointer;
  border:0;border-top:1px solid var(--line);background:var(--page);width:100%;text-align:left;font-family:inherit;transition:background .12s}
.opt:first-child{border-top:0}
.opt .well{width:42px;height:42px;border-radius:var(--r-sm);background:var(--raise);display:flex;align-items:center;justify-content:center;color:var(--ink-600);flex:0 0 auto}
.opt .lbl{font-size:17px;font-weight:500;color:var(--ink-800);flex:1 1 auto;letter-spacing:-.005em}
.opt .desc{display:block;font-size:13.5px;color:var(--ink-400);margin-top:2px;font-weight:400}
.opt .chev{color:var(--ink-300);flex:0 0 auto}
.opt .check{color:var(--acc);flex:0 0 auto;display:none}
.opt.sel{background:var(--acc-tint)}
.opt.sel .well{background:var(--acc);color:var(--white)}
.opt.sel .lbl{color:var(--acc-text);font-weight:600}
.opt.sel .chev{display:none}
.opt.sel .check{display:block}
.opt .radio{width:22px;height:22px;border-radius:50%;border:2px solid var(--ink-300);flex:0 0 auto}
.opt.sel .radio{border-color:var(--acc);background:var(--acc);box-shadow:inset 0 0 0 4px var(--page)}

/* ── fields ─────────────────────────────────────────────────── */
.field{margin-top:16px}
.field > label{display:block;font-size:14px;font-weight:600;color:var(--ink-700);margin-bottom:8px}
.field .opt-note{font-weight:400;color:var(--ink-400)}
.inp{width:100%;background:var(--page);border:1px solid var(--line2);border-radius:var(--r-sm);padding:15px 15px;
  font-family:inherit;font-size:16px;color:var(--ink-900);outline:none}
.inp:focus{border-color:var(--acc);box-shadow:0 0 0 3px var(--acc-tint)}
textarea.inp{resize:none;min-height:76px;line-height:1.45}
.inp::placeholder{color:var(--ink-300)}

/* callout / notice */
.note{display:flex;gap:11px;align-items:flex-start;padding:14px 15px;border-radius:var(--r-md);background:var(--raise);
  border:1px solid var(--line2);font-size:14px;line-height:1.45;color:var(--ink-600);margin-top:16px}
.note svg{flex:0 0 auto;margin-top:1px;color:var(--ink-400)}
.note.warn{background:var(--st-amber-bg);border-color:var(--st-amber-line)}
.note.warn svg{color:var(--acc-strong)}
.note .h{font-weight:600;color:var(--ink-800);display:block;margin-bottom:2px}

/* ── status pills (word + colour, easy to scan) ─────────────── */
.stt{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;padding:5px 11px;border-radius:var(--r-pill);white-space:nowrap}
.stt .dot{width:7px;height:7px;border-radius:50%;flex:0 0 auto;background:currentColor}
.stt.big{font-size:14px;padding:7px 13px}.stt.big .dot{width:8px;height:8px}
.t-blue{background:var(--st-blue-bg);color:var(--st-blue)}
.t-violet{background:var(--st-violet-bg);color:var(--st-violet)}
.t-amber{background:var(--st-amber-bg);color:var(--st-amber)}
.t-teal{background:var(--st-teal-bg);color:var(--st-teal)}
.t-green{background:var(--st-green-bg);color:var(--st-green)}
.t-grey{background:var(--st-grey-bg);color:var(--st-grey)}
/* small solid dots (status-change sheet, style tile) */
.d-new{background:var(--st-blue)} .d-review{background:var(--st-violet)}
.d-wait{background:var(--st-amber)} .d-sched{background:var(--st-teal)}
.d-done{background:var(--st-green)} .d-closed{background:var(--st-grey)}

/* ── queue ──────────────────────────────────────────────────── */
.q-head{display:flex;align-items:flex-end;gap:12px;padding:4px 20px 12px;flex:0 0 auto}
.q-head h1{font-family:var(--font-display);font-size:26px;color:var(--ink-900);line-height:1;font-weight:600}
.q-head .sub{font-size:13px;color:var(--ink-400);margin-top:5px;white-space:nowrap}
.strip{display:flex;gap:8px;padding:0 16px 12px;flex:0 0 auto}
.stat{flex:1;background:var(--raise);border-radius:var(--r-sm);padding:10px 11px}
.stat b{display:block;font-size:21px;font-weight:700;color:var(--ink-900);line-height:1}
.stat span{font-size:12px;color:var(--ink-500);margin-top:3px;display:block;white-space:nowrap}
.stat.warn b{color:var(--st-amber)}
.views{display:flex;gap:8px;padding:0 16px 12px;flex:0 0 auto;overflow-x:auto}
.summary{display:flex;align-items:center;gap:9px;padding:2px 18px 14px;flex:0 0 auto;font-size:14px;color:var(--ink-500);white-space:nowrap;overflow-x:auto}
.summary b{font-weight:700;color:var(--ink-900);font-variant-numeric:tabular-nums}
.summary .sum-open b{color:var(--ink-900)}
.summary .sum-dot{color:var(--ink-300)}
.summary .sum-warn b{color:var(--st-amber)}
.views::-webkit-scrollbar{height:0}
.views button{border:1px solid var(--line2);background:var(--page);cursor:pointer;padding:8px 14px;border-radius:var(--r-pill);
  font-family:inherit;font-size:14px;font-weight:500;color:var(--ink-500);white-space:nowrap;flex:0 0 auto}
.views button.on{background:var(--ink-900);color:var(--white);border-color:var(--ink-900)}
.qlist{padding:0 16px 16px;display:flex;flex-direction:column;gap:10px}
.tk{display:flex;align-items:center;gap:13px;background:var(--page);border:1px solid var(--line2);border-radius:var(--r-md);padding:12px 14px;cursor:pointer;text-align:left;font-family:inherit;width:100%;transition:transform .12s,background .12s,box-shadow .12s;box-shadow:var(--shadow-card-subtle)}
.tk:active{background:var(--raise);transform:scale(.992)}
.tk-thumb{width:54px;height:54px;border-radius:var(--r-sm);object-fit:cover;flex:0 0 auto;background:var(--raise)}
.tk-ico2{width:54px;height:54px;border-radius:var(--r-sm);background:var(--raise);color:var(--ink-500);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.tk-main{flex:1 1 auto;min-width:0}
.tk .sum{font-size:16px;font-weight:600;line-height:1.25;color:var(--ink-900);letter-spacing:-.01em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tk .meta{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--ink-500);margin-top:4px;white-space:nowrap;overflow:hidden}
.tk .meta .sep{color:var(--ink-300)}
.tk-side{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex:0 0 auto}
.av{width:26px;height:26px;border-radius:50%;background:var(--raise);border:1px solid var(--line2);
  font-size:11px;font-weight:600;color:var(--ink-600);display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
.review-photos{display:flex;gap:9px;margin-top:16px;flex-wrap:wrap}
.rev-photo{width:84px;height:84px;border-radius:var(--r-sm);overflow:hidden;border:1px solid var(--line2);padding:0;cursor:pointer;background:var(--raise);flex:0 0 auto}
.rev-photo img{width:100%;height:100%;object-fit:cover;display:block}
.rev-photo.add{display:flex;align-items:center;justify-content:center;color:var(--ink-400);border-style:dashed}
/* inline send summary (replaces the review step) */
.send-summary{display:flex;align-items:center;gap:13px;margin-top:18px;padding:12px;border:1px solid var(--line2);border-radius:var(--r-md);background:var(--raise)}
.ss-thumb{width:52px;height:52px;border-radius:var(--r-sm);overflow:hidden;flex:0 0 auto;background:var(--page);border:1px solid var(--line2)}
.ss-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.ss-thumb.ph{display:flex;align-items:center;justify-content:center;color:var(--ink-400)}
.ss-text{flex:1 1 auto;min-width:0}
.ss-loc{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--acc-text)}
.ss-loc svg{color:var(--acc-strong)}
.ss-note{font-size:14px;color:var(--ink-700);line-height:1.4;margin-top:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ── one-screen resident report ─────────────────────────────── */
.osr .h-title{margin:0}
.osr-locrow{display:flex;align-items:center;gap:11px;padding:9px 12px;background:var(--raise);border:1px solid var(--line2)}
.osr-loc-ic{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:var(--page);border:1px solid var(--line2);color:var(--acc-strong);flex:0 0 auto}
.osr-loc-t{flex:1 1 auto;min-width:0}
.osr-loc-name{font-size:15px;font-weight:600;color:var(--ink-900);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.osr-loc-meta{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-400);margin-top:3px}
.osr-h1{font-size:21px;font-weight:600;letter-spacing:-.018em;color:var(--ink-900);margin:0;line-height:1.08}
.osr-sub{font-size:13.5px;color:var(--ink-500);line-height:1.4;margin:4px 0 0;max-width:38ch}
.linkbtn{display:inline-flex;align-items:center;justify-content:center;min-height:36px;background:none;border:0;padding:0 2px;font-family:inherit;font-size:14px;color:var(--acc-text);font-weight:600;cursor:pointer;flex:0 0 auto}
.osr-label{font-size:14px;font-weight:700;color:var(--ink-900);margin:15px 0 8px;letter-spacing:-.01em}
.osr-label .opt-note{font-weight:500;color:var(--ink-400);font-size:14px}
.osr-help{font-size:12.5px;color:var(--ink-500);line-height:1.4;margin:9px 0 0}
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.cat-chip{position:relative;display:flex;align-items:center;gap:10px;padding:0 11px;min-height:48px;background:var(--page);border:1px solid var(--line2);
  font-family:var(--font-sans);font-size:14px;font-weight:600;color:var(--acc-text);text-align:left;cursor:pointer;transition:border-color .14s,background .14s}
.cat-tile{width:26px;height:26px;border-radius:var(--r-xs);display:flex;align-items:center;justify-content:center;background:var(--raise) !important;color:var(--ink-600);flex:0 0 auto}
.cat-tile svg{color:var(--ink-600)}
.cat-chip.sel .cat-tile{background:var(--acc) !important}
.cat-chip.sel .cat-tile svg{color:var(--white)}
.cat-art{width:34px;height:34px;border-radius:var(--r-xs);object-fit:contain;flex:0 0 auto}
.cat-chip span:not(.cat-tile):not(.cat-check){line-height:1.2}
.cat-chip.sel{background:var(--acc-tint);border-color:var(--acc);border-width:2px;color:var(--acc-text);font-weight:600}
.cat-chip.sel svg{color:var(--acc-strong)}
.cat-check{position:absolute;top:8px;right:8px;width:18px;height:18px;border-radius:50%;background:var(--acc);color:var(--white);display:flex;align-items:center;justify-content:center}
.osr-photos{display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.osr-photo{position:relative;width:96px;height:96px;flex:0 0 auto;overflow:hidden;border:1px solid var(--line2);background:var(--raise)}
.osr-photo img{width:100%;height:100%;object-fit:cover;display:block}
.osr-photo-x{position:absolute;top:5px;right:5px;width:26px;height:26px;border:0;border-radius:2px;background:var(--overlay-dark-62);color:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer}
.osr-photo.up{display:flex;align-items:center;justify-content:center}
.osr-photo.add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border-style:dashed;color:var(--ink-500);font-family:inherit;font-size:12px;font-weight:600;cursor:pointer}
.osr-photo.add.wide{flex-direction:row;width:100%;height:48px;gap:9px;font-size:14px;white-space:nowrap}
.osr-privacy{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-500);line-height:1.4;margin:12px 0 0}
.osr-privacy svg{color:var(--ink-400);flex:0 0 auto}
.emerg{display:none}
.osr-titlerow{display:flex;align-items:flex-start;gap:12px;margin-top:14px}
.osr-titlerow > div:first-child{flex:1 1 auto;min-width:0}
.emerg-ico{flex:0 0 auto;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:var(--st-urgent-bg);border:1px solid var(--st-urgent-line);color:var(--danger);cursor:pointer;margin-top:2px}
.osr-photo.sm{width:64px;height:64px}
.osr-photo-add-row{display:flex;align-items:center;gap:9px;height:44px;padding:0 16px;border:1px dashed var(--line2);border-radius:var(--ios-radius-sm);
  background:var(--page);color:var(--ink-600);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer}
.osr-photo-add-row svg{color:var(--ink-500);flex:0 0 auto}
.osr-photo.add .add-cam,.add-cam{width:26px;height:26px;object-fit:contain;flex:0 0 auto}
.voice-box{display:flex;align-items:center;gap:12px;margin-top:16px;padding:13px 14px;border:1px solid var(--line2);border-radius:var(--ios-radius-sm);background:var(--page)}
.voice-copy{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:2px}
.voice-k{font-size:14px;font-weight:700;color:var(--ink-900)}
.voice-v{font-size:12.5px;line-height:1.35;color:var(--ink-500)}
.voice-btn{height:40px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--acc-tint-border);border-radius:var(--r-pill);background:var(--acc-tint);color:var(--acc-text);font-family:inherit;font-size:13.5px;font-weight:700;padding:0 14px;cursor:pointer;flex:0 0 auto}
.voice-btn.recording{background:var(--st-urgent-bg);border-color:var(--st-urgent-line);color:var(--danger)}
.voice-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.voice-list.detail{margin-top:0}
.voice-item{display:flex;align-items:center;gap:9px;min-height:46px;padding:9px 10px;border:1px solid var(--line2);border-radius:var(--ios-radius-sm);background:var(--raise);font-size:13px;color:var(--ink-700)}
.voice-item svg{color:var(--acc);flex:0 0 auto}
.voice-item span{flex:1 1 auto;min-width:0}
.voice-item audio{height:32px;max-width:130px;flex:0 1 auto}
.photo-ph-img{width:100%;aspect-ratio:4/3;border-radius:var(--r-sm);object-fit:cover;border:1px solid var(--line2);background:var(--raise)}
.confirm-art{width:172px;height:172px;object-fit:contain;margin-bottom:8px}
/* report step rail */
.steprail{display:flex;align-items:center;justify-content:space-between;padding:10px 22px 14px;flex:0 0 auto}
.sr-item{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1 1 0;position:relative}
.sr-item::before{content:"";position:absolute;top:13px;left:-50%;width:100%;height:2px;background:var(--line2);z-index:0}
.sr-item:first-child::before{display:none}
.sr-item.done::before,.sr-item.on::before{background:var(--acc)}
.sr-dot{position:relative;z-index:1;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:13px;font-weight:700;background:var(--page);border:2px solid var(--line2);color:var(--ink-400)}
.sr-item.on .sr-dot{background:var(--acc);border-color:var(--acc);color:var(--white)}
.sr-item.done .sr-dot{background:var(--acc);border-color:var(--acc);color:var(--white);cursor:pointer}
.sr-lbl{font-size:11.5px;font-weight:600;color:var(--ink-400)}
.sr-item.on .sr-lbl{color:var(--acc-text)}
.sr-item.done .sr-lbl{color:var(--ink-600)}
/* review step */
.rev-list{display:flex;flex-direction:column;gap:2px;margin-top:16px;background:var(--raise);border:1px solid var(--line2);border-radius:var(--ios-radius);padding:6px 14px}
.rev-row{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-top:1px solid var(--line)}
.rev-row:first-child{border-top:0}
.rev-ic{width:22px;flex:0 0 auto;color:var(--acc);display:flex;align-items:center;justify-content:center;margin-top:1px}
.rev-k{font-size:12px;color:var(--ink-400);font-weight:600;margin-bottom:2px}
.rev-v{font-size:15px;color:var(--ink-800);line-height:1.4}
.rev-thumbs{display:flex;gap:7px;margin-top:6px}
.rev-thumbs img{width:54px;height:54px;border-radius:var(--r-xs);object-fit:cover}
/* track: next-steps progress */
.track-steps{display:flex;align-items:flex-start;justify-content:space-between;margin:4px 0 4px}
.tk-step{display:flex;flex-direction:column;align-items:center;gap:7px;flex:1 1 0;position:relative}
.tk-step::before{content:"";position:absolute;top:14px;left:-50%;width:100%;height:2px;background:var(--line2);z-index:0}
.tk-step:first-child::before{display:none}
.tk-step.done::before,.tk-step.on::before{background:var(--acc)}
.tk-step-dot{position:relative;z-index:1;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:13px;font-weight:700;background:var(--page);border:2px solid var(--line2);color:var(--ink-400)}
.tk-step.done .tk-step-dot{background:var(--acc);border-color:var(--acc);color:var(--white)}
.tk-step.on .tk-step-dot{border-color:var(--acc);color:var(--acc)}
.tk-pulse{width:10px;height:10px;border-radius:50%;background:var(--acc);box-shadow:0 0 0 4px var(--acc-tint)}
.tk-step-lbl{font-size:11.5px;font-weight:600;color:var(--ink-400);text-align:center;line-height:1.2}

/* ── council mobile: dashboard / inbox / map ─────────────────── */
.cd{background:var(--page)}
.cd-head{padding:8px 18px 14px;flex:0 0 auto;background:var(--header-bg);border-bottom:1px solid var(--header-line)}
.cd-bar{display:flex;align-items:center;margin-bottom:14px}
.cd-bar .rh-bell{margin-left:auto;width:44px;height:44px;border-radius:50%;background:var(--raise);border:1px solid var(--line2);display:flex;align-items:center;justify-content:center;color:var(--ink-700);cursor:pointer;position:relative}
.cd-bldg{display:flex;align-items:center;gap:9px;width:100%;padding:11px 14px;background:var(--page);border:1px solid var(--line2);border-radius:var(--r-sm);font-family:inherit;font-size:15px;font-weight:600;color:var(--ink-800);cursor:pointer}
.cd-bldg svg:first-child{color:var(--acc)}
.cd-title{font-family:var(--font-display);font-size:25px;font-weight:600;letter-spacing:-.02em;color:var(--ink-900);margin:14px 0 0}
.cd-title-row{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-top:14px}
.cd-title-row .cd-title{margin:0}
.cd-head-action{height:40px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--acc);border-radius:var(--r-pill);background:var(--acc);color:var(--white);font-family:inherit;font-size:13.5px;font-weight:700;padding:0 14px;white-space:nowrap;cursor:pointer}
.cd-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;padding:16px 16px 0}
.cd-stat{background:var(--page);border:1px solid var(--line2);border-radius:var(--r-md);padding:12px 8px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:5px}
.cd-stat-ic{color:var(--ink-400);display:flex}
.cd-stat.urgent .cd-stat-ic{color:var(--st-urgent)}
.cd-stat b{font-family:var(--font-display);font-size:22px;font-weight:700;line-height:1;color:var(--ink-900)}
.cd-stat.urgent b{color:var(--st-urgent)}
.cd-stat span{font-size:11.5px;color:var(--ink-500);font-weight:500}
.cd-sec{display:flex;align-items:center;justify-content:space-between;padding:22px 18px 10px}
.cd-sec h2{font-family:var(--font-display);font-size:17px;font-weight:600;color:var(--ink-900);margin:0}
.cd-list{display:flex;flex-direction:column;gap:10px;padding:0 16px}
.cd-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--page);border:1px solid var(--line2);border-radius:var(--r-md);text-align:left;font-family:inherit;cursor:pointer;width:100%}
.cd-thumb{width:48px;height:48px;border-radius:var(--r-sm);object-fit:cover;flex:0 0 auto;background:var(--raise)}
.cd-thumb.ph{display:flex;align-items:center;justify-content:center;color:var(--acc)}
.cd-card-main{flex:1 1 auto;min-width:0}
.cd-card-t{font-size:15px;font-weight:600;color:var(--ink-900);line-height:1.25;letter-spacing:-.01em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cd-card-m{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--ink-500);margin-top:4px}
.cd-card-m svg{color:var(--ink-400);flex:0 0 auto}
.cd-card-side{display:flex;flex-direction:column;align-items:flex-end;gap:7px;flex:0 0 auto}
.cd-updot{width:10px;height:10px;border-radius:50%;background:var(--acc);flex:0 0 auto;margin:0 6px}
.setup-nudge{display:flex;align-items:center;gap:12px;width:calc(100% - 32px);min-height:78px;margin:16px 16px 0;padding:13px 14px;background:var(--page);border:1px solid var(--acc-tint-border);border-radius:var(--r-md);font-family:inherit;text-align:left;cursor:pointer}
.setup-nudge-ic{width:46px;height:46px;border-radius:var(--r-sm);background:var(--acc-tint);color:var(--acc);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.setup-nudge-main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:3px}
.setup-nudge-k{font-size:15.5px;font-weight:700;color:var(--ink-900);line-height:1.2}
.setup-nudge-v{font-size:12.5px;color:var(--ink-500);line-height:1.35}
.setup-ring{width:52px;height:52px;border-radius:50%;background:var(--acc);color:var(--white);font-family:var(--font-display);font-size:14px;font-weight:750;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.cd-mapcard{margin:18px 16px 0;padding:16px;background:var(--page);border:1px solid var(--line2);border-radius:var(--r-md)}
.cd-mapcard-head{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--ink-900)}
.cd-mappin{position:absolute;transform:translate(-50%,-50%);min-width:44px;height:44px;border-radius:50%;border:3px solid var(--white);color:var(--white);font-size:14px;font-weight:750;font-family:var(--font-display);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 8px -2px rgba(0,0,0,.5)}
.cd-mappin.tone-green{background:var(--st-green)}.cd-mappin.tone-amber{background:var(--st-amber)}.cd-mappin.tone-red{background:var(--st-urgent)}.cd-mappin.tone-blue{background:var(--st-blue)}
/* inbox chips + search + cards */
.ib-chips{display:flex;gap:8px;padding:14px 16px 10px;overflow-x:auto;flex:0 0 auto}
.ib-chips::-webkit-scrollbar{height:0}
.ib-chip{display:inline-flex;align-items:center;gap:6px;min-height:40px;white-space:nowrap;border:1px solid var(--line2);background:var(--page);border-radius:var(--r-pill);padding:0 15px;font-family:inherit;font-size:13.5px;font-weight:600;color:var(--ink-600);cursor:pointer}
.ib-chip.on{background:var(--acc-tint);border-color:var(--acc);color:var(--acc-text)}
.ib-chip-dot{width:7px;height:7px;border-radius:50%;flex:0 0 auto}
.ib-search{display:flex;gap:10px;padding:0 16px 12px;flex:0 0 auto}
.ib-searchbox{flex:1 1 auto;display:flex;align-items:center;gap:8px;background:var(--raise);border:1px solid var(--line2);border-radius:var(--r-sm);padding:9px 13px;color:var(--ink-400)}
.ib-searchbox input{flex:1 1 auto;border:0;background:transparent;outline:none;font-family:inherit;font-size:14px;color:var(--ink-800)}
.ib-sort{display:flex;align-items:center;gap:6px;border:1px solid var(--line2);background:var(--page);border-radius:var(--r-sm);padding:0 14px;font-family:inherit;font-size:14px;font-weight:600;color:var(--ink-700);cursor:pointer}
.ibk{display:flex;align-items:center;gap:13px;padding:13px 14px;background:var(--page);border:1px solid var(--line2);border-radius:var(--r-md);text-align:left;font-family:inherit;cursor:pointer;width:100%}
.ibk-thumb{position:relative;width:62px;height:62px;border-radius:var(--r-sm);overflow:hidden;flex:0 0 auto;background:var(--raise)}
.ibk-thumb img{width:100%;height:100%;object-fit:cover}
.ibk-blue{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--acc);background:var(--raise)}
.ibk-num{position:absolute;top:5px;left:5px;min-width:18px;height:18px;border-radius:50%;border:2px solid var(--white);color:var(--white);font-size:10.5px;font-weight:700;display:flex;align-items:center;justify-content:center}
.ibk-num.tone-red{background:var(--st-urgent)}.ibk-num.tone-blue{background:var(--st-blue)}.ibk-num.tone-green{background:var(--st-green)}
.ibk-main{flex:1 1 auto;min-width:0}
.ibk-t{font-size:15px;font-weight:600;color:var(--ink-900);line-height:1.25;letter-spacing:-.01em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ibk-loc{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--ink-600);margin-top:4px}
.ibk-loc svg{color:var(--ink-400);flex:0 0 auto}
.ibk-meta{font-size:11.5px;color:var(--ink-400);margin-top:3px}
.ibk-side{display:flex;flex-direction:column;align-items:flex-end;gap:7px;flex:0 0 auto}
/* building map */
.bm-levels{display:flex;gap:8px;padding:14px 16px;flex:0 0 auto}
.bm-level{flex:1;border:1px solid var(--line2);background:var(--page);border-radius:var(--r-sm);padding:11px 6px;font-family:inherit;font-size:14px;font-weight:600;color:var(--ink-600);cursor:pointer}
.bm-level.on{background:var(--acc-tint);border-color:var(--acc);color:var(--acc-text)}
.bm-legend{display:flex;flex-wrap:wrap;gap:10px 14px;justify-content:center;padding:14px 12px;margin:14px 16px 0;border:1px solid var(--line2);border-radius:var(--r-sm)}
.bm-legend span{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink-700);white-space:nowrap}
.bm-openrow{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 10px;font-size:15px;color:var(--ink-700)}
.bm-openrow b{color:var(--ink-900)}
.bm-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;padding:0 16px 18px}
.bm-stat{background:var(--page);border:1px solid var(--line2);border-radius:var(--r-sm);padding:12px 6px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:5px}
.bm-stat b{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink-900);line-height:1}
.bm-stat span{font-size:11px;color:var(--ink-500)}
.ml-dot{width:11px;height:11px;border-radius:50%;flex:0 0 auto;display:inline-block}

/* ── building setup onboarding ─────────────────────────────── */
.setup-screen .cd-head{padding-bottom:16px}
.setup-hero{display:grid;grid-template-columns:auto 1fr;gap:13px;margin:16px 16px 0;padding:15px;background:linear-gradient(180deg,var(--page),var(--ink-50));border:1px solid var(--line2);border-radius:var(--r-md);overflow:hidden}
.setup-hero-art{width:86px;height:72px;border-radius:var(--r-sm);background:var(--acc-tint);border:1px solid var(--acc-tint-border);display:flex;align-items:center;justify-content:center;overflow:hidden;flex:0 0 auto}
.setup-hero-art img{display:block;width:92%;height:92%;object-fit:contain;filter:saturate(.96)}
.setup-logo-preview{width:96px;height:68px;border-radius:var(--r-sm);background:var(--page);border:1px solid var(--line2);display:flex;align-items:center;justify-content:center;overflow:hidden;flex:0 0 auto}
.setup-logo-preview.compact{width:78px;height:58px}
.setup-logo-preview .wordmark{transform:scale(.78);transform-origin:center}
.setup-logo-preview.compact .wordmark{transform:scale(.68)}
.setup-logo-preview img{width:100%;height:100%;object-fit:contain;padding:7px}
.setup-hero-copy{min-width:0}
.setup-eyebrow{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--acc-text);font-weight:700;margin-bottom:5px}
.setup-hero h2{font-family:var(--font-display);font-size:20px;font-weight:750;color:var(--ink-900);line-height:1.12;letter-spacing:-.02em;margin:0}
.setup-hero p{font-size:13px;color:var(--ink-500);line-height:1.38;margin:7px 0 0}
.setup-progress{grid-column:1 / -1;display:flex;align-items:center;gap:10px;margin-top:3px}
.setup-progress span{font-family:var(--font-display);font-size:17px;font-weight:750;color:var(--ink-900);font-variant-numeric:tabular-nums}
.setup-progress i{height:8px;flex:1 1 auto;background:var(--raise);border:1px solid var(--line2);border-radius:var(--r-pill);overflow:hidden}
.setup-progress b{display:block;height:100%;background:var(--acc);border-radius:var(--r-pill)}
.setup-checklist{display:flex;gap:8px;overflow-x:auto;padding:12px 16px 0}
.setup-checklist::-webkit-scrollbar{height:0}
.setup-checklist span,.setup-checklist button{display:inline-flex;align-items:center;gap:6px;min-height:40px;white-space:nowrap;border:1px solid var(--line2);border-radius:var(--r-pill);padding:0 12px;background:var(--page);font-family:inherit;font-size:12px;font-weight:650;color:var(--ink-500);cursor:pointer;flex:0 0 auto}
.setup-checklist span.done,.setup-checklist button.done{background:var(--st-green-bg);border-color:var(--st-green-line);color:var(--st-green)}
.setup-checklist button.on{background:var(--acc-tint);border-color:var(--acc-tint-border);color:var(--acc-text);box-shadow:inset 0 0 0 1px var(--acc-tint-border)}
.setup-checklist button:focus-visible,.setup-choice:focus-visible,.setup-theme-choice:focus-visible,.setup-loc:focus-visible,
.setup-upload:focus-within,.setup-qr-row .btn:focus-visible{outline:0;box-shadow:var(--focus)}
.setup-pad{padding-top:14px}
.setup-flow-card{background:var(--page);border:1px solid var(--line2);border-radius:var(--r-md);padding:16px;box-shadow:0 1px 2px #14120e0a}
.setup-flow-eyebrow{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--acc-text);font-weight:750;margin-bottom:8px}
.setup-flow-card h2{font-family:var(--font-display);font-size:24px;font-weight:760;line-height:1.08;letter-spacing:-.025em;color:var(--ink-900);margin:0;text-wrap:balance}
.setup-flow-card>p{font-size:14px;line-height:1.45;color:var(--ink-500);margin:8px 0 0}
.setup-flow-body{margin-top:16px}
.setup-flow-footer{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;border-top:1px solid var(--line);margin:16px -16px -16px;padding:12px 16px 14px;background:linear-gradient(180deg,var(--white),var(--ink-50))}
.setup-flow-footer .btn{width:auto;min-width:74px;min-height:44px;height:auto;padding:10px 14px;font-size:13.5px;line-height:1.15;white-space:normal;text-align:center}
.setup-flow-footer .btn-ghost{justify-self:end;color:var(--ink-500)}
.setup-flow-footer .btn-acc{grid-column:3}
.setup-bottom-actions{flex:0 0 auto;background:var(--page);border-top:1px solid var(--line);padding:10px 16px}
.setup-bottom-actions .setup-flow-footer{margin:0;padding:0;border:0;background:transparent}
.setup-choice-stack{display:grid;gap:8px;margin-top:14px}
.setup-choice{min-height:50px;width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--page);border:1px solid var(--line2);border-radius:var(--r-sm);padding:0 13px;font-family:inherit;font-size:14.5px;font-weight:700;color:var(--ink-700);cursor:pointer;text-align:left}
.setup-choice.on{background:var(--acc-tint);border-color:var(--acc-tint-border);color:var(--acc-text)}
.setup-theme-grid{display:grid;gap:8px;margin-top:4px}
.setup-theme-choice{min-height:56px;width:100%;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;background:var(--page);border:1px solid var(--line2);border-radius:var(--r-sm);padding:9px 11px;font-family:inherit;color:var(--ink-700);cursor:pointer;text-align:left}
.setup-theme-choice.on{background:var(--acc-tint);border-color:var(--acc-tint-border);color:var(--acc-text);box-shadow:inset 0 0 0 1px var(--acc-tint-border)}
.setup-theme-swatch{width:22px;height:22px;border-radius:var(--r-pill);border:2px solid var(--white);box-shadow:0 0 0 1px var(--line2);display:block}
.setup-theme-choice b{display:block;font-size:14px;line-height:1.2;color:inherit}
.setup-theme-choice small{display:block;font-size:11.5px;font-weight:600;line-height:1.25;color:var(--ink-500);margin-top:2px}
.setup-theme-choice.on small{color:var(--acc-text)}
.setup-guidance{display:grid;gap:8px;margin-top:14px}
.setup-guidance div{border:1px solid var(--line2);border-radius:var(--r-sm);background:linear-gradient(180deg,var(--white),var(--ink-50));padding:10px 12px}
.setup-guidance span{display:block;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--acc-text);font-weight:750;margin-bottom:5px}
.setup-guidance b{display:block;font-size:12.8px;line-height:1.35;color:var(--ink-700);font-weight:600}
.setup-inline-error,.setup-inline-status{border-radius:var(--r-sm);padding:10px 12px;font-size:12.5px;line-height:1.35;margin-top:10px}
.setup-inline-error{background:var(--st-urgent-bg);border:1px solid var(--st-urgent-line);color:var(--st-urgent)}
.setup-inline-status{background:var(--ink-50);border:1px solid var(--line2);color:var(--ink-600)}
.setup-review{display:grid;gap:8px;margin-top:14px}
.setup-review span{border:1px solid var(--line2);border-radius:var(--r-sm);background:var(--ink-50);padding:11px 12px;font-size:13px;font-weight:650;color:var(--ink-500)}
.setup-review span.done{background:var(--st-green-bg);border-color:var(--st-green-line);color:var(--st-green)}
.setup-step{border:1px solid var(--line2);border-radius:var(--r-md);background:var(--page);overflow:hidden;margin-bottom:10px}
.setup-step.open{border-color:var(--acc-tint-border)}
.setup-step-head{width:100%;min-height:66px;display:flex;align-items:center;gap:12px;padding:12px 14px;background:transparent;border:0;font-family:inherit;text-align:left;cursor:pointer}
.setup-step-ic{width:40px;height:40px;border-radius:var(--r-sm);background:var(--raise);color:var(--ink-600);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.setup-step-ic.done{background:var(--st-green-bg);color:var(--st-green)}
.setup-step-copy{display:flex;flex-direction:column;gap:2px;flex:1 1 auto;min-width:0}
.setup-step-copy span{font-size:15.5px;font-weight:750;color:var(--ink-900);line-height:1.2}
.setup-step-copy small{font-size:12.5px;color:var(--ink-500);line-height:1.3}
.setup-step-head .chev{color:var(--ink-400);flex:0 0 auto}
.setup-step-body{padding:0 14px 15px;border-top:1px solid var(--line)}
.setup-grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.setup-logo-row{display:flex;align-items:center;gap:13px;margin-top:15px}
.setup-upload{position:relative;overflow:hidden;margin-bottom:8px}
.setup-upload input{position:absolute;inset:0;opacity:0;cursor:pointer}
.setup-locations,.setup-qr-list{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.setup-loc{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:12px;border:1px solid var(--line2);border-radius:var(--r-sm);background:var(--raise);font-family:inherit;text-align:left;cursor:pointer}
.setup-loc.active{background:var(--page);border-color:var(--acc-tint-border)}
.setup-loc b,.setup-qr-row b{display:block;font-size:14.5px;color:var(--ink-900);line-height:1.15}
.setup-loc small,.setup-qr-row small{display:block;font-size:12px;color:var(--ink-500);margin-top:3px;line-height:1.2}
.setup-loc-state{font-size:12px;font-weight:750;color:var(--acc-text);background:var(--acc-tint);border-radius:var(--r-pill);padding:5px 9px;white-space:nowrap}
.setup-loc:not(.active) .setup-loc-state{background:var(--raise);color:var(--ink-400)}
.setup-qr-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;gap:9px;padding:10px;border:1px solid var(--line2);border-radius:var(--r-sm);background:var(--page)}
.setup-qr-row .btn{min-width:54px;padding:0 10px}
.setup-mini-qr{width:52px;height:52px;border-radius:var(--r-xs);border:1px solid var(--line2);display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--white)}
.setup-actions{display:grid;gap:9px;margin-top:14px}

/* ── issue detail & triage ──────────────────────────────────── */
.idt-card{display:flex;gap:14px;padding:14px;background:var(--page);border:1px solid var(--line2);border-radius:var(--ios-radius);margin-top:6px}
.idt-photo{width:84px;height:84px;border-radius:var(--r-sm);object-fit:cover;flex:0 0 auto;background:var(--raise)}
.idt-photo.ph{display:flex;align-items:center;justify-content:center;color:var(--acc)}
/* clean resident-photo placeholder (no muddy simulation) */
.photo-ph{aspect-ratio:4/3;border-radius:var(--r-sm);background:var(--raise);border:1px solid var(--line2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--ink-400);font-size:12px;font-weight:600}
.idt-main{flex:1 1 auto;min-width:0}
.idt-title{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.01em;color:var(--ink-900);line-height:1.2}
.idt-loc{font-size:13.5px;color:var(--ink-500);margin-top:5px}
.idt-meta{display:flex;align-items:center;gap:14px;margin-top:9px;font-size:12.5px;color:var(--ink-500)}
.idt-meta span{display:inline-flex;align-items:center;gap:5px}
.idt-meta svg{color:var(--ink-400)}
.idt-id{font-family:var(--font-mono);color:var(--acc)}
.idt-desc{font-size:14.5px;line-height:1.5;color:var(--ink-700);margin:14px 2px 0}
.prow-ic{width:26px;flex:0 0 auto;color:var(--acc);display:flex;align-items:center;justify-content:center}
.tk-step.on .tk-step-lbl{color:var(--acc-text)}
.tk-step.done .tk-step-lbl{color:var(--ink-600)}
.track-next{display:flex;gap:11px;align-items:flex-start;margin-top:16px;padding:14px;border-radius:var(--ios-radius);background:var(--acc-tint);border:1px solid var(--acc-tint-border);font-size:14px;line-height:1.45;color:var(--ink-700)}
.track-next svg{color:var(--acc);flex:0 0 auto;margin-top:1px}
.tn-k{display:block;font-size:12px;font-weight:700;color:var(--acc-text);margin-bottom:2px}
/* review: blueprint map of where it occurred */
.rev-map{position:relative;margin-top:12px;border:1px solid var(--line2);border-radius:var(--ios-radius);overflow:hidden;background:#0C2247;aspect-ratio:16/10}
.rev-map-img{width:100%;height:100%;object-fit:cover;display:block}
.rev-map.noimg{background-image:linear-gradient(rgba(150,190,240,.16) 1px,transparent 1px),linear-gradient(90deg,rgba(150,190,240,.16) 1px,transparent 1px);background-size:9% 11%}
.rev-map.noimg .rev-map-img{display:none}
.rev-map-pin{position:absolute;top:42%;left:50%;transform:translate(-50%,-100%);width:34px;height:34px;border-radius:50%;background:var(--acc);color:var(--white);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px -3px rgba(0,0,0,.5);border:2px solid var(--white)}
.rev-map-cap{position:absolute;left:12px;bottom:12px;background:rgba(255,255,255,.94);color:var(--ink-900);font-size:12.5px;font-weight:600;padding:6px 11px;border-radius:var(--r-xs)}
/* more vertical breathing room between report steps */
.osr .osr-label{margin-top:24px}
.osr textarea.inp{min-height:150px}
.osr .cat-grid{gap:10px}
.osr .cat-chip{min-height:56px}
.whatsnext{display:flex;align-items:center;gap:12px;white-space:normal}
.wn-v{flex:1 1 auto;min-width:0;font-size:14.5px;font-weight:400;color:var(--ink-700);line-height:1.35;white-space:normal}
.emerg svg{color:var(--danger);flex:0 0 auto}
.emerg b{font-weight:700}
.send-hint{display:block;width:100%;background:none;border:0;font-family:inherit;font-size:13px;color:var(--acc-text);font-weight:600;text-align:center;margin:0 0 9px;line-height:1.4;cursor:pointer}

/* bottom tab bar */
.tabbar{background:var(--page);border-top:1px solid var(--line);display:flex;flex:0 0 auto;padding-bottom:10px}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 0 0;font-size:11px;font-weight:500;color:var(--ink-400);cursor:pointer}
.tabbar a.on{color:var(--acc-strong)}

/* ── updates feed ───────────────────────────────────────────── */
.feed{padding:4px 16px 16px;display:flex;flex-direction:column}
.feed-item{display:flex;gap:13px;padding:14px 6px;background:transparent;border:0;border-top:1px solid var(--line);width:100%;text-align:left;font-family:inherit;cursor:pointer;align-items:flex-start}
.feed-item:first-child{border-top:0}
.feed-item:active{background:var(--raise)}
.feed-mk{width:32px;height:32px;border-radius:var(--r-xs);display:flex;align-items:center;justify-content:center;flex:0 0 auto;margin-top:1px;border:1px solid var(--line2)}
.feed-mk.pub{background:var(--acc);color:var(--white);border-color:transparent}
.feed-mk.priv{background:var(--raise);color:var(--ink-600)}
.feed-mk.new{background:var(--raise);color:var(--ink-700)}
.feed-mk.status{background:var(--raise);color:var(--ink-500)}
.feed-body{flex:1 1 auto;min-width:0}
.feed-top{display:flex;align-items:center;gap:8px}
.feed-tag{font-family:var(--font-mono);font-size:10.5px;font-weight:500;color:var(--ink-500);text-transform:uppercase;letter-spacing:.1em}
.feed-when{margin-left:auto;font-size:11.5px;color:var(--ink-400);white-space:nowrap}
.feed-text{font-size:14.5px;color:var(--ink-800);line-height:1.4;margin-top:5px}
.feed-ref{font-size:12.5px;color:var(--ink-400);margin-top:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.feed-ref .id-mono{color:var(--ink-500)}

/* ── ticket detail ──────────────────────────────────────────── */
.det-head{padding:6px 20px 16px;border-bottom:1px solid var(--line);flex:0 0 auto}
.det-head .sum{font-family:var(--font-display);font-size:23px;font-weight:600;line-height:1.15;color:var(--ink-900);margin:10px 0 10px;letter-spacing:-.01em}
.det-head .facts{display:flex;flex-wrap:wrap;gap:7px}
.chip{display:inline-flex;align-items:center;gap:6px;min-height:36px;font-size:13px;font-weight:500;color:var(--ink-600);
  background:var(--raise);border:1px solid var(--line2);border-radius:var(--r-xs);padding:0 11px;white-space:nowrap}
.chip svg{color:var(--ink-400)}
.sec-label{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--ink-400);margin:24px 0 12px;letter-spacing:.18em;text-transform:uppercase}

/* panel */
.panel{background:var(--page);border:1px solid var(--line2);border-radius:var(--r-md);overflow:hidden}
.panel .prow{display:flex;align-items:center;gap:12px;padding:14px 15px;border-top:1px solid var(--line-muted-light);background:transparent;width:100%;font-family:inherit;text-align:left;cursor:pointer}
.panel .prow:first-child{border-top:0}
.panel .prow:focus-visible{outline:3px solid var(--acc-tint-border);outline-offset:-3px}
.panel .prow:active{background:var(--raise)}
.panel .prow .k{font-size:14px;color:var(--ink-500);flex:0 0 auto;width:96px}
.panel .prow .v{font-size:15px;color:var(--ink-900);font-weight:500;flex:1 1 auto;display:flex;align-items:center;gap:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.panel .prow .chev{color:var(--ink-300);flex:0 0 auto}

/* timeline */
.timeline{position:relative;padding-left:8px}
.te{position:relative;padding:0 0 18px 26px}
.te::before{content:"";position:absolute;left:5px;top:3px;bottom:-4px;width:2px;background:var(--line2)}
.te:last-child::before{display:none}
.te .marker{position:absolute;left:0;top:2px;width:12px;height:12px;border-radius:50%;background:var(--ink-300);box-shadow:0 0 0 3px var(--page)}
.te.m-update .marker{background:var(--acc)} .te.m-note .marker{background:var(--ink-500)}
.te.m-status .marker{background:var(--primary-400)} .te.m-submitted .marker{background:var(--success)}
.te .when{font-size:12px;color:var(--ink-400);font-weight:500}
.te .body{font-size:15px;line-height:1.5;color:var(--ink-800);margin-top:3px}
.te .who{font-size:13px;color:var(--ink-500);margin-top:3px}
.te .lane-tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:var(--r-xs);margin-bottom:5px}
.te .lane-tag.pub{background:var(--acc-tint);color:var(--acc-text)}
.te .lane-tag.priv{background:var(--raise);color:var(--ink-600)}

/* two-lane composer entry buttons */
.lane-actions{display:grid;gap:10px;margin-top:6px}
.lane-btn{display:flex;align-items:center;gap:13px;padding:16px 16px;border-radius:var(--r-md);cursor:pointer;text-align:left;font-family:inherit;width:100%;transition:filter .14s,transform .12s}
.lane-btn:active{filter:brightness(.97);transform:scale(.99)}
.lane-btn .ic{width:42px;height:42px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.lane-btn .tt{display:block;font-size:16px;font-weight:600;line-height:1.2}
.lane-btn .ds{display:block;font-size:13px;margin-top:3px;line-height:1.35}
.lane-btn.pub{background:var(--acc-tint);border:1px solid var(--acc-tint-border)}
.lane-btn.pub .ic{background:var(--acc);color:var(--white)}
.lane-btn.pub .tt{color:var(--acc-text)} .lane-btn.pub .ds{color:var(--acc-text)}
.lane-btn.priv{background:var(--page);border:1px solid var(--line2)}
.lane-btn.priv .ic{background:var(--ink-100);color:var(--ink-700)}
.lane-btn.priv .tt{color:var(--ink-800)} .lane-btn.priv .ds{color:var(--ink-500)}
.lane-btn .chev{margin-left:auto;color:currentColor;opacity:.5;flex:0 0 auto}

/* ── sheet / modal ──────────────────────────────────────────── */
.sheet-backdrop{position:absolute;inset:0;background:rgba(20,18,14,.45);z-index:20;display:flex;align-items:flex-end;
  animation:fade .2s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.sheet{background:var(--page);width:100%;max-height:92%;border-radius:var(--r-lg) var(--r-lg) 0 0;display:flex;flex-direction:column;
  animation:slideup .28s var(--ease-out,cubic-bezier(.33,1,.68,1))}
@keyframes slideup{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sheet .grip{width:38px;height:5px;border-radius:var(--r-pill);background:var(--ink-200);margin:10px auto 4px;flex:0 0 auto}
.sheet .sh-head{display:flex;align-items:center;gap:10px;padding:8px 18px 12px;border-bottom:1px solid var(--line);flex:0 0 auto}
.sheet .sh-head h3{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--ink-900);flex:1 1 auto}
.sheet .sh-body{padding:16px 18px;overflow-y:auto;flex:1 1 auto}
.sheet .sh-body::-webkit-scrollbar{width:0}
.sheet .sh-foot{padding:12px 18px calc(12px + 6px);border-top:1px solid var(--line);flex:0 0 auto;display:flex;gap:10px}

/* lane banner inside composer — makes the destination unmistakable */
.lane-banner{display:flex;align-items:center;gap:11px;padding:13px 14px;border-radius:var(--r-md);margin-bottom:14px}
.lane-banner .ic{width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.lane-banner .tt{display:block;font-size:14px;font-weight:700;line-height:1.2}
.lane-banner .ds{display:block;font-size:12.5px;margin-top:2px}
.lane-banner.pub{background:var(--acc-tint);border:1px solid var(--acc-tint-border)}
.lane-banner.pub .ic{background:var(--acc);color:var(--white)} .lane-banner.pub .tt{color:var(--acc-text)} .lane-banner.pub .ds{color:var(--acc-text)}
.lane-banner.priv{background:var(--raise);border:1px solid var(--line2)}
.lane-banner.priv .ic{background:var(--ink-200);color:var(--ink-700)} .lane-banner.priv .tt{color:var(--ink-800)} .lane-banner.priv .ds{color:var(--ink-500)}

/* preview block */
.preview-card{background:var(--raise);border:1px solid var(--line2);border-radius:var(--r-md);padding:15px;margin-top:6px}
.preview-card .pv-when{font-size:12px;color:var(--ink-400);margin-bottom:6px}
.preview-card .pv-body{font-size:15px;line-height:1.5;color:var(--ink-800)}

/* ── confirmation / status page ─────────────────────────────── */
.center-wrap{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 26px;text-align:center;overflow-y:auto}
.big-check{width:78px;height:78px;border-radius:50%;background:var(--st-green-bg);color:var(--success);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.ref-pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:15px;color:var(--ink-800);
  background:var(--raise);border:1px solid var(--line2);border-radius:var(--r-sm);padding:9px 14px;margin-top:6px}

/* status page hero */
.status-hero{padding:18px 20px 18px;background:var(--raise);border-bottom:1px solid var(--line);flex:0 0 auto}
.update-card{background:var(--page);border:1px solid var(--line2);border-left:3px solid var(--acc);border-radius:var(--r-sm);padding:15px;margin-top:14px}
.update-card .lbl{font-size:12px;font-weight:600;color:var(--acc-text);margin-bottom:6px;display:flex;align-items:center;gap:6px}
.update-card .body{font-size:16px;line-height:1.5;color:var(--ink-900)}
.update-card .when{font-size:12px;color:var(--ink-400);margin-top:8px}
.kv{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-top:1px solid var(--line);font-size:14px}
.kv:first-of-type{border-top:0}
.kv .k{color:var(--ink-500)} .kv .v{color:var(--ink-900);font-weight:500;text-align:right}

/* powered-by footer */
.poweredby{text-align:center;font-size:12px;color:var(--ink-400);padding:14px 0 4px}
.poweredby b{color:var(--ink-600);font-weight:600}

/* ── sign-in screen (matches marketing identity) ── */
.signin{background:var(--page)}
.si-hero{position:relative;padding:34px 22px 24px;min-height:318px;overflow:hidden;
  background:linear-gradient(180deg,#E4EEFB 0%,#F1F6FE 56%,#FCFDFF 100%)}
.si-clouds{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.si-cloud{position:absolute;height:26px;background:var(--white);border-radius:60px;opacity:.94;filter:blur(.4px)}
.si-cloud::before,.si-cloud::after{content:"";position:absolute;background:var(--white);border-radius:50%}
.si-cloud.c1{width:86px;top:78px;right:18px}
.si-cloud.c1::before{width:40px;height:40px;top:-18px;left:14px}
.si-cloud.c1::after{width:28px;height:28px;top:-10px;right:14px}
.si-cloud.c2{width:62px;top:170px;left:10px;opacity:.8}
.si-cloud.c2::before{width:30px;height:30px;top:-14px;left:9px}
.si-cloud.c2::after{width:22px;height:22px;top:-7px;right:9px}
.si-cloud.c3{width:50px;top:44px;left:46%;opacity:.66}
.si-cloud.c3::before{width:24px;height:24px;top:-10px;left:7px}
.si-cloud.c3::after{width:17px;height:17px;top:-5px;right:7px}
.si-birds{position:absolute;top:118px;right:108px;z-index:1;pointer-events:none}
.si-skyline{position:absolute;left:62%;transform:translateX(-50%);bottom:-30px;width:86%;max-width:390px;height:auto;z-index:2;pointer-events:none;opacity:.84;
  -webkit-mask-image:linear-gradient(180deg,transparent 0%,transparent 30%,#000 58%);mask-image:linear-gradient(180deg,transparent 0%,transparent 30%,#000 58%)}
.si-scrim{position:absolute;left:0;right:0;top:0;height:78%;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(238,243,253,1) 0%,rgba(239,244,254,.97) 48%,rgba(242,246,254,.62) 78%,rgba(243,247,254,0) 100%)}
.si-top{position:relative;z-index:3;text-align:left;max-width:88%}
.si-logo{display:flex;justify-content:flex-start;margin-bottom:18px}
.si-h1{font-family:var(--font-display);font-size:30px;font-weight:600;letter-spacing:-.028em;line-height:1.06;color:var(--ink-900);margin:0}
.si-sub{font-size:14.5px;color:var(--ink-600);line-height:1.42;margin:10px 0 0;text-align:left;max-width:29ch;text-wrap:pretty}
.si-card{margin:-44px 18px 0;background:var(--page);border:1px solid var(--line2);border-radius:var(--r-md);padding:20px 18px;
  box-shadow:0 10px 30px -16px rgba(17,24,39,.22);position:relative;z-index:2}
.si-field{display:flex;align-items:center;gap:11px;height:54px;padding:0 15px;border:1px solid var(--line2);border-radius:var(--r-sm);margin-bottom:12px;color:var(--ink-400)}
.si-field:focus-within{border-color:var(--acc);box-shadow:0 0 0 3px var(--acc-tint)}
.si-field input{flex:1 1 auto;border:0;outline:none;background:transparent;font-family:inherit;font-size:16px;color:var(--ink-900)}
.si-field .si-eye{background:none;border:0;color:var(--ink-400);cursor:pointer;padding:4px;flex:0 0 auto}
.si-card .btn{height:54px;margin-top:2px}
.si-or{display:flex;align-items:center;gap:12px;margin:16px 2px;color:var(--ink-400);font-family:var(--font-mono);font-size:11px;letter-spacing:.16em}
.si-or::before,.si-or::after{content:"";flex:1 1 auto;height:1px;background:var(--line2)}
.si-google{display:flex;align-items:center;justify-content:center;gap:11px;width:100%;height:54px;border:1px solid var(--line2);border-radius:var(--r-sm);
  background:var(--page);font-family:inherit;font-size:16px;font-weight:600;color:var(--ink-800);cursor:pointer}
.g-mark{font-family:var(--font-display);font-weight:800;font-size:18px;
  background:conic-gradient(from -45deg,#EA4335,#FBBC05,#34A853,#4285F4,#EA4335);-webkit-background-clip:text;background-clip:text;color:transparent}
.si-links{display:flex;align-items:center;justify-content:center;gap:16px;margin:22px 0 0}
.si-links .linkbtn{font-size:14.5px;font-weight:600}
.si-div{width:1px;height:16px;background:var(--line2)}
.si-foot{display:flex;align-items:flex-start;gap:9px;justify-content:center;text-align:center;color:var(--ink-400);font-size:12.5px;line-height:1.5;padding:22px 24px 8px;max-width:340px;margin:0 auto}
.si-foot svg{color:var(--ink-300);flex:0 0 auto;margin-top:1px}
.si-foot b{color:var(--ink-600);font-weight:600}

/* sign-in card head + remember row + feature strip */
.si-card-head{margin-bottom:16px}
.si-card-head h2{font-family:var(--font-display);font-size:23px;font-weight:700;letter-spacing:-.02em;line-height:1.1;color:var(--ink-900);margin:0}
.si-card-head p{font-size:14.5px;color:var(--ink-500);margin:5px 0 0;line-height:1.4}
.si-cardrow{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:2px 0 16px}
.si-remember{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--ink-700);font-weight:500;cursor:pointer;position:relative}
.si-remember input{position:absolute;opacity:0;width:0;height:0}
.si-check{width:20px;height:20px;border-radius:var(--r-xs);border:1.5px solid var(--line-strong);background:var(--page);display:inline-flex;align-items:center;justify-content:center;color:transparent;flex:0 0 auto;transition:background .15s,border-color .15s}
.si-remember input:checked + .si-check{background:var(--acc);border-color:var(--acc);color:var(--white)}
.si-cardrow .linkbtn{font-size:14px;font-weight:600;white-space:nowrap}
.si-features{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:18px 16px 6px;text-align:center}
.si-feat{display:flex;flex-direction:column;align-items:center;gap:8px;font-size:11.5px;font-weight:600;color:var(--ink-600);line-height:1.2}
.si-feat-ic{width:46px;height:46px;border-radius:var(--r-md);background:var(--acc-tint);color:var(--acc);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.ms-mark{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
.si-cardlinks{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:18px}
.si-cardlinks .linkbtn{font-size:14px;font-weight:600}
.si-resident{display:block;width:100%;background:none;border:0;cursor:pointer;font-family:inherit;font-size:13.5px;color:var(--ink-500);text-align:center;margin:18px 0 0;padding:0 16px}
.si-resident span{color:var(--acc-text);font-weight:600}

/* ── resident dashboard ─────────────────────────────────────── */
.rh{background:var(--page)}
.rh-head{position:relative;padding:14px 20px 44px;background:var(--header-bg);border-bottom:1px solid var(--header-line);overflow:hidden}
.rh-hero-img{position:absolute;top:0;right:-4%;width:46%;max-width:200px;height:100%;object-fit:contain;object-position:right top;opacity:.95;pointer-events:none}
.rh-bar{position:relative;z-index:2;display:flex;align-items:center;margin-bottom:14px}
.rh-bell{margin-left:auto;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.7);border:1px solid var(--line2);display:flex;align-items:center;justify-content:center;color:var(--ink-700);cursor:pointer;position:relative}
.rh-dot{position:absolute;top:9px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--acc);border:1.5px solid var(--white)}
.rh-greet{position:relative;z-index:1;max-width:62%}
.rh-hello{font-size:15px;color:var(--ink-600)}
.rh-bldg{font-family:var(--font-display);font-size:27px;font-weight:600;letter-spacing:-.022em;color:var(--ink-900);line-height:1.08;margin:3px 0 0}
.rh-tag{font-size:14px;color:var(--ink-500);line-height:1.4;margin:6px 0 0;max-width:28ch}
.rh-primary{padding:16px 16px 0}
.rh-report-card{display:flex;align-items:center;gap:13px;width:100%;padding:16px;background:var(--acc);border:0;border-radius:var(--r-md);color:var(--white);font-family:inherit;text-align:left;cursor:pointer;box-shadow:var(--shadow-accent-card)}
.rh-report-card:active{filter:brightness(.96);transform:scale(.995)}
.rh-report-ic{width:46px;height:46px;border-radius:var(--r-sm);background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.24);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.rh-report-main{display:flex;flex-direction:column;gap:3px;flex:1 1 auto;min-width:0}
.rh-report-k{font-size:18px;font-weight:700;letter-spacing:-.01em}
.rh-report-v{font-size:13.5px;line-height:1.35;color:rgba(255,255,255,.82)}
.rh-report-card .rh-chev{color:var(--white-75)}
.rh-quick{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.rh-quick button{height:46px;border:1px solid var(--line2);background:var(--page);border-radius:var(--r-sm);font-family:inherit;font-size:14px;font-weight:650;color:var(--ink-800);display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer}
.rh-quick button svg{color:var(--acc)}
.rh-trust{display:flex;align-items:center;gap:7px;margin:12px 2px 0;font-size:12.5px;line-height:1.35;color:var(--ink-500)}
.rh-trust svg{color:var(--ink-400);flex:0 0 auto}
.rh-steps{display:grid;gap:8px;padding:0 16px}
.rh-steps div{display:grid;grid-template-columns:28px 1fr;column-gap:10px;align-items:start;padding:13px 14px;background:var(--raise);border:1px solid var(--line2);border-radius:var(--r-md)}
.rh-steps span{grid-row:1 / span 2;width:28px;height:28px;border-radius:50%;background:var(--acc-tint);color:var(--acc-text);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:750}
.rh-steps b{font-size:15px;color:var(--ink-900);line-height:1.15}
.rh-steps p{font-size:13px;color:var(--ink-500);line-height:1.35;margin:3px 0 0}
.rh-sec.compact{padding-top:18px}
.rh-list.quiet{padding-bottom:18px}
.rh-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-2);margin:var(--sp-4) var(--sp-4) 0}
.rh-stat{background:var(--page);border:1px solid var(--line2);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-2);display:flex;flex-direction:column;align-items:center;gap:var(--sp-2);min-height:78px;justify-content:center}
.rh-stat-n{font-family:var(--font-display);font-size:26px;font-weight:700;line-height:1;color:var(--ink-900);font-variant-numeric:tabular-nums}
.rh-stat-l{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--ink-500);text-align:center;line-height:1.2}
.rh-dotc{width:7px;height:7px;border-radius:50%;flex:0 0 auto}
.rh-dotc.s-blue{background:var(--st-blue)} .rh-dotc.s-violet{background:var(--st-violet)}
.rh-dotc.s-amber{background:var(--st-amber)} .rh-dotc.s-green{background:var(--st-green)}
.rh-dotc.s-urgent{background:var(--st-urgent)}
.rh-sec{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-6) var(--sp-5) var(--sp-3)}
.rh-sec h2{font-family:var(--font-display);font-size:var(--fs-h2);font-weight:700;color:var(--ink-900);margin:0}
.rh-sec .linkbtn{font-size:var(--fs-sm);font-weight:600;display:inline-flex;align-items:center;gap:2px;white-space:nowrap;flex:0 0 auto}
.rh-list{display:flex;flex-direction:column;gap:var(--sp-2);padding:0 var(--sp-4)}
.rh-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-3);background:var(--page);border:1px solid var(--line2);border-radius:var(--r-md);text-align:left;font-family:inherit;cursor:pointer;transition:background var(--t-fast)}
.rh-row:active{background:var(--raise)}
.rh-thumb{width:46px;height:46px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex:0 0 auto;overflow:hidden;background:var(--raise);border:1px solid var(--line);color:var(--acc)}
.rh-thumb img{width:100%;height:100%;object-fit:cover}
/* category tiles — one brand-blue icon on a neutral tile (no pastel, no rainbow) */
.rh-thumb[class*="cat-"]{background:var(--raise);color:var(--acc)}
.rh-row-main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:4px}
.rh-row-t{font-size:15.5px;font-weight:600;color:var(--ink-900);line-height:1.25;letter-spacing:-.01em;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.rh-row-d{display:block;font-size:var(--fs-meta);color:var(--ink-500)}
.rh-row-status{display:inline-flex}
.rh-row .stt{flex:0 0 auto}
.rh-chev{color:var(--ink-300);flex:0 0 auto;align-self:center}
.rh-mapcard{display:flex;align-items:center;gap:10px;margin:18px 16px 18px;padding:18px;background:var(--acc-tint);border:1px solid var(--acc-tint-border);border-radius:var(--r-md);text-align:left;font-family:inherit;cursor:pointer;width:calc(100% - 32px);overflow:hidden}
.rh-mapcard-t{flex:1 1 auto;min-width:0}
.rh-mapcard-t h3{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink-900);line-height:1.15;margin:0}
.rh-mapcard-t p{font-size:13px;color:var(--ink-600);line-height:1.4;margin:7px 0 12px}
.rh-mapbtn{display:inline-flex;align-items:center;background:var(--acc);color:var(--white);border-radius:var(--r-pill);padding:9px 16px;font-size:13.5px;font-weight:600}
.rh-iso{width:130px;flex:0 0 auto;object-fit:contain}
.rh-tabs{display:flex;background:var(--page);border-top:1px solid var(--line);flex:0 0 auto;padding-bottom:10px}
.rh-tabs a{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 0 0;font-size:11px;font-weight:600;color:var(--ink-400);cursor:pointer}
.rh-tabs a.on{color:var(--acc)}

/* ── QR-start explainer: real camera-app scan opens this page ─────── */
.qr-start{background:var(--page)}
.qr-start-head{position:relative;padding:14px 18px 16px;background:var(--header-bg);border-bottom:1px solid var(--header-line);overflow:hidden}
.qr-start-head::after{content:"";position:absolute;right:-38px;top:14px;width:168px;height:168px;border-radius:50%;background:var(--acc-tint);opacity:.48}
.qr-building-outline{position:absolute;right:-16px;bottom:-34px;width:190px;max-width:none;opacity:.24;filter:saturate(1.08);pointer-events:none;z-index:0}
.qr-paper{position:relative;z-index:1;display:flex;align-items:center;gap:13px;margin:12px 0 0;background:rgba(255,255,255,.84);border:1px solid var(--acc-tint-border);border-radius:var(--r-lg);padding:12px;box-shadow:0 18px 44px -32px rgba(14,26,43,.38);backdrop-filter:blur(6px)}
.qr-mark{width:86px;height:86px;border-radius:var(--r-md);background:var(--white);border:1px solid var(--line2);display:flex;align-items:center;justify-content:center;flex:0 0 auto;overflow:hidden}
.qr-paper-copy{flex:1 1 auto;min-width:0}
.qr-paper-top{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-400);margin-bottom:5px}
.qr-paper-title{font-size:17px;font-weight:750;color:var(--ink-900);line-height:1.18}
.qr-paper-copy p{font-size:12.5px;line-height:1.35;color:var(--ink-500);margin:5px 0 0}
.qr-start-body{padding-top:18px;padding-bottom:18px}
.qr-start-body .osr-h1{margin-top:0}
.qr-start-body .osr-sub b{color:var(--ink-800);font-weight:700}
.qr-how{padding:0;margin-top:14px;gap:8px}
.qr-how div{padding:12px 13px;background:linear-gradient(180deg,var(--white),var(--raise));}
.qr-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.qr-actions .btn{height:46px;font-size:14px;font-weight:650;padding:0 12px}
.qr-actions .btn svg{color:var(--acc)}

.case-stamp{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0 14px}
.case-stamp-item{background:linear-gradient(180deg,var(--white),var(--raise));border:1px solid var(--line2);border-radius:var(--r-md);padding:10px 11px;min-width:0}
.case-stamp-k{display:block;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-400);white-space:nowrap}
.case-stamp-v{display:block;margin-top:4px;font-size:14px;line-height:1.18;color:var(--ink-900);font-weight:750;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}

/* ── council settings (mobile) ──────────────────────────────── */
.set-section{font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-400);margin:22px 0 10px}
.set-section:first-child{margin-top:4px}
.set-row{display:flex;align-items:center;gap:14px;padding:14px 16px;width:100%;background:var(--page);border:0;border-top:1px solid var(--line);font-family:inherit;text-align:left;cursor:pointer}
.set-toggles .set-row:first-child{border-top:0}
.set-row-t{flex:1 1 auto;min-width:0}
.set-label{display:block;font-size:16px;font-weight:600;color:var(--ink-900)}
.set-desc{display:block;font-size:13px;color:var(--ink-500);margin-top:2px;line-height:1.35}
.switch{width:46px;height:28px;border-radius:var(--r-pill);background:var(--ink-200);flex:0 0 auto;position:relative;transition:background .18s}
.switch.on{background:var(--acc)}
.switch .knob{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:var(--white);transition:transform .18s;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.switch.on .knob{transform:translateX(18px)}

/* role switch pill (prototype chrome) */
.role-switch{position:static;z-index:5;display:flex;gap:4px;
  background:rgba(20,18,14,.7);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-pill);padding:4px}
.role-switch button{min-height:36px;border:0;background:transparent;color:rgba(255,255,255,.6);cursor:pointer;font-family:var(--font-sans);
  font-size:13px;font-weight:600;padding:0 16px;border-radius:var(--r-pill)}
.role-switch button.on{background:var(--acc);color:var(--white)}
.toast{position:absolute;left:16px;right:16px;bottom:96px;background:var(--ink-900);color:var(--white);border-radius:var(--r-md);
  padding:13px 15px;font-size:14px;display:flex;align-items:center;gap:10px;z-index:30;box-shadow:0 12px 30px -8px rgba(0,0,0,.5);animation:slideup .25s var(--ease-out,ease)}
.toast svg{flex:0 0 auto;color:var(--acc)}
.flex1{flex:1 1 auto}
.people-pick{display:flex;flex-direction:column;gap:0}
.spin{width:26px;height:26px;border-radius:50%;border:3px solid var(--line2);border-top-color:var(--acc);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── QR scanner landing ─────────────────────────────────────── */
.scan{position:absolute;inset:0;background:#0b0f16;display:flex;flex-direction:column;color:var(--white);overflow:hidden}
.scan-cam{position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 38%, #243244, #0b0f16 75%)}
.scan-cam::after{content:"";position:absolute;inset:0;background:var(--grain);opacity:.5;mix-blend-mode:overlay}
.scan-top{position:relative;z-index:2;padding:54px 20px 0;display:flex;align-items:center;gap:12px}
.scan-top .t{font-weight:600;font-size:16px}
.scan-body{position:relative;z-index:2;flex:1 1 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;padding:0 30px}
.viewfinder{position:relative;width:230px;height:230px;border-radius:24px}
.viewfinder .frame{position:absolute;inset:0;border-radius:24px}
.viewfinder .corner{position:absolute;width:38px;height:38px;border:3px solid var(--white);border-radius:6px}
.viewfinder .corner.tl{top:-2px;left:-2px;border-right:0;border-bottom:0;border-radius:var(--r-md) 0 0 0}
.viewfinder .corner.tr{top:-2px;right:-2px;border-left:0;border-bottom:0;border-radius:0 var(--r-md) 0 0}
.viewfinder .corner.bl{bottom:-2px;left:-2px;border-right:0;border-top:0;border-radius:0 0 0 18px}
.viewfinder .corner.br{bottom:-2px;right:-2px;border-left:0;border-top:0;border-radius:0 0 18px 0}
.viewfinder .qrwrap{position:absolute;inset:30px;border-radius:var(--r-sm);overflow:hidden;background:var(--white);opacity:.9;
  box-shadow:0 12px 40px rgba(0,0,0,.5)}
.viewfinder .scanline{position:absolute;left:8px;right:8px;height:3px;border-radius:3px;
  background:linear-gradient(90deg,transparent,var(--acc),transparent);box-shadow:0 0 14px 2px var(--acc);
  animation:scanmove 1.8s var(--ease-io,ease-in-out) infinite}
@keyframes scanmove{0%{top:14px}50%{top:calc(100% - 17px)}100%{top:14px}}
.scan-hint{text-align:center;font-size:15px;color:rgba(255,255,255,.8);line-height:1.5;max-width:30ch}
.scan-found{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  border-radius:var(--r-pill);padding:9px 16px;font-size:14px;font-weight:600;backdrop-filter:blur(6px)}
.scan-foot{position:relative;z-index:2;padding:14px 20px calc(14px + 8px)}
.scan-foot .ghost{background:transparent;border:0;color:rgba(255,255,255,.7);font-family:inherit;font-size:14px;font-weight:600;width:100%;padding:12px;cursor:pointer}

/* ── printable poster ───────────────────────────────────────── */
.poster{background:var(--white);border:1px solid var(--line2);border-radius:var(--r-md);padding:30px 26px 24px;text-align:center;
  box-shadow:0 10px 30px -16px rgba(0,0,0,.25)}
.poster-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-400)}
.poster-title{font-family:var(--font-display);font-size:26px;font-weight:700;line-height:1.1;color:var(--ink-900);margin:12px 0 0;letter-spacing:-.015em}
.poster-sub{font-size:14px;line-height:1.5;color:var(--ink-500);margin:10px auto 0;max-width:30ch}
.poster-qr{display:inline-block;margin:22px 0 18px;padding:14px;border:1px solid var(--line2);border-radius:var(--r-sm);background:var(--white)}
.poster-loc{display:inline-flex;align-items:center;gap:7px;background:var(--acc-tint);color:var(--acc-text);
  border-radius:var(--r-pill);padding:8px 16px;font-size:15px;font-weight:600}
.poster-foot{font-size:12px;color:var(--ink-400);margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.poster-foot b{color:var(--ink-600)}

/* ─── Reimagined: iOS-clean shapes — rounded cards, soft elevation ─── */
.group,.tk,.panel,.note,.lane-btn,.lane-banner,
.update-card,.preview-card,.send-summary,.qrcard,.poster{border-radius:var(--ios-radius) !important}
.tk-thumb,.tk-ico2,.stat,.inp,.ref-pill,.rev-photo,.ss-thumb,.opt,.well,.views button,
.chip,.qr,.poster-qr,.field .inp,.osr-locrow,.osr-photo,.cat-chip{border-radius:var(--ios-radius-sm) !important}
.av,.cat-check{border-radius:50% !important}
.group,.tk,.panel,.stat,.lane-btn,.qrcard,.poster,.osr-locrow{border:1px solid var(--line2) !important;box-shadow:none !important}
/* shadows reserved for floating/sticky surfaces only */
.footer,.tabbar,.sheet,.toast{box-shadow:0 -1px 2px rgba(17,24,39,.04) !important}
.btn,.btn-sm,.role-switch,.role-switch button{border-radius:var(--r-pill) !important}
.sheet{border-radius:var(--r-lg) var(--r-lg) 0 0 !important}
.timeline .te .lane-tag,.seg{border-radius:var(--r-xs) !important}
.device{border-radius:44px}
.inp:focus{box-shadow:0 0 0 3px var(--acc-tint) !important;border-color:var(--acc)}

/* ─── De-slop: status = dot + label (no pastel pill), hard selected states ─── */
/* ─── Status = dot + label (calm); Urgent = filled red pill (triage signal) ─── */
.stt:not(.is-urgent){background:transparent !important;border:0 !important;padding:0 !important;color:var(--ink-700) !important;font-weight:600}
.stt .dot{background:var(--st-blue)}
.t-blue .dot{background:var(--st-blue)} .t-violet .dot{background:var(--st-violet)}
.t-amber .dot{background:var(--st-amber)} .t-teal .dot{background:var(--st-teal)}
.t-green .dot{background:var(--st-green)} .t-grey .dot{background:var(--st-grey)}
.stt.is-urgent{background:var(--st-urgent-bg) !important;color:var(--st-urgent) !important;
  padding:4px 11px !important;border-radius:var(--r-pill) !important;font-weight:600}

/* case-file rows stay calm even after click/focus in the prototype shell */
.screen.cd .panel{border-color:var(--line2) !important;background:var(--page) !important}
.screen.cd .panel .prow{
  -webkit-appearance:none !important;appearance:none !important;
  border:0 !important;border-radius:0 !important;outline:0 !important;
  box-shadow:inset 0 1px 0 var(--line-muted-soft) !important;
  background:transparent !important;
}
.screen.cd .panel .prow:first-child{box-shadow:none !important}
.screen.cd .panel .prow:active{background:var(--raise) !important}
.screen.cd .panel .prow:focus-visible{box-shadow:inset 0 0 0 3px var(--acc-tint-border) !important}
.stt.is-urgent .dot{background:var(--st-urgent) !important}
.cat-chip.sel{background:var(--page) !important}

/* ─── StrataSnap mobile design-system alignment ─── */
button:focus-visible,
.linkbtn:focus-visible,
.rh-tabs a:focus-visible,
.tabbar a:focus-visible{
  outline:0;
  box-shadow:var(--focus);
}

.steprail{padding:12px 24px 16px}
.sr-item::before{top:12px;height:1.5px;background:var(--line2)}
.sr-dot{width:24px;height:24px;border-width:1.5px;font-size:12px;font-family:var(--font-sans);font-weight:750}
.sr-lbl{font-size:11px;font-weight:650}

.osr-locrow{
  padding:11px 12px;
  background:linear-gradient(180deg,var(--white),var(--raise));
  border-color:var(--acc-tint-border) !important;
}
.osr-loc-ic{
  width:32px;height:32px;
  background:var(--acc-tint);
  border-color:var(--acc-tint-border);
  color:var(--acc);
}
.osr-loc-meta{letter-spacing:.14em}

.cat-grid{gap:10px}
.cat-chip{
  min-height:56px;
  padding:0 12px;
  color:var(--ink-800);
  background:linear-gradient(180deg,var(--white),var(--raise));
  border-color:var(--line2);
  transition:border-color var(--t-fast),background var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast);
}
.cat-chip:active{transform:scale(.99)}
.cat-chip:focus-visible{outline:0;box-shadow:var(--focus)}
.cat-chip .cat-art{width:30px;height:30px;opacity:.82;filter:saturate(.85)}
.cat-chip .cat-tile{width:30px;height:30px;background:var(--acc-tint) !important;color:var(--acc) !important;border:1px solid var(--acc-tint-border)}
.cat-chip span:not(.cat-tile):not(.cat-check){font-weight:700;color:var(--acc-text)}
.cat-chip.sel{
  background:var(--acc-tint) !important;
  border:1px solid var(--acc-tint-border) !important;
  box-shadow:inset 0 0 0 1px var(--acc-tint-border) !important;
}
.cat-chip.sel .cat-art{opacity:1;filter:none}
.cat-chip.sel .cat-tile{background:var(--acc) !important;color:var(--white) !important;border-color:var(--acc)}

.rev-list,.rh-steps div,.cd-stat,.cd-card,.ibk,.rh-row{
  background:linear-gradient(180deg,var(--white),var(--raise));
  border-color:var(--line2) !important;
}
.cd-card:focus-visible,.ibk:focus-visible,.rh-row:focus-visible{outline:0;box-shadow:var(--focus)}
.cd-stat{min-height:92px;justify-content:center}
.cd-card,.ibk,.rh-row{transition:border-color var(--t-fast),background var(--t-fast),transform var(--t-fast)}
.cd-card:active,.ibk:active,.rh-row:active{transform:scale(.992)}

.rh-tabs,.tabbar{padding:8px 0 calc(10px + 2px)}
.rh-tabs a,.tabbar a{min-height:50px;justify-content:center;padding-top:0;border-radius:var(--r-sm);margin:0 3px}
.rh-tabs a.on,.tabbar a.on{background:var(--acc-tint);color:var(--acc-text)}
