:root{--bg: #f4f6f9;--card: #fff;--dark: #111827;--accent: #f59e0b;--border: #e2e8f0;--success: #10b981;--danger: #ef4444;--muted: #64748b;--sidebar-hover: #1f2937;--nav-muted: #9ca3af}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--dark);font-family:system-ui,-apple-system,Segoe UI,sans-serif;min-height:100vh}a{color:inherit}#root{min-height:100vh}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--dark);color:#fff;padding:20px;position:fixed;height:100vh;display:flex;flex-direction:column;z-index:10}.logo{font-weight:700;color:var(--accent);margin-bottom:30px;font-size:1.1rem}.sidebar nav a{color:var(--nav-muted);text-decoration:none;padding:12px;display:block;border-radius:6px;margin-bottom:5px;transition:background .15s,color .15s}.sidebar nav a.active,.sidebar nav a:hover{background:var(--sidebar-hover);color:#fff}.sidebar-footer{margin-top:auto;padding-top:20px;border-top:1px solid var(--sidebar-hover);font-size:.85rem;color:var(--nav-muted)}.sidebar-footer button{margin-top:10px;width:100%;padding:10px;border:1px solid var(--sidebar-hover);background:transparent;color:#fff;border-radius:6px;cursor:pointer}.sidebar-footer button:hover{background:var(--sidebar-hover)}.main-content{margin-left:240px;flex-grow:1;padding:30px;min-width:0}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;gap:16px;flex-wrap:wrap}.page-header h2{font-size:1.5rem;font-weight:600}.page-header-meta{color:var(--muted);font-size:.9rem}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:30px}.card{background:var(--card);padding:20px;border-radius:8px;border:1px solid var(--border)}.card-num{font-size:1.6rem;font-weight:700;margin-top:5px}.card-label{color:var(--muted);font-size:.9rem}.split{display:grid;grid-template-columns:2fr 1fr;gap:20px}@media(max-width:900px){.split{grid-template-columns:1fr}.sidebar{width:200px}.main-content{margin-left:200px}}.table-wrap{overflow-x:auto}table.data-table{width:100%;border-collapse:collapse;background:var(--card)}table.data-table th,table.data-table td{padding:12px;text-align:left;border-bottom:1px solid var(--border);font-size:.9rem}table.data-table th{color:var(--muted);background:#f8fafc;font-weight:600}table.data-table tr:hover td{background:#fafbfc}.card.table-card{padding:0;overflow:hidden}.badge{padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap}.b-wait{background:#fef3c7;color:#92400e}.b-ok{background:#d1fae5;color:#065f46}.b-fail{background:#fee2e2;color:#991b1b}.bar-bg{width:100%;height:6px;background:var(--border);border-radius:3px;margin-top:5px}.bar-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s}.progress-item{margin-top:15px}.progress-item:first-child{margin-top:0}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:.9rem;color:var(--muted)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:.95rem}.form-group input:focus,.form-group select:focus{outline:2px solid var(--accent);outline-offset:0}.btn{padding:10px 18px;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--dark)}.btn-primary:hover:not(:disabled){filter:brightness(1.05)}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--dark)}.btn-sm{padding:6px 12px;font-size:.8rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{width:100%;max-width:400px}.login-card h1{font-size:1.4rem;margin-bottom:8px}.login-card .subtitle{color:var(--muted);margin-bottom:24px;font-size:.9rem}.error-banner{background:#fee2e2;color:#991b1b;padding:10px 14px;border-radius:6px;margin-bottom:16px;font-size:.9rem}.loading{color:var(--muted);padding:40px;text-align:center}.toolbar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.toolbar select{padding:8px 12px;border:1px solid var(--border);border-radius:6px;background:var(--card)}.pagination{display:flex;gap:8px;align-items:center;margin-top:16px;font-size:.9rem;color:var(--muted)}.inline-edit{display:flex;gap:8px;align-items:center}.inline-edit input{width:80px;padding:4px 8px;border:1px solid var(--border);border-radius:4px}.section-title{font-size:1rem;font-weight:600;margin-bottom:4px}.map-list{list-style:none;margin-top:12px}.map-list li{padding:8px 0;border-bottom:1px solid var(--border);font-size:.85rem}.map-list li:last-child{border-bottom:none}.online-dot{display:inline-block;width:8px;height:8px;background:var(--success);border-radius:50%;margin-right:6px}
