@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--bg-primary:#060a13;--bg-secondary:#0c1220;--bg-tertiary:#111a2e;--bg-card:#0f172a99;--bg-card-hover:#141e37b3;--bg-elevated:#16213e80;--bg-overlay:#0009;--bg-input:#0f172acc;--bg-sidebar:#080d19;--bg-sidebar-hover:#3b82f614;--bg-sidebar-active:#3b82f626;--border-primary:#94a3b81a;--border-secondary:#94a3b80f;--border-focus:#3b82f680;--border-card:#94a3b814;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-tertiary:#64748b;--text-muted:#475569;--text-inverse:#0f172a;--accent-blue:#3b82f6;--accent-blue-hover:#2563eb;--accent-blue-glow:#3b82f640;--accent-blue-subtle:#3b82f61a;--color-success:#10b981;--color-success-bg:#10b9811a;--color-success-border:#10b98140;--color-warning:#f59e0b;--color-warning-bg:#f59e0b1a;--color-warning-border:#f59e0b40;--color-danger:#ef4444;--color-danger-bg:#ef44441a;--color-danger-border:#ef444440;--color-info:#06b6d4;--color-info-bg:#06b6d41a;--color-info-border:#06b6d440;--color-purple:#8b5cf6;--color-purple-bg:#8b5cf61a;--color-purple-border:#8b5cf640;--gradient-blue:linear-gradient(135deg, #3b82f6, #2563eb);--gradient-emerald:linear-gradient(135deg, #10b981, #059669);--gradient-amber:linear-gradient(135deg, #f59e0b, #d97706);--gradient-rose:linear-gradient(135deg, #f43f5e, #e11d48);--gradient-purple:linear-gradient(135deg, #8b5cf6, #7c3aed);--gradient-card:linear-gradient(135deg, #0f172acc, #0f172a66);--gradient-glow:radial-gradient(ellipse at 50% 0%, #3b82f614, transparent 60%);--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-xl:0 16px 48px #0009;--shadow-glow:0 0 20px #3b82f626;--shadow-glow-lg:0 0 40px #3b82f633;--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20% 0,#3b82f60a,#0000 50%),radial-gradient(at 80% 100%,#8b5cf608,#0000 50%);position:fixed;inset:0}a{color:var(--accent-blue);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-blue-hover)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#94a3b826}::-webkit-scrollbar-thumb:hover{background:#94a3b840}.app-layout{z-index:1;min-height:100vh;display:flex;position:relative}.main-content{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-base);flex-direction:column;flex:1;display:flex}.page-content{flex:1;width:100%;max-width:1600px;padding:28px 32px;overflow-y:auto}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-primary);z-index:100;transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden auto}.sidebar-logo{border-bottom:1px solid var(--border-secondary);align-items:center;gap:12px;margin-bottom:8px;padding:20px 20px 16px;display:flex}.sidebar-logo-icon{background:var(--gradient-blue);border-radius:var(--radius-md);width:44px;height:44px;box-shadow:var(--shadow-glow), inset 0 1px 0 #ffffff1f;flex-shrink:0;justify-content:center;align-items:center;transition:transform .2s,box-shadow .2s;display:flex}.sidebar-logo:hover .sidebar-logo-icon{box-shadow:var(--shadow-glow), 0 0 16px #3b82f673, inset 0 1px 0 #ffffff2e;transform:translateY(-1px)}.sidebar-logo-text{letter-spacing:-.02em;background:linear-gradient(135deg,#f1f5f9,#94a3b8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.1rem;font-weight:700}.sidebar-section{padding:8px 12px}.sidebar-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:8px 12px 6px;font-size:.65rem;font-weight:600}.sidebar-nav{flex-direction:column;gap:2px;display:flex}.sidebar-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;align-items:center;gap:12px;padding:10px 12px;font-size:.875rem;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-link:hover{background:var(--bg-sidebar-hover);color:var(--text-primary)}.sidebar-link.active{background:var(--bg-sidebar-active);color:var(--accent-blue)}.sidebar-link.active:before{content:"";background:var(--accent-blue);border-radius:0 var(--radius-sm) var(--radius-sm) 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link-icon{opacity:.7;flex-shrink:0;width:20px;height:20px}.sidebar-link.active .sidebar-link-icon{opacity:1}.sidebar-link-badge{background:var(--accent-blue-subtle);color:var(--accent-blue);border-radius:var(--radius-full);text-align:center;min-width:22px;margin-left:auto;padding:2px 8px;font-size:.7rem;font-weight:600}.sidebar-footer{border-top:1px solid var(--border-secondary);margin-top:auto;padding:16px}.sidebar-user{border-radius:var(--radius-md);transition:background var(--transition-fast);align-items:center;gap:10px;padding:8px;display:flex}.sidebar-user:hover{background:var(--bg-sidebar-hover)}.sidebar-avatar{border-radius:var(--radius-full);background:var(--gradient-purple);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.8rem;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-tertiary);font-size:.7rem}.header{height:var(--header-height);border-bottom:1px solid var(--border-primary);backdrop-filter:blur(12px);z-index:50;background:#060a13cc;justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:16px;display:flex}.header-title{letter-spacing:-.02em;font-size:1.15rem;font-weight:700}.header-subtitle{color:var(--text-tertiary);font-size:.85rem}.header-right{align-items:center;gap:8px;display:flex}.header-search{background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);width:280px;transition:all var(--transition-fast);align-items:center;gap:8px;padding:8px 14px;display:flex}.header-search:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-blue-glow)}.header-search input{color:var(--text-primary);font-family:var(--font-sans);background:0 0;border:none;outline:none;width:100%;font-size:.85rem}.header-search input::placeholder{color:var(--text-muted)}.header-search-icon{color:var(--text-muted);flex-shrink:0;width:16px;height:16px}.header-icon-btn{border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--bg-card);width:38px;height:38px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:relative}.header-icon-btn:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--border-focus)}.header-icon-btn .notification-dot{background:var(--color-danger);border:2px solid var(--bg-primary);border-radius:50%;width:7px;height:7px;position:absolute;top:8px;right:8px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.page-header-info h1{letter-spacing:-.03em;font-size:1.6rem;font-weight:800;line-height:1.2}.page-header-info p{color:var(--text-secondary);margin-top:4px;font-size:.9rem}.page-header-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.card{background:var(--bg-card);backdrop-filter:blur(12px);border:1px solid var(--border-card);border-radius:var(--radius-lg);transition:all var(--transition-base);padding:20px}.card:hover{border-color:#94a3b826}.card-clickable:hover{background:var(--bg-card-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text-secondary);font-size:.85rem;font-weight:600}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px;margin-bottom:24px;display:grid}.kpi-card{background:var(--bg-card);backdrop-filter:blur(12px);border:1px solid var(--border-card);border-radius:var(--radius-lg);transition:all var(--transition-base);padding:20px 22px;position:relative;overflow:hidden}.kpi-card:before{content:"";opacity:0;height:2px;transition:opacity var(--transition-base);position:absolute;top:0;left:0;right:0}.kpi-card:hover{box-shadow:var(--shadow-md);border-color:#94a3b826;transform:translateY(-2px)}.kpi-card:hover:before{opacity:1}.kpi-card.blue:before{background:var(--gradient-blue)}.kpi-card.green:before{background:var(--gradient-emerald)}.kpi-card.amber:before{background:var(--gradient-amber)}.kpi-card.rose:before{background:var(--gradient-rose)}.kpi-card.purple:before{background:var(--gradient-purple)}.kpi-card-top{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.kpi-card-label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.kpi-card-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:36px;height:36px;display:flex}.kpi-card-icon.blue{background:var(--accent-blue-subtle);color:var(--accent-blue)}.kpi-card-icon.green{background:var(--color-success-bg);color:var(--color-success)}.kpi-card-icon.amber{background:var(--color-warning-bg);color:var(--color-warning)}.kpi-card-icon.rose{background:var(--color-danger-bg);color:var(--color-danger)}.kpi-card-icon.purple{background:var(--color-purple-bg);color:var(--color-purple)}.kpi-card-header{align-items:center;gap:14px;margin-bottom:14px;display:flex}.kpi-card-header .kpi-card-icon{border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.kpi-card-value{letter-spacing:-.03em;margin-bottom:2px;font-size:1.8rem;font-weight:800;line-height:1}.kpi-card-footer{border-top:1px solid var(--border-secondary);color:var(--text-tertiary);justify-content:space-between;align-items:center;padding-top:12px;font-size:.75rem;display:flex}.kpi-card-change{border-radius:var(--radius-full);align-items:center;gap:4px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.kpi-card-change.positive{color:var(--color-success);background:var(--color-success-bg)}.kpi-card-change.negative{color:var(--color-danger);background:var(--color-danger-bg)}.btn{font-family:var(--font-sans);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:9px 18px;font-size:.85rem;font-weight:600;line-height:1.4;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--gradient-blue);color:#fff;border-color:#0000;box-shadow:0 1px 3px #3b82f64d}.btn-primary:hover{box-shadow:var(--shadow-glow), 0 4px 12px #3b82f64d;transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-primary)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-focus)}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-card);color:var(--text-primary)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#dc2626;box-shadow:0 4px 12px #ef44444d}.btn-sm{padding:6px 12px;font-size:.78rem}.btn-lg{padding:12px 24px;font-size:.95rem}.btn-icon{min-width:36px;min-height:36px;padding:8px}.badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;align-items:center;gap:5px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-blue{background:var(--accent-blue-subtle);color:var(--accent-blue);border:1px solid #3b82f633}.badge-green{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.badge-amber{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-warning-border)}.badge-red{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger-border)}.badge-purple{background:var(--color-purple-bg);color:var(--color-purple);border:1px solid var(--color-purple-border)}.badge-cyan{background:var(--color-info-bg);color:var(--color-info);border:1px solid var(--color-info-border)}.badge-neutral{color:var(--text-secondary);background:#94a3b81a;border:1px solid #94a3b826}.badge-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.badge-dot.blue{background:var(--accent-blue)}.badge-dot.green{background:var(--color-success)}.badge-dot.amber{background:var(--color-warning)}.badge-dot.red{background:var(--color-danger)}.table-wrapper{background:var(--bg-card);backdrop-filter:blur(12px);border:1px solid var(--border-card);border-radius:var(--radius-lg);overflow:hidden}.table-toolbar{border-bottom:1px solid var(--border-secondary);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.table-toolbar-left{align-items:center;gap:10px;display:flex}.table-toolbar-right{align-items:center;gap:8px;display:flex}.table-search{background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);width:260px;transition:border-color var(--transition-fast);align-items:center;gap:8px;padding:7px 12px;display:flex}.table-search:focus-within{border-color:var(--border-focus)}.table-search input{color:var(--text-primary);font-family:var(--font-sans);background:0 0;border:none;outline:none;width:100%;font-size:.82rem}.table-search input::placeholder{color:var(--text-muted)}.data-table{border-collapse:collapse;width:100%}.data-table thead{background:#0f172a80}.data-table th{text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);text-align:left;border-bottom:1px solid var(--border-secondary);white-space:nowrap;padding:11px 16px;font-size:.72rem;font-weight:600}.data-table td{color:var(--text-primary);border-bottom:1px solid var(--border-secondary);vertical-align:middle;padding:13px 16px;font-size:.85rem}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:#3b82f60a}.data-table tbody tr:last-child td{border-bottom:none}.table-cell-main{color:var(--text-primary);font-weight:600}.table-cell-sub{color:var(--text-tertiary);margin-top:1px;font-size:.78rem}.table-empty{text-align:center;color:var(--text-tertiary);padding:48px 16px}.form-group{margin-bottom:18px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.form-input,.form-select,.form-textarea{width:100%;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-md);transition:all var(--transition-fast);outline:none;padding:10px 14px;font-size:.85rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-blue-glow)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-select{cursor:pointer;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='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-textarea{resize:vertical;min-height:100px}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.tabs{border-bottom:1px solid var(--border-primary);gap:2px;margin-bottom:24px;display:flex}.tab{color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 16px}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}.kanban-board{gap:16px;padding-bottom:16px;display:flex;overflow-x:auto}.kanban-column{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);flex-direction:column;flex:1;min-width:300px;max-height:calc(100vh - 220px);display:flex}.kanban-column-header{border-bottom:1px solid var(--border-secondary);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.kanban-column-title{color:var(--text-primary);align-items:center;gap:8px;font-size:.85rem;font-weight:600;display:flex}.kanban-column-count{color:var(--text-tertiary);border-radius:var(--radius-full);background:#94a3b81a;padding:2px 8px;font-size:.72rem;font-weight:600}.kanban-column-body{flex-direction:column;flex:1;gap:10px;padding:12px;display:flex;overflow-y:auto}.kanban-card{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);padding:14px}.kanban-card:hover{border-color:var(--border-focus);box-shadow:var(--shadow-md);transform:translateY(-1px)}.kanban-card-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.kanban-card-id{color:var(--accent-blue);font-size:.82rem;font-weight:700}.kanban-card-route{color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:10px;font-size:.82rem;display:flex}.kanban-card-route-arrow{color:var(--text-muted)}.kanban-card-footer{color:var(--text-tertiary);justify-content:space-between;align-items:center;font-size:.75rem;display:flex}.kanban-card-driver{align-items:center;gap:6px;display:flex}.kanban-card-driver-avatar{background:var(--gradient-emerald);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.55rem;font-weight:700;display:flex}body.dispatch-fullscreen .sidebar,body.dispatch-fullscreen .header{display:none!important}body.dispatch-fullscreen .app-layout{grid-template-columns:1fr!important}body.dispatch-fullscreen .main-content{padding:12px!important}body.dispatch-fullscreen .page-header{margin-bottom:8px!important}.flag-icon{font-size:1rem;line-height:1}.grid-2{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.grid-2-1{grid-template-columns:2fr 1fr;gap:20px;display:grid}.grid-1-1{grid-template-columns:1fr 1fr;gap:20px;display:grid}.activity-list{flex-direction:column;gap:2px;display:flex}.activity-item{border-bottom:1px solid var(--border-secondary);align-items:flex-start;gap:12px;padding:10px 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;display:flex}.activity-content{flex:1;min-width:0}.activity-text{color:var(--text-primary);font-size:.82rem;line-height:1.4}.activity-text strong{font-weight:600}.activity-time{color:var(--text-muted);margin-top:2px;font-size:.72rem}.chart-container{width:100%;height:280px}.entity-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.entity-card{background:var(--bg-card);backdrop-filter:blur(12px);border:1px solid var(--border-card);border-radius:var(--radius-lg);transition:all var(--transition-base);cursor:pointer;padding:20px}.entity-card:hover{box-shadow:var(--shadow-md);border-color:#94a3b826;transform:translateY(-2px)}.entity-card-header{align-items:center;gap:14px;margin-bottom:16px;display:flex}.entity-card-avatar{border-radius:var(--radius-full);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:.9rem;font-weight:700;display:flex}.entity-card-name{color:var(--text-primary);font-size:.95rem;font-weight:700}.entity-card-meta{color:var(--text-tertiary);font-size:.78rem}.entity-card-stats{grid-template-columns:1fr 1fr;gap:12px;display:grid}.entity-card-stat{text-align:center;border-radius:var(--radius-md);background:#0f172a66;padding:10px}.entity-card-stat-value{color:var(--text-primary);font-size:1.1rem;font-weight:700}.entity-card-stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-size:.68rem}.hos-bar-container{margin-top:14px}.hos-bar-label{color:var(--text-tertiary);justify-content:space-between;margin-bottom:6px;font-size:.72rem;display:flex}.hos-bar-track{border-radius:var(--radius-full);background:#94a3b81a;height:6px;overflow:hidden}.hos-bar-fill{border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.hos-bar-fill.safe{background:var(--gradient-emerald)}.hos-bar-fill.warning{background:var(--gradient-amber)}.hos-bar-fill.danger{background:var(--gradient-rose)}.modal-overlay{background:var(--bg-overlay);backdrop-filter:blur(4px);z-index:200;animation:fadeIn var(--transition-fast) ease-out;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);width:100%;max-width:600px;max-height:85vh;animation:slideUp var(--transition-base) ease-out;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-secondary);justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-title{font-size:1.1rem;font-weight:700}.modal-close{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-card);color:var(--text-primary)}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid var(--border-secondary);justify-content:flex-end;align-items:center;gap:10px;padding:16px 24px 20px;display:flex}.modal-subtitle{color:var(--text-tertiary);margin-top:2px;font-size:.82rem}.skeleton-pulse{background:linear-gradient(90deg, var(--bg-card) 25%, var(--border-secondary) 50%, var(--bg-card) 75%);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.compliance-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;display:grid}.compliance-rule-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);padding:20px}.compliance-rule-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.compliance-rule-title{font-size:.9rem;font-weight:700}.compliance-rule-values{flex-direction:column;gap:10px;display:flex}.compliance-rule-row{border-radius:var(--radius-md);background:#0f172a66;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.compliance-rule-row-label{color:var(--text-secondary);align-items:center;gap:6px;font-size:.8rem;display:flex}.compliance-rule-row-value{color:var(--text-primary);font-size:.85rem;font-weight:600}.invoice-summary-bar{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.invoice-summary-item{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);text-align:center;padding:18px 20px}.invoice-summary-value{letter-spacing:-.02em;font-size:1.4rem;font-weight:800}.invoice-summary-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:.72rem;font-weight:500}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:64px 24px;display:flex}.empty-state-icon{border-radius:var(--radius-xl);background:var(--bg-card);border:1px solid var(--border-card);width:64px;height:64px;color:var(--text-tertiary);justify-content:center;align-items:center;margin-bottom:16px;display:flex}.empty-state-title{margin-bottom:6px;font-size:1.1rem;font-weight:700}.empty-state-text{color:var(--text-tertiary);max-width:400px;margin-bottom:20px;font-size:.85rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes countUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-slide-up{animation:slideUp var(--transition-base) ease-out}.animate-slide-in-left{animation:slideInLeft var(--transition-base) ease-out}.pulse-dot{animation:2s ease-in-out infinite pulse-dot}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-secondary)}.text-right{text-align:right}.font-semibold{font-weight:600}.font-bold{font-weight:700}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.w-full{width:100%}.cursor-pointer{cursor:pointer}@media (max-width:1200px){.grid-2-1{grid-template-columns:1fr}.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.sidebar{width:var(--sidebar-collapsed)}.main-content{margin-left:var(--sidebar-collapsed)}.sidebar-logo-text,.sidebar-section-label,.sidebar-link span,.sidebar-link-badge,.sidebar-user-info{display:none}.sidebar-link{justify-content:center;padding:12px}.sidebar-link-icon{width:22px;height:22px}.page-content{padding:16px}.header{padding:0 16px}.header-search{width:180px}.grid-2,.grid-1-1,.grid-3{grid-template-columns:1fr}.kpi-grid{grid-template-columns:repeat(2,1fr)}.page-header{flex-direction:column}}.auth-loading{background:var(--bg-primary);flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100vh;display:flex}.auth-loading-spinner{border:3px solid var(--border-primary);border-top-color:var(--accent-blue);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite auth-spin}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-loading-text{color:var(--text-secondary);font-size:14px}.auth-page{background:var(--bg-primary);background-image:var(--gradient-glow);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-xl);padding:40px 36px}.auth-brand{text-align:center;margin-bottom:32px}.auth-brand-icon{border-radius:var(--radius-md);background:var(--gradient-blue);justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:14px;display:inline-flex;box-shadow:0 8px 24px #3b82f659,inset 0 1px #ffffff24}.auth-brand-title{color:var(--text-primary);margin:0;font-size:22px;font-weight:700}.auth-brand-subtitle{color:var(--text-tertiary);margin:4px 0 0;font-size:13px}.auth-heading{color:var(--text-primary);text-align:center;margin:0 0 20px;font-size:17px;font-weight:600}.auth-subtext{color:var(--text-secondary);text-align:center;margin:-8px 0 20px;font-size:13px;line-height:1.5}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-label{color:var(--text-secondary);font-size:13px;font-weight:500}.auth-input{width:100%;font-size:14px;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:10px 14px}.auth-input::placeholder{color:var(--text-muted)}.auth-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-blue-subtle)}.auth-button{width:100%;font-size:14px;font-weight:600;font-family:var(--font-sans);color:#fff;background:var(--gradient-blue);border-radius:var(--radius-sm);cursor:pointer;transition:opacity var(--transition-fast), transform var(--transition-fast);border:none;margin-top:4px;padding:11px 20px}.auth-button:hover:not(:disabled){opacity:.9}.auth-button:active:not(:disabled){transform:scale(.98)}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-error{color:var(--color-danger);background:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;line-height:1.4}.auth-success{color:var(--color-success);background:var(--color-success-bg);border:1px solid var(--color-success-border);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;line-height:1.4}.auth-success-block{text-align:center}.auth-success-block .auth-subtext{margin:8px 0 24px}.auth-links{justify-content:center;align-items:center;gap:8px;margin-top:20px;font-size:13px;display:flex}.auth-link{color:var(--accent-blue);transition:color var(--transition-fast);font-weight:500;text-decoration:none}.auth-link:hover{color:var(--accent-blue-hover)}.auth-link-button{color:var(--accent-blue);font-size:13px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:0}.auth-link-button:hover{color:var(--accent-blue-hover)}.auth-link-separator{color:var(--text-muted)}.auth-link-text{color:var(--text-tertiary)}.trip-board-wrapper{scrollbar-width:thin}.trip-board-table{font-family:var(--font-sans)}.trip-board-row:hover{background:#3b82f60f!important}.trip-board-row:hover td{color:var(--text-primary)}
