/* ═══════════════════════════════════════════════
   RENTFIT INSPECTOR PORTAL — Design System v3
   Aesthetic: Refined Industrial · Light+Dark dual
   Font: Clash Display + Cabinet Grotesk
═══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --bg:       #f5f4f0;
  --bg2:      #eceae4;
  --bg3:      #e4e2da;
  --surface:  #ffffff;
  --surface2: #fafaf8;
  --border:   #e0ddd5;
  --border2:  #d0cdc4;
  --text:     #1a1a18;
  --text2:    #6b6960;
  --text3:    #a8a59e;
  --ink:      #0f0f0e;

  /* Brand */
  --green:    #1a6b4a;
  --green-l:  #e8f5ee;
  --green-m:  #4caf82;
  --green-d:  #0d4a32;

  /* Status */
  --minor:    #2563eb;
  --minor-l:  #eff6ff;
  --minor-m:  #93c5fd;
  --cost:     #d97706;
  --cost-l:   #fffbeb;
  --cost-m:   #fcd34d;
  --major:    #dc2626;
  --major-l:  #fef2f2;
  --major-m:  #fca5a5;
  --attention:#7c3aed;
  --attention-l:#f5f3ff;
  --attention-m:#c4b5fd;

  /* Work states */
  --open:     #ef4444;
  --pending:  #f59e0b;
  --approved: #3b82f6;
  --resolved: #10b981;
  --rejected: #6b7280;

  --font:   'Plus Jakarta Sans', sans-serif;
  --mono:   'JetBrains Mono', monospace;
  --r:      10px;
  --r2:     16px;
  --r3:     24px;
  --shadow: 0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.06);
  --shadow2: 0 2px 8px rgba(0,0,0,.1), 0 8px 32px rgba(0,0,0,.08);
}

/* ── RESET ── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; -webkit-tap-highlight-color:transparent; }
html, body { height:100%; background:var(--bg); color:var(--text); font-family:var(--font); font-size:15px; line-height:1.5; overscroll-behavior:none; }
input,select,textarea,button { font-family:var(--font); }
button { cursor:pointer; }
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }

/* ── APP SHELL ── */
#app { position:relative; height:100dvh; width:100%; max-width:480px; margin:0 auto; overflow:hidden; background:var(--bg); }

/* ── SCREENS ── */
.screen { position:absolute; inset:0; display:flex; flex-direction:column; opacity:0; pointer-events:none; transition:opacity .28s, transform .28s cubic-bezier(.4,0,.2,1); will-change:transform,opacity; }
.screen.active { opacity:1; pointer-events:all; transform:translateX(0)!important; }
.screen.enter-right { transform:translateX(100%); }
.screen.enter-left  { transform:translateX(-100%); }
.screen.exit-right  { transform:translateX(100%); opacity:0; }
.screen.exit-left   { transform:translateX(-100%); opacity:0; }

.scrollable { flex:1; overflow-y:auto; overflow-x:hidden; -webkit-overflow-scrolling:touch; }
.scrollable::-webkit-scrollbar { width:2px; }
.scrollable::-webkit-scrollbar-thumb { background:var(--border2); border-radius:2px; }

/* ── TOPBAR ── */
.topbar {
  display:flex; align-items:center; gap:10px;
  padding:12px 16px 10px;
  background:var(--surface); border-bottom:1px solid var(--border);
  flex-shrink:0; position:sticky; top:0; z-index:30;
}
.topbar-back {
  width:36px; height:36px; border-radius:10px; background:var(--bg2);
  border:1px solid var(--border); display:flex; align-items:center;
  justify-content:center; cursor:pointer; color:var(--text2); transition:.15s; flex-shrink:0;
}
.topbar-back:active { background:var(--bg3); transform:scale(.93); }
.topbar-title { font-size:16px; font-weight:700; flex:1; letter-spacing:-.3px; }
.topbar-sub   { font-size:11px; color:var(--text3); display:block; font-weight:400; }
.topbar-icon-btn {
  width:36px; height:36px; border-radius:10px; background:var(--bg2);
  border:1px solid var(--border); display:flex; align-items:center;
  justify-content:center; cursor:pointer; color:var(--text2); transition:.15s; flex-shrink:0;
}
.topbar-icon-btn:active { background:var(--bg3); transform:scale(.93); }
.topbar-icon-btn.accent { background:var(--green-l); border-color:var(--green-m); color:var(--green); }

/* ── BOTTOM NAV ── */
.bottomnav {
  display:flex; background:var(--surface); border-top:1px solid var(--border);
  padding:6px 8px calc(6px + env(safe-area-inset-bottom,0px)); gap:2px; flex-shrink:0;
}
.nav-btn {
  flex:1; display:flex; flex-direction:column; align-items:center; gap:2px;
  padding:7px 4px; border-radius:12px; cursor:pointer; color:var(--text3);
  font-size:10px; font-weight:600; letter-spacing:.03em; text-transform:uppercase; transition:.15s;
  border:none; background:transparent;
}
.nav-btn svg { width:20px; height:20px; stroke-width:1.8; }
.nav-btn.active { color:var(--green); background:var(--green-l); }
.nav-btn:active { transform:scale(.94); }

/* ── CARDS ── */
.card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r2);
  overflow:hidden; margin-bottom:12px; box-shadow:var(--shadow);
}
.card-p { padding:16px; }
.card-header { display:flex; align-items:center; gap:10px; padding:14px 16px 12px; border-bottom:1px solid var(--border); }
.card-header h4 { font-size:13px; font-weight:600; flex:1; }

/* ── PROPERTY CARD ── */
.prop-card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r2);
  padding:16px; margin-bottom:10px; cursor:pointer; transition:.2s; position:relative; overflow:hidden;
  box-shadow:var(--shadow);
}
.prop-card::before { content:''; position:absolute; left:0; top:0; bottom:0; width:4px; border-radius:4px 0 0 4px; }
.prop-card.status-scheduled::before { background:var(--approved); }
.prop-card.status-inprogress::before { background:var(--pending); }
.prop-card.status-completed::before { background:var(--resolved); }
.prop-card.status-overdue::before   { background:var(--open); }
.prop-card:active { transform:scale(.99); background:var(--bg2); }
.prop-card:hover  { box-shadow:var(--shadow2); }

.prop-top { display:flex; align-items:flex-start; gap:12px; margin-bottom:12px; }
.prop-avatar {
  width:46px; height:46px; border-radius:14px; display:flex; align-items:center;
  justify-content:center; font-size:17px; font-weight:800; flex-shrink:0;
}
.prop-meta { flex:1; min-width:0; }
.prop-name { font-size:15px; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-bottom:2px; }
.prop-addr { font-size:12px; color:var(--text2); line-height:1.4; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.prop-badge {
  flex-shrink:0; font-size:10px; font-weight:700; padding:4px 9px; border-radius:20px;
  letter-spacing:.03em; text-transform:uppercase;
}
.prop-details { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.prop-detail { background:var(--bg2); border-radius:8px; padding:8px 10px; }
.prop-detail-label { font-size:9px; color:var(--text3); margin-bottom:2px; text-transform:uppercase; letter-spacing:.06em; font-weight:600; }
.prop-detail-val   { font-size:12px; font-weight:600; color:var(--text); }
.prop-footer { display:flex; align-items:center; justify-content:space-between; margin-top:10px; padding-top:10px; border-top:1px solid var(--border); }
.known-issue-tag {
  display:inline-flex; align-items:center; gap:4px; font-size:10px; font-weight:600;
  padding:3px 8px; border-radius:6px; background:var(--attention-l); color:var(--attention);
  border:1px solid var(--attention-m); margin-right:4px;
}

/* ── DASHBOARD STATS ── */
.period-tabs {
  display:flex; gap:4px; padding:12px 16px; background:var(--surface);
  border-bottom:1px solid var(--border); overflow-x:auto; scrollbar-width:none; flex-shrink:0;
}
.period-tabs::-webkit-scrollbar { display:none; }
.period-tab {
  flex-shrink:0; padding:6px 14px; border-radius:20px; font-size:12px; font-weight:600;
  background:var(--bg2); border:1px solid var(--border); color:var(--text2); cursor:pointer; transition:.15s;
}
.period-tab.active { background:var(--green); border-color:var(--green); color:#fff; }
.period-tab:active { transform:scale(.95); }

.dash-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; padding:16px; }
.stat-card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r2);
  padding:14px; box-shadow:var(--shadow); cursor:pointer; transition:.15s; position:relative; overflow:hidden;
}
.stat-card:active { transform:scale(.98); }
.stat-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; }
.stat-card.c-green::after { background:var(--green); }
.stat-card.c-blue::after  { background:var(--approved); }
.stat-card.c-amber::after { background:var(--pending); }
.stat-card.c-red::after   { background:var(--open); }
.stat-card.c-purple::after { background:var(--attention); }
.stat-card.c-teal::after  { background:var(--resolved); }
.stat-num { font-size:28px; font-weight:800; line-height:1; letter-spacing:-1px; }
.stat-lbl { font-size:11px; color:var(--text2); margin-top:4px; font-weight:500; line-height:1.3; }
.stat-card .trend { font-size:10px; margin-top:6px; font-weight:600; }
.trend.up   { color:var(--resolved); }
.trend.down { color:var(--open); }

/* ── SECTION TITLES ── */
.sec-title {
  font-size:11px; font-weight:700; color:var(--text3); text-transform:uppercase;
  letter-spacing:.1em; padding:16px 16px 8px;
}
.sec-title-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px 8px;
}
.sec-title-row h3 { font-size:13px; font-weight:700; }
.sec-title-row a  { font-size:12px; color:var(--green); font-weight:600; }

/* ── CHECKIN / PIN ── */
.checkin-wrap { padding:24px 20px 16px; }
.checkin-icon-wrap {
  width:80px; height:80px; border-radius:50%; background:var(--green-l);
  border:2px solid var(--green-m); display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px;
}
.checkin-icon-wrap svg { width:34px; height:34px; stroke-width:1.5; color:var(--green); }
.checkin-h { font-size:22px; font-weight:800; text-align:center; margin-bottom:6px; letter-spacing:-.4px; }
.checkin-s { font-size:13px; color:var(--text2); text-align:center; line-height:1.6; }

.prop-info-card {
  background:var(--bg2); border:1px solid var(--border); border-radius:var(--r2);
  overflow:hidden; margin:20px 0;
}
.pic-row { display:flex; align-items:center; gap:10px; padding:12px 14px; border-bottom:1px solid var(--border); }
.pic-row:last-child { border-bottom:none; }
.pic-ico { width:30px; height:30px; border-radius:8px; background:var(--surface); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.pic-ico svg { width:14px; height:14px; stroke-width:2; color:var(--text2); }
.pic-text p   { font-size:13px; font-weight:500; }
.pic-text span { font-size:11px; color:var(--text2); }

.pin-row { display:flex; gap:10px; justify-content:center; margin:24px 0 8px; }
.pin-cell {
  width:52px; height:60px; border-radius:14px; background:var(--bg2); border:1.5px solid var(--border2);
  display:flex; align-items:center; justify-content:center; font-size:28px; font-weight:800;
  font-family:var(--mono); color:var(--text); transition:.15s;
}
.pin-cell.filled { border-color:var(--green); background:var(--green-l); color:var(--green); }
.pin-cell.err    { border-color:var(--major); background:var(--major-l); animation:shake .4s; }
@keyframes shake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-6px)} 75%{transform:translateX(6px)} }

.keypad { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; padding:0 4px; }
.key {
  height:58px; border-radius:14px; background:var(--surface); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center; cursor:pointer;
  font-size:22px; font-weight:700; color:var(--text); transition:.12s; user-select:none;
  box-shadow:0 1px 3px rgba(0,0,0,.06);
}
.key:active { transform:scale(.91); background:var(--bg2); }
.key.key-del { font-size:20px; color:var(--text2); }
.key.key-ok  { background:var(--green); color:#fff; border-color:var(--green-d); font-size:18px; }
.key.key-ok:active { background:var(--green-d); }

/* ── INSPECTION HEADER ── */
.insp-header {
  background:var(--surface); border-bottom:1px solid var(--border);
  padding:12px 16px; flex-shrink:0;
}
.insp-proj-row { display:flex; align-items:center; gap:10px; }
.insp-avatar {
  width:38px; height:38px; border-radius:11px; display:flex; align-items:center;
  justify-content:center; font-size:15px; font-weight:800; flex-shrink:0;
  background:var(--green-l); color:var(--green);
}
.insp-proj-text p    { font-size:13px; font-weight:700; }
.insp-proj-text span { font-size:11px; color:var(--text2); }
.session-timer {
  margin-left:auto; font-size:11px; font-weight:600; font-family:var(--mono);
  padding:4px 10px; border-radius:20px; background:var(--green-l); color:var(--green);
  border:1px solid var(--green-m);
}

.room-tabs {
  display:flex; gap:6px; overflow-x:auto; padding:10px 14px; flex-shrink:0;
  border-bottom:1px solid var(--border); scrollbar-width:none;
}
.room-tabs::-webkit-scrollbar { display:none; }
.room-tab {
  flex-shrink:0; padding:6px 12px; border-radius:20px; font-size:12px; font-weight:600;
  background:var(--bg2); border:1px solid var(--border); color:var(--text2); cursor:pointer;
  transition:.15s; display:flex; align-items:center; gap:5px; white-space:nowrap;
}
.room-tab.active { background:var(--green); border-color:var(--green-d); color:#fff; }
.room-tab:active { transform:scale(.95); }
.room-tab .rc { font-size:10px; background:rgba(0,0,0,.1); padding:1px 6px; border-radius:8px; min-width:18px; text-align:center; }
.room-tab.active .rc { background:rgba(255,255,255,.25); color:#fff; }

/* ── INSPECTION SUBNAV ── */
.subnav {
  display:flex; background:var(--bg2); border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.subnav-btn {
  flex:1; padding:10px 4px; font-size:11px; font-weight:700; color:var(--text3);
  text-align:center; cursor:pointer; border-bottom:2px solid transparent;
  transition:.15s; text-transform:uppercase; letter-spacing:.05em; border:none; background:transparent;
  display:flex; flex-direction:column; align-items:center; gap:2px;
}
.subnav-btn svg { width:16px; height:16px; stroke-width:2; }
.subnav-btn.active { color:var(--green); border-bottom-color:var(--green); background:var(--surface); }
.subnav-btn:active { transform:scale(.95); }

/* ── ISSUE ITEMS ── */
.issue-item {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r2);
  padding:14px 16px; margin-bottom:8px; cursor:pointer; transition:.2s;
  position:relative; overflow:hidden; box-shadow:var(--shadow);
}
.issue-item::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:4px; border-radius:4px 0 0 4px;
}
.issue-item.cl-minor::before    { background:var(--minor); }
.issue-item.cl-cost::before     { background:var(--cost); }
.issue-item.cl-major::before    { background:var(--major); }
.issue-item.cl-attention::before { background:var(--attention); }
.issue-item.cl-known::before    { background:var(--text3); }
.issue-item:active { background:var(--bg2); transform:scale(.99); }
.issue-title { font-size:13px; font-weight:600; line-height:1.4; margin-bottom:6px; padding-right:4px; }
.issue-meta  { display:flex; flex-wrap:wrap; gap:5px; align-items:center; }
.issue-photos-strip { display:flex; gap:4px; margin-top:8px; }
.iph { width:38px; height:38px; border-radius:8px; object-fit:cover; border:1px solid var(--border); }
.iph-more { width:38px; height:38px; border-radius:8px; background:var(--bg2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:600; color:var(--text2); }
.issue-closed-overlay {
  position:absolute; inset:0; background:rgba(245,244,240,.85);
  display:flex; align-items:center; justify-content:center; pointer-events:none;
}
.issue-closed-overlay span { font-size:11px; font-weight:700; color:var(--resolved); background:var(--green-l); padding:4px 12px; border-radius:20px; border:1px solid var(--green-m); }

/* ── BADGES / TAGS ── */
.badge {
  display:inline-flex; align-items:center; gap:3px; font-size:10px; font-weight:700;
  padding:3px 8px; border-radius:20px; text-transform:uppercase; letter-spacing:.04em;
}
.badge.minor    { background:var(--minor-l);    color:var(--minor);    border:1px solid var(--minor-m); }
.badge.cost     { background:var(--cost-l);     color:var(--cost);     border:1px solid var(--cost-m); }
.badge.major    { background:var(--major-l);    color:var(--major);    border:1px solid var(--major-m); }
.badge.attention{ background:var(--attention-l);color:var(--attention);border:1px solid var(--attention-m); }
.badge.known    { background:var(--bg2);        color:var(--text2);    border:1px solid var(--border2); }
.badge.open     { background:#fef2f2;           color:var(--open);     border:1px solid #fca5a5; }
.badge.pending  { background:#fffbeb;           color:var(--pending);  border:1px solid #fcd34d; }
.badge.approved { background:#eff6ff;           color:var(--approved); border:1px solid #93c5fd; }
.badge.resolved { background:var(--green-l);   color:var(--green);    border:1px solid var(--green-m); }
.badge.rejected { background:#f9fafb;           color:var(--rejected); border:1px solid #d1d5db; }
.badge.proposal { background:#f5f3ff;           color:var(--attention);border:1px solid #c4b5fd; }
.rtag { font-size:10px; font-weight:600; background:var(--bg2); color:var(--text2); padding:2px 8px; border-radius:6px; border:1px solid var(--border); }

/* ── FORMS ── */
.field { margin-bottom:14px; }
.field label { display:block; font-size:11px; font-weight:700; color:var(--text3); margin-bottom:5px; text-transform:uppercase; letter-spacing:.07em; }
.field input,
.field select,
.field textarea {
  width:100%; background:var(--bg2); border:1px solid var(--border2); border-radius:var(--r);
  padding:11px 14px; color:var(--text); font-size:14px; transition:.15s; outline:none; appearance:none;
}
.field textarea { resize:vertical; min-height:80px; line-height:1.5; }
.field input:focus,
.field select:focus,
.field textarea:focus { border-color:var(--green); background:var(--surface); box-shadow:0 0 0 3px var(--green-l); }
.field select option { background:var(--surface); }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.field-row3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; }

/* ── CLASSIFICATION SELECTOR ── */
.cls-selector { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-bottom:14px; }
.cls-opt {
  padding:10px 6px; border-radius:var(--r); background:var(--bg2); border:1.5px solid var(--border2);
  text-align:center; cursor:pointer; transition:.15s;
}
.cls-opt:active { transform:scale(.95); }
.cls-opt .cls-icon { font-size:18px; margin-bottom:4px; }
.cls-opt .cls-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--text3); }
.cls-opt.active-minor    { background:var(--minor-l);    border-color:var(--minor);    }
.cls-opt.active-minor    .cls-label { color:var(--minor); }
.cls-opt.active-cost     { background:var(--cost-l);     border-color:var(--cost);     }
.cls-opt.active-cost     .cls-label { color:var(--cost); }
.cls-opt.active-major    { background:var(--major-l);    border-color:var(--major);    }
.cls-opt.active-major    .cls-label { color:var(--major); }
.cls-opt.active-attention{ background:var(--attention-l);border-color:var(--attention);}
.cls-opt.active-attention .cls-label { color:var(--attention); }

/* ── PHOTO GRID ── */
.photo-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.photo-thumb { position:relative; aspect-ratio:1; border-radius:10px; overflow:hidden; background:var(--bg2); border:1px solid var(--border); }
.photo-thumb img { width:100%; height:100%; object-fit:cover; }
.photo-del { position:absolute; top:4px; right:4px; width:22px; height:22px; background:rgba(0,0,0,.6); border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:11px; color:#fff; border:none; }
.add-photo {
  aspect-ratio:1; border-radius:10px; background:var(--bg2); border:2px dashed var(--border2);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:5px; cursor:pointer; color:var(--text3); font-size:11px; font-weight:600; transition:.15s;
}
.add-photo svg { width:22px; height:22px; stroke-width:1.5; }
.add-photo:active { border-color:var(--green); color:var(--green); background:var(--green-l); }

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 20px; border-radius:var(--r); font-weight:600; font-size:14px;
  cursor:pointer; transition:.15s; border:none; outline:none; font-family:var(--font);
}
.btn:active { transform:scale(.97); }
.btn:disabled { opacity:.4; pointer-events:none; }
.btn svg { width:16px; height:16px; stroke-width:2; flex-shrink:0; }
.btn-primary  { background:var(--green); color:#fff; }
.btn-primary:hover { background:var(--green-d); }
.btn-ghost    { background:var(--bg2); color:var(--text); border:1px solid var(--border2); }
.btn-ghost:hover { background:var(--bg3); }
.btn-danger   { background:var(--major-l); color:var(--major); border:1px solid var(--major-m); }
.btn-amber    { background:var(--cost-l); color:var(--cost); border:1px solid var(--cost-m); }
.btn-blue     { background:var(--minor-l); color:var(--minor); border:1px solid var(--minor-m); }
.btn-purple   { background:var(--attention-l); color:var(--attention); border:1px solid var(--attention-m); }
.btn-full     { width:100%; }

/* ── MODALS ── */
.overlay { position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:200; display:none; align-items:flex-end; justify-content:center; }
.overlay.open { display:flex; }
.modal {
  background:var(--surface); border:1px solid var(--border); border-radius:28px 28px 0 0;
  width:100%; max-width:480px; max-height:94dvh; display:flex; flex-direction:column;
  animation:slideUp .28s cubic-bezier(.22,.8,.4,1); box-shadow:0 -4px 40px rgba(0,0,0,.15);
}
@keyframes slideUp { from{transform:translateY(100%);opacity:.6} to{transform:translateY(0);opacity:1} }
.modal-bar { width:36px; height:4px; background:var(--border2); border-radius:4px; margin:12px auto 4px; }
.modal-head { display:flex; align-items:center; justify-content:space-between; padding:10px 20px 10px; border-bottom:1px solid var(--border); }
.modal-head h3 { font-size:16px; font-weight:700; }
.modal-x { width:28px; height:28px; border-radius:50%; background:var(--bg2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:13px; color:var(--text2); border:none; }
.modal-body { overflow-y:auto; padding:16px 20px 24px; flex:1; }
.modal-body::-webkit-scrollbar { width:2px; }
.modal-body::-webkit-scrollbar-thumb { background:var(--border2); }
.modal-footer { padding:12px 20px 16px; border-top:1px solid var(--border); display:flex; gap:8px; }

/* ── SIGN-OFF ── */
.signoff-card { background:var(--green-l); border:1px solid var(--green-m); border-radius:var(--r2); padding:20px; margin-bottom:12px; }
.signoff-icon { width:48px; height:48px; border-radius:50%; background:var(--green); display:flex; align-items:center; justify-content:center; margin-bottom:12px; }
.signoff-icon svg { width:24px; height:24px; stroke-width:2; color:#fff; }

/* ── REPORT SECTIONS ── */
.report-section { background:var(--surface); border:1px solid var(--border); border-radius:var(--r2); margin-bottom:10px; overflow:hidden; box-shadow:var(--shadow); }
.report-section-head { display:flex; align-items:center; gap:10px; padding:14px 16px; border-bottom:1px solid var(--border); }
.report-section-head .rsh-icon { width:32px; height:32px; border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.report-section-head h4 { font-size:14px; font-weight:700; flex:1; }
.report-item { display:flex; align-items:flex-start; gap:10px; padding:12px 16px; border-bottom:1px solid var(--border); }
.report-item:last-child { border-bottom:none; }
.ri-num { width:22px; height:22px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:10px; font-weight:700; flex-shrink:0; margin-top:1px; }
.ri-body { flex:1; min-width:0; }
.ri-title { font-size:13px; font-weight:500; line-height:1.4; margin-bottom:4px; }
.ri-meta  { display:flex; flex-wrap:wrap; gap:4px; }
.ri-cost  { font-size:11px; font-weight:700; color:var(--cost); font-family:var(--mono); }
.ri-photos { display:flex; gap:4px; margin-top:6px; }
.ri-photo  { width:40px; height:40px; border-radius:7px; object-fit:cover; border:1px solid var(--border); cursor:pointer; }

/* ── KNOWN ISSUES BANNER ── */
.known-banner {
  background:var(--attention-l); border:1px solid var(--attention-m);
  border-radius:var(--r); padding:10px 14px; margin-bottom:10px;
  display:flex; align-items:flex-start; gap:8px;
}
.known-banner svg { width:16px; height:16px; stroke-width:2; color:var(--attention); flex-shrink:0; margin-top:1px; }
.known-banner p { font-size:12px; color:var(--attention); font-weight:500; }

/* ── PROGRESS INDICATOR ── */
.progress-steps { display:flex; align-items:center; gap:6px; justify-content:center; padding:12px 20px 4px; }
.ps-dot { width:8px; height:8px; border-radius:50%; background:var(--bg3); border:1px solid var(--border2); transition:.3s; }
.ps-dot.done   { background:var(--green); border-color:var(--green); }
.ps-dot.active { width:24px; border-radius:6px; background:var(--green); border-color:var(--green); }
.ps-line { flex:1; height:1px; background:var(--border); max-width:40px; }

/* ── COMPLETE SCREEN ── */
.complete-hero { text-align:center; padding:48px 24px 32px; }
.complete-check {
  width:96px; height:96px; border-radius:50%; background:var(--green);
  display:flex; align-items:center; justify-content:center; margin:0 auto 24px;
  animation:popIn .5s cubic-bezier(.34,1.56,.64,1);
}
@keyframes popIn { from{transform:scale(.4);opacity:0} to{transform:scale(1);opacity:1} }
.complete-check svg { width:46px; height:46px; stroke-width:2; color:#fff; }
.complete-h { font-size:26px; font-weight:800; letter-spacing:-.5px; margin-bottom:8px; }
.complete-s { font-size:13px; color:var(--text2); line-height:1.6; }

/* ── EMPTY ── */
.empty { text-align:center; padding:40px 24px; }
.empty svg { width:44px; height:44px; stroke-width:1.2; color:var(--text3); margin:0 auto 12px; display:block; }
.empty-h { font-size:14px; font-weight:700; color:var(--text2); margin-bottom:4px; }
.empty p { font-size:13px; color:var(--text3); line-height:1.6; }

/* ── TOAST ── */
.toast {
  position:fixed; bottom:80px; left:50%; transform:translateX(-50%) translateY(12px);
  background:var(--ink); color:#fff; border-radius:var(--r); padding:10px 18px;
  font-size:13px; font-weight:500; z-index:500; opacity:0; transition:.22s;
  white-space:nowrap; pointer-events:none;
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.ok   { background:var(--green); }
.toast.err  { background:var(--major); }
.toast.warn { background:var(--pending); color:var(--ink); }

/* ── LIGHTBOX ── */
.lightbox { position:fixed; inset:0; background:rgba(0,0,0,.92); z-index:400; display:none; align-items:center; justify-content:center; }
.lightbox.open { display:flex; }
.lightbox img { max-width:95vw; max-height:88dvh; border-radius:10px; object-fit:contain; }
.lb-x { position:absolute; top:16px; right:16px; width:36px; height:36px; background:rgba(255,255,255,.15); border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:18px; color:#fff; border:none; }

/* ── SEARCH ── */
.search-wrap { position:relative; }
.search-wrap input { padding-left:38px !important; }
.si { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--text3); width:16px; height:16px; stroke-width:2; pointer-events:none; }

/* ── FILTER CHIPS ── */
.chips { display:flex; gap:6px; overflow-x:auto; padding-bottom:2px; scrollbar-width:none; }
.chips::-webkit-scrollbar { display:none; }
.chip {
  flex-shrink:0; padding:5px 12px; border-radius:20px; font-size:11px; font-weight:600;
  background:var(--bg2); border:1px solid var(--border); color:var(--text2); cursor:pointer; transition:.15s;
}
.chip.active { background:var(--green); border-color:var(--green-d); color:#fff; }
.chip:active { transform:scale(.95); }

/* ── OFFLINE BAR ── */
.offline-bar { background:var(--major-l); border-bottom:1px solid var(--major-m); color:var(--major); font-size:11px; font-weight:600; text-align:center; padding:5px; display:none; }
.offline-bar.show { display:block; }

/* ── SETTINGS ── */
.setting-row { display:flex; align-items:center; gap:12px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r); padding:13px 14px; margin-bottom:8px; box-shadow:var(--shadow); }
.setting-ico { width:34px; height:34px; border-radius:9px; background:var(--bg2); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.setting-ico svg { width:16px; height:16px; stroke-width:1.8; color:var(--text2); }
.setting-info { flex:1; }
.setting-info p    { font-size:13px; font-weight:500; }
.setting-info span { font-size:11px; color:var(--text2); }
.tog { width:44px; height:24px; border-radius:12px; background:var(--bg3); border:1px solid var(--border2); position:relative; cursor:pointer; transition:.2s; flex-shrink:0; }
.tog.on { background:var(--green); border-color:var(--green-d); }
.tog::after { content:''; position:absolute; width:18px; height:18px; border-radius:50%; background:#fff; top:2px; left:2px; transition:.2s; box-shadow:0 1px 3px rgba(0,0,0,.2); }
.tog.on::after { left:22px; }

/* ── UTILITY ── */
.divider { border:none; border-top:1px solid var(--border); margin:12px 0; }
.text-green  { color:var(--green); }
.text-muted  { color:var(--text2); }
.text-red    { color:var(--major); }
.text-amber  { color:var(--cost); }
.fw-700 { font-weight:700; }
.fs-12  { font-size:12px; }
.fs-11  { font-size:11px; }
.mono   { font-family:var(--mono); }
.p16    { padding:16px; }
.pb16   { padding-bottom:16px; }
.mb12   { margin-bottom:12px; }
.mb8    { margin-bottom:8px; }
.gap8   { gap:8px; }
.grid2  { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.flex-center { display:flex; align-items:center; }
.flex-between { display:flex; align-items:center; justify-content:space-between; }
