@import "https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Mono:wght@400;500&display=swap";:root{--bg:#0a0a0f;--bg2:#111118;--bg3:#1a1a24;--border:#2a2a3a;--accent:#e8ff47;--accent2:#47c8ff;--text:#f0f0f8;--muted:#6a6a8a;--success:#47ffb8;--warning:#ffb847;--danger:#ff4766;--font-heading:"Syne", system-ui, sans-serif;--font-mono:"DM Mono", ui-monospace, Consolas, monospace;--font-body:"DM Mono", system-ui, sans-serif;font-family:var(--font-body);color:var(--text);background:var(--bg);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);min-height:100dvh}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;font-weight:700}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}a{color:var(--accent2);text-decoration:none}code,.mono{font-family:var(--font-mono)}.page{width:100%;max-width:1200px;margin:0 auto;padding:1.5rem}.loading-screen{min-height:100dvh;color:var(--muted);font-family:var(--font-mono);justify-content:center;align-items:center;display:flex}.shell{flex-direction:column;min-height:100dvh;display:flex;position:relative}.grain{pointer-events:none;z-index:999;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='0.15'/%3E%3C/svg%3E");background-repeat:repeat;position:fixed;inset:0}.shell-header{z-index:50;background:var(--bg);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);justify-content:space-between;align-items:center;padding:.75rem 1.25rem;display:flex;position:sticky;top:0}.shell-brand{align-items:center;gap:.625rem;display:flex}.shell-logo{mix-blend-mode:screen;width:auto;height:30px}.shell-title{font-family:var(--font-heading);color:var(--text);letter-spacing:-.02em;font-size:18px;font-weight:700}.shell-user{align-items:center;gap:.625rem;display:flex}.shell-role-badge{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;border-radius:20px;padding:.2rem .6rem;font-size:10px;font-weight:500}.badge-admin{color:var(--accent);background:#e8ff471f}.badge-inspector{color:var(--accent2);background:#47c8ff1f}.shell-avatar{background:var(--bg3);border:1px solid var(--border);width:32px;height:32px;font-family:var(--font-heading);color:var(--accent);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.shell-signout{color:var(--muted);cursor:pointer;background:0 0;border:none;align-items:center;padding:.25rem;transition:color .2s;display:flex}.shell-signout:hover{color:var(--danger)}.shell-nav{z-index:49;background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:53px}.shell-tabs{scrollbar-width:none;-ms-overflow-style:none;gap:0;padding:0 1.25rem;display:flex;overflow-x:auto}.shell-tabs::-webkit-scrollbar{display:none}.shell-tab{font-family:var(--font-mono);color:var(--muted);white-space:nowrap;border-bottom:2px solid #0000;padding:.75rem 1rem;font-size:12px;text-decoration:none;transition:color .2s,border-color .2s}.shell-tab:hover{color:var(--text)}.shell-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.shell-content{flex:1}.login-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100dvh;padding:1rem;display:flex}.login-card{background:var(--bg2);border:1px solid var(--border);border-radius:20px;flex-direction:column;align-items:center;gap:0;width:100%;max-width:380px;padding:2.5rem 2rem 2rem;display:flex;position:relative;overflow:hidden}.login-card:before{content:"";pointer-events:none;background:radial-gradient(circle,#e8ff4714 0%,#0000 70%);width:240px;height:240px;position:absolute;top:-60px;left:-60px}.login-logo{mix-blend-mode:screen;width:180px;height:auto;margin-bottom:1.25rem;position:relative}.login-title{font-family:var(--font-heading);color:var(--text);margin:0;font-size:28px;font-weight:700;line-height:1;position:relative}.login-subtitle{font-family:var(--font-mono);color:var(--muted);margin:.375rem 0 1.75rem;font-size:12px;position:relative}.login-error{width:100%;color:var(--danger);font-family:var(--font-mono);text-align:center;background:#ff47661a;border:1px solid #ff47664d;border-radius:10px;margin-bottom:1rem;padding:.625rem .75rem;font-size:12px;position:relative}.login-label{width:100%;font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;flex-direction:column;gap:.375rem;margin-bottom:1rem;font-size:11px;display:flex;position:relative}.login-label input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font-mono);border-radius:10px;outline:none;padding:.75rem 1rem;font-size:14px;transition:border-color .2s}.login-label input::placeholder{color:var(--muted);opacity:.6}.login-label input:focus{border-color:var(--accent)}.login-btn{background:var(--accent);color:#0a0a0f;width:100%;font-family:var(--font-heading);cursor:pointer;border:none;border-radius:10px;margin-top:.25rem;padding:.8rem;font-size:15px;font-weight:700;transition:opacity .2s;position:relative}.login-btn:hover{opacity:.9}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-demo{font-family:var(--font-mono);color:var(--muted);text-align:center;margin-top:1.5rem;font-size:11px;position:relative}.login-demo a{color:var(--accent2);text-underline-offset:2px;text-decoration:underline}.admin-page{width:100%;max-width:1200px;min-height:100dvh;margin:0 auto;padding:1.5rem}.admin-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.admin-header h1{margin:0;font-size:1.5rem}.admin-header .header-meta{font-family:var(--font-mono);color:var(--muted);font-size:13px}.btn{font-family:var(--font-heading);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:13px;font-weight:600;transition:opacity .2s;display:inline-flex}.btn:hover{opacity:.85}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-accent{background:var(--accent);color:#0a0a0f}.btn-secondary{background:var(--bg3);color:var(--text);border:1px solid var(--border)}.btn-danger{color:var(--danger);background:#ff476626;border:1px solid #ff47664d}.btn-back{color:var(--accent2);font-family:var(--font-mono);cursor:pointer;background:0 0;border:none;align-items:center;gap:.25rem;margin-bottom:1rem;padding:0;font-size:13px;display:inline-flex}.btn-back:hover{text-decoration:underline}.card{background:var(--bg2);border:1px solid var(--border);cursor:pointer;border-radius:12px;padding:1rem 1.125rem;transition:border-color .2s,background .2s;position:relative}.card:hover{border-color:var(--accent);background:var(--bg3)}.card-title{font-family:var(--font-heading);color:var(--text);margin-bottom:.25rem;font-size:15px;font-weight:600}.card-meta{font-family:var(--font-mono);color:var(--muted);font-size:11px}.chip{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em;border-radius:20px;align-items:center;gap:.25rem;padding:.2rem .6rem;font-size:10px;font-weight:500;display:inline-flex}.chip-pending{color:var(--accent);background:#e8ff471f}.chip-assigned{color:var(--accent2);background:#47c8ff1f}.chip-complete{color:var(--success);background:#47ffb81f}.chip-urgent{color:var(--danger);background:#ff47661f}.chip-low{color:var(--muted);background:#6a6a8a26}.chip-active{color:var(--success);background:#47ffb81f}.chip-inactive{color:var(--muted);background:#6a6a8a26}.chips-row{flex-wrap:wrap;gap:.375rem;margin-top:.5rem;display:flex}.status-dot{border-radius:50%;width:8px;height:8px;position:absolute;top:1rem;right:1rem}.status-dot.urgent{background:var(--danger);box-shadow:0 0 8px var(--danger)}.status-dot.complete{background:var(--success);box-shadow:0 0 8px var(--success)}.status-dot.pending{background:var(--accent);box-shadow:0 0 8px #e8ff4780}.status-dot.assigned{background:var(--accent2);box-shadow:0 0 6px #47c8ff80}.city-divider{align-items:center;gap:.75rem;margin:1.5rem 0 .75rem;display:flex}.city-divider:first-of-type{margin-top:0}.city-name{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.15em;color:var(--accent);white-space:nowrap;font-size:11px;font-weight:500}.city-line{background:var(--border);flex:1;height:1px}.city-count{font-family:var(--font-mono);color:var(--muted);white-space:nowrap;font-size:11px}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:.75rem;display:grid}.form-group{flex-direction:column;gap:.375rem;margin-bottom:1rem;display:flex}.form-label{font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px}.form-input,.form-select,.form-textarea{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font-mono);border-radius:10px;outline:none;padding:.65rem .875rem;font-size:13px;transition:border-color .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236a6a8a' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2rem}.form-textarea{resize:vertical;min-height:80px}.form-actions{gap:.75rem;margin-top:.5rem;display:flex}.form-actions .btn{flex:1;justify-content:center}.modal-overlay{z-index:100;background:#0009;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--bg2);border:1px solid var(--border);border-radius:20px 20px 0 0;width:100%;max-width:480px;max-height:85dvh;padding:1.5rem;animation:.25s slideUp;overflow-y:auto}.modal-sheet h2{margin-bottom:1.25rem;font-size:1.125rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.skeleton{background:var(--bg3);border-radius:10px;animation:1.5s ease-in-out infinite pulse}.skeleton-card{height:100px;margin-bottom:.75rem}.skeleton-line{width:60%;height:14px;margin-bottom:.5rem}.skeleton-line.short{width:35%}@keyframes pulse{0%,to{opacity:.4}50%{opacity:.8}}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:1.125rem}.stat-value{font-family:var(--font-heading);color:var(--text);font-size:2rem;font-weight:700;line-height:1}.stat-label{font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:.375rem;font-size:11px}.section-heading{font-family:var(--font-heading);color:var(--text);margin-bottom:.75rem;font-size:1rem;font-weight:600}.detail-section{background:var(--bg2);border:1px solid var(--border);border-radius:12px;margin-bottom:1rem;padding:1.125rem}.detail-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.detail-row:last-child{border-bottom:none}.detail-key{font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px}.detail-value{font-family:var(--font-mono);color:var(--text);font-size:13px}.toast-container{z-index:200;pointer-events:none;flex-direction:column;gap:.5rem;display:flex;position:fixed;top:1rem;left:50%;transform:translate(-50%)}.toast{background:var(--bg2);border:1px solid var(--accent2);font-family:var(--font-mono);color:var(--text);border-radius:12px;max-width:420px;padding:.75rem 1.125rem;font-size:12px;animation:.3s toastIn,.3s 3.7s forwards toastOut;box-shadow:0 4px 20px #0006}@keyframes toastIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0;transform:translateY(-12px)}}.stars{color:var(--accent);gap:2px;font-size:14px;display:inline-flex}.stars .empty{color:var(--border)}.avatar{background:var(--bg3);border:1px solid var(--border);width:36px;height:36px;font-family:var(--font-heading);color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.list-item{background:var(--bg2);border:1px solid var(--border);cursor:pointer;border-radius:12px;align-items:center;gap:.875rem;margin-bottom:.5rem;padding:.875rem 1rem;transition:border-color .2s;display:flex}.list-item:hover{border-color:var(--accent)}.list-item-body{flex:1;min-width:0}.list-item-title{font-family:var(--font-heading);color:var(--text);font-size:14px;font-weight:600}.list-item-meta{font-family:var(--font-mono);color:var(--muted);margin-top:2px;font-size:11px}.empty-state{text-align:center;color:var(--muted);font-family:var(--font-mono);padding:3rem 1rem;font-size:13px}.tab-row{border-bottom:1px solid var(--border);gap:0;margin-bottom:1.25rem;display:flex}.tab-btn{font-family:var(--font-mono);color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:.625rem 1rem;font-size:12px;transition:color .2s,border-color .2s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.photo-gallery{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem;margin-bottom:1rem;display:grid}.photo-gallery-item{aspect-ratio:4/3;border:1px solid var(--border);cursor:pointer;border-radius:10px;transition:border-color .2s;position:relative;overflow:hidden}.photo-gallery-item:hover{border-color:var(--accent)}.photo-gallery-item img{object-fit:cover;width:100%;height:100%}.photo-gallery-label{font-family:var(--font-mono);color:var(--text);text-transform:uppercase;letter-spacing:.06em;background:#000000b3;padding:.25rem .5rem;font-size:9px;position:absolute;bottom:0;left:0;right:0}.photo-viewer-overlay{z-index:300;cursor:pointer;background:#000000f2;flex-direction:column;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.photo-viewer-close{width:36px;height:36px;color:var(--text);cursor:pointer;z-index:1;background:#00000080;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;font-size:16px;display:flex;position:absolute;top:1rem;right:1rem}.photo-viewer-img{object-fit:contain;cursor:default;border-radius:4px;max-width:90vw;max-height:75vh}.photo-viewer-bar{cursor:default;align-items:center;gap:1rem;margin-top:1rem;display:flex}.photo-viewer-label{font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:12px}.im-overlay{align-items:flex-end}.im-sheet{border-radius:20px 20px 0 0;max-height:92dvh;padding-bottom:2rem}.im-handle{background:var(--border);border-radius:2px;width:36px;height:4px;margin:0 auto 1rem}.im-title{margin-bottom:.5rem;font-size:1.125rem}.im-gps{margin-bottom:.75rem}.im-divider{background:var(--border);height:1px;margin:1rem 0}.im-section-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.im-label-row{flex-wrap:wrap;gap:.375rem;margin-bottom:.75rem;display:flex}.im-label-pill{border:1px solid var(--border);color:var(--muted);font-family:var(--font-mono);cursor:pointer;background:0 0;border-radius:20px;padding:.25rem .65rem;font-size:11px;transition:all .2s}.im-label-pill.active{background:var(--accent);color:#0a0a0f;border-color:var(--accent)}.im-photo-grid{grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.im-photo-thumb{aspect-ratio:1;cursor:pointer;border:1px solid var(--border);border-radius:10px;position:relative;overflow:hidden}.im-photo-thumb img{object-fit:cover;width:100%;height:100%}.im-photo-label{font-family:var(--font-mono);color:var(--text);text-transform:uppercase;letter-spacing:.06em;background:#000000b3;padding:.25rem .5rem;font-size:9px;position:absolute;bottom:0;left:0;right:0}.im-photo-add{aspect-ratio:1;border:2px dashed var(--border);cursor:pointer;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;transition:border-color .2s;display:flex}.im-photo-add:hover{border-color:var(--accent)}.im-photo-add-icon{color:var(--muted);font-size:1.5rem;line-height:1}.im-photo-add-text{font-family:var(--font-mono);color:var(--muted);font-size:10px}.im-notes-header{justify-content:space-between;align-items:center;margin-bottom:.375rem;display:flex}.im-voice-btn{border:1px solid var(--border);color:var(--muted);font-family:var(--font-mono);cursor:pointer;background:0 0;border-radius:20px;padding:.2rem .6rem;font-size:11px;transition:all .2s}.im-voice-btn.active{border-color:var(--danger);color:var(--danger);background:#ff476626;animation:1s ease-in-out infinite voicePulse}@keyframes voicePulse{0%,to{opacity:1}50%{opacity:.6}}.im-issues-grid{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.im-issue-check{font-family:var(--font-mono);color:var(--text);cursor:pointer;align-items:center;gap:.5rem;font-size:12px;display:flex}.im-issue-check input[type=checkbox]{appearance:none;border:1px solid var(--border);background:var(--bg);cursor:pointer;border-radius:4px;flex-shrink:0;width:18px;height:18px;position:relative}.im-issue-check input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.im-issue-check input[type=checkbox]:checked:after{content:"✓";color:#0a0a0f;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex;position:absolute;inset:0}.im-error{color:var(--danger);font-family:var(--font-mono);text-align:center;background:#ff47661a;border:1px solid #ff47664d;border-radius:10px;margin-bottom:.75rem;padding:.5rem .75rem;font-size:12px}.im-progress-track{background:var(--bg3);border-radius:3px;height:6px;margin-bottom:.5rem;overflow:hidden}.im-progress-bar{background:var(--accent);border-radius:3px;height:100%;transition:width .3s}.im-fullscreen{z-index:300;cursor:pointer;background:#000000f2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.im-fullscreen img{object-fit:contain;border-radius:4px;max-width:95vw;max-height:90vh}.im-fullscreen-label{font-family:var(--font-mono);color:var(--text);text-transform:uppercase;letter-spacing:.08em;background:#000000b3;border-radius:20px;padding:.375rem 1rem;font-size:12px;position:absolute;bottom:2rem;left:50%;transform:translate(-50%)}.im-fullscreen-close{width:36px;height:36px;color:var(--text);cursor:pointer;background:#00000080;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;font-size:16px;display:flex;position:absolute;top:1rem;right:1rem}.gps-badge{background:var(--bg2);border:1px solid var(--border);font-family:var(--font-mono);color:var(--accent2);border-radius:20px;align-items:center;gap:.5rem;padding:.375rem .875rem;font-size:11px;display:inline-flex}.gps-dot{background:var(--success);width:8px;height:8px;box-shadow:0 0 6px var(--success);border-radius:50%;animation:2s ease-in-out infinite gpsPulse}@keyframes gpsPulse{0%,to{opacity:1;box-shadow:0 0 6px var(--success)}50%{opacity:.5;box-shadow:0 0 12px var(--success)}}.gps-coords{color:var(--muted)}.insp-cards{flex-direction:column;gap:.625rem;display:flex}.insp-card{background:var(--bg2);border:1px solid var(--border);cursor:pointer;border-radius:12px;padding:1rem 1.125rem;transition:border-color .2s,background .2s}.insp-card:hover{border-color:var(--accent);background:var(--bg3)}.insp-card-urgent{border-color:#ff476659}.insp-card-urgent:hover{border-color:var(--danger)}.insp-card-header{align-items:flex-start;gap:.875rem;display:flex}.insp-badge{background:var(--bg3);border:1px solid var(--border);width:32px;height:32px;font-family:var(--font-mono);color:var(--accent);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:500;display:flex}.insp-card-body{flex:1;min-width:0}.insp-priority-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--danger);vertical-align:middle;background:#ff47661f;border-radius:4px;margin-left:.5rem;padding:.125rem .4rem;font-size:9px;font-weight:500;display:inline-block}.insp-notes{font-family:var(--font-mono);color:var(--accent2);margin-top:.375rem;font-size:12px;line-height:1.4}.insp-card-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.625rem;display:flex}.insp-status{font-family:var(--font-mono);color:var(--muted);font-size:11px}.insp-tap-link{font-family:var(--font-mono);color:var(--accent);white-space:nowrap;font-size:11px}.proximity-modal{text-align:center;padding-top:2rem}.proximity-icon{margin-bottom:.75rem;font-size:2.5rem}.proximity-text{font-family:var(--font-mono);color:var(--muted);margin:.75rem 0 1.5rem;font-size:13px;line-height:1.5}.proximity-text strong{color:var(--danger)}.proximity-checking{font-family:var(--font-mono);color:var(--muted);background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:1rem 1.5rem;font-size:13px}
