@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0c0e12;--bg-1:#111318;--bg-2:#161b22;--bg-3:#1c2230;--bg-4:#222a38;--bg-hover:rgba(255,255,255,0.04);--bg-subtle:rgba(255,255,255,0.06);--bg-raised:rgba(255,255,255,0.12);--text:#e8ecf2;--text-2:#a0aec0;--text-3:#7b8ba2;--text-inverse:#ffffff;--border:rgba(255,255,255,0.07);--border-2:rgba(255,255,255,0.13);--primary:#818cf8;--primary-dim:rgba(129,140,248,0.10);--primary-glow:rgba(129,140,248,0.20);--primary-border:rgba(129,140,248,0.30);--green:#10b981;--green-dim:rgba(16,185,129,0.10);--yellow:#f59e0b;--yellow-dim:rgba(245,158,11,0.10);--red:#ef4444;--red-dim:rgba(239,68,68,0.10);--blue:#3b82f6;--indigo:#818cf8;--indigo-dim:rgba(129,140,248,0.10);--blue-dim:rgba(59,130,246,0.10);--purple:#a78bfa;--purple-dim:rgba(167,139,250,0.10);--cyan:#06b6d4;--cyan-dim:rgba(6,182,212,0.09);--success:var(--green);--success-dim:var(--green-dim);--warning:var(--yellow);--warning-dim:var(--yellow-dim);--error:var(--red);--error-dim:var(--red-dim);--accent:var(--primary);--shadow-xs:0 1px 3px rgba(0,0,0,0.35);--shadow-sm:0 2px 8px rgba(0,0,0,0.4),0 1px 2px rgba(0,0,0,0.3);--shadow:0 4px 16px rgba(0,0,0,0.5),0 1px 4px rgba(0,0,0,0.3);--shadow-md:0 8px 32px rgba(0,0,0,0.55),0 2px 8px rgba(0,0,0,0.35);--shadow-lg:0 20px 60px rgba(0,0,0,0.65),0 4px 16px rgba(0,0,0,0.4);--radius:8px;--radius-lg:12px;--radius-xl:16px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-7:32px;--space-8:48px;--font:"IBM Plex Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--mono:"IBM Plex Mono","JetBrains Mono","Fira Code",monospace}[data-theme=light]{--bg:#f8fafc;--bg-1:#ffffff;--bg-2:#f1f5f9;--bg-3:#e2e8f0;--bg-4:#cbd5e1;--bg-hover:rgba(0,0,0,0.03);--bg-subtle:rgba(0,0,0,0.04);--bg-raised:rgba(0,0,0,0.06);--text:#0f172a;--text-2:#334155;--text-3:#475569;--text-inverse:#ffffff;--green:#047857;--yellow:#b45309;--red:#b91c1c;--blue:#1d4ed8;--indigo:#4f46e5;--purple:#7c3aed;--cyan:#0e7490;--border:rgba(0,0,0,0.12);--border-2:rgba(0,0,0,0.20);--primary:#4f46e5;--primary-dim:rgba(79,70,229,0.08);--primary-glow:rgba(79,70,229,0.15);--primary-border:rgba(79,70,229,0.25);--green-dim:rgba(4,120,87,0.08);--yellow-dim:rgba(180,83,9,0.08);--red-dim:rgba(185,28,28,0.08);--blue-dim:rgba(29,78,216,0.08);--indigo-dim:rgba(79,70,229,0.08);--purple-dim:rgba(124,58,237,0.08);--cyan-dim:rgba(14,116,144,0.07);--shadow-xs:0 1px 2px rgba(0,0,0,0.05);--shadow-sm:0 1px 3px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.04);--shadow:0 4px 12px rgba(0,0,0,0.08),0 1px 3px rgba(0,0,0,0.05);--shadow-md:0 8px 24px rgba(0,0,0,0.10),0 2px 6px rgba(0,0,0,0.06);--shadow-lg:0 16px 48px rgba(0,0,0,0.12),0 4px 12px rgba(0,0,0,0.06)}html{background:var(--bg);color-scheme:dark}[data-theme=light]{color-scheme:light}body{font-family:var(--font);font-size:13px;color:var(--text);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--primary);outline-offset:1px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:var(--text-3);border-radius:4px;border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background:var(--text-2);background-clip:content-box}select{background-color:var(--bg-1);color:var(--text);border:1px solid var(--border-2);border-radius:var(--radius);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239ba6b8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:28px}[data-theme=light] select{background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23475569' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.page-container{max-width:1080px;margin:0 auto;padding:0 var(--space-4)}.page-container-narrow{max-width:860px;margin:0 auto;padding:0 var(--space-4)}.page-container-wide{max-width:1280px;margin:0 auto;padding:0 var(--space-4)}table{line-height:1.5}.sidebar{width:224px;min-width:224px;background:var(--bg-1);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;flex-shrink:0;position:relative}.sidebar:after{content:"";position:absolute;top:0;right:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,rgba(129,140,248,.18) 50%,transparent);pointer-events:none}.sidebar-logo{padding:15px 16px 13px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.sidebar-logo-mark{width:28px;height:28px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 0 1px rgba(129,140,248,.4),0 4px 14px rgba(129,140,248,.25)}.sidebar-logo-mark svg{color:#fff}.sidebar-logo-text h1{font-size:15px;font-weight:800;color:var(--text);letter-spacing:-.04em}.sidebar-logo-text p{font-size:10px;color:var(--text-3);margin-top:1px;letter-spacing:.07em;text-transform:uppercase}.sidebar-nav{flex:1 1;padding:8px;overflow-y:auto}.nav-section-label{font-size:9.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.09em;padding:10px 10px 4px}.nav-item{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:8px;color:var(--text-2);text-decoration:none;font-size:13px;font-weight:450;cursor:pointer;margin-bottom:1px;transition:background .1s,color .1s;position:relative;white-space:nowrap}.nav-item:hover{background:var(--bg-2);color:var(--text)}.nav-item.active{background:rgba(59,130,246,.09);color:var(--primary);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:22%;bottom:22%;width:2px;background:var(--primary);border-radius:0 2px 2px 0;box-shadow:0 0 10px rgba(129,140,248,.6)}.nav-icon{width:16px;height:16px;flex-shrink:0;opacity:.65}.nav-item.active .nav-icon{opacity:1}.nav-item-label{flex:1 1}.nav-badge{font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;background:var(--red);color:#fff;min-width:18px;text-align:center;letter-spacing:-.02em}.sidebar-footer{padding:12px 10px;border-top:1px solid var(--border)}.app-shell{display:flex;height:100vh;overflow:hidden;background:var(--bg)}.page-content{flex:1 1;overflow-y:auto;padding:24px 28px;background:var(--bg)}.topbar{border-bottom:1px solid var(--border);padding:0 24px;height:52px;display:flex;align-items:center;gap:14px;flex-shrink:0}.panel,.topbar{background:var(--bg-1)}.panel{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .12s}.panel:hover{border-color:var(--border-2)}.panel-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg-hover)}.panel-title{font-size:13px;font-weight:600;color:var(--text);letter-spacing:-.01em}.panel-subtitle{font-size:11px;color:var(--text-3);margin-top:1px}.card,.panel-body{padding:var(--space-4)}.card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color .12s,box-shadow .12s}.card:hover{border-color:var(--border-2);box-shadow:var(--shadow-sm)}.card-kpi{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);position:relative;overflow:hidden;transition:border-color .12s}.card-kpi:hover{border-color:var(--border-2)}.card-kpi-accent{position:absolute;top:0;left:0;right:0;height:2px;background:var(--primary);opacity:.6}.table-wrap{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}table{width:100%;border-collapse:collapse}thead,thead th{background:var(--bg-2)}thead th{padding:var(--space-3) var(--space-3);font-size:10px;color:var(--text-3);text-align:left;text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border-2);position:-webkit-sticky;position:sticky;top:0;z-index:2}th,thead th{font-weight:600}td{padding:var(--space-3) var(--space-3);font-size:13px;color:var(--text-2);border-bottom:1px solid var(--border)}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background .08s}tbody tr:nth-child(2n){background:var(--bg-hover)}tbody tr:hover{background:var(--bg-subtle)}tbody tr:hover td{color:var(--text)}tbody tr[data-clickable]{cursor:pointer}tbody tr[data-clickable]:hover{border-left:2px solid var(--primary)}table.compact td{font-size:12px}table.compact td,table.compact thead th{padding:var(--space-2) var(--space-3)}.form-input,.form-select,.form-textarea{background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:13px;padding:var(--space-2) var(--space-3);outline:none;width:100%;transition:border-color .12s,box-shadow .12s;-webkit-appearance:none;-moz-appearance:none;appearance:none;min-height:36px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(129,140,248,.18);background:var(--bg-3)}.form-input::placeholder{color:var(--text-3)}.form-label{font-size:11px;font-weight:600;color:var(--text-2);display:block;margin-bottom:var(--space-1);letter-spacing:.01em}.form-group{margin-bottom:var(--space-4)}.form-row{display:grid;grid-gap:var(--space-3);gap:var(--space-3)}.form-row-2{grid-template-columns:1fr 1fr}.form-row-3{grid-template-columns:1fr 1fr 1fr}.form-row-4{grid-template-columns:1fr 1fr 1fr 1fr}.form-select{background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%233d4756' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;border-radius:var(--radius);border:1px solid var(--border-2);background:var(--bg-2);color:var(--text-2);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:all .1s;white-space:nowrap;text-decoration:none}.btn:hover{background:var(--bg-3);color:var(--text);border-color:rgba(255,255,255,.18)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600;box-shadow:0 1px 4px rgba(0,0,0,.25),inset 0 0 0 1px rgba(129,140,248,.4)}.btn-primary:hover{background:#6366f1;border-color:#6366f1;box-shadow:0 2px 10px rgba(129,140,248,.35),inset 0 0 0 1px rgba(129,140,248,.45)}.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}.btn-danger:hover{background:#dc2626;border-color:#dc2626}.btn-ghost{background:transparent;border-color:transparent;box-shadow:none}.btn-ghost:hover{background:var(--bg-2);border-color:transparent}.btn-sm{padding:4px 10px;font-size:12px}.btn-xs{padding:3px 8px;font-size:11px;border-radius:6px}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.01em;line-height:1.6;border:1px solid transparent}.badge-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.badge-success{background:rgba(16,185,129,.09);color:#34d399;border-color:rgba(16,185,129,.2)}.badge-success .badge-dot{background:#10b981;box-shadow:0 0 5px rgba(16,185,129,.8)}.badge-warning{background:rgba(245,158,11,.09);color:#fbbf24;border-color:rgba(245,158,11,.2)}.badge-warning .badge-dot{background:#f59e0b;box-shadow:0 0 5px rgba(245,158,11,.8)}.badge-danger{background:rgba(239,68,68,.09);color:#f87171;border-color:rgba(239,68,68,.2)}.badge-danger .badge-dot{background:#ef4444;box-shadow:0 0 5px rgba(239,68,68,.8)}.badge-info{background:rgba(59,130,246,.09);color:#60a5fa;border-color:rgba(59,130,246,.22)}.badge-info .badge-dot{background:var(--primary);box-shadow:0 0 5px rgba(129,140,248,.8)}.badge-gray{background:var(--bg-hover);color:var(--text-3);border-color:var(--border)}.badge-gray .badge-dot{background:var(--text-3)}.badge-purple{background:rgba(167,139,250,.09);color:#c4b5fd;border-color:rgba(167,139,250,.22)}.badge-purple .badge-dot{background:#a78bfa;box-shadow:0 0 5px rgba(167,139,250,.8)}.suggestion-chip{padding:5px 12px;background:var(--bg-2);border:1px solid var(--border);border-radius:20px;color:var(--text-2);font-size:12px;cursor:pointer;font-family:var(--font);transition:all .1s;white-space:nowrap}.suggestion-chip:hover{background:var(--bg-3);border-color:var(--border-2);color:var(--text)}.chat-container{gap:14px}.chat-container,.chat-messages{display:flex;flex-direction:column}.chat-messages{gap:10px;min-height:80px}.chat-msg{padding:10px 14px;border-radius:var(--radius-lg);font-size:13px;line-height:1.65;max-width:85%}.chat-msg-user{align-self:flex-end;background:var(--primary);color:#fff;border-radius:var(--radius-lg) var(--radius-lg) 4px var(--radius-lg)}.chat-msg-agent{align-self:flex-start;background:var(--bg-2);border:1px solid var(--border);color:var(--text);border-radius:4px var(--radius-lg) var(--radius-lg) var(--radius-lg)}.chat-input-wrap{display:flex;gap:8px;align-items:flex-end;padding-top:10px;border-top:1px solid var(--border)}.chat-input{flex:1 1;background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:13px;padding:9px 12px;resize:none;outline:none;min-height:38px;max-height:160px;transition:border-color .12s}.chat-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(129,140,248,.18);background:var(--bg-3)}.chat-send-btn{background:var(--primary);border:none;border-radius:var(--radius);color:#fff;cursor:pointer;padding:9px 14px;font-size:13px;font-weight:600;font-family:var(--font);height:38px;box-shadow:inset 0 0 0 1px rgba(129,140,248,.4);transition:all .1s}.chat-send-btn:hover{background:#4f46e5;box-shadow:0 2px 10px rgba(129,140,248,.35),inset 0 0 0 1px rgba(129,140,248,.45)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}button:not(:disabled):hover{filter:brightness(1.1)}button:not(:disabled):active{filter:brightness(.95);transform:scale(.98)}button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.hide-scrollbar{scrollbar-width:none;-ms-overflow-style:none}.hide-scrollbar::-webkit-scrollbar{display:none}.skeleton{border-radius:var(--radius);display:block}.loading-dots{display:flex;gap:4px;padding:8px 14px;align-items:center}.loading-dots span{width:5px;height:5px;border-radius:50%;background:var(--primary);animation:consol-bounce 1.2s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.15s}.loading-dots span:nth-child(3){animation-delay:.3s}@keyframes consol-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.07);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.13)}.search-input{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:13px;padding:7px 12px 7px 34px;outline:none;width:100%;transition:border-color .12s,box-shadow .12s}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(129,140,248,.18);background:var(--bg-3)}.search-input::placeholder{color:var(--text-3)}.divider{height:1px;background:var(--border);margin:12px 0}.mono{font-family:var(--mono)!important}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.glow-primary{box-shadow:0 0 0 1px rgba(129,140,248,.28),0 4px 18px rgba(129,140,248,.18)}.glow-green{box-shadow:0 0 0 1px rgba(16,185,129,.28),0 4px 18px rgba(16,185,129,.14)}.glow-red{box-shadow:0 0 0 1px rgba(239,68,68,.28),0 4px 18px rgba(239,68,68,.14)}.kpi-value{font-size:26px;font-weight:800;letter-spacing:-.05em;color:var(--text);font-family:var(--mono);line-height:1.1}.kpi-label{font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:5px}.route-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.18);border-radius:20px;font-size:11px;font-family:var(--mono);font-weight:500;color:#60a5fa;letter-spacing:.02em}.mode-pill-ocean{background:rgba(59,130,246,.09);border-color:rgba(59,130,246,.2);color:#60a5fa}.mode-pill-air{background:rgba(245,158,11,.09);border-color:rgba(245,158,11,.2);color:#fbbf24}.code,code{font-family:var(--mono);font-size:11px;background:var(--bg-3);border:1px solid var(--border);border-radius:4px;padding:1px 5px;color:var(--cyan)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 32px;color:var(--text-3)}.empty-icon{font-size:32px;margin-bottom:14px;opacity:.6}.empty-title{font-size:15px;font-weight:600;color:var(--text-2);margin-bottom:6px}.empty-body{font-size:13px;line-height:1.65;max-width:340px}::selection{background:rgba(129,140,248,.3);color:#fff}.data-table{width:100%;border-collapse:collapse}.data-table th{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;text-align:left;border-bottom:1px solid var(--border-2);position:-webkit-sticky;position:sticky;top:0;z-index:2;background:var(--bg-2)}.data-table td,.data-table th{padding:var(--space-3) var(--space-3)}.data-table td{font-size:13px;border-bottom:1px solid var(--border)}.data-table tbody tr:nth-child(2n){background:var(--bg-hover)}.data-table tbody tr:hover{background:var(--bg-subtle)}.data-table tbody tr:hover td{color:var(--text)}.badge,[class*=badge-]{min-height:22px;display:inline-flex;align-items:center;padding:3px 10px;font-size:11px;border-radius:20px;font-weight:600}input:not([type=checkbox]):not([type=radio]):not([type=file]),select,textarea{min-height:36px}@media (max-width:768px){.app-sidebar{display:none!important}.app-main{margin-left:0!important;width:100%!important}.module-content,[class*=page-container]{padding:12px!important}.data-table thead{display:none!important}.data-table tbody tr{display:block!important;border:1px solid var(--border);border-radius:8px;margin-bottom:8px;padding:10px 12px!important}.data-table tbody td{display:flex!important;justify-content:space-between;padding:3px 0!important;font-size:12px!important;border:none!important}.data-table tbody td:before{content:attr(data-label);color:var(--text-3);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}[style*="grid-template-columns: repeat(4"],[style*="gridTemplateColumns: 'repeat(3"],[style*="gridTemplateColumns: 'repeat(4"]{grid-template-columns:1fr 1fr!important}.kpi-value{font-size:18px!important}.kpi-label{font-size:9px!important}.topbar-title{font-size:13px!important}.form-grid-2,.form-grid-3{grid-template-columns:1fr!important}.wr-card-actions{flex-direction:column!important}.wr-card-meta{flex-wrap:wrap!important;gap:6px!important}.hide-mobile{display:none!important}.mobile-stack{flex-direction:column!important}.mobile-full-width{width:100%!important}}@keyframes skeleton-pulse{0%{opacity:.6}50%{opacity:.3}to{opacity:.6}}.skeleton{background:var(--bg-3);border-radius:6px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-text{height:12px;margin-bottom:8px;border-radius:4px}.skeleton-text-sm{height:10px;margin-bottom:6px;width:60%;border-radius:3px}.skeleton-card{background:var(--bg-1);border:1px solid var(--border);border-radius:10px;padding:18px;min-height:100px}.skeleton-card .skeleton{margin-bottom:10px}.skeleton-row{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.skeleton-row .skeleton{flex:1 1;height:14px}.skeleton-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0}.fade-in{animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .25s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.card-hover{transition:all .15s ease}.card-hover:hover{border-color:var(--primary)!important;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.08)}.tab-content{animation:tabSlide .2s ease-out}@keyframes tabSlide{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}a[role=button],button{transition:all .12s ease}.btn-lift:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.12)}.empty-state{text-align:center;padding:48px 24px;background:var(--bg-1);border:1px dashed var(--border);border-radius:12px}.empty-state-icon{width:64px;height:64px;margin:0 auto 16px;border-radius:16px;background:var(--bg-2);display:flex;align-items:center;justify-content:center;font-size:28px;border:1px solid var(--border)}.empty-state-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}.empty-state-body{font-size:13px;color:var(--text-3);line-height:1.6;max-width:360px;margin:0 auto 20px}.empty-state-action{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;padding:10px 20px;border-radius:8px;border:none;background:var(--primary);color:#fff;cursor:pointer;text-decoration:none}@media (max-width:900px){.page-content{padding:16px}.topbar{padding:0 12px}}@media (max-width:768px){.page-content{padding:12px}}@media (max-width:480px){.page-content{padding:8px}}@media (max-width:768px){.portal-kpis{grid-template-columns:repeat(2,1fr)!important}.portal-actions{grid-template-columns:1fr!important}.portal-header{flex-direction:column;gap:8px;align-items:flex-start!important}.portal-header-right{flex-wrap:wrap}.portal-tabs{gap:1px!important}.portal-tabs button{padding:6px 10px!important;font-size:11px!important}}@media (max-width:480px){.portal-kpis{grid-template-columns:1fr!important}}.portal-light{--bg:#f5f7fa;--bg-1:#ffffff;--bg-2:#f0f2f5;--bg-3:#e8ebef;--bg-4:#dfe2e6;--bg-hover:rgba(0,0,0,0.03);--bg-subtle:rgba(0,0,0,0.04);--bg-raised:rgba(0,0,0,0.08);--text:#1a1d23;--text-2:#4a5568;--text-3:#8896a6;--text-inverse:#ffffff;--border:rgba(0,0,0,0.08);--border-2:rgba(0,0,0,0.14);--primary:#4f46e5;--primary-dim:rgba(79,70,229,0.08);--primary-glow:rgba(79,70,229,0.15);--primary-border:rgba(79,70,229,0.25);--shadow-xs:0 1px 3px rgba(0,0,0,0.06);--shadow-sm:0 2px 8px rgba(0,0,0,0.08);--shadow:0 4px 16px rgba(0,0,0,0.10);color:var(--text);background:var(--bg)}.portal-light .portal-tabs{background:#e8ebef}.portal-light .portal-tabs button,.portal-light .portal-tabs button[aria-selected=true]{color:#4a5568}.chat-bubble{padding:10px 14px;border-radius:12px;max-width:85%;font-size:13px;line-height:1.6}.chat-bubble-user{background:var(--primary);color:#fff;border-bottom-right-radius:4px;margin-left:auto}.chat-bubble-staff{background:var(--bg-2);color:var(--text);border-bottom-left-radius:4px;border:1px solid var(--border)}.chat-bubble-time{font-size:10px;color:var(--text-3);margin-top:4px}.doc-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;font-weight:700}.doc-icon-pdf{background:rgba(239,68,68,.1);color:#DC2626}.doc-icon-image{background:rgba(59,130,246,.1);color:#3B82F6}.doc-icon-excel{background:rgba(16,185,129,.1);color:#059669}.doc-icon-doc{background:rgba(99,102,241,.1);color:#6366f1}.doc-icon-other{background:var(--bg-3);color:var(--text-3)}@media (max-width:600px){.portal-invoice-header{flex-direction:column!important;gap:8px!important}.portal-invoice-summary{grid-template-columns:1fr!important}.portal-invoice-amount{font-size:18px!important}.portal-booking-form-cargo,.portal-booking-form-dates,.portal-booking-form-route{grid-template-columns:1fr!important}.portal-shipment-card{padding:12px!important}.portal-shipment-eta{display:none!important}.portal-shipment-dates{flex-direction:column!important;gap:2px!important}}@media print{.chat-bubble-user,.empty-state-action,.portal-header-right,.portal-tabs,[role=tablist],button{display:none!important}.portal-light{background:#fff!important}*{color:#000!important;border-color:#ddd!important}.card-hover{box-shadow:none!important;transform:none!important}}