
:root {
  --navy: #003d6f;
  --cyan: #50bfe5;
  --cyan-dark: #2a9bc4;
  --bg: #0a1628;
  --surface: #111e33;
  --surface2: #1a2d47;
  --surface3: #223558;
  --border: #2a3f5f;
  --text: #e8f0f8;
  --muted: #7a9bbf;
  --success: #22c55e;
  --warn: #f59e0b;
  --error: #ef4444;
  --radius: 14px;
  --radius-sm: 8px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);font-size:16px;line-height:1.5}

/* ── Screens ── */
.screen{display:none;position:fixed;inset:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
.screen.active{display:flex;flex-direction:column}

/* ── Password Screen ── */
#screen-password{background:linear-gradient(160deg,#0a1628 0%,#0d2040 50%,#0a1628 100%);align-items:center;justify-content:center;padding:32px 24px}
.pw-logo{width:240px;max-width:80vw;margin-bottom:40px}
.pw-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:32px 24px;width:100%;max-width:360px}
.pw-title{font-size:1.1rem;font-weight:600;color:var(--cyan);margin-bottom:6px;text-align:center}
.pw-sub{font-size:0.82rem;color:var(--muted);text-align:center;margin-bottom:24px}
.pw-input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;color:var(--text);font-size:1rem;font-family:'DM Mono',monospace;outline:none;letter-spacing:2px;text-align:center;transition:border-color 0.2s}
.pw-input:focus{border-color:var(--cyan)}
.pw-error{color:var(--error);font-size:0.8rem;text-align:center;margin-top:8px;min-height:20px}
.btn-pw{width:100%;margin-top:16px;background:var(--cyan);color:var(--navy);border:none;border-radius:var(--radius-sm);padding:14px;font-size:1rem;font-weight:700;cursor:pointer;transition:all 0.2s}
.btn-pw:hover{background:#6dcfed}

/* ── Onboarding ── */
#screen-onboard{background:var(--bg);padding:0}
.onboard-slide{display:none;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 28px;text-align:center}
.onboard-slide.active{display:flex}
.onboard-icon{font-size:4rem;margin-bottom:24px}
.onboard-title{font-size:1.6rem;font-weight:700;color:var(--cyan);margin-bottom:12px}
.onboard-text{font-size:0.95rem;color:var(--muted);line-height:1.7;max-width:320px}
.onboard-text strong{color:var(--text)}
.onboard-dots{display:flex;gap:8px;margin:32px 0 24px}
.onboard-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all 0.3s}
.onboard-dot.active{background:var(--cyan);width:24px;border-radius:4px}
.btn-onboard{background:var(--cyan);color:var(--navy);border:none;border-radius:var(--radius-sm);padding:14px 40px;font-size:1rem;font-weight:700;cursor:pointer;transition:all 0.2s}
.btn-onboard-skip{background:transparent;color:var(--muted);border:none;padding:12px;font-size:0.85rem;cursor:pointer;margin-top:8px}

/* ── Top Bar ── */
.top-bar{background:var(--surface);border-bottom:1px solid var(--border);padding:12px 16px;display:flex;align-items:center;gap:12px;flex-shrink:0;position:sticky;top:0;z-index:100}
.top-bar-logo{height:32px}
.top-bar-title{font-size:1rem;font-weight:600;color:var(--text);flex:1}
.top-bar-sub{font-size:0.75rem;color:var(--muted);font-family:'DM Mono',monospace}
.top-bar-back{background:transparent;border:none;color:var(--cyan);font-size:0.9rem;font-weight:600;cursor:pointer;padding:4px 8px;display:flex;align-items:center;gap:4px;flex-shrink:0}

/* ── Start Survey Screen ── */
#screen-start{background:var(--bg)}
.start-hero{background:linear-gradient(160deg,var(--surface) 0%,var(--surface2) 100%);border-bottom:1px solid var(--border);padding:28px 20px 24px;text-align:center}
.start-logo{height:56px;margin-bottom:16px}
.start-title{font-size:1.4rem;font-weight:700;color:var(--text);margin-bottom:4px}
.start-sub{font-size:0.82rem;color:#ffffff;font-weight:600}
.start-body{padding:20px 16px;flex:1}
.form-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 16px;margin-bottom:16px}
.form-section-title{font-size:0.72rem;font-weight:600;color:var(--cyan);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;font-family:'DM Mono',monospace}
.form-group{margin-bottom:14px}
.form-group:last-child{margin-bottom:0}
.form-label{font-size:0.82rem;color:var(--muted);margin-bottom:6px;display:block;font-weight:500}
.form-label .req{color:var(--error);margin-left:2px}
.form-input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--text);font-size:0.95rem;font-family:'DM Sans',sans-serif;outline:none;transition:border-color 0.2s;-webkit-appearance:none}
.form-input:focus{border-color:var(--cyan)}
.form-input::placeholder{color:var(--muted)}
select.form-input{cursor:pointer}
textarea.form-input{resize:vertical;min-height:80px}
.building-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}
.building-chip{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px}
.building-chip-name{font-size:0.9rem;color:var(--text)}
.building-chip-del{background:transparent;border:none;color:var(--error);font-size:1rem;cursor:pointer;padding:4px}
.btn-add-building{background:transparent;border:1.5px dashed var(--border);border-radius:var(--radius-sm);padding:10px;color:var(--cyan);font-size:0.85rem;font-weight:600;cursor:pointer;width:100%;transition:all 0.2s}
.btn-add-building:hover{border-color:var(--cyan);background:rgba(80,191,229,0.05)}
.btn-primary{background:var(--cyan);color:var(--navy);border:none;border-radius:var(--radius-sm);padding:16px;font-size:1rem;font-weight:700;cursor:pointer;width:100%;transition:all 0.2s;margin-top:8px}
.btn-primary:hover{background:#6dcfed}
.btn-primary:disabled{background:var(--border);color:var(--muted);cursor:not-allowed}
.btn-secondary{background:transparent;color:var(--cyan);border:1.5px solid var(--cyan);border-radius:var(--radius-sm);padding:12px;font-size:0.9rem;font-weight:600;cursor:pointer;width:100%;transition:all 0.2s}

/* ── Unit List Screen ── */
#screen-units{background:var(--bg)}
.units-header{padding:16px;background:var(--surface);border-bottom:1px solid var(--border)}
.units-survey-info{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.units-site{font-size:1rem;font-weight:600;color:var(--text)}
.units-surveyor{font-size:0.78rem;color:var(--muted);font-family:'DM Mono',monospace}
.units-stats{display:flex;gap:12px}
.units-stat{font-size:0.75rem;font-family:'DM Mono',monospace;color:var(--muted)}
.units-stat span{color:var(--cyan);font-weight:600}
.search-bar{padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border)}
.search-input-wrap{position:relative}
.search-input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px 10px 36px;color:var(--text);font-size:0.9rem;outline:none;transition:border-color 0.2s;-webkit-appearance:none}
.search-input:focus{border-color:var(--cyan)}
.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:0.9rem}
.filter-row{display:flex;gap:8px;margin-top:8px;overflow-x:auto;padding-bottom:4px}
.filter-chip{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:6px 14px;font-size:0.75rem;color:var(--muted);cursor:pointer;white-space:nowrap;transition:all 0.2s;flex-shrink:0}
.filter-chip.active{background:rgba(80,191,229,0.15);border-color:var(--cyan);color:var(--cyan)}
.units-list{flex:1;padding:12px 16px 100px;overflow-y:auto}
.unit-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:10px;cursor:pointer;transition:all 0.2s;position:relative}
.unit-card:hover{border-color:var(--cyan);background:var(--surface2)}
.unit-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}
.unit-card-id{font-size:1rem;font-weight:700;color:var(--cyan);font-family:'DM Mono',monospace}
.unit-card-type{font-size:0.78rem;color:var(--muted);margin-top:2px}
.unit-card-badges{display:flex;gap:6px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:4px;font-size:0.7rem;padding:3px 8px;border-radius:20px;font-weight:600;white-space:nowrap}
.badge-good{background:rgba(34,197,94,0.15);color:#22c55e;border:1px solid rgba(34,197,94,0.3)}
.badge-fair{background:rgba(245,158,11,0.15);color:#f59e0b;border:1px solid rgba(245,158,11,0.3)}
.badge-poor{background:rgba(239,68,68,0.15);color:#ef4444;border:1px solid rgba(239,68,68,0.3)}
.badge-critical{background:rgba(239,68,68,0.25);color:#ff6b6b;border:1px solid rgba(239,68,68,0.5)}
.badge-unknown{background:rgba(122,155,191,0.15);color:var(--muted);border:1px solid var(--border)}
.badge-inaccessible{background:rgba(245,158,11,0.15);color:#f59e0b;border:1px solid rgba(245,158,11,0.3)}
.badge-pending{background:rgba(80,191,229,0.15);color:var(--cyan);border:1px solid rgba(80,191,229,0.3)}
.badge-complete{background:rgba(34,197,94,0.12);color:#22c55e;border:1px solid rgba(34,197,94,0.25)}
.unit-card-info{font-size:0.78rem;color:var(--muted);display:flex;gap:12px;flex-wrap:wrap}
.unit-card-order{position:absolute;top:8px;right:8px;font-size:0.65rem;color:var(--muted);font-family:'DM Mono',monospace}
.units-fab{position:fixed;bottom:24px;right:16px;left:16px;display:flex;gap:10px;z-index:50}
.btn-fab{flex:1;background:var(--cyan);color:var(--navy);border:none;border-radius:var(--radius-sm);padding:16px;font-size:0.95rem;font-weight:700;cursor:pointer;transition:all 0.2s;box-shadow:0 4px 20px rgba(80,191,229,0.3)}
.btn-fab-finish{background:var(--navy);color:var(--cyan);border:1.5px solid var(--cyan)}
.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}
.empty-icon{font-size:3rem;margin-bottom:16px}
.empty-title{font-size:1rem;font-weight:600;color:var(--text);margin-bottom:8px}
.empty-sub{font-size:0.85rem}

/* ── Add Unit Screen ── */
#screen-add{background:var(--bg)}
.add-progress{display:flex;gap:4px;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border)}
.step-dot{flex:1;height:4px;border-radius:2px;background:var(--border);transition:all 0.3s}
.step-dot.done{background:var(--success)}
.step-dot.active{background:var(--cyan)}
.add-body{flex:1;padding:16px;overflow-y:auto;padding-bottom:100px}
.step-section{display:none}
.step-section.active{display:block}
.step-title{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:4px}
.step-sub{font-size:0.82rem;color:var(--muted);margin-bottom:20px}
.step-actions{position:fixed;bottom:0;left:0;right:0;padding:12px 16px;background:var(--surface);border-top:1px solid var(--border);display:flex;gap:10px;z-index:50}
.btn-next{flex:1;background:var(--cyan);color:var(--navy);border:none;border-radius:var(--radius-sm);padding:14px;font-size:0.95rem;font-weight:700;cursor:pointer;transition:all 0.2s}
.btn-next:disabled{background:var(--border);color:var(--muted);cursor:not-allowed}
.btn-back-step{background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 20px;font-size:0.9rem;cursor:pointer}

/* ── Tag builder ── */
.tag-builder{display:flex;gap:8px;align-items:center}
.tag-prefix-display{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--cyan);font-family:'DM Mono',monospace;font-size:1rem;font-weight:600;white-space:nowrap}
.tag-separator{color:var(--muted);font-size:1.2rem;font-weight:300}
.tag-number-input{flex:1;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--text);font-size:1rem;font-family:'DM Mono',monospace;outline:none;transition:border-color 0.2s;-webkit-appearance:none}
.tag-number-input:focus{border-color:var(--cyan)}
.tag-free-input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--text);font-size:1rem;font-family:'DM Mono',monospace;outline:none;transition:border-color 0.2s;-webkit-appearance:none}
.tag-free-input:focus{border-color:var(--cyan)}
.tag-preview{font-size:0.8rem;color:var(--muted);margin-top:6px;font-family:'DM Mono',monospace}
.tag-preview strong{color:var(--cyan)}

/* ── Inaccessible toggle ── */
.toggle-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px}
.toggle-label{font-size:0.9rem;color:var(--text);font-weight:500}
.toggle-sub{font-size:0.75rem;color:var(--muted);margin-top:2px}
.toggle-switch{position:relative;width:48px;height:26px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:var(--border);border-radius:13px;cursor:pointer;transition:0.3s}
.toggle-slider:before{content:'';position:absolute;height:20px;width:20px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:0.3s}
input:checked + .toggle-slider{background:var(--warn)}
input:checked + .toggle-slider:before{transform:translateX(22px)}

/* ── Scan Step ── */
.scan-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}
.btn-scan-primary{background:var(--cyan);color:var(--navy);border:none;border-radius:var(--radius);padding:20px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:10px}
.btn-scan-primary:hover{background:#6dcfed}
.btn-scan-secondary{background:transparent;color:var(--muted);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:14px;font-size:0.88rem;font-weight:600;cursor:pointer;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-scan-secondary:hover{border-color:var(--muted);color:var(--text)}
.extracted-fields{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-top:16px}
.extracted-title{font-size:0.72rem;font-weight:600;color:var(--cyan);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;font-family:'DM Mono',monospace;display:flex;align-items:center;justify-content:space-between}
.extracted-field{margin-bottom:12px}
.extracted-field:last-child{margin-bottom:0}
.extracted-label{font-size:0.75rem;color:var(--muted);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.decoded-badge{font-size:0.62rem;background:rgba(245,158,11,0.15);color:#f59e0b;border:1px solid rgba(245,158,11,0.3);padding:1px 6px;border-radius:10px;font-family:'DM Mono',monospace}
.extracted-value{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);font-size:0.9rem;outline:none;transition:border-color 0.2s;-webkit-appearance:none;font-family:'DM Sans',sans-serif}
.extracted-value:focus{border-color:var(--cyan)}
.ai-processing{display:flex;align-items:center;gap:10px;padding:16px;background:rgba(80,191,229,0.08);border:1px solid rgba(80,191,229,0.2);border-radius:var(--radius-sm);margin-top:12px}
.ai-spinner{width:20px;height:20px;border:2px solid rgba(80,191,229,0.3);border-top-color:var(--cyan);border-radius:50%;animation:spin 0.8s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.ai-status-text{font-size:0.82rem;color:var(--cyan)}
.scan-tip{background:rgba(80,191,229,0.06);border:1px solid rgba(80,191,229,0.15);border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:16px;font-size:0.78rem;color:var(--muted);line-height:1.5}
.scan-tip strong{color:var(--cyan)}

/* ── Camera Modal ── */
#camera-modal{position:fixed;inset:0;background:#000;z-index:1000;display:none;flex-direction:column}
#camera-modal.active{display:flex}
#camera-video{width:100%;flex:1;object-fit:cover}
.camera-overlay{position:absolute;inset:0;display:flex;flex-direction:column;pointer-events:none}
.camera-top-bar{background:rgba(0,0,0,0.6);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;pointer-events:all}
.camera-title{color:#fff;font-size:0.9rem;font-weight:600}
.btn-camera-close{background:transparent;border:none;color:#fff;font-size:1.4rem;cursor:pointer;padding:4px;pointer-events:all}
.camera-frame-area{flex:1;display:flex;align-items:center;justify-content:center;padding:20px}
.camera-frame{border:2px solid rgba(80,191,229,0.8);border-radius:12px;width:72%;max-width:280px;aspect-ratio:3/4;position:relative;box-shadow:0 0 0 9999px rgba(0,0,0,0.5)}
.camera-frame-corner{position:absolute;width:20px;height:20px;border-color:var(--cyan);border-style:solid}
.camera-frame-corner.tl{top:-2px;left:-2px;border-width:3px 0 0 3px;border-radius:4px 0 0 0}
.camera-frame-corner.tr{top:-2px;right:-2px;border-width:3px 3px 0 0;border-radius:0 4px 0 0}
.camera-frame-corner.bl{bottom:-2px;left:-2px;border-width:0 0 3px 3px;border-radius:0 0 0 4px}
.camera-frame-corner.br{bottom:-2px;right:-2px;border-width:0 3px 3px 0;border-radius:0 0 4px 0}
.camera-frame-hint{position:absolute;bottom:-28px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,0.7);font-size:0.72rem;white-space:nowrap}
.camera-bottom{background:rgba(0,0,0,0.7);padding:24px 20px;display:flex;align-items:center;justify-content:space-between;pointer-events:all}
.btn-flash{background:rgba(255,255,255,0.15);border:none;border-radius:50%;width:48px;height:48px;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.btn-flash.active{background:rgba(255,220,50,0.3);color:#ffd700}
.btn-capture{width:72px;height:72px;border-radius:50%;background:#fff;border:4px solid rgba(255,255,255,0.5);cursor:pointer;transition:all 0.1s;display:flex;align-items:center;justify-content:center}
.btn-capture:active{transform:scale(0.92)}
.btn-capture-inner{width:52px;height:52px;border-radius:50%;background:#fff;border:2px solid #ddd}
.btn-gallery{background:rgba(255,255,255,0.15);border:none;border-radius:var(--radius-sm);width:48px;height:48px;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
#camera-canvas{display:none}

/* ── Photos ── */
.photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.photo-thumb{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface2)}
.photo-thumb img{width:100%;height:100%;object-fit:cover}
.photo-thumb-del{position:absolute;top:4px;right:4px;background:rgba(0,0,0,0.7);border:none;border-radius:50%;width:22px;height:22px;color:#fff;font-size:0.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.photo-thumb-label{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,0.6);padding:3px 5px;font-size:0.62rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.btn-add-photo{background:var(--surface2);border:1.5px dashed var(--border);border-radius:var(--radius-sm);padding:14px;color:var(--cyan);font-size:0.85rem;font-weight:600;cursor:pointer;width:100%;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:8px}
.btn-add-photo:hover{border-color:var(--cyan);background:rgba(80,191,229,0.05)}
.photo-section{margin-bottom:20px}
.photo-section-title{font-size:0.82rem;font-weight:600;color:var(--text);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.photo-section-title .badge{font-size:0.65rem}

/* ── Service Data ── */
.filter-entry{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:10px;position:relative}
.filter-entry-num{font-size:0.72rem;font-weight:600;color:var(--cyan);font-family:'DM Mono',monospace;margin-bottom:10px}
.btn-remove-filter{position:absolute;top:10px;right:10px;background:transparent;border:none;color:var(--error);font-size:1rem;cursor:pointer;padding:4px}
.btn-add-filter{background:transparent;border:1.5px dashed var(--border);border-radius:var(--radius-sm);padding:12px;color:var(--cyan);font-size:0.85rem;font-weight:600;cursor:pointer;width:100%;transition:all 0.2s;margin-bottom:8px}
.btn-add-filter:hover{border-color:var(--cyan)}

/* ── Condition buttons ── */
.condition-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.condition-buttons-wide{grid-template-columns:repeat(2,1fr)}
.btn-condition{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:14px 8px;font-size:0.82rem;font-weight:600;cursor:pointer;transition:all 0.2s;color:var(--muted);text-align:center}
.btn-condition.sel-good{background:rgba(34,197,94,0.15);border-color:#22c55e;color:#22c55e}
.btn-condition.sel-fair{background:rgba(245,158,11,0.15);border-color:#f59e0b;color:#f59e0b}
.btn-condition.sel-poor{background:rgba(239,68,68,0.15);border-color:#ef4444;color:#ef4444}
.btn-condition.sel-critical{background:rgba(239,68,68,0.25);border-color:#ff6b6b;color:#ff6b6b}
.btn-condition.sel-unknown{background:rgba(122,155,191,0.15);border-color:var(--muted);color:var(--muted)}

/* ── Warranty ── */
.warranty-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.checkbox-custom{width:22px;height:22px;border:2px solid var(--border);border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.2s}
.checkbox-custom.checked{background:var(--cyan);border-color:var(--cyan)}
.checkbox-custom.checked::after{content:'✓';color:var(--navy);font-size:0.9rem;font-weight:700}
.warranty-label{font-size:0.9rem;color:var(--text)}

/* ── Review Screen ── */
#screen-review{background:var(--bg)}
.review-body{padding:16px;flex:1;overflow-y:auto;padding-bottom:100px}
.review-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:12px}
.review-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.review-section-title{font-size:0.72rem;font-weight:600;color:var(--cyan);text-transform:uppercase;letter-spacing:1px;font-family:'DM Mono',monospace}
.btn-review-edit{background:transparent;border:none;color:var(--cyan);font-size:0.78rem;font-weight:600;cursor:pointer;padding:2px 6px}
.review-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.review-item{}
.review-item-label{font-size:0.7rem;color:var(--muted);margin-bottom:2px}
.review-item-value{font-size:0.85rem;color:var(--text);font-weight:500}
.review-item-value.empty{color:var(--muted);font-style:italic}
.review-item-value.decoded{color:#f59e0b}
.review-photos-row{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px}
.review-photo-thumb{width:60px;height:60px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}
.review-filter-item{font-size:0.82rem;color:var(--text);padding:6px 0;border-bottom:1px solid var(--border)}
.review-filter-item:last-child{border-bottom:none}
.review-actions{position:fixed;bottom:0;left:0;right:0;padding:12px 16px;background:var(--surface);border-top:1px solid var(--border);display:flex;gap:10px;z-index:50}
.warning-banner{background:rgba(245,158,11,0.1);border:1px solid rgba(245,158,11,0.3);border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:12px;font-size:0.8rem;color:#f59e0b;display:flex;align-items:center;gap:8px}

/* ── Finish Screen ── */
#screen-finish{background:var(--bg)}
.finish-body{padding:16px;flex:1;overflow-y:auto;padding-bottom:100px}
.finish-hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px;text-align:center}
.finish-site{font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:4px}
.finish-meta{font-size:0.8rem;color:var(--muted);font-family:'DM Mono',monospace}
.finish-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:16px}
.finish-stat{background:var(--bg);border-radius:var(--radius-sm);padding:12px;text-align:center}
.finish-stat-num{font-size:1.4rem;font-weight:700;color:var(--cyan);font-family:'DM Mono',monospace}
.finish-stat-label{font-size:0.7rem;color:var(--muted);margin-top:2px}
.building-summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:12px}
.building-summary-name{font-size:0.88rem;font-weight:600;color:var(--text);margin-bottom:8px}
.building-summary-units{font-size:0.78rem;color:var(--muted)}
.pending-banner{background:rgba(80,191,229,0.08);border:1px solid rgba(80,191,229,0.2);border-radius:var(--radius-sm);padding:12px;margin-bottom:12px;font-size:0.82rem;color:var(--cyan)}
.pending-banner strong{display:block;margin-bottom:4px}
.export-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}
.export-title{font-size:0.82rem;font-weight:600;color:var(--text);margin-bottom:4px}
.export-sub{font-size:0.75rem;color:var(--muted);margin-bottom:12px}
.btn-export{background:var(--navy);color:var(--cyan);border:1.5px solid var(--cyan);border-radius:var(--radius-sm);padding:14px;font-size:0.9rem;font-weight:700;cursor:pointer;width:100%;margin-bottom:8px;transition:all 0.2s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-export:hover{background:rgba(80,191,229,0.1)}
.btn-export-primary{background:var(--cyan);color:var(--navy);border-color:var(--cyan)}
.btn-export-primary:hover{background:#6dcfed}
.export-fallback{font-size:0.72rem;color:var(--muted);margin-top:8px;padding:8px;background:var(--bg);border-radius:var(--radius-sm);line-height:1.5}
.export-fallback strong{color:var(--text)}
.camera-reminder{background:rgba(34,197,94,0.08);border:1px solid rgba(34,197,94,0.2);border-radius:var(--radius-sm);padding:10px 12px;font-size:0.78rem;color:#22c55e;margin-bottom:12px}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:200;display:none;align-items:flex-end}
.modal-overlay.active{display:flex}
.modal{background:var(--surface);border-radius:20px 20px 0 0;width:100%;padding:24px 20px;max-height:80vh;overflow-y:auto}
.modal-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 20px}
.modal-title{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:16px}
.modal-actions{display:flex;gap:10px;margin-top:16px}
.btn-modal-cancel{flex:1;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;color:var(--muted);font-size:0.9rem;cursor:pointer}
.btn-modal-confirm{flex:1;background:var(--cyan);border:none;border-radius:var(--radius-sm);padding:12px;color:var(--navy);font-size:0.9rem;font-weight:700;cursor:pointer}
.btn-modal-danger{background:var(--error)}

/* ── Toast ── */
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 20px;font-size:0.82rem;z-index:500;opacity:0;transition:all 0.3s;white-space:nowrap;max-width:90vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.success{border-color:var(--success);color:var(--success)}
.toast.error{border-color:var(--error);color:var(--error)}
.toast.info{border-color:var(--cyan);color:var(--cyan)}

/* ── Misc ── */
.divider{border:none;border-top:1px solid var(--border);margin:16px 0}
.text-warn{color:#f59e0b}
.text-error{color:var(--error)}
.text-success{color:var(--success)}
.text-cyan{color:var(--cyan)}
.text-muted{color:var(--muted)}
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active{
  -webkit-box-shadow:0 0 0 999px var(--bg) inset !important;
  -webkit-text-fill-color:var(--text) !important;
  caret-color:var(--text);
  transition:background-color 9999s ease-in-out 0s;
}
.full-width{width:100%}
.mt-8{margin-top:8px}
.mt-12{margin-top:12px}
.mt-16{margin-top:16px}
.mb-8{margin-bottom:8px}
.mb-12{margin-bottom:12px}
.duplicate-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}
.duplicate-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;cursor:pointer;transition:all 0.2s}
.duplicate-item:hover{border-color:var(--cyan)}
.duplicate-item-id{font-size:0.9rem;font-weight:600;color:var(--cyan);font-family:'DM Mono',monospace}
.duplicate-item-info{font-size:0.75rem;color:var(--muted);margin-top:2px}

@media(orientation:landscape){
  .camera-frame{max-width:200px;aspect-ratio:3/4}
}
