:root,:root[data-theme=dark]{--bg: #0b1220;--bg-elev: #0f172a;--surface: #1a2433;--surface-2: #243044;--surface-3: #2d3a52;--text: #f1f5f9;--text-dim: #94a3b8;--text-mute: #64748b;--border: #1f2a3d;--border-strong: #334155;--accent: #6366f1;--accent-soft: rgba(99, 102, 241, .16);--accent-text: #a5b4fc;--success: #22c55e;--success-soft: rgba(34, 197, 94, .16);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .16);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .16);--shadow-card: 0 1px 2px rgba(0,0,0,.4);--shadow-pop: 0 10px 30px rgba(0,0,0,.5);--tint-overlay: rgba(255,255,255,.04);color-scheme:dark}:root[data-theme=light]{--bg: #f7f8fa;--bg-elev: #ffffff;--surface: #ffffff;--surface-2: #f1f5f9;--surface-3: #e2e8f0;--text: #0f172a;--text-dim: #475569;--text-mute: #94a3b8;--border: #e5e7eb;--border-strong: #cbd5e1;--accent: #4f46e5;--accent-soft: rgba(79, 70, 229, .1);--accent-text: #4338ca;--success: #15803d;--success-soft: rgba(34, 197, 94, .13);--warning: #b45309;--warning-soft: rgba(245, 158, 11, .14);--danger: #b91c1c;--danger-soft: rgba(239, 68, 68, .1);--shadow-card: 0 1px 2px rgba(15, 23, 42, .06), 0 1px 3px rgba(15, 23, 42, .04);--shadow-pop: 0 12px 32px rgba(15, 23, 42, .12);--tint-overlay: rgba(15, 23, 42, .03);color-scheme:light}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Inter,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overscroll-behavior-y:none}button{font-family:inherit}a{color:var(--accent-text);text-decoration:none}input,select,textarea{color-scheme:inherit}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;background:var(--bg)}.header{padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0px));background:var(--bg-elev);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;position:sticky;top:0;z-index:10;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px)}.header h1{margin:0;font-size:17px;font-weight:600;letter-spacing:-.01em}.header .user{font-size:12px;color:var(--text-dim)}.main{flex:1;overflow-y:auto;padding:14px 16px 24px;-webkit-overflow-scrolling:touch;scroll-padding-bottom:100px}.tabs{display:flex;background:var(--bg-elev);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom,0px);flex-shrink:0;position:sticky;bottom:0;z-index:10;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px)}.tab{flex:1;padding:8px 4px 6px;text-align:center;color:var(--text-mute);font-size:10.5px;font-weight:500;text-decoration:none;display:flex;flex-direction:column;align-items:center;gap:3px;border:none;background:none;cursor:pointer;min-height:56px;transition:color .15s ease;position:relative}.tab svg{width:24px;height:24px;transition:transform .15s ease}.tab.active{color:var(--accent)}.tab.active svg{transform:scale(1.08)}.tab.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:3px;background:var(--accent);border-radius:0 0 3px 3px}.tab:active{background:var(--tint-overlay)}.card{display:block;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 16px;margin-bottom:10px;color:inherit;text-decoration:none;box-shadow:var(--shadow-card);transition:transform .12s ease,background .12s ease}.card h3{margin:0 0 6px;font-size:15px;font-weight:600;letter-spacing:-.005em}.card .meta{font-size:12.5px;color:var(--text-dim)}.card-link:active{background:var(--surface-2);transform:scale(.99)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:8px}.card-body{font-size:14px;margin-bottom:4px;color:var(--text)}.prewrap{white-space:pre-wrap;font-size:14px}.list-group{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:18px;box-shadow:var(--shadow-card)}.list-group-label{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-mute);margin:6px 16px}.list-row{display:flex;align-items:center;gap:12px;padding:14px 16px;border-top:1px solid var(--border);color:var(--text);background:none;border-left:none;border-right:none;border-bottom:none;width:100%;text-align:left;font:inherit;cursor:pointer}.list-row:first-child{border-top:none}.list-row:active{background:var(--surface-2)}.list-row-icon{width:32px;height:32px;display:grid;place-items:center;border-radius:8px;background:var(--accent-soft);color:var(--accent-text);flex-shrink:0}.list-row-icon svg{width:18px;height:18px}.list-row-main{flex:1;min-width:0}.list-row-title{font-size:15px;font-weight:500}.list-row-sub{font-size:12.5px;color:var(--text-dim);margin-top:2px}.list-row-right{font-size:14px;color:var(--text-dim)}.segmented{display:inline-flex;background:var(--surface-2);border-radius:9px;padding:2px;gap:2px}.segmented-option{border:none;background:transparent;padding:6px 12px;border-radius:7px;font-size:13px;font-weight:500;color:var(--text-dim);cursor:pointer;transition:background .12s ease,color .12s ease}.segmented-option.active{background:var(--surface);color:var(--text);box-shadow:0 1px 2px #00000014}.field{margin-bottom:14px}.field label{display:block;font-size:12px;color:var(--text-dim);margin-bottom:6px;font-weight:500}.field input,.field select,.field textarea{width:100%;padding:13px 14px;background:var(--surface);border:1px solid var(--border-strong);border-radius:10px;color:var(--text);font-size:16px;font-family:inherit;transition:border-color .12s ease,box-shadow .12s ease}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.phone-input{display:flex;align-items:stretch;background:var(--surface);border:1px solid var(--border-strong);border-radius:10px;overflow:hidden;transition:border-color .12s ease,box-shadow .12s ease}.phone-input:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.phone-input-prefix{display:flex;align-items:center;padding:0 12px;background:var(--surface-2, #f1f5f9);border-right:1px solid var(--border-strong);color:var(--text-muted);font-size:16px;font-weight:500;-webkit-user-select:none;user-select:none}.phone-input input{flex:1;min-width:0;padding:13px 14px;font-size:16px;font-family:ui-monospace,SFMono-Regular,monospace;background:transparent;border:none;outline:none;color:var(--text)}.btn{display:block;width:100%;padding:14px 16px;border-radius:12px;border:none;background:var(--accent);color:#fff;font-size:16px;font-weight:600;letter-spacing:-.005em;cursor:pointer;text-decoration:none;text-align:center;min-height:48px;transition:transform .12s ease,opacity .12s ease,background .12s ease}.btn:active{transform:scale(.98);opacity:.92}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-secondary{background:var(--surface-2);color:var(--text)}.btn-secondary:active{background:var(--surface-3)}.btn-danger{background:var(--danger)}.btn-ghost{background:transparent;color:var(--accent-text);border:1px solid var(--border-strong)}.back{margin-bottom:14px}.btn-pill{background:var(--accent);color:#fff;border:none;border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer;min-height:32px}.btn-pill:active{opacity:.85}.badge{display:inline-block;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;text-transform:capitalize;letter-spacing:.01em}.badge-open{background:var(--warning-soft);color:var(--warning)}.badge-progress{background:var(--accent-soft);color:var(--accent-text)}.badge-resolved{background:var(--success-soft);color:var(--success)}.badge-urgent{background:var(--danger-soft);color:var(--danger)}.banner{padding:11px 14px;margin-bottom:12px;border-radius:10px;font-size:13px;display:flex;align-items:center;gap:10px}.banner-error{background:var(--danger-soft);color:var(--danger)}.banner-success{background:var(--success-soft);color:var(--success)}.banner-offline{background:var(--warning-soft);color:var(--warning)}.ticket-flash{position:sticky;top:8px;z-index:20;box-shadow:0 6px 16px #0f172a24;font-weight:500;border-left:4px solid currentColor}.ticket-flash.banner-error{background:#fef2f2}.ticket-flash.banner-success{background:#ecfdf5}.ticket-flash.banner-offline{background:#fffbeb}@media (prefers-color-scheme: dark){.ticket-flash.banner-error{background:#2a1414}.ticket-flash.banner-success{background:#0f2a1c}.ticket-flash.banner-offline{background:#2a200d}}.login{flex:1;display:flex;flex-direction:column;justify-content:center;padding:24px;min-height:100vh;min-height:100dvh;max-width:380px;margin:0 auto;width:100%}.login-brand{text-align:center;margin-bottom:28px}.login-brand-logo{width:64px;height:64px;margin:0 auto 16px;border-radius:16px;background:var(--accent);display:grid;place-items:center;color:#fff;box-shadow:0 10px 30px var(--accent-soft)}.login-brand-logo svg{width:32px;height:32px}.login h1{text-align:center;margin:0 0 6px;font-size:24px;font-weight:700;letter-spacing:-.02em}.login .subtitle{text-align:center;color:var(--text-dim);font-size:14px;margin-bottom:24px}.empty{text-align:center;padding:56px 24px 24px;color:var(--text-dim);font-size:14px}.empty-icon{width:56px;height:56px;margin:0 auto 12px;border-radius:14px;background:var(--surface);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-mute)}.empty-icon svg{width:24px;height:24px}.empty-title{color:var(--text);font-weight:600;font-size:15px;margin-bottom:4px}.empty-hint{font-size:13px;max-width:280px;margin:0 auto}.skeleton{background:linear-gradient(90deg,var(--surface) 0%,var(--surface-2) 50%,var(--surface) 100%);background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:8px}.skeleton-card{height:84px;margin-bottom:10px;border-radius:14px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.toast-host{position:fixed;top:calc(env(safe-area-inset-top,0px) + 12px);left:12px;right:12px;z-index:100;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{pointer-events:auto;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:12px;padding:12px 14px;color:var(--text);text-decoration:none;box-shadow:var(--shadow-pop);animation:slideDown .22s cubic-bezier(.16,1,.3,1);display:block}.toast-title{font-weight:600;font-size:14px}.toast-body{font-size:13px;color:var(--text-dim);margin-top:2px}.toast-info{border-left-color:var(--accent)}.toast-success{border-left-color:var(--success)}.toast-warn{border-left-color:var(--warning)}.toast-error{border-left-color:var(--danger)}@keyframes slideDown{0%{transform:translateY(-12px);opacity:0}to{transform:none;opacity:1}}.map-view{display:flex;flex-direction:column;height:100%}.leaflet-container{flex:1;min-height:320px;border-radius:12px;background:var(--surface)}.camera{position:fixed;top:0;right:0;bottom:0;left:0;height:100vh;height:100dvh;background:#000;display:flex;flex-direction:column;z-index:50}.camera-video{flex:1 1 auto;min-height:0;width:100%;object-fit:cover;background:#000}.camera-controls{flex-shrink:0;display:flex;gap:10px;padding:14px 16px;padding-bottom:calc(14px + env(safe-area-inset-bottom,0px));background:#000000d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.camera-controls .btn{margin:0}.camera-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:#fff;font-weight:600;font-size:15px;z-index:1;pointer-events:none}.camera-overlay-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:camera-overlay-spin .8s linear infinite}.camera-overlay-label{letter-spacing:.02em}@keyframes camera-overlay-spin{to{transform:rotate(360deg)}}.thumb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:8px}.thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;display:block}.thumb-cell{position:relative}.thumb-delete{position:absolute;top:4px;right:4px;width:24px;height:24px;padding:0;line-height:1;border:none;border-radius:50%;background:#0009;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.thumb-delete:disabled{opacity:.4}.qr-hint{position:absolute;top:12%;left:0;right:0;text-align:center;color:#fff;font-size:14px;padding:8px 16px;background:#0000008c}.csat-stars{color:var(--warning);font-size:16px;letter-spacing:2px}.critical-pill{display:inline-block;padding:2px 8px;background:var(--danger);color:#fff;border-radius:999px;font-size:11px;font-weight:700;margin-left:8px}.punch-row{display:flex;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid var(--border)}.punch-row:last-child{border-bottom:none}.punch-thumb{width:40px;height:40px;object-fit:cover;border-radius:8px;margin-left:auto}
