:root{--bg: #f4f6fa;--surface: #ffffff;--surface-2: #f8fafc;--text: #0f172a;--text-2: #334155;--muted: #64748b;--border: #e2e8f0;--border-strong: #cbd5e1;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-soft: #eff6ff;--primary-soft-border: #bfdbfe;--accent: #d97706;--accent-soft: #fffbeb;--success: #15803d;--success-soft: #dcfce7;--danger: #dc2626;--danger-soft: #fee2e2;--warn-bg: #fefce8;--warn-border: #fde047;--warn-text: #713f12;--sidebar-bg: #0b1220;--sidebar-text: #94a3b8;--sidebar-text-active: #ffffff;--sidebar-active-bg: rgba(59, 130, 246, .16);--sidebar-border: rgba(148, 163, 184, .12);--sidebar-w: 236px;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow: 0 1px 3px rgba(15, 23, 42, .07), 0 4px 14px rgba(15, 23, 42, .05);--shadow-lg: 0 8px 30px rgba(15, 23, 42, .16);--font: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;font-family:var(--font)}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.5}h1{font-size:1.45rem;font-weight:700;letter-spacing:-.02em}h2{font-size:1.15rem;font-weight:700;letter-spacing:-.01em}h3{font-size:.95rem;font-weight:600}a{color:var(--primary)}.muted{color:var(--muted)}.small{font-size:.82rem}.error{color:var(--danger);font-size:.88rem}.num,.mono-num{font-variant-numeric:tabular-nums}.app-shell{display:flex;min-height:100dvh}.sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar-w);background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;padding:1rem .75rem;z-index:40}.sidebar-brand{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.25rem .4rem 1rem;border-bottom:1px solid var(--sidebar-border);margin-bottom:.9rem}.brand-logo{width:100%;background:#fff;border-radius:10px;padding:.6rem;display:grid;place-items:center}.brand-logo img{max-width:100%;max-height:84px;height:auto;display:block}.brand-tagline{font-size:.66rem;color:var(--sidebar-text);letter-spacing:.12em;text-transform:uppercase}.brand-logo-mobile{height:30px;width:auto;background:#fff;border-radius:6px;padding:3px 6px}.login-logo{display:block;max-width:200px;max-height:96px;height:auto;margin:0 auto .3rem}.brand-mark{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1e40af);display:grid;place-items:center;color:#fff;flex-shrink:0}.brand-name{color:#fff;font-weight:700;font-size:.95rem;line-height:1.2}.brand-sub{font-size:.7rem;color:var(--sidebar-text);letter-spacing:.06em;text-transform:uppercase}.sidebar-section{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#475569;padding:.9rem .65rem .35rem}.sidebar nav{display:flex;flex-direction:column;gap:2px;flex:1}.side-link{display:flex;align-items:center;gap:.65rem;padding:.55rem .65rem;border-radius:var(--radius-sm);color:var(--sidebar-text);text-decoration:none;font-size:.88rem;font-weight:500;transition:background .15s ease,color .15s ease}.side-link svg{flex-shrink:0;opacity:.85}.side-link:hover{background:#94a3b81a;color:#e2e8f0}.side-link.active{background:var(--sidebar-active-bg);color:var(--sidebar-text-active);box-shadow:inset 2px 0 0 var(--primary)}.sidebar-footer{border-top:1px solid var(--sidebar-border);padding-top:.75rem;display:flex;align-items:center;gap:.6rem}.avatar{width:32px;height:32px;border-radius:50%;background:#1e293b;color:#93c5fd;display:grid;place-items:center;font-size:.78rem;font-weight:700;flex-shrink:0}.sidebar-user{flex:1;min-width:0}.sidebar-user .name{color:#e2e8f0;font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.icon-btn{background:none;border:none;color:var(--sidebar-text);padding:.45rem;border-radius:var(--radius-sm);cursor:pointer;display:grid;place-items:center;transition:background .15s ease,color .15s ease}.icon-btn:hover{background:#94a3b81f;color:#fff}.content{flex:1;min-width:0;margin-left:var(--sidebar-w);padding:1.5rem 1.75rem 3rem;width:100%}.mobile-bar{display:none;position:sticky;top:0;z-index:30;align-items:center;gap:.75rem;background:var(--sidebar-bg);color:#fff;padding:.65rem 1rem}.mobile-bar .brand-name{font-size:.92rem}.backdrop{display:none}@media(max-width:900px){.sidebar{transform:translate(-100%);transition:transform .2s ease;width:min(280px,84vw)}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-lg)}.backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0206178c;z-index:35;border:none;padding:0}.mobile-bar{display:flex}.content{margin-left:0;padding:1rem 1rem 3rem}}@media(prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important}}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.1rem;flex-wrap:wrap}.page-head h1{margin:0}.page-head .sub{margin:.15rem 0 0;color:var(--muted);font-size:.88rem}.page-actions{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.breadcrumb{margin-bottom:.6rem;font-size:.85rem}.breadcrumb a{color:var(--muted);text-decoration:none;display:inline-flex;align-items:center;gap:.3rem}.breadcrumb a:hover{color:var(--primary)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow-sm)}.card h3{margin:0 0 .9rem;font-size:.92rem;color:var(--text-2)}.card-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem}.card-title-row h3{margin:0}button,.btn{font-family:var(--font);display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.55rem .95rem;border:1px solid transparent;border-radius:var(--radius-sm);background:var(--primary);color:#fff;font-size:.88rem;font-weight:600;cursor:pointer;text-decoration:none;white-space:nowrap;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .1s ease}button:hover,.btn:hover{background:var(--primary-hover)}button:active,.btn:active{transform:scale(.98)}button:focus-visible,.btn:focus-visible,a:focus-visible{outline:2px solid var(--primary);outline-offset:2px}button:disabled{opacity:.55;cursor:not-allowed;transform:none}button.secondary,.btn.secondary{background:var(--surface);color:var(--text-2);border-color:var(--border-strong)}button.secondary:hover,.btn.secondary:hover{background:var(--surface-2);border-color:var(--muted)}button.ghost{background:transparent;color:var(--text-2);border-color:transparent}button.ghost:hover{background:var(--surface-2)}button.danger-btn{background:var(--danger)}button.danger-btn:hover{background:#b91c1c}button.sm{padding:.32rem .6rem;font-size:.8rem}button.link{background:none;border:none;color:var(--primary);padding:0;font-weight:600;font-size:.85rem}button.link:hover{background:none;text-decoration:underline}button.link.danger,.danger{color:var(--danger)}.row-actions{display:flex;gap:.25rem;white-space:nowrap;justify-content:flex-end}.icon-action{background:none;border:none;padding:.35rem;border-radius:6px;color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:background .15s ease,color .15s ease}.icon-action:hover{background:var(--primary-soft);color:var(--primary)}.icon-action.danger:hover{background:var(--danger-soft);color:var(--danger)}.icon-action:disabled{opacity:.5;cursor:not-allowed}label{display:flex;flex-direction:column;gap:.32rem;font-size:.8rem;font-weight:600;color:var(--text-2)}input,select,textarea{font-family:var(--font);padding:.55rem .7rem;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:.92rem;color:var(--text);background:var(--surface);transition:border-color .15s ease,box-shadow .15s ease;min-width:0}input:hover,select:hover{border-color:var(--muted)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb29}input::placeholder{color:#94a3b8}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.9rem}.form-grid .span-2,.form-grid-3 .span-2{grid-column:1 / -1}.card .actions{display:flex;gap:.6rem;margin-top:1.1rem}.checkbox{flex-direction:row;align-items:center;gap:.5rem;font-weight:500;color:var(--text);text-transform:none}.checkbox input{width:auto;accent-color:var(--primary)}.month-pick{max-width:220px;margin-bottom:1rem}.field-hint{font-weight:400;color:var(--muted);font-size:.75rem}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow-x:auto}.table{width:100%;border-collapse:collapse;background:var(--surface)}.table th,.table td{text-align:left;padding:.6rem .75rem;border-bottom:1px solid var(--border);font-size:.87rem;vertical-align:middle}.table th{background:var(--surface-2);color:var(--muted);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;position:sticky;top:0;z-index:1}.table tbody tr{transition:background .12s ease}.table tbody tr:hover{background:#f8fafc}.table tr:last-child td{border-bottom:none}.table .num{text-align:right;white-space:nowrap}.table .route{color:var(--muted);font-size:.8rem;max-width:320px}.table tfoot td{background:var(--surface-2);font-weight:700;border-top:2px solid var(--border-strong);border-bottom:none}.table a{text-decoration:none;font-weight:600}.table a:hover{text-decoration:underline}.table tr.editing,.table tr.editing:hover{background:var(--primary-soft)}.table tr.editing td{padding:.4rem}.table tr.detail-row td{background:var(--primary-soft);border-bottom:1px solid var(--primary-soft-border);padding:.75rem 1rem 1rem}.table input.cell,.table select.cell{width:100%;padding:.4rem .5rem;font-size:.85rem}.table input.cell.num{text-align:right}.cell-w-date{min-width:6.5rem;width:6.5rem}.date-cell{white-space:nowrap;font-variant-numeric:tabular-nums;width:6.5rem}.route-cell{min-width:22rem}.route-inputs{display:flex;gap:.3rem;align-items:center}.route-inputs input{flex:1 1 0;min-width:0}.cell-w-sm{min-width:5rem}.cell-w-md{min-width:7.5rem}.cell-w-lg{min-width:10rem}.add-row td{background:var(--surface-2);border-top:1px dashed var(--border-strong)}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.13rem .55rem;border-radius:999px;font-size:.72rem;font-weight:600;white-space:nowrap}.badge-ok{background:var(--success-soft);color:var(--success)}.badge-muted{background:#f1f5f9;color:var(--muted)}.badge-warn{background:#fef08a;color:#854d0e}.badge-blue{background:var(--primary-soft);color:var(--primary-hover)}.badge-amber{background:var(--accent-soft);color:var(--accent)}.dot{width:7px;height:7px;border-radius:50%;background:currentColor;display:inline-block}.tabs{display:inline-flex;gap:.25rem;margin:0 0 1.1rem;background:#e8edf4;padding:.25rem;border-radius:10px}.tab{background:none;color:var(--muted);border-radius:8px;padding:.42rem .95rem;font-size:.85rem;border:none}.tab:hover{background:#fff9;color:var(--text-2)}.tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin:1.1rem 0}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.2rem}.kpi-label{font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.4rem}.kpi-value{font-size:1.42rem;font-weight:700;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.kpi-value.pos,.num.pos,.pos{color:var(--success)}.kpi-value.neg,.num.neg,.neg{color:var(--danger)}.kpi-sub{font-size:.75rem;color:var(--muted)}.filters{display:flex;gap:.9rem;align-items:flex-end;flex-wrap:wrap}.filters label{flex-direction:column}.filters select,.filters input{min-width:170px}.preset-row{display:flex;gap:.4rem;flex-wrap:wrap}.chip{background:var(--surface);border:1px solid var(--border-strong);color:var(--text-2);border-radius:999px;padding:.3rem .8rem;font-size:.78rem;font-weight:600}.chip:hover{background:var(--primary-soft);border-color:var(--primary-soft-border);color:var(--primary)}.chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.bar-row{display:grid;grid-template-columns:130px 1fr 90px;align-items:center;gap:.6rem;margin-bottom:.55rem;font-size:.84rem}.bar-label{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-track{background:#eef2f7;border-radius:6px;height:12px;overflow:hidden}.bar-fill{background:linear-gradient(90deg,#3b82f6,#2563eb);height:100%;border-radius:6px;transition:width .3s ease}.bar-fill.amber{background:linear-gradient(90deg,#f59e0b,#d97706)}.bar-value{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}.bar-total{display:flex;justify-content:space-between;border-top:1px solid var(--border);margin-top:.7rem;padding-top:.7rem;font-weight:700;font-size:.9rem}.sub-stats{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}.sub-stats>div{display:flex;justify-content:space-between;font-size:.87rem}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.warn{background:var(--warn-bg);border:1px solid var(--warn-border);color:var(--warn-text);border-radius:var(--radius);padding:.8rem 1rem;margin-bottom:1rem;display:flex;gap:.6rem;font-size:.88rem}.warn svg{flex-shrink:0;margin-top:.1rem}.warn ul{margin:.4rem 0 0;padding-left:1.1rem;font-size:.82rem}.empty{background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--radius);padding:2.5rem 1.5rem;text-align:center;color:var(--muted)}.empty svg{color:#cbd5e1;margin-bottom:.6rem}.empty .empty-title{font-weight:600;color:var(--text-2);margin-bottom:.2rem}.empty button{margin-top:.9rem}.toasts{position:fixed;bottom:1.25rem;right:1.25rem;display:flex;flex-direction:column;gap:.5rem;z-index:100}.toast{display:flex;align-items:center;gap:.55rem;background:#0f172a;color:#f1f5f9;border-radius:10px;padding:.65rem 1rem;font-size:.86rem;font-weight:500;box-shadow:var(--shadow-lg);animation:toast-in .2s ease;max-width:360px}.toast.success svg{color:#4ade80}.toast.error svg{color:#f87171}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0206178c;display:grid;place-items:center;z-index:60;padding:1rem}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90dvh;overflow-y:auto;padding:1.4rem;animation:toast-in .18s ease}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.modal-head h2{margin:0}.modal-head .icon-btn{color:var(--muted)}.modal-head .icon-btn:hover{background:var(--surface-2);color:var(--text)}.centered{min-height:100dvh;display:grid;place-items:center;padding:1rem;background:radial-gradient(800px 400px at 80% -10%,rgba(37,99,235,.18),transparent),radial-gradient(620px 320px at 12% 112%,rgba(193,39,45,.16),transparent),var(--sidebar-bg)}.login{width:100%;max-width:380px;display:flex;flex-direction:column;gap:.85rem;padding:2rem;border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.login-brand{display:flex;justify-content:center;margin-bottom:.3rem}.login h1{margin:0;font-size:1.25rem}.login p{margin:0 0 .4rem}.toolbar{margin-bottom:1rem;display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.spacer{flex:1}.export-row{display:flex;align-items:center;gap:.5rem;margin:1.5rem 0 0;flex-wrap:wrap;font-size:.85rem}.btn-link{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .85rem;background:var(--primary);color:#fff;border-radius:var(--radius-sm);text-decoration:none;font-weight:600;font-size:.84rem;transition:background .15s ease}.btn-link:hover{background:var(--primary-hover)}.btn-link.subtle{background:var(--surface);color:var(--text-2);border:1px solid var(--border-strong)}.btn-link.subtle:hover{background:var(--surface-2)}.section-gap{margin-top:1.5rem}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}.legs{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:.9rem 0}.leg{border:1px solid var(--primary-soft-border);border-radius:var(--radius-sm);padding:.85rem;background:var(--surface)}.leg-head{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.85rem}.waypoints{margin:.5rem 0}.waypoint-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.4rem}.miles-input{display:flex;align-items:center;gap:.5rem}.calc-row{display:flex;align-items:center;gap:1rem;margin:.9rem 0 0;flex-wrap:wrap}.file-drop{border:2px dashed var(--border-strong);border-radius:var(--radius);padding:1.6rem;text-align:center;color:var(--muted);cursor:pointer;transition:border-color .15s ease,background .15s ease;font-size:.9rem}.file-drop:hover,.file-drop.drag{border-color:var(--primary);background:var(--primary-soft)}.import-result{margin-top:1rem;font-size:.88rem}.import-result ul{margin:.4rem 0 0;padding-left:1.2rem;color:var(--muted);font-size:.82rem;max-height:180px;overflow-y:auto}code.csv-hint{display:block;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.6rem .8rem;font-size:.78rem;color:var(--text-2);overflow-x:auto;white-space:pre;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.summary-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin-bottom:1.1rem}.skeleton{border-radius:var(--radius);background:linear-gradient(90deg,#eef2f7 25%,#f6f8fb,#eef2f7 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;height:90px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:1100px){.kpi-grid,.summary-strip{grid-template-columns:repeat(2,1fr)}}@media(max-width:760px){.form-grid,.form-grid-3,.legs,.two-col,.detail-grid{grid-template-columns:1fr}.kpi-grid,.summary-strip{grid-template-columns:1fr 1fr}.kpi-value{font-size:1.2rem}.page-head{flex-direction:column}.filters label,.filters select,.filters input{width:100%;min-width:0}.filters{width:100%}}.control-bar{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap;margin-bottom:1.25rem}.control-bar label{flex-direction:column}.control-bar .grow{flex:1}.stat-chips{display:flex;gap:.5rem;flex-wrap:wrap}.stat-chip{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:.4rem .75rem;min-width:116px}.stat-chip .k{font-size:.64rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}.stat-chip .v{font-size:1.05rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.stat-chip .v.accent{color:var(--primary)}.costs-grid{display:grid;grid-template-columns:minmax(0,1.9fr) minmax(0,1fr);gap:1rem;align-items:start}@media(max-width:980px){.costs-grid{grid-template-columns:1fr}}.cost-cols{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:0 1.75rem}.cost-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:.2rem 0 .4rem;padding-bottom:.35rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.cost-line{display:grid;grid-template-columns:minmax(0,1fr) 120px 74px 26px 16px;gap:.45rem;align-items:center;padding:.28rem 0}.cost-line input,.cost-line select{width:100%;padding:.45rem .55rem;font-size:.88rem}.cost-line+.cost-line{border-top:1px dashed var(--border)}.cost-line .name{font-size:.84rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cost-line input,.cost-line select{padding:.38rem .45rem;font-size:.84rem}.cost-empty{color:var(--muted);font-size:.82rem;padding:.4rem 0}@media(max-width:1180px){.cost-cols{grid-template-columns:1fr;gap:0}}@media(max-width:1180px){.two-col.stack-wide{grid-template-columns:1fr}}
