:root{--bg: #ffffff;--panel: #ffffff;--accent: #e30613;--accent-ink: #ffffff;--cab: #2b2b2b;--text: #1a1a1a;--muted: #8a8a8a;--border: #e5e7eb;--ok: #21d07a;--off: #9e9e9e;--danger: #ef4444}.brand-logo{line-height:1}.brand-word{font-weight:800;font-size:1.5rem;letter-spacing:-.01em}.brand-easy{color:var(--accent)}.brand-cab{color:var(--cab)}.brand-tagline{display:flex;align-items:center;gap:.3rem;margin-top:.2rem}.brand-partner{font-size:.58rem;font-weight:700;letter-spacing:.18em;color:var(--muted)}.brand-yango{font-size:.58rem;font-weight:800;letter-spacing:.04em;background:var(--accent);color:#fff;padding:.08rem .3rem;border-radius:3px}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#f1f5f9;color:#0f172a}.centered{display:grid;place-items:center;height:100vh}.login-page{display:grid;place-items:center;height:100vh;background:#f1f5f9}.login-card{background:var(--panel);color:var(--text);padding:2rem;border-radius:12px;width:320px;display:flex;flex-direction:column;gap:.75rem;border:1px solid var(--border);box-shadow:0 10px 40px #0000001f}.login-brand{margin-bottom:.25rem}.login-card h1{margin:0;color:var(--accent)}.login-card .subtitle{margin:0 0 1rem;color:var(--muted)}.login-card label{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:#475569}.login-card input{padding:.6rem;border-radius:8px;border:1px solid #cbd5e1;background:#fff;color:var(--text)}.login-card button,button[type=submit]{margin-top:.5rem;padding:.65rem;border:none;border-radius:8px;background:var(--accent);color:var(--accent-ink);font-weight:600;cursor:pointer}.error{color:var(--danger);font-size:.85rem}.app-shell{display:grid;grid-template-columns:230px 1fr;min-height:100vh}.sidebar{background:var(--bg);color:var(--text);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1.25rem 1rem}.brand{margin-bottom:1.5rem}.sidebar nav{display:flex;flex-direction:column;gap:.25rem}.sidebar nav a{color:#374151;text-decoration:none;padding:.55rem .75rem;border-radius:8px;font-size:.95rem}.sidebar nav a:hover{background:#f3f4f6}.sidebar nav a.active{background:var(--accent);color:var(--accent-ink);font-weight:600}.user-box{margin-top:auto;padding-top:1rem;border-top:1px solid var(--border)}.user-name{font-weight:600}.user-role{color:var(--muted);font-size:.8rem;margin-bottom:.5rem}.link-btn{background:none;border:none;color:var(--accent);cursor:pointer;padding:0;font-size:.85rem}.content{padding:2rem}.content h1{margin-top:0}.muted{color:#64748b}.topbar{display:none}.nav-toggle{background:none;border:none;color:var(--text);font-size:1.6rem;line-height:1;padding:.1rem .4rem;cursor:pointer}.cards{display:flex;gap:1rem;margin:1.5rem 0;flex-wrap:wrap}.card{background:#fff;border-radius:12px;padding:1.25rem 1.5rem;min-width:160px;box-shadow:0 1px 3px #0000001a}.card-value{font-size:2rem;font-weight:700;color:#0f172a}.card-label{color:#64748b;font-size:.9rem}.pill-list{list-style:none;padding:0;display:flex;gap:.5rem;flex-wrap:wrap}.pill{background:#ffe5e2;color:#c8281a;padding:.35rem .75rem;border-radius:999px;font-size:.85rem}.table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.table th,.table td{text-align:left;padding:.7rem 1rem;border-bottom:1px solid #e2e8f0;font-size:.9rem}.table th{background:#f8fafc;color:#475569;font-weight:600}.badge{padding:.2rem .55rem;border-radius:999px;font-size:.75rem;color:#fff}.badge.ok{background:var(--ok)}.badge.off{background:var(--off)}.card-value.accent{color:var(--ok)}.card-danger{border-left:4px solid var(--danger)}.card-warn{border-left:4px solid #f59e0b}.nav-sep{margin:1rem 0 .25rem;font-size:.7rem;text-transform:uppercase;color:#475569;letter-spacing:.05em}.page-head{display:flex;align-items:center;justify-content:space-between}.table a{color:var(--accent);text-decoration:none;font-weight:600}.table a:hover{text-decoration:underline}.amount-neg{color:var(--danger);font-weight:600}.amount-pos{color:var(--ok);font-weight:600}.table-toolbar{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-bottom:.8rem}.search-input,.filter-select{padding:.5rem .7rem;border:1px solid #cbd5e1;border-radius:8px;font-size:.9rem;background:#fff;color:#0f172a}.search-input{flex:1;min-width:220px}.filter-select{cursor:pointer}.pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.6rem;margin-top:.8rem;font-size:.9rem}.pagination-controls{display:flex;align-items:center;gap:.5rem}.pagination-controls button{padding:.4rem .7rem}.th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.th-sortable:hover{background:#eef2f7}.sort-arrow{color:var(--accent);font-size:.8em}button{padding:.55rem .9rem;border:none;border-radius:8px;background:var(--accent);color:var(--accent-ink);font-weight:600;cursor:pointer}button:disabled{opacity:.6;cursor:default}.btn-secondary{background:#e2e8f0;color:#0f172a}.form{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;max-width:760px;margin-bottom:1.5rem}.inline-form{background:#f8fafc;border:1px dashed #cbd5e1}.form-row{display:flex;gap:1rem;flex-wrap:wrap}.field{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:#475569;flex:1;min-width:160px;margin-bottom:.75rem}.field input,.field select{padding:.55rem;border:1px solid #cbd5e1;border-radius:8px;font-size:.9rem}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem}.success{color:var(--ok);font-size:.9rem}.checkbox-list{display:flex;gap:1rem;flex-wrap:wrap;padding:.5rem 0}.checkbox{display:flex;align-items:center;gap:.35rem;color:#0f172a;font-size:.9rem}.panel{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.kv{display:grid;grid-template-columns:auto 1fr;gap:.35rem 1rem;margin:0}.kv dt{color:#64748b;font-size:.85rem}.kv dd{margin:0;font-weight:500}.impersonation-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#fef3c7;border:1px solid #f59e0b;color:#92400e;padding:.6rem 1rem;border-radius:8px;margin-bottom:1.25rem;font-size:.9rem}.impersonation-banner button{background:#92400e;color:#fff}.login-tabs{display:flex;gap:.5rem;margin-bottom:.5rem}.login-tabs button{flex:1;background:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.login-tabs button.active{background:var(--accent);color:var(--accent-ink)}.hint{font-size:.8rem;color:var(--muted);margin:0}.driver-portal{min-height:100vh;background:#f1f5f9}.driver-header{display:flex;align-items:center;justify-content:space-between;background:var(--bg);color:var(--text);padding:1rem 2rem;border-bottom:1px solid var(--border)}.driver-header .brand{margin-bottom:0}.driver-header .muted{margin-right:1rem}.driver-portal .content{padding:2rem;max-width:1000px;margin:0 auto}.driver-portal .panel button{margin-top:.5rem}@media (max-width: 768px){.app-shell{grid-template-columns:1fr}.topbar{display:flex;align-items:center;gap:.75rem;background:#fff;border-bottom:1px solid var(--border);padding:.55rem 1rem;position:sticky;top:0;z-index:30}.sidebar{position:fixed;top:0;bottom:0;left:0;width:250px;transform:translate(-100%);transition:transform .22s ease;z-index:50;box-shadow:2px 0 18px #0000002e}.sidebar.open{transform:translate(0)}.nav-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:40}.sidebar nav a{padding:.8rem .85rem}.content{padding:1rem}.page-head{flex-direction:column;align-items:flex-start;gap:.6rem}.cards{gap:.75rem}.card{min-width:0;flex:1 1 140px;padding:1rem 1.1rem}.card-value{font-size:1.6rem}.table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.table.cards-mobile{display:block;overflow:visible;white-space:normal;box-shadow:none;background:none}.cards-mobile thead{display:none}.cards-mobile tbody,.cards-mobile tr,.cards-mobile td{display:block}.cards-mobile tr{background:#fff;border:1px solid var(--border);border-radius:12px;padding:.35rem .95rem;margin-bottom:.75rem;box-shadow:0 1px 3px #0000000f}.cards-mobile td{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px solid #f1f5f9;text-align:right}.cards-mobile td:last-child{border-bottom:none}.cards-mobile td:before{content:attr(data-label);font-weight:600;color:#64748b;text-align:left;flex:0 0 auto}.cards-mobile td.card-title{display:block;text-align:left;font-size:1.05rem;font-weight:700;padding:.25rem 0 .55rem;border-bottom:1px solid var(--border);margin-bottom:.2rem}.cards-mobile td.card-title:before{display:none}.cards-mobile td.card-title a{color:var(--text)}.cards-mobile td.card-action{justify-content:flex-end}.cards-mobile td.card-action:before{display:none}.form-row{flex-direction:column;gap:0}.field{min-width:0}.detail-grid{grid-template-columns:1fr}.form{padding:1.1rem}.search-input{min-width:0;width:100%}.table-toolbar{gap:.5rem}.driver-header{padding:.8rem 1rem}.driver-portal .content{padding:1rem}.impersonation-banner{flex-direction:column;align-items:flex-start}.dash-grid{grid-template-columns:1fr}.kpi-row{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.gauges{gap:1rem}}.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.period-switch{display:flex;gap:.25rem;background:#f1f5f9;border-radius:10px;padding:.25rem}.period-switch button{border:none;background:transparent;padding:.4rem .85rem;border-radius:8px;cursor:pointer;font-size:.85rem;color:var(--muted);font:inherit}.period-switch button.active{background:#fff;color:var(--text);box-shadow:0 1px 2px #0000001f;font-weight:600}.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:1rem;margin:1.25rem 0}.kpi{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:1rem 1.1rem}.kpi-label{color:var(--muted);font-size:.8rem}.kpi-value{font-size:1.7rem;font-weight:700;color:#0f172a;line-height:1.2;margin-top:.2rem}.kpi-value.accent{color:var(--accent)}.kpi-value.ok{color:var(--ok)}.kpi-value.danger{color:var(--danger)}.kpi-delta{font-size:.8rem;font-weight:600;margin-top:.15rem}.kpi-delta.up{color:var(--ok)}.kpi-delta.down{color:var(--danger)}.kpi-sub{color:var(--muted);font-size:.75rem;margin-top:.25rem}.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.barchart{display:flex;align-items:flex-end;gap:4px;height:150px;margin-top:1rem}.barchart-col{flex:1;display:flex;flex-direction:column;justify-content:flex-end;height:100%;min-width:0}.barchart-bar{background:linear-gradient(180deg,var(--accent),#ff5a67);border-radius:4px 4px 0 0;min-height:2px}.barchart-x{font-size:9px;color:var(--muted);text-align:center;margin-top:4px;white-space:nowrap;overflow:hidden}.gauges{display:flex;gap:1.5rem;flex-wrap:wrap;margin:1rem 0;justify-content:space-around}.gauge{text-align:center}.gauge-ring{width:96px;height:96px;border-radius:50%;display:grid;place-items:center}.gauge-num{width:70px;height:70px;border-radius:50%;background:var(--panel);display:grid;place-items:center;font-weight:700;font-size:1.05rem;color:var(--text)}.gauge-label{font-size:.8rem;color:var(--muted);margin-top:.5rem}.mini-stats{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.85rem;color:var(--text);margin-top:.75rem}.mini-stats span{background:#f8fafc;border:1px solid var(--border);border-radius:8px;padding:.3rem .6rem}.table.mini{font-size:.9rem}.table.mini th,.table.mini td{padding:.4rem .5rem}.insights{display:flex;flex-direction:column;gap:.6rem}.insight{display:flex;gap:.6rem;align-items:flex-start;padding:.7rem .9rem;border-radius:10px;border-left:4px solid var(--border);background:#f8fafc}.insight-danger{border-left-color:var(--danger);background:#fef2f2}.insight-warn{border-left-color:#f59e0b;background:#fffbeb}.insight-success{border-left-color:var(--ok);background:#f0fdf4}.insight-info{border-left-color:#3b82f6;background:#eff6ff}.insight-icon{font-size:1.1rem;line-height:1.4}.insight-title{font-weight:600}.insight-detail{font-size:.85rem;color:var(--muted)}.veh-picker{width:100%;max-width:230px;padding:.35rem .5rem;border:1px solid var(--border);border-radius:8px;font:inherit;background:#fff}.veh-picker:focus{outline:2px solid var(--accent);outline-offset:-1px}.veh-picker:disabled{opacity:.6}.chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.chip{display:inline-flex;align-items:center;gap:.35rem;background:#eef2ff;border:1px solid var(--border);border-radius:999px;padding:.2rem .6rem;font-size:.85rem}.chip button{border:none;background:none;cursor:pointer;color:var(--muted);font-size:.9rem;line-height:1;padding:0}.tabs{display:flex;gap:.5rem;margin:1rem 0;border-bottom:1px solid var(--border)}.tabs button{border:none;background:none;padding:.6rem 1rem;cursor:pointer;font:inherit;color:var(--muted);border-bottom:2px solid transparent}.tabs button.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.row-inactive{opacity:.55}
