/* SiteLog styles — built 2026-03-27T10:12:35.343Z */
:root {
  --orange:#E85D24;--orange-dim:#c04e1c;--orange-pale:rgba(232,93,36,0.12);
  --slate:#0f1117;--slate2:#181c25;--slate3:#1f2535;--slate4:#252d3d;
  --border:rgba(255,255,255,0.08);--border2:rgba(255,255,255,0.13);
  --text:#f0f2f7;--text2:#8d95aa;--text3:#555f78;
  --green:#27c47a;--green-pale:rgba(39,196,122,0.12);
  --amber:#f0a023;--amber-pale:rgba(240,160,35,0.12);
  --red:#e24b4a;--red-pale:rgba(226,75,74,0.12);
  --blue:#4a9eff;--blue-pale:rgba(74,158,255,0.12);
  --purple:#a78bfa;--purple-pale:rgba(167,139,250,0.12);
  --r:10px;--r-sm:6px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;background:#000;font-family:'Barlow',sans-serif;}
.app-shell{max-width:430px;margin:0 auto;height:100dvh;background:var(--slate);display:flex;flex-direction:column;overflow:hidden;}

/* STATUS */
.status-bar{background:var(--slate2);padding:8px 16px 6px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);flex-shrink:0;}
.status-site{display:flex;align-items:center;gap:7px;}
.status-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);}
.status-name{font-size:12px;font-weight:600;color:var(--text);}
.status-sub{font-size:10px;color:var(--text2);}
.status-right{display:flex;align-items:center;gap:10px;}
.status-time{font-family:'DM Mono',monospace;font-size:12px;color:var(--text2);}
.admin-btn{width:28px;height:28px;border-radius:6px;background:var(--slate4);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;cursor:pointer;}
.admin-btn svg{width:14px;height:14px;stroke:var(--text2);}

/* SCREENS */
.screens{flex:1;overflow:hidden;position:relative;}
.screen{position:absolute;inset:0;overflow-y:auto;padding-bottom:76px;opacity:0;pointer-events:none;transition:opacity 0.16s;}
.screen.active{opacity:1;pointer-events:all;}
.screen::-webkit-scrollbar{display:none;}

/* PAGE HEADER */
.ph{padding:14px 16px 11px;display:flex;align-items:flex-start;justify-content:space-between;position:sticky;top:0;background:var(--slate);z-index:10;border-bottom:1px solid var(--border);}
.ph-title{font-family:'Barlow Condensed',sans-serif;font-size:21px;font-weight:700;color:var(--text);letter-spacing:.02em;text-transform:uppercase;}
.ph-sub{font-size:11px;color:var(--text2);margin-top:1px;}
.ph-btn{background:var(--orange);color:white;border:none;border-radius:var(--r-sm);padding:7px 12px;font-size:12px;font-weight:600;font-family:'Barlow',sans-serif;cursor:pointer;}
.ph-btn:hover{background:var(--orange-dim);}
.ph-btn.ghost{background:transparent;color:var(--text2);border:1px solid var(--border2);}
.ph-btn.ghost:hover{background:var(--slate3);}
.ph-btn:disabled{opacity:.4;cursor:default;}

/* CARDS */
.card{background:var(--slate3);border-radius:var(--r);border:1px solid var(--border);}
.sec{padding:0 16px;margin-top:12px;}
.sec-lbl{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:7px;}

/* CLOCK CARD */
.clock-card{margin:12px 16px 0;background:var(--slate3);border:1px solid var(--border);border-radius:var(--r);padding:16px;display:flex;align-items:center;gap:14px;}
.ck-btn{width:60px;height:60px;border-radius:50%;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;transition:transform .15s;}
.ck-btn:hover{transform:scale(1.05);}
.ck-btn.in{background:var(--red);box-shadow:0 0 0 4px var(--red-pale);}
.ck-btn.out{background:var(--green);box-shadow:0 0 0 4px var(--green-pale);}
.ck-lbl{font-size:8px;font-weight:700;color:white;letter-spacing:.08em;margin-top:2px;}
.ck-info{flex:1;}
.ck-status{font-size:14px;font-weight:600;color:var(--text);}
.ck-detail{font-size:11px;color:var(--text2);margin-top:1px;}
.ck-timer{font-family:'DM Mono',monospace;font-size:21px;font-weight:500;color:var(--orange);margin-top:4px;}

/* STATS */
.stats-row{display:flex;gap:8px;margin:10px 16px 0;}
.stat-card{flex:1;background:var(--slate3);border:1px solid var(--border);border-radius:var(--r);padding:11px;}
.stat-n{font-family:'Barlow Condensed',sans-serif;font-size:24px;font-weight:700;color:var(--text);}
.stat-l{font-size:10px;color:var(--text2);margin-top:1px;}
.stat-d{font-size:10px;color:var(--text3);margin-top:2px;}

/* EVENTS */
.ev{display:flex;gap:9px;padding:10px 14px;align-items:flex-start;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;}
.ev:last-child{border-bottom:none;}
.ev:active{background:var(--slate4);}
.ev-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.ev-time{font-family:'DM Mono',monospace;font-size:10px;color:var(--text3);}
.ev-text{font-size:13px;color:var(--text);margin-top:1px;line-height:1.4;}
.ev-src{font-size:11px;color:var(--text3);margin-top:2px;}
.tag{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;margin-left:4px;}
.tr{background:var(--red-pale);color:#f87171;}
.tg{background:var(--green-pale);color:#4ade80;}
.ta{background:var(--amber-pale);color:#fbbf24;}
.tb{background:var(--blue-pale);color:#93c5fd;}
.tp{background:var(--purple-pale);color:var(--purple);}

/* CHAT */
.msg{display:flex;gap:8px;margin-bottom:9px;align-items:flex-end;padding:0 16px;}
.msg.mine{flex-direction:row-reverse;}
.av{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0;}
.bubble{max-width:72%;background:var(--slate3);border-radius:14px;padding:8px 12px;border:1px solid var(--border);font-size:13px;color:var(--text);line-height:1.45;}
.msg.mine .bubble{background:var(--orange);border-color:var(--orange);color:white;border-bottom-right-radius:4px;}
.msg:not(.mine) .bubble{border-bottom-left-radius:4px;}
.bm{font-size:10px;opacity:.6;margin-top:3px;font-family:'DM Mono',monospace;}
.msg.mine .bm{text-align:right;}
.photo-msg{max-width:76%;background:var(--slate3);border-radius:10px;overflow:hidden;border:1px solid var(--border);cursor:pointer;}
.photo-thumb{width:100%;height:120px;background:var(--slate4);display:flex;align-items:center;justify-content:center;position:relative;}
.pm-meta{padding:7px 10px;}
.pm-gps{font-size:10px;color:var(--text3);font-family:'DM Mono',monospace;}
.cib{background:var(--slate2);border-top:1px solid var(--border);padding:9px 14px;display:flex;gap:8px;align-items:center;}
.ci{flex:1;background:var(--slate4);border:1px solid var(--border2);border-radius:20px;padding:8px 14px;font-size:13px;color:var(--text);font-family:'Barlow',sans-serif;outline:none;}
.ci::placeholder{color:var(--text3);}
.cb{width:34px;height:34px;border-radius:50%;border:1px solid var(--border2);background:var(--slate4);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;}
.cb svg{width:15px;height:15px;}
.cb.send{background:var(--orange);border-color:var(--orange);}

/* PHOTOS */
.pgrid{display:grid;grid-template-columns:1fr 1fr;gap:2px;padding:2px;}
.pc{aspect-ratio:1;background:var(--slate3);position:relative;overflow:hidden;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s;}
.pc:active{opacity:.75;}
.pc svg{width:26px;height:26px;opacity:.15;}
.pc-ov{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.78));padding:18px 7px 6px;}
.pc-t{font-family:'DM Mono',monospace;font-size:10px;color:rgba(255,255,255,.85);}
.pc-tag{font-size:10px;font-weight:600;padding:1px 5px;border-radius:3px;display:inline-block;margin-top:2px;}
.pc-u{position:absolute;top:5px;right:5px;font-size:10px;font-weight:700;background:rgba(0,0,0,.55);color:white;padding:2px 5px;border-radius:3px;}
.add-pc{background:var(--slate4);border:2px dashed var(--border2);cursor:pointer;flex-direction:column;gap:4px;transition:all .15s;}
.add-pc:hover{border-color:var(--orange);background:var(--orange-pale);}
.add-pc span{font-size:11px;color:var(--text3);}
.pill-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px;}
.pill{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;border:1px solid var(--border2);color:var(--text2);background:var(--slate4);cursor:pointer;transition:all .15s;}
.pill.on{background:var(--orange-pale);border-color:rgba(232,93,36,.4);color:var(--orange);}
.folder-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;}
.folder-row:last-child{border-bottom:none;}
.folder-row:active{background:var(--slate4);}
.fi{width:32px;height:32px;background:var(--amber-pale);border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.fi svg{width:16px;height:16px;fill:var(--amber);}

/* TIMESHEET */
.ts-card{margin:12px 16px 0;background:var(--slate3);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;}
.ts-hd{padding:13px 15px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;}
.ts-proj{font-size:13px;font-weight:600;color:var(--text);}
.ts-ref{font-size:11px;color:var(--text2);margin-top:2px;}
.ts-body{padding:13px 15px;}
.ts-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px;}
.ts-row:last-child{margin-bottom:0;}
.ts-lbl{font-size:12px;color:var(--text2);}
.ts-val{font-family:'DM Mono',monospace;font-size:13px;color:var(--text);font-weight:500;}
.ts-big{font-size:21px;color:var(--orange);}
.ts-div{border:none;border-top:1px solid var(--border);margin:10px 0;}
.task-item{display:flex;gap:8px;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--border);}
.task-item:last-child{border-bottom:none;}
.t-bullet{width:6px;height:6px;border-radius:50%;background:var(--orange);flex-shrink:0;margin-top:5px;}
.t-text{font-size:13px;color:var(--text);line-height:1.45;flex:1;}
.t-time{font-family:'DM Mono',monospace;font-size:10px;color:var(--text3);margin-top:2px;}
.ai-badge{display:inline-flex;align-items:center;gap:5px;background:var(--orange-pale);border:1px solid rgba(232,93,36,.25);border-radius:20px;padding:3px 9px;margin-bottom:9px;}
.ai-badge span{font-size:11px;font-weight:600;color:var(--orange);}
.sig-area{margin:10px 16px 0;background:var(--slate3);border:1px solid var(--border);border-radius:var(--r);padding:14px;}
.sig-title{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;}
.sig-pad{height:72px;border:1px dashed var(--border2);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;}
.sig-pad.signed{border-style:solid;border-color:var(--green);background:var(--green-pale);}
.sig-mr{display:flex;justify-content:space-between;margin-top:7px;}
.sig-who{font-size:11px;color:var(--text2);}
.sig-when{font-size:11px;color:var(--text3);font-family:'DM Mono',monospace;}

/* WEEKLY */
.week-table{width:100%;border-collapse:collapse;}
.week-table th{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);padding:8px 12px;text-align:left;border-bottom:1px solid var(--border);}
.week-table td{padding:10px 12px;font-size:12px;color:var(--text);border-bottom:1px solid var(--border);}
.week-table tr:last-child td{border-bottom:none;}
.week-table tr:hover td{background:var(--slate4);}
.wk-day{font-weight:600;}
.wk-hrs{font-family:'DM Mono',monospace;font-size:12px;}
.wk-total{background:var(--slate4);}
.wk-total td{font-weight:600;color:var(--orange);}
.week-stat{flex:1;background:var(--slate3);border:1px solid var(--border);border-radius:var(--r);padding:12px;text-align:center;}
.week-stat-n{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:700;color:var(--text);}
.week-stat-l{font-size:10px;color:var(--text2);margin-top:2px;}

/* REPORT */
.report-band{background:var(--orange);padding:14px 16px;}
.rb-title{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;color:white;letter-spacing:.05em;text-transform:uppercase;}
.rb-meta{font-size:12px;color:rgba(255,255,255,.8);margin-top:2px;}
.rb-body{padding:14px 16px;}
.rs-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:7px;}
.rs-text{font-size:13px;color:var(--text2);line-height:1.7;}
.ri{display:flex;gap:9px;align-items:flex-start;padding:7px 0;border-bottom:1px solid var(--border);}
.ri:last-child{border-bottom:none;}
.ri-t{font-family:'DM Mono',monospace;font-size:11px;color:var(--text3);min-width:44px;padding-top:1px;}
.ri-body{flex:1;}
.ri-txt{font-size:12px;color:var(--text);line-height:1.4;}
.sp{display:inline-flex;align-items:center;font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;margin-top:3px;}
.wx-row{display:flex;gap:10px;align-items:center;padding:8px 0;}

/* MAP */
#mapContainer{height:320px;background:var(--slate3);position:relative;z-index:0;}
.map-controls{padding:12px 16px;display:flex;flex-direction:column;gap:8px;}
.map-ctrl-card{background:var(--slate3);border:1px solid var(--border);border-radius:var(--r);padding:13px;}
.mc-title{font-size:12px;font-weight:600;color:var(--text);margin-bottom:8px;}
.mc-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px;}
.mc-row:last-child{margin-bottom:0;}
.mc-label{font-size:12px;color:var(--text2);}
.mc-val{font-family:'DM Mono',monospace;font-size:12px;color:var(--orange);font-weight:500;}
.worker-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);}
.worker-row:last-child{border-bottom:none;}
.w-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;}
.w-info{flex:1;}
.w-name{font-size:13px;font-weight:600;color:var(--text);}
.w-gps{font-family:'DM Mono',monospace;font-size:10px;color:var(--text3);margin-top:1px;}
.w-status{font-size:11px;font-weight:600;padding:3px 8px;border-radius:12px;}
.w-on{background:var(--green-pale);color:var(--green);}
.w-off{background:var(--slate4);color:var(--text3);}
input[type=range]{-webkit-appearance:none;width:100%;height:4px;border-radius:2px;background:var(--slate4);outline:none;cursor:pointer;}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--orange);cursor:pointer;}

/* ADMIN */
.admin-section{margin-bottom:4px;}
.adm-item{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;}
.adm-item:last-child{border-bottom:none;}
.adm-item:active{background:var(--slate4);}
.adm-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.adm-icon svg{width:16px;height:16px;}
.adm-label{flex:1;font-size:13px;font-weight:600;color:var(--text);}
.adm-sub{font-size:11px;color:var(--text2);margin-top:1px;}
.adm-arrow{color:var(--text3);font-size:15px;}
.toggle-wrap{display:flex;align-items:center;gap:8px;}
.toggle{width:40px;height:22px;border-radius:11px;background:var(--green);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;}
.toggle.off{background:var(--slate4);border:1px solid var(--border2);}
.toggle-knob{position:absolute;top:2px;left:20px;width:18px;height:18px;border-radius:50%;background:white;transition:left .2s;}
.toggle.off .toggle-knob{left:2px;}
.badge-pill{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;background:var(--green-pale);color:var(--green);}
.badge-pill.amber{background:var(--amber-pale);color:var(--amber);}
.badge-pill.red{background:var(--red-pale);color:var(--red);}

/* ACTION BUTTONS */
.abtn{width:100%;padding:13px;border-radius:var(--r-sm);border:none;font-size:14px;font-weight:700;font-family:'Barlow',sans-serif;cursor:pointer;transition:opacity .15s;display:flex;align-items:center;justify-content:center;gap:8px;}
.abtn:hover{opacity:.87;}
.abtn:disabled{opacity:.4;cursor:default;}
.a-orange{background:var(--orange);color:white;}
.a-outline{background:transparent;color:var(--text2);border:1px solid var(--border2);}
.a-green{background:var(--green);color:var(--slate);}

/* ONLINE USERS */
.ou{display:flex;align-items:center;}
.u-av{width:24px;height:24px;border-radius:50%;border:2px solid var(--slate);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;margin-left:-5px;}
.u-av:first-child{margin-left:0;}
.ou-n{font-size:11px;color:var(--text2);margin-left:5px;}

/* MODAL */
.mo{position:absolute;inset:0;background:rgba(0,0,0,.65);z-index:200;display:flex;flex-direction:column;justify-content:flex-end;opacity:0;pointer-events:none;transition:opacity .2s;}
.mo.open{opacity:1;pointer-events:all;}
.ms{background:var(--slate2);border-radius:16px 16px 0 0;border-top:1px solid var(--border2);padding:18px 18px 34px;max-height:88vh;overflow-y:auto;transform:translateY(12px);transition:transform .22s ease;}
.ms::-webkit-scrollbar{display:none;}
.mo.open .ms{transform:translateY(0);}
.mh{width:34px;height:4px;border-radius:2px;background:var(--border2);margin:0 auto 14px;}
.mt{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.03em;margin-bottom:4px;}
.msub{font-size:13px;color:var(--text2);margin-bottom:16px;line-height:1.5;}
.tag-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:14px;}
.tg-btn{padding:11px;border-radius:var(--r-sm);border:1px solid var(--border2);background:var(--slate3);font-size:13px;font-weight:600;font-family:'Barlow',sans-serif;color:var(--text2);cursor:pointer;display:flex;align-items:center;gap:7px;transition:all .15s;}
.tg-btn.sel,.tg-btn:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-pale);}
.tg-red.sel,.tg-red:hover{border-color:var(--red);color:var(--red);background:var(--red-pale);}
.tg-green.sel,.tg-green:hover{border-color:var(--green);color:var(--green);background:var(--green-pale);}
.tg-amber.sel,.tg-amber:hover{border-color:var(--amber);color:var(--amber);background:var(--amber-pale);}
.tg-blue.sel,.tg-blue:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-pale);}
.mi{width:100%;background:var(--slate4);border:1px solid var(--border2);border-radius:var(--r-sm);padding:10px 13px;font-size:13px;color:var(--text);font-family:'Barlow',sans-serif;outline:none;margin-bottom:10px;resize:none;}
.mi::placeholder{color:var(--text3);}

/* AI STREAM */
.ai-stream{font-size:13px;color:var(--text2);line-height:1.7;min-height:70px;padding:11px 13px;background:var(--slate3);border-radius:var(--r-sm);border:1px solid var(--border);margin-bottom:11px;white-space:pre-line;}
.ai-cur{display:inline-block;width:2px;height:13px;background:var(--orange);margin-left:2px;animation:blink .8s step-end infinite;vertical-align:text-bottom;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.spinner{width:17px;height:17px;border:2px solid var(--border2);border-top-color:var(--orange);border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}

/* NAV */
.bnav{height:65px;background:var(--slate2);border-top:1px solid var(--border);display:flex;flex-shrink:0;}
.nb{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;background:none;border:none;color:var(--text3);transition:color .15s;}
.nb.active{color:var(--orange);}
.nb svg{width:20px;height:20px;}
.nb span{font-size:9px;font-weight:600;letter-spacing:.04em;}
.nb-dot{width:4px;height:4px;border-radius:50%;background:var(--orange);opacity:0;}
.nb.active .nb-dot{opacity:1;}

/* TOAST */
.toast{position:fixed;bottom:86px;left:50%;transform:translateX(-50%) translateY(14px);background:var(--slate4);border:1px solid var(--border2);color:var(--text);padding:9px 17px;border-radius:20px;font-size:13px;font-weight:500;opacity:0;transition:all .22s;pointer-events:none;z-index:999;white-space:nowrap;max-width:92vw;text-align:center;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* MISC */
@keyframes fadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.fi-anim{animation:fadeIn .28s ease forwards;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.live{animation:pulse 2s ease-in-out infinite;}
.divider{border:none;border-top:1px solid var(--border);margin:10px 0;}

/* LEAFLET OVERRIDES */
.leaflet-container{background:var(--slate3);}
.leaflet-control-zoom{display:none;}
.leaflet-control-attribution{display:none;}

/* ── SEARCH BAR ──────────────────────────────────────────────────────────────── */
.search-bar{
  display:flex;align-items:center;gap:8px;
  background:var(--slate3);border:1px solid var(--border);
  border-radius:var(--r-sm);padding:8px 10px;
}
.search-bar:focus-within{border-color:var(--orange);background:var(--slate2);}
.search-icon{width:14px;height:14px;color:var(--text3);flex-shrink:0;}
.search-inp{
  flex:1;background:none;border:none;outline:none;
  font-size:13px;color:var(--text);font-family:'Barlow',sans-serif;
  min-width:0;
}
.search-inp::placeholder{color:var(--text3);}
.search-clear{
  background:none;border:none;color:var(--text3);cursor:pointer;
  font-size:14px;padding:0 2px;line-height:1;flex-shrink:0;
}
.search-highlight{background:rgba(232,93,36,.25);border-radius:2px;padding:0 1px;}
.search-no-results{
  padding:20px;text-align:center;font-size:13px;color:var(--text3);
}

/* ── ANNOTATION TOOLS ────────────────────────────────────────────────────────── */
.ann-tool{
  padding:6px 10px;border-radius:6px;border:1px solid var(--border2);
  background:var(--slate4);font-size:12px;font-weight:600;
  font-family:'Barlow',sans-serif;color:var(--text2);cursor:pointer;
  white-space:nowrap;flex-shrink:0;
}
.ann-tool.sel{background:var(--orange-pale);border-color:rgba(232,93,36,.4);color:var(--orange);}
.ann-colour{
  width:22px;height:22px;border-radius:50%;cursor:pointer;
  border:2px solid transparent;flex-shrink:0;
}
.ann-colour.sel{border-color:white;box-shadow:0 0 0 2px var(--orange);}

/* ── PROJECT SWITCHER ────────────────────────────────────────────────────────── */
.proj-switch-btn{display:flex;align-items:center;gap:5px;cursor:pointer;padding:2px 0;}
.proj-switch-btn svg{width:12px;height:12px;color:var(--text3);flex-shrink:0;transition:transform .2s;}
.proj-switch-btn:active svg{transform:rotate(180deg);}

.proj-sheet{
  position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:7000;
  display:flex;flex-direction:column;justify-content:flex-end;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.proj-sheet.open{opacity:1;pointer-events:all;}
.proj-sheet-inner{
  background:var(--slate2);border-radius:16px 16px 0 0;
  border-top:1px solid var(--border2);
  padding:16px 0 max(env(safe-area-inset-bottom),20px);
  transform:translateY(12px);transition:transform .22s ease;
  max-height:70vh;overflow-y:auto;
}
.proj-sheet.open .proj-sheet-inner{transform:translateY(0);}
.proj-sheet-title{
  font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--text3);
  padding:0 18px 10px;
}
.proj-item{
  display:flex;align-items:center;gap:12px;padding:12px 18px;
  cursor:pointer;transition:background .1s;
}
.proj-item:active{background:var(--slate3);}
.proj-item.active-proj{background:var(--orange-pale);}
.proj-dot{
  width:10px;height:10px;border-radius:50%;flex-shrink:0;
  background:var(--slate4);border:2px solid var(--border2);
}
.proj-item.active-proj .proj-dot{background:var(--orange);border-color:var(--orange);}
.proj-item-info{flex:1;min-width:0;}
.proj-item-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.proj-item-meta{font-size:11px;color:var(--text3);margin-top:2px;}
.proj-item.active-proj .proj-item-name{color:var(--orange);}
.proj-item-tick{color:var(--orange);font-weight:700;flex-shrink:0;}
.proj-add-btn{
  margin:10px 18px 0;padding:12px;border-radius:8px;
  background:var(--slate3);border:1px dashed var(--border2);
  font-size:13px;font-weight:600;color:var(--text2);
  width:calc(100% - 36px);cursor:pointer;font-family:'Barlow',sans-serif;
  display:flex;align-items:center;justify-content:center;gap:7px;
}

/* ── PWA INSTALL BANNER ──────────────────────────────────────────────────────── */
.pwa-banner{
  position:fixed;bottom:max(env(safe-area-inset-bottom),0px);left:0;right:0;z-index:6000;
  background:var(--slate2);border-top:1px solid var(--border2);
  padding:14px 16px max(env(safe-area-inset-bottom),14px);
  display:flex;align-items:center;gap:12px;
  transform:translateY(100%);transition:transform .3s ease;
}
.pwa-banner.show{transform:translateY(0);}
.pwa-banner-icon{
  width:44px;height:44px;border-radius:10px;background:var(--orange);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.pwa-banner-icon svg{width:22px;height:22px;fill:white;}
.pwa-banner-text{flex:1;min-width:0;}
.pwa-banner-title{font-size:13px;font-weight:700;color:var(--text);}
.pwa-banner-sub{font-size:11px;color:var(--text3);margin-top:2px;}
.pwa-banner-btn{
  background:var(--orange);color:white;border:none;border-radius:7px;
  padding:9px 14px;font-size:13px;font-weight:700;font-family:'Barlow',sans-serif;
  cursor:pointer;flex-shrink:0;
}
.pwa-banner-dismiss{
  background:none;border:none;color:var(--text3);font-size:18px;
  cursor:pointer;padding:4px;flex-shrink:0;line-height:1;
}

/* ── INVITE MODAL ────────────────────────────────────────────────────────────── */
.invite-role-row{display:flex;gap:7px;margin-top:6px;}
.invite-role-chip{
  flex:1;padding:8px 5px;border-radius:7px;border:1px solid var(--border2);
  background:var(--slate4);font-size:12px;font-weight:600;
  font-family:'Barlow',sans-serif;color:var(--text2);cursor:pointer;text-align:center;
}
.invite-role-chip.sel{background:var(--orange-pale);border-color:rgba(232,93,36,.4);color:var(--orange);}
.invite-ok{
  background:var(--green-pale);border:1px solid rgba(39,196,122,.3);
  border-radius:8px;padding:10px 13px;font-size:13px;color:var(--green);
  margin-bottom:12px;display:none;line-height:1.5;
}
.invite-ok.show{display:block;}
.invite-err{font-size:12px;color:var(--red);margin-bottom:10px;display:none;}
.invite-err.show{display:block;}

.auth-shell{position:fixed;inset:0;background:var(--slate);z-index:8000;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 28px max(env(safe-area-inset-bottom),24px);overflow-y:auto;}
.auth-shell::-webkit-scrollbar{display:none;}
.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:32px;}
.auth-logo-mark{width:44px;height:44px;background:var(--orange);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.auth-logo-mark svg{width:24px;height:24px;fill:white;}
.auth-logo-name{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:700;color:var(--text);letter-spacing:.04em;text-transform:uppercase;}
.auth-logo-tag{font-size:11px;color:var(--text3);margin-top:-2px;}
.auth-card{width:100%;max-width:380px;background:var(--slate3);border:1px solid var(--border2);border-radius:14px;overflow:hidden;}
.auth-panel{display:none;padding:24px;}
.auth-panel.active{display:block;}
.auth-title{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.03em;margin-bottom:4px;}
.auth-sub{font-size:13px;color:var(--text2);margin-bottom:20px;line-height:1.5;}
.auth-field{margin-bottom:13px;}
.auth-label{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text3);margin-bottom:6px;display:block;}
.auth-input{width:100%;background:var(--slate4);border:1px solid var(--border2);border-radius:8px;padding:12px 14px;font-size:14px;color:var(--text);font-family:'Barlow',sans-serif;outline:none;transition:border-color .15s;-webkit-appearance:none;}
.auth-input:focus{border-color:var(--orange);}
.auth-input::placeholder{color:var(--text3);}
.auth-input.err{border-color:var(--red);}
.auth-err{font-size:12px;color:var(--red);margin-top:5px;display:none;line-height:1.4;}
.auth-err.show{display:block;}
.auth-btn{width:100%;padding:14px;background:var(--orange);color:white;border:none;border-radius:8px;font-size:14px;font-weight:700;font-family:'Barlow',sans-serif;cursor:pointer;transition:opacity .15s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px;}
.auth-btn:hover{opacity:.88;}
.auth-btn:disabled{opacity:.4;cursor:default;}
.auth-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:white;border-radius:50%;animation:authSpin .65s linear infinite;}
@keyframes authSpin{to{transform:rotate(360deg)}}
.auth-divider{display:flex;align-items:center;gap:10px;margin:16px 0;}
.auth-divider-line{flex:1;height:1px;background:var(--border);}
.auth-divider-text{font-size:11px;color:var(--text3);}
.auth-ghost{background:transparent;border:1px solid var(--border2);color:var(--text2);}
.auth-ghost:hover{background:var(--slate4);opacity:1;}
.auth-footer{text-align:center;margin-top:16px;font-size:12px;color:var(--text3);line-height:1.7;}
.auth-footer button{color:var(--orange);cursor:pointer;background:none;border:none;font-size:12px;font-family:inherit;text-decoration:none;padding:0;}
.auth-footer button:hover{text-decoration:underline;}
.auth-ok{background:var(--green-pale);border:1px solid rgba(39,196,122,.3);border-radius:8px;padding:10px 13px;font-size:13px;color:var(--green);margin-bottom:13px;display:none;line-height:1.5;}
.auth-ok.show{display:block;}
.auth-2col{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.role-row{display:flex;gap:7px;flex-wrap:wrap;margin-top:6px;}
.role-chip{flex:1;min-width:68px;padding:9px 5px;border-radius:7px;border:1px solid var(--border2);background:var(--slate4);font-size:12px;font-weight:600;font-family:'Barlow',sans-serif;color:var(--text2);cursor:pointer;text-align:center;transition:all .15s;}
.role-chip.sel{background:var(--orange-pale);border-color:rgba(232,93,36,.4);color:var(--orange);}
.logout-btn{width:100%;padding:13px;border-radius:8px;border:1px solid var(--red-pale);background:var(--red-pale);color:var(--red);font-size:14px;font-weight:700;font-family:'Barlow',sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;}
.logout-btn:hover{opacity:.8;}
.status-av{width:22px;height:22px;border-radius:50%;background:var(--orange);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:white;flex-shrink:0;cursor:pointer;}

/* CANVAS SIGNATURE */
.sig-canvas-wrap{position:relative;border:1px dashed var(--border2);border-radius:var(--r-sm);overflow:hidden;background:var(--slate4);cursor:crosshair;}
.sig-canvas-wrap.has-sig{border-style:solid;border-color:var(--green);}
.sig-canvas-wrap canvas{display:block;touch-action:none;}
.sig-clear{position:absolute;top:6px;right:8px;font-size:11px;color:var(--text3);cursor:pointer;background:var(--slate3);border:1px solid var(--border);border-radius:4px;padding:2px 7px;font-family:'Barlow',sans-serif;font-weight:600;}
.sig-clear:hover{color:var(--red);border-color:var(--red);}
.sig-preview{width:100%;height:68px;border:1px solid var(--green);border-radius:var(--r-sm);background:var(--green-pale);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.sig-preview img{max-height:60px;max-width:100%;}

/* PHOTO DETAIL MODAL */
.photo-detail-img{width:100%;aspect-ratio:4/3;background:var(--slate4);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;margin-bottom:14px;}
.photo-detail-img svg{width:48px;height:48px;opacity:.15;}
.photo-detail-badge{position:absolute;top:10px;left:10px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:5px;}
.photo-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;}
.pm-cell{background:var(--slate4);border-radius:var(--r-sm);padding:9px 11px;}
.pm-cell-label{font-size:10px;color:var(--text3);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:3px;}
.pm-cell-val{font-size:12px;color:var(--text);font-family:'DM Mono',monospace;}

/* HISTORY */
.hist-item{display:flex;align-items:center;gap:11px;padding:11px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;}
.hist-item:last-child{border-bottom:none;}
.hist-item:active{background:var(--slate4);}
.hist-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.hist-icon svg{width:18px;height:18px;}
.hist-date{font-size:13px;font-weight:600;color:var(--text);}
.hist-meta{font-size:11px;color:var(--text2);margin-top:2px;}
.hist-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0;}
.hist-size{font-size:10px;color:var(--text3);font-family:'DM Mono',monospace;}

/* RFI */
.rfi-stream{font-size:12px;color:var(--text2);line-height:1.75;min-height:120px;padding:12px 13px;background:var(--slate3);border-radius:var(--r-sm);border:1px solid var(--border);white-space:pre-line;margin-bottom:11px;max-height:320px;overflow-y:auto;}

/* NCR / DEFECT */
.ncr-card{background:var(--slate3);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:10px;cursor:pointer;transition:border-color .15s;}
.ncr-card:hover{border-color:var(--border2);}
.ncr-card:active{background:var(--slate4);}
.ncr-head{padding:12px 14px;display:flex;align-items:flex-start;gap:10px;border-bottom:1px solid var(--border);}
.ncr-num{font-family:'DM Mono',monospace;font-size:11px;font-weight:500;color:var(--text3);min-width:72px;}
.ncr-title{font-size:13px;font-weight:600;color:var(--text);flex:1;line-height:1.35;}
.ncr-sev{font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;flex-shrink:0;}
.sev-crit{background:var(--red-pale);color:#f87171;}
.sev-major{background:var(--amber-pale);color:#fbbf24;}
.sev-minor{background:var(--blue-pale);color:#93c5fd;}
.sev-obs{background:var(--purple-pale);color:var(--purple);}
.ncr-body{padding:10px 14px;display:flex;flex-direction:column;gap:5px;}
.ncr-meta-row{display:flex;gap:12px;flex-wrap:wrap;}
.ncr-meta{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text3);}
.ncr-meta strong{color:var(--text2);font-weight:500;}
.ncr-desc{font-size:12px;color:var(--text2);line-height:1.5;margin-top:2px;}
.ncr-footer{padding:8px 14px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.ncr-status{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;}
.ns-open{background:var(--red-pale);color:#f87171;}
.ns-prog{background:var(--amber-pale);color:#fbbf24;}
.ns-closed{background:var(--green-pale);color:#4ade80;}
.ncr-due{font-family:'DM Mono',monospace;font-size:10px;color:var(--text3);}
.ncr-due.overdue{color:var(--red);}
.ncr-tabs{display:flex;gap:0;margin:12px 16px 0;background:var(--slate3);border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden;}
.ncr-tab{flex:1;padding:9px;font-size:12px;font-weight:600;font-family:'Barlow',sans-serif;background:none;border:none;color:var(--text3);cursor:pointer;transition:all .15s;border-right:1px solid var(--border);}
.ncr-tab:last-child{border-right:none;}
.ncr-tab.on{background:var(--orange);color:white;}
.ncr-stat-row{display:flex;gap:8px;margin:12px 16px 0;}
.ncr-stat{flex:1;background:var(--slate3);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px;text-align:center;}
.ncr-stat-n{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:700;color:var(--text);}
.ncr-stat-l{font-size:10px;color:var(--text2);margin-top:2px;}

/* NCR DETAIL */
.detail-row{display:flex;gap:0;margin-bottom:8px;}
.detail-lbl{font-size:11px;color:var(--text3);font-weight:500;min-width:90px;padding-top:2px;}
.detail-val{font-size:13px;color:var(--text);flex:1;line-height:1.45;}
.photo-strip{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;margin-top:4px;}
.photo-strip::-webkit-scrollbar{display:none;}
.ps-cell{width:72px;height:72px;border-radius:6px;background:var(--slate4);border:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.ps-cell svg{width:20px;height:20px;opacity:.2;}
.ps-add{border-style:dashed;cursor:pointer;transition:all .15s;}
.ps-add:hover{border-color:var(--orange);background:var(--orange-pale);}
.action-log{font-size:12px;color:var(--text2);background:var(--slate4);border-radius:var(--r-sm);padding:10px 12px;line-height:1.65;white-space:pre-line;}