@font-face {
  font-family: 'VisbyCF';
  src: url('../fonts/VisbyCF-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
}
:root{
  --font:'VisbyCF','Outfit',system-ui,sans-serif;
  --navy:#0a1520;--navy-mid:#1e3a5f;
  --gold:#9e8958;--gold-lt:#b8a478;
  --amber:#f5a623;--amber-dark:#d4891a;
  --emerald:#10b981;--red:#ef4444;--orange:#f97316;
  --yellow:#ca8a04;--purple:#7c3aed;--blue:#3b82f6;
  --teal:#0891b2;--sky:#0ea5e9;
  --bg:#0d1b2a;--card:#132335;--card2:#1a2e45;
  --border:rgba(255,255,255,.08);
  --text:rgba(255,255,255,.9);--muted:rgba(255,255,255,.45);
  --r-sm:8px;--r:14px;--r-lg:20px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.3),0 1px 2px rgba(0,0,0,.2);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

button,a{touch-action:manipulation}

.view-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px;padding-bottom:calc(20px + env(safe-area-inset-bottom));scrollbar-width:none}.view-body::-webkit-scrollbar{display:none}
.top-bar{background:var(--navy);padding:12px 16px;display:flex;align-items:center;gap:12px;flex-shrink:0;z-index:10}
.top-bar-avatar{width:36px;height:36px;border-radius:50%;background:var(--amber);color:var(--navy);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:13px;flex-shrink:0}
.top-bar-info{flex:1}
.top-bar-name{font-family:'Syne',sans-serif;font-weight:700;color:#fff;font-size:15px;line-height:1.2}
.top-bar-sub{font-size:11px;color:rgba(255,255,255,.45);font-weight:300}
.top-bar-actions{display:flex;gap:8px;align-items:center}
.icon-btn{width:36px;height:36px;border:none;background:rgba(255,255,255,.1);border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s;-webkit-appearance:none}
.icon-btn:active{background:rgba(255,255,255,.22)}
.status-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:500;padding:3px 8px;border-radius:20px}
.status-pill.online{background:rgba(16,185,129,.15);color:#10b981}
.status-pill.offline{background:rgba(239,68,68,.15);color:#ef4444}
.status-dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.status-dot.pulse{animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
#view-login{background:var(--navy);background-image:radial-gradient(ellipse at 20% 50%,rgba(30,58,95,.8) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(245,166,35,.1) 0%,transparent 50%);overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}#view-login::-webkit-scrollbar{display:none}
.login-header{padding:24px 24px 24px;padding-top:calc(env(safe-area-inset-top) + 20px);text-align:center}
.login-logo{width:68px;height:68px;border-radius:18px;overflow:hidden;margin:0 auto 18px;display:flex;align-items:center;justify-content:center}
.login-title{font-family:'Syne',sans-serif;font-weight:800;font-size:26px;color:#fff;letter-spacing:-.5px}
.login-subtitle{font-size:13px;color:rgba(255,255,255,.4);margin-top:5px;font-weight:300}
.login-who{font-size:11px;font-weight:600;color:var(--amber);text-transform:uppercase;letter-spacing:1.5px;padding:0 20px;margin-bottom:10px}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:0 16px 32px}
.team-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:13px 8px;display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;transition:all .15s;-webkit-appearance:none}
.team-card:active{background:rgba(255,255,255,.13);transform:scale(.96)}
.team-initial{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:14px;color:#fff}
.team-name{font-size:12px;font-weight:500;color:#fff;text-align:center;line-height:1.3}
#view-choice{background:var(--navy);background-image:radial-gradient(ellipse at 30% 60%,rgba(30,58,95,.7) 0%,transparent 60%)}
.choice-body{flex:1;display:flex;flex-direction:column;padding:0 24px;justify-content:center;gap:12px;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:40px}
.choice-greeting{font-family:'Syne',sans-serif;font-weight:800;font-size:26px;color:#fff;margin-bottom:6px}
.choice-sub{font-size:14px;color:rgba(255,255,255,.4);font-weight:300;margin-bottom:24px}
.choice-btn{padding:18px 20px;border:1.5px solid rgba(255,255,255,.12);border-radius:var(--r-lg);background:rgba(255,255,255,.05);display:flex;align-items:center;gap:14px;cursor:pointer;transition:all .18s;text-align:left;-webkit-appearance:none;width:100%}
.choice-btn:active{background:rgba(255,255,255,.12);transform:scale(.98)}
.choice-btn.primary{background:linear-gradient(135deg,var(--amber) 0%,var(--amber-dark) 100%);border-color:transparent;box-shadow:0 6px 24px rgba(245,166,35,.3)}
.choice-btn-icon{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.choice-btn.primary .choice-btn-icon{background:rgba(255,255,255,.22)}
.choice-btn-text{flex:1}
.choice-btn-title{font-family:'Syne',sans-serif;font-weight:700;font-size:15px;color:#fff;margin-bottom:2px}
.choice-btn-desc{font-size:12px;color:rgba(255,255,255,.5);font-weight:300;line-height:1.4}
.choice-btn.primary .choice-btn-desc{color:rgba(13,27,42,.65)}
.choice-btn.primary .choice-btn-title{color:var(--navy)}
.choice-btn.primary .choice-btn-icon svg{stroke:var(--navy)}
#pin-overlay{position:fixed;inset:0;background:rgba(13,27,42,.94);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:100;display:none;flex-direction:column;align-items:center;justify-content:center;padding:24px}
#pin-overlay.show{display:flex}
.pin-title{font-family:'Syne',sans-serif;font-weight:700;font-size:20px;color:#fff;text-align:center;margin-bottom:6px}
.pin-sub{font-size:13px;color:rgba(255,255,255,.4);text-align:center;margin-bottom:32px}
.pin-dots{display:flex;gap:14px;margin-bottom:32px}
.pin-dot{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.3);transition:all .15s}
.pin-dot.filled{background:var(--amber);border-color:var(--amber)}
.pin-dot.success{background:var(--emerald);border-color:var(--emerald)}
.pin-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:270px;width:100%}
.pin-key{height:64px;border:none;border-radius:var(--r);background:rgba(255,255,255,.08);color:#fff;font-size:22px;font-family:'Outfit',sans-serif;font-weight:500;cursor:pointer;transition:all .1s;-webkit-appearance:none;display:flex;align-items:center;justify-content:center}
.pin-key:active{background:rgba(255,255,255,.2);transform:scale(.93)}
.pin-key.pin-zero{grid-column:2}.pin-key.pin-back{grid-column:3}
.pin-cancel{margin-top:24px;background:none;border:none;color:rgba(255,255,255,.35);font-size:14px;font-family:'Outfit',sans-serif;cursor:pointer;padding:8px 16px}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-9px)}40%{transform:translateX(9px)}60%{transform:translateX(-6px)}80%{transform:translateX(6px)}}
.shake{animation:shake .4s ease}
.section-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:8px;margin-top:20px}
.section-label:first-child{margin-top:0}
.photo-area{border:2px dashed var(--border);border-radius:var(--r-lg);min-height:180px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;overflow:hidden;position:relative;background:#fff}
.photo-area.has-photo{border-style:solid;border-color:var(--amber)}
.photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:10px;padding:32px;text-align:center}
.photo-icon{width:56px;height:56px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center}
.photo-placeholder p{font-size:14px;font-weight:500;color:var(--text)}
.photo-placeholder span{font-size:12px;color:var(--muted)}
#photo-preview{width:100%;height:220px;object-fit:cover;display:none}
.photo-retake{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:20px;padding:5px 12px;font-size:12px;font-family:'Outfit',sans-serif;cursor:pointer;display:none;z-index:2}
#photo-input{display:none}
.category-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.category-scroll::-webkit-scrollbar{display:none}
.cat-pill{flex-shrink:0;padding:7px 14px;border-radius:20px;border:1.5px solid var(--border);background:var(--card);font-size:13px;font-family:'Outfit',sans-serif;font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s;white-space:nowrap}
.cat-pill.selected{border-color:var(--navy-mid);background:var(--navy-mid);color:#fff}
.priority-row{display:flex;gap:8px}
.prio-btn{flex:1;padding:8px;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--card);font-size:12px;font-family:'Outfit',sans-serif;font-weight:500;cursor:pointer;text-align:center;transition:all .15s;color:var(--muted)}
.prio-btn.selected[data-p="low"]{border-color:var(--emerald);background:rgba(16,185,129,.08);color:var(--emerald)}
.prio-btn.selected[data-p="medium"]{border-color:var(--orange);background:rgba(249,115,22,.08);color:var(--orange)}
.prio-btn.selected[data-p="high"]{border-color:var(--red);background:rgba(239,68,68,.08);color:var(--red)}
.location-row{display:flex;align-items:center;gap:10px}
.gps-btn{flex-shrink:0;padding:10px 14px;border-radius:var(--r-sm);border:1.5px solid var(--border);background:var(--card);font-size:13px;font-family:'Outfit',sans-serif;font-weight:500;color:var(--text);cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s;white-space:nowrap}
.gps-btn.active{border-color:var(--emerald);color:var(--emerald)}
textarea,input[type=text],input[type=email]{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:16px;font-family:'Outfit',sans-serif;color:var(--text);background:var(--card);transition:border-color .15s;-webkit-appearance:none;resize:none}
textarea:focus,input[type=text]:focus,input[type=email]:focus{outline:none;border-color:var(--navy-mid)}
textarea{min-height:100px}
.submit-btn{width:100%;padding:16px;border:none;border-radius:var(--r);background:var(--amber);color:var(--navy);font-family:'Syne',sans-serif;font-weight:700;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .15s;margin-top:24px;box-shadow:0 4px 20px rgba(245,166,35,.35)}
.submit-btn:active{transform:scale(.98);background:var(--amber-dark)}
.submit-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.pending-banner{background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.3);border-radius:var(--r-sm);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:12px;cursor:pointer}
.pending-banner-text{font-size:13px;font-weight:500;color:var(--orange)}
#view-success{background:var(--bg)}
.success-body{flex:1;display:flex;flex-direction:column;align-items:center;padding:40px 24px 24px}
.success-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--emerald),#059669);display:flex;align-items:center;justify-content:center;margin-bottom:20px;box-shadow:0 8px 32px rgba(16,185,129,.3);animation:popIn .4s cubic-bezier(.175,.885,.32,1.275)}
.success-icon.offline-icon{background:linear-gradient(135deg,var(--orange),#ea6b06);box-shadow:0 8px 32px rgba(249,115,22,.3)}
@keyframes popIn{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.success-title{font-family:'Syne',sans-serif;font-weight:800;font-size:24px;text-align:center;margin-bottom:6px}
.success-sub{font-size:14px;color:var(--muted);text-align:center;max-width:280px;line-height:1.5;margin-bottom:28px}
.success-ref{background:var(--card);border-radius:var(--r);padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%;max-width:340px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.success-ref-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.success-ref-value{font-family:'Syne',sans-serif;font-weight:700;font-size:18px;color:var(--navy-mid)}
.success-summary-card{background:var(--card);border-radius:var(--r);overflow:hidden;width:100%;max-width:340px;box-shadow:var(--shadow-sm);margin-bottom:28px}
.success-summary-photo{width:100%;height:140px;object-fit:cover}
.success-summary-details{padding:14px 16px}
.ss-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;font-size:13px}
.ss-row:last-child{margin-bottom:0}
.s-lbl{color:var(--muted);font-weight:500;flex-shrink:0;min-width:80px}
.s-val{color:var(--text)}
.new-report-btn{width:100%;max-width:340px;padding:15px;border:none;border-radius:var(--r);background:var(--navy-mid);color:#fff;font-family:'Syne',sans-serif;font-weight:700;font-size:15px;cursor:pointer;margin-bottom:10px}
.secondary-btn{width:100%;max-width:340px;padding:13px;border:1.5px solid var(--border);border-radius:var(--r);background:transparent;color:var(--text);font-family:'Outfit',sans-serif;font-weight:500;font-size:14px;cursor:pointer}
.queue-empty{text-align:center;padding:60px 24px;color:var(--muted)}
.queue-empty p{margin-top:8px;font-size:14px}
.queue-card{background:var(--card);border-radius:var(--r);overflow:hidden;margin-bottom:10px;box-shadow:var(--shadow-sm);display:flex;border-left:4px solid var(--orange)}
.queue-delete-btn{flex-shrink:0;align-self:stretch;padding:0 14px;background:transparent;border:none;border-left:1px solid var(--border);color:var(--muted);cursor:pointer;display:flex;align-items:center;transition:background .15s,color .15s}
.queue-delete-btn:hover{background:rgba(239,68,68,.1);color:var(--red)}
.queue-card-thumb{width:72px;height:72px;object-fit:cover;flex-shrink:0}
.queue-card-cat{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:2px}
.queue-card-desc{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.queue-card-time{font-size:11px;color:var(--muted);margin-top:4px}
.retry-btn{width:100%;padding:14px;border:none;border-radius:var(--r);background:var(--orange);color:#fff;font-family:'Syne',sans-serif;font-weight:700;font-size:15px;cursor:pointer;margin-bottom:16px}
.mgr-header{background:var(--navy);padding:16px;padding-top:max(16px,env(safe-area-inset-top));flex-shrink:0}
.mgr-header-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.mgr-title{font-family:'Syne',sans-serif;font-weight:800;font-size:20px;color:#fff}
.filter-tabs{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none}
.filter-tabs::-webkit-scrollbar{display:none}
.filter-tab{flex-shrink:0;padding:5px 12px;border-radius:20px;border:1.5px solid rgba(255,255,255,.2);background:transparent;color:rgba(255,255,255,.6);font-size:12px;font-family:'Outfit',sans-serif;font-weight:500;cursor:pointer;transition:all .15s}
.filter-tab.active{background:var(--amber);border-color:var(--amber);color:var(--navy)}
.report-card{background:var(--card);border-radius:var(--r);overflow:hidden;margin-bottom:10px;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;border-left:4px solid var(--border)}
.report-card[data-status=open]{border-left-color:var(--red)}
.report-card[data-status=ongoing]{border-left-color:var(--orange)}
.report-card[data-status=monitoring]{border-left-color:var(--yellow)}
.report-card[data-status=closed]{border-left-color:var(--emerald)}
.report-card-thumb{width:80px;height:80px;object-fit:cover;flex-shrink:0}
.report-card-body{flex:1;padding:10px 12px;min-width:0}
.report-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:4px}
.report-card-cat{font-size:12px;font-weight:600;color:var(--text)}
.status-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;white-space:nowrap}
.status-sel-btn{border:2px solid transparent;border-radius:10px;padding:7px 16px;font-size:12px;font-weight:700;cursor:pointer;font-family:var(--font);opacity:.45;transition:opacity .15s,border-color .15s}
.status-sel-btn.selected{opacity:1;border-color:currentColor}
.status-badge.open{background:rgba(239,68,68,.1);color:var(--red)}
.status-badge.ongoing{background:rgba(249,115,22,.1);color:var(--orange)}
.status-badge.monitoring{background:rgba(202,138,4,.12);color:var(--yellow)}
.status-badge.closed{background:rgba(16,185,129,.1);color:var(--emerald)}
.report-card-desc{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.report-card-meta{font-size:11px;color:var(--muted);margin-top:5px}
.report-card-assigned{font-size:11px;font-weight:500;color:var(--navy-mid);margin-top:2px}
.snap-header{background:var(--navy);padding:16px;padding-top:max(16px,env(safe-area-inset-top));flex-shrink:0}
.snap-header-row{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.snap-title{font-family:'Syne',sans-serif;font-weight:800;font-size:20px;color:#fff;flex:1}
.snap-month{font-size:13px;color:rgba(255,255,255,.5);font-weight:300}
.snap-total-card{background:var(--navy-mid);border-radius:var(--r);padding:16px 20px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.snap-total-num{font-family:'Syne',sans-serif;font-weight:800;font-size:40px;color:#fff}
.snap-total-label{font-size:13px;color:rgba(255,255,255,.65)}
.snap-total-sub{font-size:11px;color:rgba(255,255,255,.4);margin-top:2px}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.stat-card{background:var(--card);border-radius:var(--r);padding:14px 16px;box-shadow:var(--shadow-sm);border-top:3px solid var(--border)}
.stat-card.c-open{border-top-color:var(--red)}.stat-card.c-ongoing{border-top-color:var(--orange)}.stat-card.c-monitoring{border-top-color:var(--yellow)}.stat-card.c-closed{border-top-color:var(--emerald)}
.stat-number{font-family:'Syne',sans-serif;font-weight:800;font-size:32px;line-height:1;color:var(--text);margin-bottom:4px}
.stat-label{font-size:12px;font-weight:500;color:var(--muted)}
.snap-section{background:var(--card);border-radius:var(--r);padding:16px;margin-bottom:12px;box-shadow:var(--shadow-sm)}
.snap-section-title{font-family:'Syne',sans-serif;font-weight:700;font-size:14px;color:var(--text);margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}
.snap-total-inline{font-size:12px;color:var(--muted);font-family:'Outfit',sans-serif;font-weight:400}
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:13px}
.bar-row:last-child{margin-bottom:0}
.bar-label{flex-shrink:0;width:120px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;font-size:13px}
.bar-track{flex:1;height:8px;background:var(--border);border-radius:4px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px;transition:width .6s ease}
.bar-count{flex-shrink:0;font-size:12px;color:var(--muted);min-width:22px;text-align:right;font-weight:600}
.config-header{background:var(--navy);padding:16px;flex-shrink:0}
.config-header-row{display:flex;align-items:center;gap:10px}
.config-title{font-family:'Syne',sans-serif;font-weight:800;font-size:20px;color:#fff}


.config-add-btn{background:var(--navy-mid);border:none;border-radius:20px;color:#fff;font-size:12px;font-family:'Outfit',sans-serif;font-weight:600;padding:5px 12px;cursor:pointer}
.config-card{background:var(--card);border-radius:var(--r);padding:12px 14px;margin-bottom:8px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .15s;border:none;width:100%;text-align:left;-webkit-appearance:none;font-family:inherit}
.config-card:active{box-shadow:none;transform:scale(.99)}
.config-card-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:13px;color:#fff;flex-shrink:0}
.config-card-info{flex:1;min-width:0}
.config-card-name{font-size:14px;font-weight:600;color:var(--text);margin-bottom:3px}
.config-card-meta{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.config-card-chevron{color:var(--border);flex-shrink:0}
.role-chip{display:inline-block;font-size:10px;font-weight:600;padding:2px 7px;border-radius:8px;text-transform:uppercase;letter-spacing:.4px;margin-right:3px}
.role-chip.admin{background:rgba(124,58,237,.12);color:var(--purple)}
.role-chip.manager{background:rgba(245,166,35,.15);color:#92570a}
.role-chip.dashboard{background:rgba(59,130,246,.12);color:var(--blue)}
.config-divider{height:1px;background:var(--border);margin:20px 0 16px}
#report-modal,#user-edit-modal,#assignee-edit-modal,#distlist-edit-modal,#my-settings-modal{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;display:none;align-items:flex-end;justify-content:center}
#report-modal.show,#user-edit-modal.show,#assignee-edit-modal.show,#distlist-edit-modal.show,#my-settings-modal.show{display:flex}
.modal-sheet{background:var(--card);border-radius:20px 20px 0 0;width:100%;max-width:480px;max-height:88vh;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:slideUp .3s cubic-bezier(.32,.72,0,1);padding-bottom:calc(16px + env(safe-area-inset-bottom))}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-handle{width:40px;height:4px;border-radius:2px;background:var(--border);margin:12px auto 8px}
.modal-photo{width:100%;height:200px;object-fit:cover}
.modal-body{padding:16px}
.modal-title{font-family:'Syne',sans-serif;font-weight:700;font-size:18px;margin-bottom:4px}
.modal-meta{font-size:12px;color:var(--muted);margin-bottom:16px;line-height:1.5}
.modal-desc{font-size:14px;line-height:1.6;color:var(--text);padding:12px;background:var(--bg);border-radius:var(--r-sm);margin-bottom:16px}
.modal-field{margin-bottom:14px}
.modal-field label{display:block;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.modal-select{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:16px;font-family:'Outfit',sans-serif;color:var(--text);background:var(--card);-webkit-appearance:none;cursor:pointer}
.modal-save-btn{width:100%;padding:14px;border:none;border-radius:var(--r);background:var(--navy-mid);color:#fff;font-family:'Syne',sans-serif;font-weight:700;font-size:15px;cursor:pointer;margin-top:8px}
.modal-danger-btn{width:100%;padding:12px;border:1.5px solid rgba(239,68,68,.3);border-radius:var(--r);background:rgba(239,68,68,.05);color:var(--red);font-family:'Outfit',sans-serif;font-weight:500;font-size:14px;cursor:pointer;margin-top:8px}
.modal-sub-btn{width:100%;padding:12px;border:1.5px solid var(--border);border-radius:var(--r);background:transparent;color:var(--text);font-family:'Outfit',sans-serif;font-weight:500;font-size:14px;cursor:pointer;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:8px}
.colour-swatches{display:flex;gap:8px;flex-wrap:wrap}
.colour-swatch{width:32px;height:32px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all .15s}
.colour-swatch.selected{border-color:var(--text);transform:scale(1.15)}
.role-toggles{display:flex;gap:8px;flex-wrap:wrap}
.role-toggle{padding:6px 14px;border-radius:20px;border:1.5px solid var(--border);background:var(--card);font-size:12px;font-family:'Outfit',sans-serif;font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s}
.role-toggle.active.admin{border-color:var(--purple);background:rgba(124,58,237,.1);color:var(--purple)}
.role-toggle.active.manager{border-color:#d97706;background:rgba(217,119,6,.1);color:#d97706}
.role-toggle.active.dashboard{border-color:var(--blue);background:rgba(59,130,246,.1);color:var(--blue)}
.loading-overlay{position:fixed;inset:0;background:rgba(13,27,42,.75);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:300;display:none;flex-direction:column;align-items:center;justify-content:center;gap:16px}
.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.2);border-top-color:var(--amber);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{color:#fff;font-size:14px;font-weight:500}
.demo-badge{position:fixed;top:max(8px,env(safe-area-inset-top));right:8px;background:var(--purple);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:10px;z-index:500;display:none;letter-spacing:.5px;text-transform:uppercase}
#toast{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%) translateY(calc(100% + 60px));background:var(--navy);color:#fff;padding:10px 20px;border-radius:24px;font-size:13px;font-weight:500;z-index:1000;transition:transform .35s cubic-bezier(.32,.72,0,1);white-space:nowrap;max-width:90vw;text-align:center;pointer-events:none;visibility:hidden}
.input-hint{font-size:11px;color:var(--muted);margin-top:4px}

.map-preview{width:100%;height:140px;border-radius:var(--r-sm);overflow:hidden;margin-top:10px;display:none;border:1.5px solid var(--border)}
.fp-wrap{position:relative;width:100%;border-radius:var(--r-sm);overflow:hidden;margin-top:10px;background:#111;border:1.5px solid var(--border);display:none}
.fp-wrap.show{display:block}
.fp-img{display:block;width:100%;height:auto;opacity:.9}
.fp-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}
.fp-badge{position:absolute;bottom:6px;left:8px;background:rgba(0,0,0,.65);color:#fff;font-size:10px;padding:2px 7px;border-radius:8px;pointer-events:none}
.fp-badge.outside{color:#f87171}

.map-preview.show{display:block}
.snap-drill{background:rgba(0,0,0,.55);z-index:200}
.snap-drill.show{display:flex}
.drill-list{padding:0 16px 16px}
.drill-item{background:var(--card);border-radius:var(--r);overflow:hidden;margin-bottom:8px;box-shadow:var(--shadow-sm);border-left:4px solid var(--border);display:flex;gap:0}
.drill-item-thumb{width:72px;min-height:72px;flex-shrink:0;object-fit:cover;display:block}
.drill-item-content{flex:1;min-width:0;padding:12px 14px}
.drill-item[data-status=open]{border-left-color:var(--red)}
.drill-item[data-status=ongoing]{border-left-color:var(--orange)}
.drill-item[data-status=monitoring]{border-left-color:var(--yellow)}
.drill-item[data-status=closed]{border-left-color:var(--emerald)}
.drill-item-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.drill-item-cat{font-size:12px;font-weight:600;color:var(--text)}
.drill-item-ref{font-size:11px;color:var(--muted)}
.drill-item-desc{font-size:13px;color:var(--muted);line-height:1.5;margin-bottom:4px}
.drill-item-meta{font-size:11px;color:var(--muted)}
.drill-item:active{opacity:.75;transform:scale(.99)}
.drill-header{display:flex;align-items:center;gap:10px;padding:16px 16px 12px}
.drill-title{font-family:'Syne',sans-serif;font-weight:700;font-size:17px;color:var(--text);flex:1}
.pin-change-strip{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-sm);padding:11px 16px;display:flex;align-items:center;gap:10px;cursor:pointer;margin-top:8px;width:100%;-webkit-appearance:none;text-align:left}
.pin-change-strip:active{background:rgba(255,255,255,.13)}
.pin-change-label{font-size:13px;font-weight:500;color:rgba(255,255,255,.75);flex:1}
.pin-change-hint{font-size:11px;color:rgba(255,255,255,.35)}

.admin-act-bar{background:var(--navy);padding:12px 16px;display:flex;gap:8px;flex-shrink:0;overflow-x:auto}
.admin-act-bar::-webkit-scrollbar{display:none}
.aab-btn{flex-shrink:0;padding:9px 14px;border:none;border-radius:var(--r-sm);font-family:'Outfit',sans-serif;font-weight:600;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:6px;white-space:nowrap}
.aab-btn.pdf{background:var(--amber);color:var(--navy)}
.aab-btn.mail{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.2)}
.aab-btn:disabled{opacity:.4;cursor:not-allowed}
.report-rec{background:var(--card);border-radius:var(--r);padding:12px 14px;margin-bottom:8px;box-shadow:var(--shadow-sm);border-left:4px solid var(--emerald)}
.report-rec-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}
.report-rec-ref{font-size:11px;font-weight:700;color:var(--navy-mid);font-family:monospace}
.report-rec-date{font-size:11px;color:var(--muted)}
.report-rec-cat{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px}
.report-rec-desc{font-size:13px;color:var(--muted);line-height:1.5;margin-bottom:3px}
.report-rec-meta{font-size:11px;color:var(--muted)}
.report-summary{background:var(--navy-mid);border-radius:var(--r);padding:14px 16px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}
.report-summary-num{font-family:'Syne',sans-serif;font-weight:800;font-size:32px;color:#fff}
.report-summary-lbl{font-size:12px;color:rgba(255,255,255,.6)}
.report-summary-range{font-size:12px;color:rgba(255,255,255,.5);text-align:right}

.view-body{flex:1;overflow-y:auto;padding:16px;-webkit-overflow-scrolling:touch}

/* TOP BAR */
.icon-btn{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:color .15s}
.icon-btn:active{color:var(--text)}

/* LOGIN */
.login-logo svg,.login-logo img{width:80px;height:80px}
.team-btn{background:var(--card);border:1.5px solid var(--border);border-radius:var(--r);padding:14px 10px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:border-color .15s;color:var(--text)}
.team-btn:active{border-color:var(--gold)}
.pin-dot{width:14px;height:14px;border-radius:50%;background:var(--border);transition:background .15s}
.keypad-btn{background:var(--card2);border:1px solid var(--border);border-radius:var(--r-sm);padding:14px;font-size:20px;font-weight:600;color:var(--text);cursor:pointer;font-family:var(--font);transition:background .1s}


/* CHOICE SCREEN */
.choice-greeting{font-size:26px;font-weight:700;color:var(--text);margin-bottom:4px}
.choice-sub{font-size:14px;color:var(--muted);margin-bottom:20px}
.choice-btn{width:100%;background:var(--card);border:1.5px solid var(--border);border-radius:var(--r);padding:16px;display:flex;align-items:center;gap:14px;cursor:pointer;margin-bottom:10px;text-align:left;color:var(--text);transition:border-color .15s}
.choice-btn:active{border-color:var(--gold)}
.pin-change-label{font-size:13px;font-weight:600}
.pin-change-hint{font-size:11px;color:var(--muted)}

/* WALKROUND FORM */
.wr-header{background:var(--navy);padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.wr-date{font-size:18px;font-weight:700;color:var(--text)}
.wr-meta{font-size:12px;color:var(--muted);margin-top:2px}
.wr-reporter-row{display:flex;align-items:center;gap:10px;margin-top:8px}.wr-reporter-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:var(--navy);flex-shrink:0}.wr-reporter-info{min-width:0;flex:1}.wr-reporter-name{font-size:14px;font-weight:700;color:var(--text)}.wr-reporter-sub{font-size:12px;margin-top:1px;font-weight:600}.wr-progress{height:3px;background:var(--border);flex-shrink:0}
.wr-progress-bar{height:3px;background:var(--gold);transition:width .3s;width:0%}
.wr-submit-wrap{padding:12px 16px;flex-shrink:0;border-top:1px solid var(--border)}
.submit-btn{width:100%;background:var(--gold);border:none;border-radius:var(--r);padding:14px;font-family:var(--font);font-size:16px;font-weight:700;color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .15s}

/* SECTION CARDS */
.check-card{background:var(--card);border-radius:var(--r);margin-bottom:10px;overflow:hidden;border:1px solid var(--border)}
.check-card.all-done{border-color:var(--emerald)}
.check-card.partial{border-color:var(--amber)}
.check-card-header{display:flex;align-items:center;gap:8px;padding:12px 14px;cursor:pointer;user-select:none}
.check-card-title{flex:1;font-size:14px;font-weight:700;color:var(--text)}
.check-card-status{font-size:11px;font-weight:600}
.check-card.all-done .check-card-status{color:var(--emerald)}
.check-card.partial .check-card-status{color:var(--amber)}
.check-card-chevron{color:var(--muted);transition:transform .2s;flex-shrink:0}
.check-card-chevron.open{transform:rotate(180deg)}
.check-card-body{padding:0 14px 14px;display:none}
.check-card-body.open{display:block}
.period-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;margin-top:12px}
.period-label{font-size:11px;font-weight:700;padding:3px 8px;border-radius:4px;flex-shrink:0;width:32px;text-align:center}
.period-label.am{background:rgba(16,185,129,.15);color:#34d399}
.period-label.pm{background:rgba(59,130,246,.15);color:#60a5fa}
.tick-btn{width:38px;height:38px;border-radius:var(--r-sm);border:2px solid var(--border);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0;transition:all .15s}
.tick-btn.ticked{background:var(--emerald);border-color:var(--emerald);color:#fff}
.cam-btn{width:38px;height:38px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--card2);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0;transition:background .15s}
.cam-btn:active{background:var(--navy-mid)}
.thumb-del{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;background:var(--red);color:#fff;border:none;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;line-height:1}
.check-notes{width:100%;background:var(--card2);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;color:var(--text);font-family:var(--font);font-size:13px;resize:none;min-height:36px;max-height:120px;outline:none;margin-top:4px;line-height:1.5}
.check-notes:focus{border-color:var(--gold)}
.check-notes::placeholder{color:var(--muted)}

/* COVER MODAL */.discard-btn:active{background:rgba(239,68,68,.1)}

/* SUCCESS */

/* QUEUE */
.queue-card{background:var(--card);border-radius:var(--r);overflow:hidden;margin-bottom:10px;box-shadow:var(--shadow);display:flex;border-left:4px solid var(--orange)}
.queue-del-btn{flex-shrink:0;align-self:stretch;padding:0 14px;background:transparent;border:none;border-left:1px solid var(--border);color:var(--muted);cursor:pointer;display:flex;align-items:center;transition:background .15s,color .15s}
.queue-del-btn:hover{background:rgba(239,68,68,.1);color:var(--red)}

/* ADMIN */
.admin-card-day{font-size:13px;font-weight:700;color:var(--gold)}
.admin-card-date{font-size:12px;color:var(--muted);margin-left:auto}
.admin-card-reporter{font-size:12px;color:var(--muted)}

.admin-card-actions{display:flex;gap:8px;padding:0 14px 12px}

/* CONFIG */

.config-select{width:100%;background:var(--card2);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 12px;color:var(--text);font-family:var(--font);font-size:16px;outline:none;cursor:pointer}

/* TOAST & LOADING */
@keyframes spin{to{transform:rotate(360deg)}}
.pending-banner{background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.3);border-radius:var(--r-sm);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px;cursor:pointer}

/* PIN CHANGE */

/* CAMERA INPUT */

.cal-nav-btn:active{background:var(--card)}
.cal-day{background:var(--card);min-height:52px;padding:6px;cursor:default;position:relative;transition:background .15s}
.cal-day.has-report:active{background:var(--card2)}
.cal-dot{display:flex;align-items:center;gap:4px;margin-top:2px}
.cal-dot-circle{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.cal-dot-name{font-size:10px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 12px)}
.cal-detail-sheet{background:var(--bg);border-radius:var(--r) var(--r) 0 0;width:100%;max-width:480px;margin:0 auto;max-height:85vh;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom)}
.cal-section{border-radius:var(--r);background:var(--card);margin:8px 12px 0;overflow:hidden;border:1px solid var(--border)}
.cal-section.all-done{border-color:var(--emerald)}
.cal-section.partial{border-color:var(--amber)}
.cal-section-header{padding:10px 14px;display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.cal-section-name{font-size:13px;font-weight:700;color:var(--text)}
.cal-section-badge{font-size:11px;font-weight:600}
.cal-section.all-done .cal-section-badge{color:var(--emerald)}
.cal-section.partial .cal-section-badge{color:var(--amber)}
.cal-section.has-issue>.cal-section-header{border-left:3px solid #ef4444;padding-left:10px}
.cal-section-body{padding:0 14px 12px;display:none}
.cal-section-body.open{display:block}
.cal-period{display:flex;align-items:flex-start;gap:8px;margin-top:10px}
.cal-period-label{font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;flex-shrink:0;margin-top:2px}
.cal-period-label.am{background:rgba(16,185,129,.15);color:#34d399}
.cal-period-label.pm{background:rgba(59,130,246,.15);color:#60a5fa}
.cal-period-content{flex:1}
.cal-tick{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600}
.cal-tick.fail{color:#ef4444;font-weight:600}
.cal-tick.yes{color:var(--emerald)}
.cal-tick.no{color:var(--muted)}
.cal-notes{font-size:12px;color:var(--muted);margin-top:4px;line-height:1.5}
.cal-photo{width:80px;height:56px;object-fit:cover;border-radius:6px;border:1px solid var(--border);margin-top:6px;cursor:pointer}

/* ── Settings view light theme (matches IRT) ── */
.pf-label{font-size:12px;font-weight:700;color:var(--muted);width:30px;flex-shrink:0}
.pf-btn{width:44px;height:44px;border-radius:8px;border:1.5px solid var(--border);background:var(--card);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s;-webkit-tap-highlight-color:transparent}
.pf-fail-photo{display:none;align-items:center;gap:8px;margin-top:6px;padding:6px 8px;background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.25);border-radius:var(--r-sm)}
.pf-fail-photo.show{display:flex}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}

.view-body{flex:1;overflow-y:auto;padding:12px 14px;-webkit-overflow-scrolling:touch}
.view-body::-webkit-scrollbar{width:4px}
.view-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* TOP BAR */
.top-bar{background:var(--navy);padding:12px 16px;display:flex;align-items:center;gap:10px;flex-shrink:0;border-bottom:1px solid var(--border)}
.top-bar-avatar{width:34px;height:34px;border-radius:50%;background:var(--gold);color:var(--navy);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.top-bar-info{flex:1;min-width:0}
.top-bar-name{font-weight:700;font-size:15px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top-bar-sub{font-size:11px;color:var(--muted)}
.icon-btn{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center}

/* LOGIN */
.login-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;padding-top:max(24px,calc(env(safe-area-inset-top) + 24px))}
.login-logo{width:80px;height:80px;border-radius:16px;background:var(--navy);margin-bottom:20px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.login-title{font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px;text-align:center}
.login-sub{font-size:13px;color:var(--muted);margin-bottom:32px;text-align:center}
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:320px;margin-bottom:24px}
.team-btn{background:var(--card);border:1.5px solid var(--border);border-radius:var(--r);padding:14px 10px;display:flex;align-items:center;gap:10px;cursor:pointer;color:var(--text)}
.team-btn.selected{border-color:var(--gold);background:var(--card2)}
.team-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:var(--navy);flex-shrink:0}
.team-name{font-size:13px;font-weight:600}
.team-role{font-size:10px;color:var(--muted)}
.pin-wrap{background:var(--card);border-radius:var(--r);padding:20px;width:100%;max-width:320px}
.pin-user{font-size:14px;font-weight:700;color:var(--text);text-align:center;margin-bottom:16px}
.pin-dots{display:flex;gap:12px;justify-content:center;margin-bottom:20px}
.pin-dot{width:14px;height:14px;border-radius:50%;background:var(--border)}
.pin-dot.filled{background:var(--gold)}
.pin-dot.error{background:var(--red)}
.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.keypad-btn{background:var(--card2);border:1px solid var(--border);border-radius:var(--r-sm);padding:14px;font-size:20px;font-weight:600;color:var(--text);cursor:pointer;font-family:var(--font)}
.keypad-btn:active{background:var(--navy-mid)}


/* CHOICE */
.choice-body{flex:1;overflow-y:auto;padding:16px}
.choice-btn{width:100%;background:var(--card);border:1.5px solid var(--border);border-radius:var(--r);padding:16px;display:flex;align-items:center;gap:14px;cursor:pointer;margin-bottom:10px;text-align:left;color:var(--text)}
.choice-btn.primary{background:var(--gold);border-color:var(--gold);color:var(--navy)}
.choice-btn-icon{width:44px;height:44px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.choice-btn.primary .choice-btn-icon{background:rgba(0,0,0,.15)}
.choice-btn-title{font-size:15px;font-weight:700}
.choice-btn-desc{font-size:12px;color:var(--muted);margin-top:2px}
.choice-btn.primary .choice-btn-desc{color:rgba(10,21,32,.7)}
.pin-change-strip{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;margin-top:4px;color:var(--text)}
.choice-queue-banner{display:none;margin:0 0 12px;background:rgba(245,166,35,.12);border:1px solid rgba(245,166,35,.3);border-radius:var(--r);padding:12px 14px;align-items:center;justify-content:space-between;gap:10px}

/* FLOOR CHECK FORM */
.fc-header{background:var(--navy);padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.fc-date{font-size:18px;font-weight:700;color:var(--text)}
.fc-meta{font-size:12px;color:var(--muted);margin-top:2px}
.fc-building-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(14,165,233,.15);border:1px solid rgba(14,165,233,.3);border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700;color:var(--sky);margin-top:6px}
.fc-reporter-row{display:flex;align-items:center;gap:10px;margin-top:8px}
.fc-reporter-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:var(--navy);flex-shrink:0}
.fc-reporter-name{font-size:14px;font-weight:700;color:var(--text)}
.fc-reporter-sub{font-size:12px;margin-top:1px;font-weight:600}
.cover-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(245,166,35,.15);border:1px solid rgba(245,166,35,.4);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600;color:var(--amber);margin-top:6px}
.fc-progress{height:3px;background:var(--border);flex-shrink:0}
.fc-progress-bar{height:3px;background:var(--gold);transition:width .3s;width:0%}
.fc-submit-wrap{padding:12px 16px;flex-shrink:0;border-top:1px solid var(--border)}
.submit-btn{width:100%;background:var(--gold);border:none;border-radius:var(--r);padding:14px;font-family:var(--font);font-size:16px;font-weight:700;color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
.submit-btn:disabled{opacity:.4;cursor:not-allowed}

/* FLOOR CARDS */
.floor-card{background:var(--card);border-radius:var(--r);margin-bottom:8px;border:1.5px solid var(--border);overflow:hidden}
.floor-card.complete{border-color:var(--emerald)}
.floor-card.has-fail{border-color:var(--red)}
.floor-card.partial{border-color:var(--amber)}
.floor-card-header{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;user-select:none}
.floor-num{font-size:20px;font-weight:700;color:var(--gold);min-width:56px;flex-shrink:0}
.floor-check-grid{display:flex;flex-wrap:wrap;gap:4px;flex:1}
.floor-check-dot{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s;pointer-events:none}
.floor-check-dot.pass{background:var(--emerald);border-color:var(--emerald)}
.floor-check-dot.fail{background:var(--red);border-color:var(--red)}
.floor-check-dot svg{display:none}
.floor-check-dot.pass svg,.floor-check-dot.fail svg{display:block}

.pf-row{display:flex;align-items:center;gap:6px;margin-bottom:6px;background:var(--card2);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:6px 8px}
.floor-all-ok{background:var(--emerald);border:none;border-radius:6px;padding:5px 10px;font-family:var(--font);font-size:11px;font-weight:700;color:#fff;cursor:pointer;flex-shrink:0;white-space:nowrap}
.floor-card.complete 
.pf-row{display:flex;align-items:center;gap:6px;margin-bottom:6px;background:var(--card2);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:6px 8px}
.pf-row.pass{background:rgba(16,185,129,.1);border-color:var(--emerald)}
.pf-row.fail{background:rgba(239,68,68,.1);border-color:var(--red)}
.pf-label{font-size:11px;font-weight:600;color:var(--text);flex:1;line-height:1.2}
.pf-btn{width:34px;height:28px;border-radius:6px;border:1.5px solid var(--border);background:var(--card);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s}
.pf-btn.active-pass{background:var(--emerald);border-color:var(--emerald)}
.pf-btn.active-fail{background:var(--red);border-color:var(--red)}
.floor-all-ok{background:var(--card2);color:var(--muted)}
.floor-chevron{color:var(--muted);flex-shrink:0;transition:transform .2s}
.floor-chevron.open{transform:rotate(180deg)}
.floor-card-body{display:none;padding:0 12px 12px}
.floor-card-body.open{display:block}
.floor-items{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:10px}
.floor-item-btn{background:var(--card2);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;display:flex;align-items:center;gap:7px;cursor:pointer;color:var(--text);text-align:left}
.floor-item-btn.pass{background:rgba(16,185,129,.12);border-color:var(--emerald)}
.floor-item-btn.fail{background:rgba(239,68,68,.12);border-color:var(--red)}
.floor-item-tick{width:16px;height:16px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center}
.floor-item-btn.pass .floor-item-tick{background:var(--emerald);border-color:var(--emerald)}
.floor-item-btn.fail .floor-item-tick{background:var(--red);border-color:var(--red)}
.floor-item-label{font-size:11px;font-weight:600;line-height:1.2}
.floor-photo-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.cam-btn{width:36px;height:36px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--card2);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0}
.photo-thumb-wrap{position:relative;flex-shrink:0}
.photo-thumb{width:48px;height:48px;border-radius:6px;object-fit:cover;border:1.5px solid var(--border)}
.thumb-del{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;background:var(--red);color:#fff;border:none;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center}
.floor-notes{width:100%;background:var(--card2);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;color:var(--text);font-family:var(--font);font-size:13px;resize:none;min-height:36px;max-height:100px;outline:none}
.floor-notes:focus{border-color:var(--gold)}
.floor-notes::placeholder{color:var(--muted)}
.floor-status-text{font-size:10px;font-weight:600;margin-left:auto;flex-shrink:0}
.floor-card.complete .floor-status-text{color:var(--emerald)}
.floor-card.partial .floor-status-text{color:var(--amber)}

/* COVER MODAL */
.cover-modal{position:absolute;inset:0;background:rgba(0,0,0,.7);display:none;align-items:flex-end;z-index:100;padding:16px}
.cover-modal.show{display:flex}
.cover-sheet{background:var(--card);border-radius:var(--r);padding:24px;width:100%;max-width:480px}
.cover-icon{font-size:40px;text-align:center;margin-bottom:12px}
.cover-title{font-size:18px;font-weight:700;color:var(--text);text-align:center;margin-bottom:6px}
.cover-body{font-size:14px;color:var(--muted);text-align:center;margin-bottom:20px;line-height:1.5}
.cover-yes-btn{width:100%;background:var(--gold);border:none;border-radius:var(--r);padding:14px;font-family:var(--font);font-size:15px;font-weight:700;color:var(--navy);cursor:pointer;margin-bottom:10px}
.cover-no-btn{width:100%;background:transparent;border:1px solid var(--border);border-radius:var(--r);padding:14px;font-family:var(--font);font-size:15px;color:var(--muted);cursor:pointer}
.cover-third-btn{width:100%;background:transparent;border:none;color:var(--red);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;padding:8px;margin-top:4px}
.discard-btn{background:transparent;border:none;color:var(--red);cursor:pointer;font-family:var(--font);font-size:12px;font-weight:600;padding:6px 10px;border-radius:6px}

/* SUCCESS */
.success-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;text-align:center}
.success-icon{width:72px;height:72px;border-radius:50%;background:var(--emerald);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.success-title{font-size:24px;font-weight:700;color:var(--text);margin-bottom:6px}
.success-sub{font-size:14px;color:var(--muted);margin-bottom:8px}
.success-ref{font-size:13px;font-weight:700;color:var(--gold);font-family:monospace;margin-bottom:24px}
.success-action-btn{width:100%;max-width:280px;background:var(--card);border:1.5px solid var(--border);border-radius:var(--r);padding:14px;font-family:var(--font);font-size:14px;font-weight:600;color:var(--text);cursor:pointer;margin-bottom:10px}
.success-action-btn.primary{background:var(--gold);border-color:var(--gold);color:var(--navy)}

/* QUEUE */
.queue-empty{text-align:center;padding:48px 24px;color:var(--muted)}
.queue-card{background:var(--card);border-radius:var(--r);overflow:hidden;margin-bottom:10px;display:flex;border-left:4px solid var(--orange)}
.queue-card-body{flex:1;padding:10px 12px;min-width:0}
.queue-card-day{font-size:12px;font-weight:700;color:var(--gold)}
.queue-card-reporter{font-size:13px;font-weight:600;color:var(--text)}
.queue-card-time{font-size:11px;color:var(--muted);margin-top:2px}
.queue-del-btn{flex-shrink:0;align-self:stretch;padding:0 14px;background:transparent;border:none;border-left:1px solid var(--border);color:var(--muted);cursor:pointer;display:flex;align-items:center}
.retry-btn{width:100%;background:var(--gold);border:none;border-radius:var(--r);padding:12px;font-family:var(--font);font-size:14px;font-weight:700;color:var(--navy);cursor:pointer;margin-bottom:12px}

/* ADMIN */
.admin-card{background:var(--card);border-radius:var(--r);margin-bottom:10px;border:1.5px solid var(--border);overflow:hidden}
.admin-card-header{padding:12px 14px;display:flex;align-items:center;gap:10px}
.status-pill{padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700}
.status-pill.submitted{background:rgba(59,130,246,.15);color:#60a5fa}
.status-pill.complete{background:rgba(16,185,129,.15);color:#34d399}
.admin-act-btn{flex:1;padding:8px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--card2);color:var(--text);cursor:pointer;font-family:var(--font);font-size:12px;font-weight:600}
.admin-act-btn.complete{background:var(--emerald);border-color:var(--emerald);color:#fff}
.admin-act-btn.purge{background:rgba(239,68,68,.12);color:var(--red);border-color:rgba(239,68,68,.3)}
.admin-act-bar{background:var(--navy);padding:12px 16px;display:flex;gap:8px;border-bottom:1px solid var(--border)}
.aab-btn{padding:9px 14px;border:none;border-radius:var(--r-sm);font-family:var(--font);font-weight:700;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:6px}
.aab-btn.purge{background:rgba(239,68,68,.12);color:var(--red);border:1px solid rgba(239,68,68,.3)}

/* CONFIG */
.config-section{background:#1a2e45;border-radius:var(--r);margin-bottom:12px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.config-section-header{padding:14px 16px;display:flex;align-items:center;gap:10px;cursor:pointer}
.config-section-title{flex:1;font-size:14px;font-weight:700;color:var(--text);letter-spacing:0.2px}
.config-section-body{padding:0 16px 16px;display:none}
.config-section-body.open{display:block}
.config-field{margin-bottom:12px}
.config-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:5px}
.config-input{width:100%;background:var(--card2);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;color:var(--text);font-family:var(--font);font-size:16px;outline:none;transition:border-color .15s}
.config-input:focus{border-color:var(--gold);background:rgba(158,137,88,0.05);outline:none}
.save-btn{width:100%;padding:14px;border:none;border-radius:var(--r);background:var(--navy-mid);color:#fff;font-family:var(--font);font-weight:700;font-size:15px;cursor:pointer;margin-top:8px;transition:opacity .15s}

/* CALENDAR */
.cal-nav{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--navy);border-bottom:1px solid var(--border)}
.cal-month-label{font-size:17px;font-weight:700;color:var(--text)}
.cal-nav-btn{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:6px 10px;font-size:18px;border-radius:6px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:12px}
.cal-dow{background:var(--navy);padding:8px 0;text-align:center;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.cal-day{background:var(--card);min-height:52px;padding:6px;cursor:default;position:relative}
.cal-day.has-report{cursor:pointer}
.cal-day.other-month{background:rgba(10,21,32,.4)}
.cal-day-num{font-size:12px;font-weight:600;color:var(--muted);margin-bottom:4px}
.cal-day.today .cal-day-num{color:var(--gold);font-weight:700}
.cal-dot{display:flex;align-items:center;gap:3px;margin-top:2px}
.cal-dot-circle{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.cal-dot-name{font-size:9px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 10px)}
.cal-legend{display:flex;gap:14px;padding:0 2px 12px;flex-wrap:wrap}
.cal-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted)}
.cal-legend-dot{width:10px;height:10px;border-radius:50%}
.cal-detail{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;display:none;align-items:flex-end}
.cal-detail.show{display:flex}
.cal-detail-sheet{background:var(--bg);border-radius:var(--r) var(--r) 0 0;width:100%;max-width:480px;margin:0 auto;max-height:88vh;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom)}
.cal-detail-header{background:var(--navy);padding:16px 16px 12px;position:sticky;top:0;z-index:1}
.cal-detail-title{font-size:17px;font-weight:700;color:var(--text)}
.cal-detail-sub{font-size:12px;color:var(--muted);margin-top:3px}
.cal-detail-close{position:absolute;top:14px;right:14px;background:var(--card);border:none;border-radius:50%;width:28px;height:28px;color:var(--muted);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center}
.cal-summary-bar{display:flex;gap:8px;padding:12px 12px 0;flex-wrap:wrap}
.cal-summary-pill{background:var(--card);border-radius:8px;padding:8px 12px;text-align:center;flex:1;min-width:70px}
.cal-summary-num{font-size:22px;font-weight:700;color:var(--text)}
.cal-summary-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:1px}
.cal-floor-list{padding:8px 12px 24px}
.cal-floor-row{background:var(--card);border-radius:8px;margin-bottom:6px;padding:10px 12px;border-left:3px solid var(--border)}
.cal-floor-row.ok{border-left-color:var(--emerald)}
.cal-floor-row.partial{border-left-color:var(--amber)}
.cal-floor-num{font-size:13px;font-weight:700;color:var(--gold)}
.cal-floor-checks{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}
.cal-check-dot{width:16px;height:16px;border-radius:50%;font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center}
.cal-check-dot.ok{background:rgba(16,185,129,.2);color:var(--emerald)}
.cal-check-dot.no{background:rgba(148,163,184,.1);color:var(--muted)}
.cal-check-dot.fail{background:rgba(239,68,68,.2);color:var(--red)}
.cal-floor-notes{font-size:11px;color:var(--muted);margin-top:4px;font-style:italic}

/* PIN CHANGE */
.pin-mode-wrap{padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:12px}

/* TOAST + LOADING */
#toast{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%) translateY(100px);background:#0d1b2a;color:#fff;padding:10px 20px;border-radius:24px;font-size:13px;font-weight:500;z-index:1000;transition:transform .3s cubic-bezier(.32,.72,0,1);white-space:nowrap;max-width:90vw;text-align:center;pointer-events:none}
#toast.show{transform:translateX(-50%) translateY(0)}
.loading-overlay{position:absolute;inset:0;background:rgba(10,21,32,.8);display:none;align-items:center;justify-content:center;flex-direction:column;gap:12px;z-index:400}
.loading-overlay.show{display:flex}
.loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
.loading-text{font-size:13px;color:var(--muted)}
@keyframes spin{to{transform:rotate(360deg)}}
.pending-banner{background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.3);border-radius:var(--r-sm);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px;cursor:pointer}
.pending-text{font-size:13px;font-weight:600;color:var(--orange)}
.test-mode-banner{display:none;background:#f97316;color:#fff;padding:8px 16px;font-size:13px;font-weight:700;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0}
#camera-input{display:none}

/* ── Settings view light theme (matches IRT) ── */
#view-config .view-body{background:#f0f4f8}
#view-config .config-section{background:#fff;border:1px solid #e2e8f0}
#view-config .config-section-header{border-bottom:1px solid #f0f4f8}
#view-config .config-section-title{color:#0d1b2a}
#view-config .config-section-body{background:#fff}
#view-config .config-label{color:#64748b}
#view-config .config-input{background:#fff;border-color:#e2e8f0;color:#1a202c}
#view-config .config-input:focus{border-color:#9e8958;background:#fff}
#view-config .config-select{background:#fff;border-color:#e2e8f0;color:#1a202c}
#view-config .save-btn{background:#1e3a5f;color:#fff}
#view-config [style*="background:var(--card2)"]{background:#f8fafc !important}
#view-config [style*="border:1px solid var(--border)"]{border-color:#e2e8f0 !important}
#view-config [style*="color:var(--muted)"]{color:#64748b !important}
#view-config [style*="color:var(--text)"]{color:#1a202c !important}
#view-config [style*="color:var(--red)"]{color:#dc2626 !important}
#view-config [style*="background:rgba(239,68,68"]{background:rgba(239,68,68,.1) !important}
#view-config .config-section-body input[type=checkbox]{accent-color:#1e3a5f}
#view-config label{color:#475569}
#view-config .test-mode-banner{display:none !important}

.pf-photo-row{display:flex;align-items:center;gap:8px;padding:6px 8px 8px 8px;margin-top:-2px;background:rgba(239,68,68,.05);border:1.5px solid rgba(239,68,68,.2);border-top:none;border-radius:0 0 var(--r-sm) var(--r-sm)}
.pf-cam-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.3);border-radius:var(--r-sm);cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font)}
.pf-cam-btn:active{background:rgba(239,68,68,.2)}

.cfc-btn{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--card);border:1.5px solid var(--bord);border-radius:var(--r);cursor:pointer;text-align:left;width:100%;font-family:var(--font)}
.cfc-btn:active{background:var(--gold-dim,rgba(158,137,88,.15))}
.cfc-btn-title{font-size:14px;font-weight:700;color:var(--text)}
.cfc-btn-sub{font-size:12px;color:var(--muted);margin-top:2px}

/* ═══ SUPER APP SHELL ═══ */
html,body{height:100%;overflow:hidden;background:var(--navy);margin:0;padding:0;
  font-family:var(--font);-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased}
#app{height:100dvh;display:flex;flex-direction:column;overflow:hidden;max-width:480px;
  margin:0 auto;position:relative;padding-top:env(safe-area-inset-top);
  box-sizing:border-box;background:var(--bg)}
.safe-area-fill{position:fixed;top:0;left:0;right:0;height:env(safe-area-inset-top);
  background:var(--navy);z-index:9999;max-width:480px;margin:0 auto}
.view{display:none;flex-direction:column;height:100%;overflow:hidden}

/* ── Login ── */
.login-header{display:flex;flex-direction:column;align-items:center;padding:32px 20px 16px;flex-shrink:0}
.login-title{font-size:22px;font-weight:800;color:var(--text);font-family:var(--font);margin-bottom:2px;text-align:center}
.login-subtitle{font-size:13px;color:var(--muted);text-align:center}
.login-scroll{flex:1;overflow-y:auto;scrollbar-width:none;padding:8px 16px}
.login-scroll::-webkit-scrollbar{display:none}
.login-footer{padding:12px 20px calc(12px + env(safe-area-inset-bottom));text-align:center}
.login-version{font-size:11px;color:rgba(255,255,255,.2)}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.team-btn{background:var(--card);border:1.5px solid var(--border);border-radius:var(--r);
  padding:14px 8px;display:flex;flex-direction:column;align-items:center;gap:7px;
  cursor:pointer;transition:all .12s;-webkit-tap-highlight-color:transparent}
.team-btn:active{transform:scale(.95);background:var(--card2)}
.team-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}
.team-name{font-size:12px;font-weight:600;color:var(--text);text-align:center;line-height:1.2}

/* ── PIN ── */
.pin-header{display:flex;flex-direction:column;align-items:center;padding:24px 20px 16px;position:relative;flex-shrink:0}
.pin-back-btn{position:absolute;left:16px;top:24px;background:none;border:none;color:var(--muted);cursor:pointer;padding:4px}
.pin-avatar{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;margin-bottom:8px}
.pin-name{font-size:17px;font-weight:700;color:var(--text);margin-bottom:4px}
.pin-prompt{font-size:13px;color:var(--muted);margin-bottom:16px}
.pin-dots{display:flex;gap:12px}
.pin-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--muted);transition:all .15s}
.pin-dot.filled{background:var(--gold);border-color:var(--gold)}
.pin-dot.error{background:var(--red);border-color:var(--red)}
.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:16px 32px calc(24px + env(safe-area-inset-bottom));flex:1;align-content:center}
.pin-key{background:var(--card);border:1.5px solid var(--border);border-radius:var(--r);
  padding:0;height:64px;font-size:22px;font-weight:600;color:var(--text);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .1s;font-family:var(--font);
  -webkit-tap-highlight-color:transparent}
.pin-key:active{background:var(--card2);transform:scale(.94)}
.pin-del{color:var(--muted);font-size:14px}

/* ── Module selector ── */
#view-modules{overflow-y:auto;scrollbar-width:none}
#view-modules::-webkit-scrollbar{display:none}
.modules-header{padding:20px 20px 8px;display:flex;align-items:flex-start;justify-content:space-between}
.modules-greeting{font-size:22px;font-weight:800;color:var(--text);font-family:var(--font)}
.modules-greeting span{color:var(--gold)}
.modules-settings-btn{width:40px;height:40px;border-radius:50%;background:var(--card2);
  border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.module-tiles{padding:8px 16px;display:flex;flex-direction:column;gap:14px}
.module-tile{background:var(--card);border:1.5px solid var(--border);border-radius:var(--r-lg);
  padding:20px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:16px;
  -webkit-tap-highlight-color:transparent;text-align:left;width:100%;font-family:var(--font)}
.module-tile:active{transform:scale(.98);background:var(--card2)}
.module-tile-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;
  justify-content:center;flex-shrink:0;font-size:26px}
.module-tile-icon.irt{background:rgba(245,166,35,.15);border:1.5px solid rgba(245,166,35,.3)}
.module-tile-icon.dwc{background:rgba(16,185,129,.15);border:1.5px solid rgba(16,185,129,.3)}
.module-tile-icon.dfc{background:rgba(59,130,246,.15);border:1.5px solid rgba(59,130,246,.3)}
.module-tile-body{flex:1;min-width:0}
.module-tile-name{font-size:16px;font-weight:700;color:var(--text);margin-bottom:3px}
.module-tile-desc{font-size:13px;color:var(--muted);line-height:1.4}
.module-tile-arrow{color:var(--border)}

/* ── Unified settings ── */
#view-settings{background:var(--bg)}
.settings-tabs{display:flex;border-bottom:1.5px solid var(--border);background:var(--card);
  overflow-x:auto;scrollbar-width:none;flex-shrink:0;-webkit-overflow-scrolling:touch}
.settings-tabs::-webkit-scrollbar{display:none}
.settings-tab{flex-shrink:0;padding:12px 18px;font-size:13px;font-weight:600;color:var(--muted);
  cursor:pointer;border-bottom:2.5px solid transparent;transition:all .15s;font-family:var(--font);white-space:nowrap}
.settings-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.settings-panel{display:none;padding:16px}
.settings-panel.active{display:block}

/* user edit cards in settings */
.super-user-card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--r);
  margin-bottom:10px;overflow:hidden}
.super-user-summary{display:flex;align-items:center;gap:12px;padding:12px 14px}
.super-user-edit{padding:12px 14px;border-top:1px solid var(--border);background:var(--card2);display:none}
.super-user-edit.open{display:block}
.sue-field{margin-bottom:10px}
.sue-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;
  letter-spacing:.5px;margin-bottom:4px}
.sue-input{width:100%;background:var(--card);border:1.5px solid var(--border);border-radius:var(--r-sm);
  padding:10px 12px;color:var(--text);font-family:var(--font);font-size:16px;
  box-sizing:border-box;outline:none;transition:border-color .15s}
.sue-input:focus{border-color:var(--gold)}
.sue-apps{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.sue-app-chip{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;
  border:1.5px solid var(--border);background:var(--card);color:var(--muted);transition:all .12s;
  font-family:var(--font)}
.sue-app-chip.on.irt{background:rgba(245,166,35,.2);border-color:var(--gold);color:var(--gold)}
.sue-app-chip.on.dwc{background:rgba(16,185,129,.2);border-color:var(--emerald);color:var(--emerald)}
.sue-app-chip.on.dfc{background:rgba(59,130,246,.2);border-color:var(--blue);color:var(--blue)}
.sue-roles{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.sue-role-chip{padding:4px 10px;border-radius:16px;font-size:11px;font-weight:600;cursor:pointer;
  border:1.5px solid var(--border);background:var(--card);color:var(--muted);font-family:var(--font)}
.sue-role-chip.on{background:rgba(255,255,255,.1);border-color:var(--text);color:var(--text)}
.sue-actions{display:flex;gap:8px;margin-top:12px}
.sue-save{flex:1;background:var(--emerald);border:none;border-radius:8px;padding:10px;
  color:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font)}
.sue-cancel{background:none;border:1.5px solid var(--border);border-radius:8px;padding:10px 16px;
  color:var(--muted);font-size:13px;cursor:pointer;font-family:var(--font)}
.sue-delete{background:rgba(239,68,68,.1);border:1.5px solid rgba(239,68,68,.3);border-radius:8px;
  padding:10px 16px;color:var(--red);font-size:13px;cursor:pointer;font-family:var(--font)}

/* ── Toast ── */
#toast{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom));left:50%;
  transform:translateX(-50%) translateY(calc(100% + 60px));
  background:var(--navy-mid);color:#fff;padding:10px 20px;border-radius:24px;
  font-size:13px;font-weight:500;z-index:9000;
  transition:transform .35s cubic-bezier(.32,.72,0,1);
  white-space:nowrap;max-width:90vw;text-align:center;pointer-events:none;visibility:hidden}
#toast.show{transform:translateX(-50%) translateY(0);visibility:visible}

/* ── Loading ── */
#loading-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);
  z-index:8000;align-items:center;justify-content:center;flex-direction:column;gap:16px}
#loading-overlay.show{display:flex}
.loading-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.15);
  border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
.loading-text{color:#fff;font-size:14px;font-weight:500;font-family:var(--font)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Module top bar back button ── */
.module-back-btn{display:flex;align-items:center;gap:6px;background:none;border:none;
  color:var(--muted);cursor:pointer;font-size:13px;font-family:var(--font);padding:0;
  -webkit-tap-highlight-color:transparent;white-space:nowrap}
.module-back-btn:active{color:var(--text)}

#view-login .team-grid{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:10px!important;max-width:none!important;width:100%!important;margin:0!important;padding:0!important;box-sizing:border-box!important}
#view-login .login-header{padding:20px 20px 12px!important}
#view-login{flex-direction:column!important;height:100%!important;overflow:hidden!important}
#view-login .login-scroll{flex:1!important;overflow-y:auto!important;padding:8px 16px!important;box-sizing:border-box!important}
.view.active{display:flex!important}
/* DWC: match IRT/DFC greeting spacing exactly */
#view-dwc-choice .choice-body{justify-content:flex-start!important;padding:22px 16px 16px!important}
#irt-choice-body{justify-content:flex-start!important;padding-top:22px!important}
#dfc-choice-body{justify-content:flex-start!important;padding-top:22px!important}
#view-dwc-choice .choice-queue-banner{display:none}
#view-dwc-choice .choice-queue-banner[style*="flex"]{display:flex!important}

/* User list drag-to-reorder */
.sue-drag-handle{
  font-size:16px;color:var(--muted);cursor:grab;padding:4px 6px 4px 0;
  user-select:none;-webkit-user-select:none;touch-action:none;flex-shrink:0;
}
.sue-drag-handle:active{cursor:grabbing}
.super-user-card{transition:border-color .15s}
.super-user-card[dragging]{opacity:0.4}


/* ── Stage 1 utility classes ── */
.d-none{display:none}
.flex-1{flex:1}
.ml-auto{margin-left:auto}
.cursor-ptr{cursor:pointer}
.mb-8{margin-bottom:8px}
.mb-20{margin-bottom:20px}
.p-12{padding:12px}
.txt-muted{font-size:12px;color:var(--muted)}
.txt-muted-sm{font-size:11px;color:var(--muted)}
.txt-muted-lg{font-size:14px;font-weight:600;color:var(--text)}
.txt-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.section-label{padding:8px;color:#9e8958;text-align:left;font-size:11px}
.flex-col-gap10{display:flex;flex-direction:column;gap:10px}
.flex-item-ptr{display:flex;align-items:center;gap:8px;flex:1;cursor:pointer}
.queue-empty-inner{text-align:center;padding:40px 20px;color:var(--muted);font-size:13px}
.queue-empty-icon{font-size:24px;margin-bottom:8px}
.thumb-placeholder{width:80px;height:80px;flex-shrink:0;background:var(--card2);display:flex;align-items:center;justify-content:center}
