*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f5f5f7;--card:#fff;--text:#1d1d1f;--text-secondary:#6e6e73;--text-tertiary:#aeaeb2;--accent:#0071e3;--accent-hover:#0077ed;--accent-light:#0071e317;--police-navy:#0d1b3e;--police-navy2:#162447;--police-gold:#c8a951;--police-gold-l:#e2c472;--police-gold-bg:#c8a9511f;--border:#d2d2d7;--border-light:#e8e8ed;--success:#34c759;--success-bg:#e8f9ed;--success-text:#1a7a31;--danger:#ff3b30;--danger-bg:#fff0ef;--danger-text:#c0392b;--warning-bg:#fff8ec;--warning-text:#92400e;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-pill:100px;--shadow-card:0 1px 3px #0000000f, 0 4px 16px #0000000f;--shadow-elevated:0 8px 40px #0000001f;--font:-apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Helvetica, Arial, sans-serif;--transition:.15s ease}html,body,#root{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px}.app-shell{flex-direction:column;min-height:100vh;display:flex}.app-header{-webkit-backdrop-filter:blur(20px);z-index:100;background:#1d1d1ff5;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;height:52px;padding:0 24px;display:flex;position:sticky;top:0}.app-header-brand{color:#fff;letter-spacing:-.2px;font-size:15px;font-weight:600}.app-header-right{align-items:center;gap:16px;display:flex}.app-header-user{color:#ffffffbf;font-size:13px}.app-header-user strong{color:#fffffff2}.btn-logout{border-radius:var(--r-pill);color:#fff;cursor:pointer;transition:background var(--transition);background:#ffffff1f;border:1px solid #ffffff2e;padding:5px 14px;font-size:13px;font-weight:500}.btn-logout:hover{background:#fff3}.app-body{flex:1;display:flex}.app-sidebar{background:var(--card);border-right:1px solid var(--border-light);flex-direction:column;flex-shrink:0;gap:2px;width:220px;min-height:calc(100vh - 52px);padding:16px 12px;display:flex}.app-sidebar-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);padding:12px 10px 6px;font-size:11px;font-weight:600}.nav-link{border-radius:var(--r-sm);color:var(--text-secondary);transition:background var(--transition), color var(--transition);align-items:center;gap:8px;padding:8px 12px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.nav-link:hover{background:var(--border-light);color:var(--text)}.nav-link.active{background:var(--accent-light);color:var(--accent)}.app-main{flex:1;min-width:0;padding:32px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-title{color:var(--text);letter-spacing:-.4px;font-size:24px;font-weight:700}.btn{border-radius:var(--r-pill);cursor:pointer;transition:opacity var(--transition), transform var(--transition);font-size:14px;font-weight:500;font-family:var(--font);white-space:nowrap;border:none;align-items:center;gap:6px;padding:8px 18px;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--card);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg)}.btn-danger-ghost{background:var(--danger-bg);color:var(--danger-text)}.btn-danger-ghost:hover{background:#ffe0de}.btn-sm{padding:5px 12px;font-size:13px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.card{background:var(--card);border-radius:var(--r-lg);box-shadow:var(--shadow-card);border:1px solid var(--border-light)}.table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table thead tr{border-bottom:1px solid var(--border-light)}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);white-space:nowrap;background:0 0;padding:12px 16px;font-size:12px;font-weight:600}.data-table td{color:var(--text);border-bottom:1px solid var(--border-light);vertical-align:middle;padding:13px 16px}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background var(--transition)}.data-table tbody tr:hover{background:#00000005}.table-empty{text-align:center;color:var(--text-tertiary);padding:48px 16px;font-size:14px}.badge{border-radius:var(--r-pill);letter-spacing:.02em;align-items:center;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-success{background:var(--success-bg);color:var(--success-text)}.badge-danger{background:var(--danger-bg);color:var(--danger-text)}.badge-neutral{background:var(--border-light);color:var(--text-secondary)}.code-tag{background:var(--bg);border:1px solid var(--border-light);color:var(--text-secondary);border-radius:5px;padding:2px 7px;font-family:SF Mono,Fira Code,monospace;font-size:12px}.form-card{background:var(--card);border-radius:var(--r-lg);box-shadow:var(--shadow-card);border:1px solid var(--border-light);padding:28px}.form-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-tertiary);margin-bottom:16px;font-size:13px;font-weight:600}.form-grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-grid-full{grid-column:1/-1}.form-field{flex-direction:column;gap:5px;display:flex}.form-label{color:var(--text-secondary);font-size:13px;font-weight:500}.form-input{border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:14px;font-family:var(--font);color:var(--text);background:var(--card);transition:border-color var(--transition), box-shadow var(--transition);outline:none;width:100%;padding:10px 14px}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31f}.form-input.error{border-color:var(--danger)}.form-input.error:focus{box-shadow:0 0 0 3px #ff3b301f}.form-input:disabled{background:var(--bg);color:var(--text-tertiary);cursor:not-allowed}.form-error-msg{color:var(--danger);font-size:12px}.form-hint{color:var(--text-tertiary);font-size:12px}.form-actions{justify-content:flex-end;align-items:center;gap:10px;margin-top:8px;display:flex}.filter-bar{background:var(--card);border-radius:var(--r-md);border:1px solid var(--border-light);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;padding:14px 16px;display:flex}.toast{border-radius:var(--r-md);color:#fff;z-index:9999;box-shadow:var(--shadow-elevated);padding:12px 20px;font-size:14px;font-weight:500;animation:.2s slide-in;position:fixed;top:20px;right:20px}.toast-success{background:#1d7a3a}.toast-error{background:#c0392b}@keyframes slide-in{0%{opacity:0;transform:translateY(-8px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.duration-pill{background:var(--accent-light);border-radius:var(--r-md);color:var(--accent);align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:500;display:inline-flex}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--card);width:100%;max-width:400px;box-shadow:var(--shadow-elevated);border:1px solid var(--border-light);border-radius:20px;padding:40px}.login-logo{background:var(--text);border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 20px;display:flex}.login-title{color:var(--text);text-align:center;letter-spacing:-.4px;margin-bottom:4px;font-size:22px;font-weight:700}.login-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:28px;font-size:14px}.coord-block{border:1.5px solid var(--border-light);border-radius:var(--r-md);transition:border-color var(--transition);padding:14px}.coord-block:focus-within{border-color:var(--accent)}@media (width<=768px){.app-sidebar{display:none}.app-main{padding:20px 16px}.form-grid-2{grid-template-columns:1fr}.page-title{font-size:20px}}
