*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--ps-navy: #0F1E35;--ps-navy-mid: #1B2E4A;--ps-navy-light: #243D5E;--ps-blue: #1A6FBF;--ps-blue-bright:#2484E4;--ps-accent: #F59E0B;--ps-green: #16A34A;--ps-red: #DC2626;--bg: #F0F2F5;--bg-card: #FFFFFF;--bg-hover: #F7F9FC;--border: #DDE3EC;--border-strong: #B8C4D4;--text-primary: #0F1E35;--text-secondary:#52657A;--text-muted: #8A9BB0;--text-inverse: #FFFFFF;--sidebar-w: 220px;--topbar-h: 56px;--ease: cubic-bezier(.16, 1, .3, 1);--dur: .16s;--font-sans: "DM Sans", system-ui, sans-serif;--font-mono: "DM Mono", "Fira Code", monospace;--shadow-sm: 0 1px 3px rgba(15,30,53,.08), 0 1px 2px rgba(15,30,53,.04);--shadow-md: 0 4px 12px rgba(15,30,53,.1), 0 2px 4px rgba(15,30,53,.06);--shadow-lg: 0 12px 32px rgba(15,30,53,.14), 0 4px 8px rgba(15,30,53,.08);--r-sm: 4px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px}html,body,#root{height:100%;font-family:var(--font-sans);font-size:14px;color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"topbar topbar" "sidebar main";height:100vh;overflow:hidden}.topbar{grid-area:topbar;background:var(--ps-navy);display:flex;align-items:center;padding:0 20px;gap:16px;position:relative;z-index:50;border-bottom:1px solid rgba(255,255,255,.06)}.topbar-logo{display:flex;align-items:center;gap:10px;text-decoration:none}.topbar-logo-mark{width:30px;height:30px;background:var(--ps-blue);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;letter-spacing:-.5px;flex-shrink:0}.topbar-logo-text{font-size:14px;font-weight:600;color:#fff;letter-spacing:.2px;line-height:1.2}.topbar-logo-sub{font-size:10px;font-weight:400;color:#ffffff73;letter-spacing:.8px;text-transform:uppercase}.topbar-spacer{flex:1}.topbar-env-badge{font-size:11px;font-family:var(--font-mono);padding:3px 8px;border-radius:var(--r-sm);background:#f59e0b26;color:var(--ps-accent);border:1px solid rgba(245,158,11,.25);letter-spacing:.5px}.topbar-user{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:var(--r-md);cursor:pointer;transition:background var(--dur) var(--ease)}.topbar-user:hover{background:#ffffff12}.topbar-avatar{width:30px;height:30px;border-radius:50%;background:var(--ps-blue);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;overflow:hidden;flex-shrink:0}.topbar-avatar img{width:100%;height:100%;object-fit:cover}.topbar-user-info{line-height:1.3}.topbar-user-name{font-size:13px;font-weight:500;color:#fff}.topbar-user-role{font-size:11px;color:#ffffff73}.topbar-logout-btn{background:none;border:1px solid rgba(255,255,255,.15);color:#fff9;padding:5px 12px;border-radius:var(--r-sm);font-size:12px;font-family:var(--font-sans);cursor:pointer;transition:all var(--dur) var(--ease)}.topbar-logout-btn:hover{background:#ffffff14;color:#fff;border-color:#ffffff4d}.sidebar{grid-area:sidebar;background:var(--ps-navy-mid);display:flex;flex-direction:column;overflow-y:auto;border-right:1px solid rgba(255,255,255,.04)}.sidebar-section{padding:20px 12px 8px}.sidebar-section-label{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:#ffffff40;padding:0 8px;margin-bottom:4px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--r-md);text-decoration:none;color:#ffffff8c;font-size:13.5px;font-weight:400;transition:all var(--dur) var(--ease);cursor:pointer;border:none;background:none;width:100%;text-align:left;position:relative}.nav-item:hover{background:#ffffff0f;color:#ffffffd9}.nav-item.active{background:#2484e42e;color:#fff;font-weight:500}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--ps-blue-bright);border-radius:0 2px 2px 0}.nav-icon{width:18px;height:18px;flex-shrink:0;opacity:.75}.nav-item.active .nav-icon,.nav-item:hover .nav-icon{opacity:1}.nav-badge{margin-left:auto;font-size:10px;font-weight:600;background:var(--ps-accent);color:var(--ps-navy);padding:2px 6px;border-radius:99px;min-width:18px;text-align:center}.sidebar-divider{height:1px;background:#ffffff0f;margin:8px 12px}.sidebar-spacer{flex:1}.sidebar-footer{padding:12px;border-top:1px solid rgba(255,255,255,.06)}.sidebar-version{font-size:10px;font-family:var(--font-mono);color:#fff3;padding:4px 8px}.main-content{grid-area:main;overflow-y:auto;overflow-x:hidden;background:var(--bg)}.page-container{padding:28px 32px;max-width:1400px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.page-title{font-size:22px;font-weight:600;color:var(--text-primary);letter-spacing:-.3px;line-height:1.2}.page-subtitle{font-size:13px;color:var(--text-secondary);margin-top:3px;font-weight:400}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.card-title{font-size:14px;font-weight:600;color:var(--text-primary)}.card-body{padding:20px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:8px;transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-label{font-size:11px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--text-muted)}.stat-value{font-size:28px;font-weight:600;color:var(--text-primary);letter-spacing:-1px;line-height:1}.stat-meta{font-size:12px;color:var(--text-secondary)}.stat-card.alert{border-left:3px solid var(--ps-red)}.stat-card.warning{border-left:3px solid var(--ps-accent)}.stat-card.success{border-left:3px solid var(--ps-green)}.stat-card.info{border-left:3px solid var(--ps-blue)}.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:99px;white-space:nowrap}.badge-green{background:#dcfce7;color:#166534}.badge-red{background:#fee2e2;color:#991b1b}.badge-amber{background:#fef3c7;color:#92400e}.badge-blue{background:#dbeafe;color:#1e40af}.badge-gray{background:#f1f5f9;color:#475569}.badge-navy{background:var(--ps-navy);color:#fff}.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--r-md);font-size:13px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--dur) var(--ease);border:none;white-space:nowrap;text-decoration:none}.btn-primary{background:var(--ps-blue);color:#fff}.btn-primary:hover{background:var(--ps-blue-bright);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{background:var(--ps-red);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:11px 22px;font-size:15px}.btn-icon{padding:7px;border-radius:var(--r-md)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{text-align:left;padding:10px 16px;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle}.data-table tbody tr{transition:background var(--dur) var(--ease)}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table tbody tr:last-child td{border-bottom:none}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.active{background:var(--ps-green);box-shadow:0 0 0 2px #16a34a33}.status-dot.inactive{background:var(--text-muted)}.status-dot.alert{background:var(--ps-red);box-shadow:0 0 0 2px #dc262633}.status-dot.warning{background:var(--ps-accent)}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:12px;font-weight:500;color:var(--text-secondary);letter-spacing:.2px}.form-input{padding:9px 12px;border:1px solid var(--border);border-radius:var(--r-md);font-size:13px;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-card);transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);outline:none}.form-input:focus{border-color:var(--ps-blue);box-shadow:0 0 0 3px #1a6fbf1f}.module-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;text-align:center;gap:16px}.module-placeholder-icon{width:56px;height:56px;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-muted)}.module-placeholder h3{font-size:16px;font-weight:600;color:var(--text-primary)}.module-placeholder p{font-size:13px;color:var(--text-secondary);max-width:360px;line-height:1.6}.module-placeholder .roadmap-items{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:4px}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--ps-navy);flex-direction:column;gap:20px}.loading-logo{display:flex;align-items:center;gap:12px}.loading-logo-mark{width:40px;height:40px;background:var(--ps-blue);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff}.loading-logo-text{font-size:20px;font-weight:600;color:#fff}.loading-spinner{width:24px;height:24px;border:2px solid rgba(255,255,255,.15);border-top-color:var(--ps-blue-bright);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--ps-navy);position:relative;overflow:hidden}.login-bg-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(36,132,228,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(36,132,228,.04) 1px,transparent 1px);background-size:40px 40px}.login-card{position:relative;z-index:10;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--r-xl);padding:48px 40px;width:100%;max-width:380px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:28px;animation:loginFadeIn .4s var(--ease) both}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login-brand{display:flex;flex-direction:column;align-items:center;gap:12px}.login-logo-mark{width:52px;height:52px;background:var(--ps-blue);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;letter-spacing:-.5px;box-shadow:0 8px 24px #1a6fbf66}.login-title{font-size:22px;font-weight:600;color:#fff;text-align:center;line-height:1.2}.login-subtitle{font-size:13px;color:#ffffff73;text-align:center;margin-top:-16px}.login-divider{width:100%;height:1px;background:#ffffff14}.login-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:13px 20px;background:#fff;color:var(--text-primary);border:none;border-radius:var(--r-md);font-size:14px;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--dur) var(--ease);box-shadow:var(--shadow-sm)}.login-btn:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.login-btn:active{transform:translateY(0)}.login-google-icon{width:18px;height:18px}.login-error{font-size:12px;color:#fca5a5;text-align:center;padding:8px 12px;background:#dc26261f;border-radius:var(--r-sm);border:1px solid rgba(220,38,38,.2);width:100%}.login-footer{font-size:11px;color:#fff3;text-align:center}.orders-shell{display:flex;flex-direction:column;height:calc(100vh - var(--topbar-h))}.orders-toolbar{display:flex;align-items:center;gap:12px;padding:10px 20px;background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0}.orders-toolbar-title{font-size:13px;font-weight:500;color:var(--text-secondary)}.orders-iframe-wrap{flex:1;position:relative;overflow:hidden}.orders-iframe{width:100%;height:100%;border:none;display:block}.orders-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px;z-index:5;transition:opacity .3s ease}.orders-loading-overlay.hidden{opacity:0;pointer-events:none}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:24px}.dashboard-grid-2{display:grid;grid-template-columns:2fr 1fr;gap:16px}@media (max-width: 1100px){.dashboard-grid{grid-template-columns:1fr 1fr}.dashboard-grid-2{grid-template-columns:1fr}}.van-id{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--ps-blue);background:#1a6fbf14;padding:2px 7px;border-radius:var(--r-sm)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center;color:var(--text-muted);gap:10px}.empty-state svg{opacity:.4}.empty-state h4{font-size:14px;font-weight:500;color:var(--text-secondary)}.empty-state p{font-size:13px;max-width:280px;line-height:1.5}.alert-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:var(--r-md);font-size:13px;margin-bottom:16px}.alert-banner.warning{background:#fef3c7;border:1px solid #F59E0B;color:#92400e}.alert-banner.error{background:#fee2e2;border:1px solid #DC2626;color:#991b1b}.alert-banner.info{background:#dbeafe;border:1px solid #3B82F6;color:#1e40af}
