@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@500;600;700&display=swap";
:root{--bg-base:#0a0d14;--bg-surface:#111827;--bg-elevated:#1a2236;--bg-card:#1e2d45;--border:#243048;--border-light:#2e3d58;--brand:#3b82f6;--brand-light:#60a5fa;--brand-dark:#1d4ed8;--brand-glow:#3b82f626;--accent:#06b6d4;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--danger-soft:#ef44441f;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#4b6080;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-brand:0 0 24px #3b82f633;--nav-width:240px;--header-h:60px;--transition:.15s cubic-bezier(.4,0,.2,1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scrollbar-width:thin;scrollbar-color:var(--border-light)transparent;height:100%}body{background:var(--bg-base);height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;line-height:1.6}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:0 0;border-radius:99px}:hover::-webkit-scrollbar-thumb{background:var(--border-light)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::-webkit-scrollbar-corner{background:0 0}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit}.app-shell{min-height:100vh;display:flex}.main-content{margin-left:var(--nav-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.page-content{flex:1;width:100%;max-width:1400px;padding:28px 32px}.sidebar{width:var(--nav-width);background:var(--bg-surface);border-right:1px solid var(--border);z-index:100;scrollbar-width:thin;scrollbar-color:transparent transparent;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar:hover{scrollbar-color:var(--border-light)transparent}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:0 0}.sidebar::-webkit-scrollbar-thumb{background:0 0;border-radius:99px;transition:background .2s}.sidebar:hover::-webkit-scrollbar-thumb{background:var(--border-light)}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.sidebar-logo{border-bottom:1px solid var(--border);padding:24px 20px 20px}.sidebar-logo h1{background:linear-gradient(135deg,var(--brand-light),var(--accent));-webkit-text-fill-color:transparent;letter-spacing:-.3px;-webkit-background-clip:text;background-clip:text;font-family:Space Grotesk,sans-serif;font-size:20px;font-weight:700}.sidebar-logo p{color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;margin-top:2px;font-size:11px}.nav-section{padding:16px 12px 8px}.nav-section-label{color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px;padding:0 8px;font-size:10px;font-weight:600}.nav-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition);align-items:center;gap:10px;margin-bottom:2px;padding:9px 12px;font-size:14px;font-weight:500;display:flex}.nav-link:hover{background:var(--bg-elevated);color:var(--text-primary)}.nav-link.active{background:var(--brand-glow);color:var(--brand-light);border:1px solid #3b82f633}.nav-link svg{opacity:.8;flex-shrink:0;width:17px;height:17px}.nav-link.active svg{opacity:1}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding:16px 12px}.user-badge{border-radius:var(--radius-md);background:var(--bg-elevated);align-items:center;gap:10px;padding:10px 12px;display:flex}.user-avatar{background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.user-info{min-width:0}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-role{color:var(--text-muted);text-transform:capitalize;font-size:11px}.page-header{margin-bottom:28px}.page-header h2{letter-spacing:-.5px;color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:26px;font-weight:700}.page-header p{color:var(--text-secondary);margin-top:4px;font-size:14px}.page-header-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.card-sm{padding:16px}.card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px;font-size:13px;font-weight:600}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px;display:grid}.kpi-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition),transform var(--transition);padding:20px;position:relative;overflow:hidden}.kpi-card:hover{border-color:var(--border-light);transform:translateY(-1px)}.kpi-card:before{content:"";background:var(--kpi-color,var(--brand));height:2px;position:absolute;top:0;left:0;right:0}.kpi-icon{border-radius:var(--radius-md);background:color-mix(in srgb,var(--kpi-color,var(--brand))15%,transparent);width:36px;height:36px;color:var(--kpi-color,var(--brand));justify-content:center;align-items:center;margin-bottom:12px;display:flex}.kpi-label{color:var(--text-muted);letter-spacing:.3px;margin-bottom:4px;font-size:12px;font-weight:500}.kpi-value{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:24px;font-weight:700;line-height:1.1}.kpi-sub{color:var(--text-muted);margin-top:4px;font-size:12px}.kpi-trend{margin-top:6px;font-size:12px;font-weight:600}.kpi-trend.up{color:var(--success)}.kpi-trend.down{color:var(--danger)}.btn{border-radius:var(--radius-md);transition:all var(--transition);white-space:nowrap;align-items:center;gap:7px;padding:9px 18px;font-size:14px;font-weight:600;display:inline-flex}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-dark);box-shadow:var(--shadow-brand)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-light);background:var(--bg-card)}.btn-ghost{color:var(--text-secondary)}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-elevated)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{opacity:.85}.btn-sm{padding:6px 12px;font-size:12px}.btn-lg{padding:12px 24px;font-size:15px}.badge{letter-spacing:.3px;border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-blue{color:#60a5fa;background:#3b82f626}.badge-green{color:#34d399;background:#10b98126}.badge-yellow{color:#fbbf24;background:#f59e0b26}.badge-red{color:#f87171;background:#ef444426}.badge-gray{color:#94a3b8;background:#94a3b81a}.badge-cyan{color:#22d3ee;background:#06b6d426}.table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--border);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13.5px}thead{background:var(--bg-elevated);border-bottom:1px solid var(--border)}th{text-align:left;color:var(--text-muted);letter-spacing:.6px;text-transform:uppercase;white-space:nowrap;padding:12px 16px;font-size:11px;font-weight:600}td{border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle;padding:12px 16px}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background var(--transition)}tbody tr:hover{background:var(--bg-elevated)}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:border-color var(--transition),box-shadow var(--transition);outline:none;padding:10px 14px;font-size:14px}.form-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #3b82f61f}.form-input::placeholder{color:var(--text-muted)}.form-input-error{border-color:var(--danger)}select.form-input{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='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-error{color:var(--danger);margin-top:4px;font-size:12px}.form-hint{color:var(--text-muted);margin-top:4px;font-size:12px}.form-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000000b3;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;padding:28px;animation:.2s cubic-bezier(.34,1.56,.64,1) slideUp;overflow-y:auto}.modal-lg{max-width:760px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-title{font-family:Space Grotesk,sans-serif;font-size:20px;font-weight:700}.modal-close{border-radius:var(--radius-md);background:var(--bg-elevated);width:32px;height:32px;color:var(--text-secondary);transition:all var(--transition);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-card);color:var(--text-primary)}.alert{border-radius:var(--radius-md);border-left:3px solid;align-items:flex-start;gap:12px;margin-bottom:12px;padding:14px 16px;font-size:13.5px;display:flex}.alert-warning{border-color:var(--warning);color:#fbbf24;background:#f59e0b14}.alert-danger{background:var(--danger-soft);border-color:var(--danger);color:#f87171}.alert-success{border-color:var(--success);color:#34d399;background:#10b98114}.alert-info{background:var(--brand-glow);border-color:var(--brand);color:var(--brand-light)}.tabs{background:var(--bg-elevated);border-radius:var(--radius-lg);gap:4px;width:fit-content;margin-bottom:24px;padding:4px;display:flex}.tab{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition);padding:8px 20px;font-size:13.5px;font-weight:500}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--bg-surface);color:var(--text-primary);box-shadow:var(--shadow-sm)}.filter-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.search-box{flex:1;min-width:200px;max-width:360px;position:relative}.search-box svg{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-box input{padding-left:38px}.spinner{border:2px solid var(--border);border-top-color:var(--brand);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.loading-state{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 20px;display:flex}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty-state svg{opacity:.3}input[type=range]{appearance:none;background:var(--border);border-radius:99px;outline:none;width:100%;height:4px}input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--brand);cursor:pointer;width:16px;height:16px;transition:transform var(--transition);border-radius:50%}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton{background:linear-gradient(90deg,var(--bg-elevated)25%,var(--bg-card)50%,var(--bg-elevated)75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200%}to{background-position:-200%}}.mobile-header,.mobile-bottom-nav,.mobile-drawer,.mobile-drawer-backdrop,.page-fab{display:none}@media (max-width:768px){:root{--nav-width:0px;--mobile-header-h:60px;--mobile-bottom-h:72px}.sidebar{display:none}.mobile-header,.mobile-bottom-nav,.mobile-drawer,.mobile-drawer-backdrop{display:flex}.main-content{padding-top:var(--mobile-header-h);padding-bottom:var(--mobile-bottom-h);margin-left:0}.page-content{max-width:100%;padding:14px 16px}.page-header{margin-bottom:16px}.page-header h2{letter-spacing:-.3px;font-size:20px}.page-header p{margin-top:2px;font-size:13px}.page-header-row{flex-flow:wrap;justify-content:space-between;align-items:center;gap:10px}.page-header-row>div:first-child{flex:1;min-width:0}.page-header-row>.btn,.page-header-row>div:last-child .btn{flex-shrink:0;padding:8px 14px;font-size:13px}button,.btn,a.btn{min-height:40px}.btn-sm{min-height:34px;padding:6px 12px}input,select,textarea{font-size:16px!important}.form-input{padding:11px 14px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.kpi-card{padding:14px}.kpi-value{font-size:20px}.kpi-label{font-size:10.5px}.card{padding:14px 16px}.tabs{scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;gap:4px;width:100%;padding:4px;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{scroll-snap-align:start;white-space:nowrap;flex-shrink:0;padding:7px 14px;font-size:13px}.filter-bar{scrollbar-width:none;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:8px;padding-bottom:2px;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.filter-bar .btn{white-space:nowrap;scroll-snap-align:start;flex-shrink:0}.search-box{flex:1 0;min-width:160px;max-width:100%}.form-grid{grid-template-columns:1fr}.form-group{margin-bottom:14px}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:var(--radius-xl)var(--radius-xl)0 0;max-height:92vh;padding:20px 18px;padding-bottom:max(20px,env(safe-area-inset-bottom,20px));background-image:linear-gradient(#0000 0% 16px,#0000 16px);animation:.26s cubic-bezier(.34,1.2,.64,1) slideUpSheet}.modal:before{content:"";background:var(--border-light);border-radius:99px;width:36px;height:4px;margin:-8px auto 16px;display:block}.modal-lg{max-width:100%}.modal-header{margin-bottom:18px}.modal-title{font-size:17px}.table-wrapper{border:none;border-radius:0;overflow-x:visible}table{display:block}thead{display:none}tbody{flex-direction:column;gap:10px;display:flex}tbody tr{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition);flex-direction:column;gap:6px;padding:14px;display:flex}tbody tr:hover{background:var(--bg-surface);border-color:var(--border-light)}tbody tr:last-child td{border-bottom:none}td{color:var(--text-primary);border:none;align-items:flex-start;gap:8px;min-height:0;padding:3px 0;font-size:13.5px;line-height:1.5;display:flex}td[data-label]:before{content:attr(data-label);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0;min-width:80px;padding-top:2px;font-size:10.5px;font-weight:600}td:not([data-label]){border-top:1px solid var(--border);justify-content:flex-end;margin-top:4px;padding-top:8px}td:first-child{border-bottom:1px solid var(--border);margin-bottom:2px;padding-bottom:6px;font-size:14.5px;font-weight:600}td:first-child:before,td>svg:only-child{display:none}tfoot{border-radius:var(--radius-lg);border:1px solid var(--border);margin-top:10px;display:block;overflow:hidden}tfoot tr{background:var(--bg-elevated);gap:0;padding:12px 14px;display:flex}tfoot td{color:var(--text-primary);border:none;flex:1;padding:0;font-size:13px;font-weight:700}tfoot td:first-child{border-bottom:none;margin-bottom:0;padding-bottom:0;font-size:13px}.page-fab{bottom:calc(var(--mobile-bottom-h) + 16px);z-index:80;background:var(--brand);color:#fff;transition:transform var(--transition),box-shadow var(--transition);cursor:pointer;border:none;border-radius:99px;align-items:center;gap:7px;padding:13px 20px;font-family:inherit;font-size:14px;font-weight:700;animation:.3s cubic-bezier(.34,1.56,.64,1) fabIn;display:flex;position:fixed;right:16px;box-shadow:0 4px 20px #3b82f673,0 2px 8px #0000004d}.page-fab:active{transform:scale(.94);box-shadow:0 2px 10px #3b82f666}@keyframes fabIn{0%{opacity:0;transform:scale(.5)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.alert{padding:12px 14px;font-size:13px}.badge{font-size:10.5px}.summary-strip{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}.technician-grid{grid-template-columns:1fr!important}.card-actions{flex-wrap:wrap;gap:8px;display:flex}.card-actions .btn{flex:1;justify-content:center;min-width:0}}@media (max-width:480px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.page-content{padding:12px 14px}td[data-label]:before{min-width:70px}}@media (max-width:380px){.kpi-grid{grid-template-columns:1fr}.page-content{padding:10px 12px}}.mobile-header{height:var(--mobile-header-h,58px);background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:90;-webkit-backdrop-filter:blur(12px);justify-content:space-between;align-items:center;padding:0 16px;display:flex;position:fixed;top:0;left:0;right:0}.mobile-header-logo{flex-direction:column;gap:1px;display:flex}.mobile-logo-text{background:linear-gradient(135deg,var(--brand-light),var(--accent));-webkit-text-fill-color:transparent;letter-spacing:-.3px;-webkit-background-clip:text;background-clip:text;font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700;line-height:1.1}.mobile-logo-sub{color:var(--text-muted);letter-spacing:.8px;text-transform:uppercase;font-size:9px;line-height:1}.mobile-page-title{color:var(--text-primary);letter-spacing:-.2px;font-family:Space Grotesk,sans-serif;font-size:17px;font-weight:700;line-height:1.2}.mobile-menu-btn{border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border);width:38px;height:38px;color:var(--text-secondary);transition:all var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:flex}.mobile-menu-btn:hover,.mobile-menu-btn:active{background:var(--bg-card);color:var(--text-primary)}.mobile-bottom-nav{height:var(--mobile-bottom-h,68px);background:var(--bg-surface);border-top:1px solid var(--border);z-index:90;padding-bottom:env(safe-area-inset-bottom,0px);-webkit-backdrop-filter:blur(16px);align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-tab{color:var(--text-muted);transition:color var(--transition);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;min-width:0;padding:8px 4px;font-family:inherit;text-decoration:none;display:flex;position:relative}.mobile-tab:active{opacity:.7}.mobile-tab.active{color:var(--brand-light)}.mobile-tab-icon{justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:relative}.mobile-tab-dot{background:var(--brand-light);border-radius:50%;width:6px;height:6px;animation:.2s fadeIn;position:absolute;top:-2px;right:-4px}.mobile-tab-label{letter-spacing:.2px;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:9.5px;font-weight:500;overflow:hidden}.mobile-tab.active:before{content:"";background:var(--brand-light);border-radius:0 0 4px 4px;height:2px;position:absolute;top:0;left:20%;right:20%;box-shadow:0 0 8px #60a5fa80}.mobile-drawer-backdrop{-webkit-backdrop-filter:blur(3px);z-index:110;background:#0009;animation:.18s fadeIn;position:fixed;inset:0}.mobile-drawer{background:var(--bg-surface);border-left:1px solid var(--border);z-index:120;flex-direction:column;width:min(320px,85vw);transition:transform .28s cubic-bezier(.32,.72,0,1);display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden;transform:translate(100%);box-shadow:-8px 0 40px #00000080}.mobile-drawer.open{transform:translate(0)}.mobile-drawer-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 16px 16px;display:flex}.mobile-drawer-brand{flex-direction:column;gap:2px;display:flex}.mobile-drawer-close{border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border);width:34px;height:34px;color:var(--text-secondary);transition:all var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:flex}.mobile-drawer-close:hover,.mobile-drawer-close:active{background:var(--bg-card);color:var(--text-primary)}.mobile-drawer-user{background:var(--bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;margin:12px;padding:14px 16px;display:flex}.mobile-user-avatar{background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:14px;font-weight:700;display:flex;box-shadow:0 0 12px #3b82f64d}.mobile-user-info{min-width:0}.mobile-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.mobile-user-role{color:var(--text-muted);text-transform:capitalize;margin-top:1px;font-size:11px}.mobile-drawer-nav{scrollbar-width:thin;scrollbar-color:transparent transparent;flex:1;padding:4px 0 8px;overflow-y:auto}.mobile-drawer-nav:hover{scrollbar-color:var(--border-light)transparent}.mobile-drawer-section{padding:8px 12px 4px}.mobile-drawer-section-label{color:var(--text-muted);letter-spacing:1.2px;text-transform:uppercase;margin-bottom:4px;padding:0 4px;font-size:9.5px;font-weight:700}.mobile-drawer-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition);justify-content:space-between;align-items:center;margin-bottom:2px;padding:12px 10px;font-size:14.5px;font-weight:500;text-decoration:none;display:flex}.mobile-drawer-link:active{opacity:.7}.mobile-drawer-link:hover{background:var(--bg-elevated);color:var(--text-primary)}.mobile-drawer-link.active{background:var(--brand-glow);color:var(--brand-light);border:1px solid #3b82f633}.mobile-drawer-link-left{align-items:center;gap:11px;display:flex}.mobile-drawer-chevron{opacity:.35;flex-shrink:0}.mobile-drawer-link.active .mobile-drawer-chevron{opacity:.7;color:var(--brand-light)}.mobile-drawer-footer{border-top:1px solid var(--border);padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom,12px));flex-shrink:0}.mobile-signout-btn{border-radius:var(--radius-md);background:var(--danger-soft);color:#f87171;cursor:pointer;width:100%;transition:all var(--transition);border:1px solid #ef444433;justify-content:center;align-items:center;gap:8px;padding:11px;font-family:inherit;font-size:14px;font-weight:600;display:flex}.mobile-signout-btn:hover,.mobile-signout-btn:active{background:#ef444433;border-color:#ef444459}@keyframes slideUpSheet{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.leaflet-container{border-radius:var(--radius-lg);z-index:1}.leaflet-popup-content-wrapper{background:var(--bg-surface)!important;color:var(--text-primary)!important;border:1px solid var(--border)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important}.leaflet-popup-tip{background:var(--bg-surface)!important}.leaflet-control-zoom a{background:var(--bg-surface)!important;color:var(--text-primary)!important;border-color:var(--border)!important}.leaflet-control-zoom a:hover{background:var(--bg-elevated)!important}
