@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap");:root{--primary-50:#eff6ff;--primary-100:#dbeafe;--primary-200:#bfdbfe;--primary-300:#93c5fd;--primary-400:#60a5fa;--primary-500:#3b82f6;--primary-600:#2563eb;--primary-700:#1d4ed8;--primary-800:#1e40af;--primary-900:#1e3a8a;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--success:#10b981;--success-bg:#d1fae5;--success-text:#065f46;--warning:#f59e0b;--warning-bg:#fef3c7;--warning-text:#92400e;--danger:#ef4444;--danger-bg:#fee2e2;--danger-text:#991b1b;--info:#3b82f6;--info-bg:#dbeafe;--info-text:#1e40af;--sidebar-width:260px;--sidebar-collapsed-width:72px;--topbar-height:56px;--page-padding:24px;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-xs:0.6875rem;--font-sm:0.8125rem;--font-base:0.875rem;--font-md:1rem;--font-lg:1.125rem;--font-xl:1.25rem;--font-2xl:1.5rem;--font-3xl:1.875rem;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--border-color:#e2e8f0;--shadow-xs:0 1px 2px rgba(0,0,0,.04);--shadow-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 6px -1px rgba(0,0,0,.07),0 2px 4px -2px rgba(0,0,0,.05);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -4px rgba(0,0,0,.04);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.08),0 8px 10px -6px rgba(0,0,0,.04);--transition-fast:150ms ease;--transition-base:200ms ease;--transition-slow:300ms ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-base);color:var(--gray-800);background:var(--gray-100);line-height:1.5;overflow-x:hidden}a{color:var(--primary-600);text-decoration:none}a:hover{color:var(--primary-700)}h1,h2,h3,h4,h5,h6{font-weight:600;color:var(--gray-900);line-height:1.3}h1{font-size:var(--font-3xl)}h2{font-size:var(--font-2xl)}h3{font-size:var(--font-xl)}h4{font-size:var(--font-lg)}img{max-width:100%;display:block}::selection{background:var(--primary-200);color:var(--primary-900)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.app-layout,.main-wrapper{display:flex;min-height:100vh}.main-wrapper{flex:1 1;margin-left:var(--sidebar-width);flex-direction:column;transition:margin-left var(--transition-slow)}.main-wrapper.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.page-content{flex:1 1;padding:var(--page-padding);max-width:1440px;width:100%}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:linear-gradient(180deg,var(--gray-900) 0,var(--gray-800) 100%);color:#fff;display:flex;flex-direction:column;z-index:100;transition:width var(--transition-slow);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{justify-content:space-between;padding:var(--space-4) var(--space-5);height:var(--topbar-height);border-bottom:1px solid hsla(0,0%,100%,.08);flex-shrink:0}.sidebar-header,.sidebar-logo{display:flex;align-items:center}.sidebar-logo{gap:var(--space-3);font-weight:700;font-size:var(--font-lg);white-space:nowrap}.sidebar-logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--primary-500),var(--primary-700));border-radius:var(--radius-lg);flex-shrink:0}.sidebar-logo-icon,.sidebar-toggle{display:flex;align-items:center;justify-content:center;font-size:1.1rem}.sidebar-toggle{background:none;border:none;color:var(--gray-400);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.sidebar-toggle:hover{color:#fff;background:hsla(0,0%,100%,.1)}.sidebar-nav{flex:1 1;overflow-y:auto;padding:var(--space-3) 0}.nav-group{margin-bottom:var(--space-2)}.nav-group-title{font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);padding:var(--space-2) var(--space-5) var(--space-1);white-space:nowrap;overflow:hidden}.sidebar.collapsed .nav-group-title{font-size:0;padding:var(--space-1) var(--space-5)}.sidebar.collapsed .nav-group-title:after{content:"";display:block;width:20px;height:1px;background:var(--gray-700);margin:0 auto}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-5);color:var(--gray-400);cursor:pointer;transition:all var(--transition-fast);border-left:3px solid transparent;font-size:var(--font-sm);white-space:nowrap;overflow:hidden;text-decoration:none}.nav-item:hover{color:#fff;background:hsla(0,0%,100%,.05)}.nav-item.active{color:#fff;background:rgba(59,130,246,.15);border-left-color:var(--primary-500)}.nav-item-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem}.nav-item-label{flex:1 1;overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .nav-item-label{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:var(--space-3) 0;border-left:none}.nav-item-badge{background:var(--primary-600);color:#fff;font-size:var(--font-xs);padding:1px 7px;border-radius:10px;font-weight:600;flex-shrink:0}.sidebar.collapsed .nav-item-badge{display:none}.sidebar-footer{padding:var(--space-4) var(--space-5);border-top:1px solid hsla(0,0%,100%,.08);flex-shrink:0}.sidebar-user{gap:var(--space-3)}.sidebar-avatar,.sidebar-user{display:flex;align-items:center}.sidebar-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--primary-500),var(--primary-300));justify-content:center;font-weight:600;font-size:var(--font-sm);flex-shrink:0}.sidebar-user-info{overflow:hidden}.sidebar-user-name{font-size:var(--font-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:var(--font-xs);color:var(--gray-500);white-space:nowrap}.sidebar.collapsed .sidebar-user-info{display:none}.topbar{height:var(--topbar-height);background:#fff;border-bottom:1px solid var(--border-color);justify-content:space-between;padding:0 var(--page-padding);position:-webkit-sticky;position:sticky;top:0;z-index:50}.topbar,.topbar-left{display:flex;align-items:center}.topbar-left{gap:var(--space-4)}.breadcrumbs{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm)}.breadcrumb-item,.breadcrumbs{color:var(--gray-500)}.breadcrumb-item:hover{color:var(--primary-600)}.breadcrumb-item.active{color:var(--gray-800);font-weight:500}.breadcrumb-separator{color:var(--gray-300);font-size:var(--font-xs)}.topbar-right{display:flex;align-items:center;gap:var(--space-3)}.topbar-search{position:relative}.topbar-search input{width:260px;height:34px;padding:0 var(--space-4) 0 36px;border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--font-sm);background:var(--gray-50);transition:all var(--transition-fast);font-family:var(--font-family);outline:none}.topbar-search input:focus{border-color:var(--primary-400);background:#fff;box-shadow:0 0 0 3px var(--primary-100);width:320px}.topbar-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--gray-400);font-size:var(--font-base);pointer-events:none}.topbar-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:var(--radius-md);cursor:pointer;color:var(--gray-500);transition:all var(--transition-fast);position:relative;font-size:1.1rem}.topbar-btn:hover{background:var(--gray-100);color:var(--gray-700)}.topbar-btn .notification-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;background:var(--danger);border-radius:50%;border:1.5px solid #fff}.user-menu-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border:none;background:transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.user-menu-btn:hover{background:var(--gray-100)}.user-menu-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--primary-600),var(--primary-400));color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);font-weight:600}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-6)}.page-header-left h1{font-size:var(--font-2xl);font-weight:700;margin-bottom:var(--space-1)}.page-header-subtitle{color:var(--gray-500);font-size:var(--font-sm)}.page-header-actions{display:flex;align-items:center;gap:var(--space-3)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid transparent;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;line-height:1.5}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-600);color:#fff;border-color:var(--primary-600)}.btn-primary:hover:not(:disabled){background:var(--primary-700);border-color:var(--primary-700)}.btn-secondary{background:#fff;color:var(--gray-700);border-color:var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover:not(:disabled){background:#059669}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:transparent;color:var(--gray-600)}.btn-ghost:hover:not(:disabled){background:var(--gray-100)}.btn-warning{background:var(--warning);color:#fff;border-color:var(--warning)}.btn-warning:hover:not(:disabled){background:#d97706}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--font-md)}.btn-icon{width:34px;height:34px;padding:0;border-radius:var(--radius-md)}.card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);transition:box-shadow var(--transition-base)}.card:hover{box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-color)}.card-header h3{font-size:var(--font-base);font-weight:600}.card-body{padding:var(--space-5)}.card-footer{padding:var(--space-3) var(--space-5);border-top:1px solid var(--border-color);background:var(--gray-50);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:var(--space-4);gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;align-items:flex-start;gap:var(--space-4);transition:all var(--transition-base);box-shadow:var(--shadow-xs)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.stat-card-icon.blue{background:var(--primary-100);color:var(--primary-600)}.stat-card-icon.green{background:var(--success-bg);color:var(--success)}.stat-card-icon.orange{background:var(--warning-bg);color:var(--warning)}.stat-card-icon.red{background:var(--danger-bg);color:var(--danger)}.stat-card-icon.purple{background:#ede9fe;color:#7c3aed}.stat-card-content{flex:1 1;min-width:0}.stat-card-label{font-size:var(--font-xs);color:var(--gray-500);text-transform:uppercase;letter-spacing:.03em;font-weight:500;margin-bottom:var(--space-1)}.stat-card-value{font-size:var(--font-2xl);font-weight:700;color:var(--gray-900);line-height:1.2}.stat-card-trend{display:inline-flex;align-items:center;gap:3px;font-size:var(--font-xs);font-weight:500;margin-top:var(--space-1);padding:1px 6px;border-radius:var(--radius-sm)}.stat-card-trend.up{color:var(--success-text);background:var(--success-bg)}.stat-card-trend.down{color:var(--danger-text);background:var(--danger-bg)}.stat-card-trend.neutral{color:var(--gray-600);background:var(--gray-100)}.data-table-wrapper{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden}.data-table-toolbar{justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-color);flex-wrap:wrap}.data-table-toolbar,.data-table-toolbar-left{display:flex;align-items:center;gap:var(--space-3)}.data-table-toolbar-right{display:flex;align-items:center;gap:var(--space-2)}.data-table-search{position:relative}.data-table-search input{width:240px;height:32px;padding:0 var(--space-3) 0 32px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-sm);font-family:var(--font-family);outline:none;transition:all var(--transition-fast)}.data-table-search input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100)}.data-table-search-icon{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--gray-400);font-size:var(--font-sm)}.data-table-filter{display:flex;align-items:center;gap:var(--space-2)}.data-table-filter select{height:32px;padding:0 var(--space-6) 0 var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-sm);font-family:var(--font-family);background:#fff;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;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 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.data-table{width:100%;border-collapse:collapse}.data-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);background:var(--gray-50);border-bottom:1px solid var(--border-color);white-space:nowrap;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:all var(--transition-fast)}.data-table th:hover{color:var(--gray-700);background:var(--gray-100)}.data-table th .sort-icon{margin-left:var(--space-1);opacity:.4;font-size:10px}.data-table th.sorted .sort-icon{opacity:1;color:var(--primary-600)}.data-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-color);font-size:var(--font-sm);color:var(--gray-700);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--primary-50)}.data-table tbody tr.clickable{cursor:pointer}.data-table-id{font-weight:600;color:var(--primary-600)}.data-table-pagination{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-color);font-size:var(--font-sm);color:var(--gray-500)}.data-table-pagination-btns{display:flex;gap:var(--space-1)}.data-table-pagination-btns button{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#fff;cursor:pointer;font-size:var(--font-sm);transition:all var(--transition-fast);color:var(--gray-600);font-family:var(--font-family)}.data-table-pagination-btns button:hover{background:var(--gray-50);border-color:var(--gray-300)}.data-table-pagination-btns button.active{background:var(--primary-600);color:#fff;border-color:var(--primary-600)}.data-table-pagination-btns button:disabled{opacity:.4;cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 10px;border-radius:20px;font-size:var(--font-xs);font-weight:500;white-space:nowrap;line-height:1.6}.badge-dot{width:6px;height:6px;border-radius:50%}.badge-draft{background:var(--gray-100);color:var(--gray-600)}.badge-draft .badge-dot{background:var(--gray-400)}.badge-pending{background:var(--warning-bg);color:var(--warning-text)}.badge-pending .badge-dot{background:var(--warning)}.badge-active,.badge-approved,.badge-completed,.badge-delivered,.badge-matched,.badge-paid{background:var(--success-bg);color:var(--success-text)}.badge-active .badge-dot,.badge-approved .badge-dot,.badge-completed .badge-dot,.badge-delivered .badge-dot,.badge-matched .badge-dot,.badge-paid .badge-dot{background:var(--success)}.badge-cancelled,.badge-critical,.badge-overdue,.badge-rejected{background:var(--danger-bg);color:var(--danger-text)}.badge-cancelled .badge-dot,.badge-critical .badge-dot,.badge-overdue .badge-dot,.badge-rejected .badge-dot{background:var(--danger)}.badge-in-progress,.badge-open,.badge-processing,.badge-sent,.badge-submitted{background:var(--info-bg);color:var(--info-text)}.badge-in-progress .badge-dot,.badge-open .badge-dot,.badge-processing .badge-dot,.badge-sent .badge-dot,.badge-submitted .badge-dot{background:var(--info)}.badge-partial,.badge-review{background:#fdf4ff;color:#86198f}.badge-partial .badge-dot,.badge-review .badge-dot{background:#a855f7}.badge-closed{background:var(--gray-100);color:var(--gray-600)}.badge-closed .badge-dot{background:var(--gray-500)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--font-sm);font-weight:500;color:var(--gray-700);margin-bottom:var(--space-1)}.form-label .required{color:var(--danger);margin-left:2px}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-sm);font-family:var(--font-family);color:var(--gray-800);background:#fff;transition:all var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100)}.form-input::placeholder{color:var(--gray-400)}.form-textarea{min-height:80px;resize:vertical}.form-hint{color:var(--gray-500)}.form-error,.form-hint{font-size:var(--font-xs);margin-top:var(--space-1)}.form-error{color:var(--danger)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:var(--space-4);gap:var(--space-4)}.ai-insights-section{margin-bottom:var(--space-6)}.ai-insight-card{background:linear-gradient(135deg,var(--primary-50) 0,#f0f4ff 100%);border:1px solid var(--primary-200);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);display:flex;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-3);transition:all var(--transition-base);position:relative;overflow:hidden}.ai-insight-card:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg,var(--primary-500),var(--primary-300))}.ai-insight-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-300)}.ai-insight-card.warning{background:linear-gradient(135deg,#fffbeb,#fff8e6);border-color:#fde68a}.ai-insight-card.warning:before{background:linear-gradient(180deg,var(--warning),#fbbf24)}.ai-insight-card.danger{background:linear-gradient(135deg,#fef2f2,#fff1f1);border-color:#fecaca}.ai-insight-card.danger:before{background:linear-gradient(180deg,var(--danger),#f87171)}.ai-insight-card.success{background:linear-gradient(135deg,#ecfdf5,#f0fff4);border-color:#a7f3d0}.ai-insight-card.success:before{background:linear-gradient(180deg,var(--success),#34d399)}.ai-insight-icon{width:36px;height:36px;border-radius:var(--radius-md);background:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:var(--shadow-sm);flex-shrink:0}.ai-insight-content{flex:1 1;min-width:0}.ai-insight-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1)}.ai-insight-title{font-size:var(--font-sm);font-weight:600;color:var(--gray-900)}.ai-insight-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:1px 6px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff}.ai-insight-message{font-size:var(--font-sm);color:var(--gray-600);line-height:1.5}.ai-insight-actions{display:flex;gap:var(--space-2);margin-top:var(--space-3)}.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:var(--space-10) var(--space-4);animation:fadeIn var(--transition-base);overflow-y:auto}.modal{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:640px;animation:slideUp var(--transition-slow)}.modal-lg{max-width:860px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:var(--font-lg);font-weight:600}.modal-close{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:none;background:var(--gray-100);border-radius:var(--radius-md);cursor:pointer;color:var(--gray-500);font-size:var(--font-lg);transition:all var(--transition-fast)}.modal-close:hover{background:var(--gray-200);color:var(--gray-700)}.modal-body{padding:var(--space-5);max-height:60vh;overflow-y:auto}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-color);background:var(--gray-50);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.detail-panel{position:fixed;top:0;right:0;width:520px;max-width:90vw;height:100vh;background:#fff;box-shadow:var(--shadow-xl);z-index:200;display:flex;flex-direction:column;animation:slideInRight var(--transition-slow)}.detail-panel-overlay{position:fixed;inset:0;background:rgba(15,23,42,.3);z-index:199}.detail-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-color);flex-shrink:0}.detail-panel-body{flex:1 1;overflow-y:auto;padding:var(--space-5)}.detail-panel-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-color);background:var(--gray-50);flex-shrink:0}.detail-section{margin-bottom:var(--space-6)}.detail-section-title{font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-color)}.detail-field{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-2) 0;font-size:var(--font-sm)}.detail-field-label{color:var(--gray-500);font-weight:500;flex-shrink:0;width:140px}.detail-field-value{color:var(--gray-800);text-align:right;flex:1 1}.timeline{position:relative;padding-left:var(--space-6)}.timeline:before{content:"";position:absolute;left:11px;top:4px;bottom:4px;width:2px;background:var(--border-color)}.timeline-item{position:relative;padding-bottom:var(--space-5)}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:calc(-1 * var(--space-6) + 5px);top:4px;width:14px;height:14px;border-radius:50%;background:#fff;border:2px solid var(--primary-500)}.timeline-dot.success{border-color:var(--success)}.timeline-dot.warning{border-color:var(--warning)}.timeline-dot.danger{border-color:var(--danger)}.timeline-content{font-size:var(--font-sm)}.timeline-title{font-weight:500;color:var(--gray-800)}.timeline-meta{font-size:var(--font-xs);color:var(--gray-500);margin-top:2px}.charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));grid-gap:var(--space-4);gap:var(--space-4);margin-bottom:var(--space-6);min-width:0}.chart-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden;min-width:0}.chart-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-color)}.chart-card-header h3{font-size:var(--font-base);font-weight:600}.chart-card-body{padding:var(--space-4) var(--space-4) var(--space-2)}.tabs{display:flex;border-bottom:2px solid var(--border-color);margin-bottom:var(--space-5);gap:0}.tab{padding:var(--space-3) var(--space-5);font-size:var(--font-sm);font-weight:500;color:var(--gray-500);cursor:pointer;margin-bottom:-2px;transition:all var(--transition-fast);background:none;border:none;border-bottom:2px solid transparent;font-family:var(--font-family)}.tab:hover{color:var(--gray-700)}.tab.active{color:var(--primary-600);border-bottom-color:var(--primary-600)}.empty-state{text-align:center;padding:var(--space-12) var(--space-6);color:var(--gray-500)}.empty-state-icon{font-size:3rem;margin-bottom:var(--space-4);opacity:.5}.empty-state h3{font-size:var(--font-lg);color:var(--gray-600);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--font-sm);max-width:360px;margin:0 auto var(--space-5)}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:var(--space-12)}.spinner{width:36px;height:36px;border:3px solid var(--gray-200);border-top-color:var(--primary-600);border-radius:50%;animation:spin .7s linear infinite}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:500;background:var(--gray-100);color:var(--gray-700)}.tag-blue{background:var(--primary-100);color:var(--primary-700)}.tag-green{background:var(--success-bg);color:var(--success-text)}.tag-red{background:var(--danger-bg);color:var(--danger-text)}.tag-orange{background:var(--warning-bg);color:var(--warning-text)}.progress-bar{width:100%;height:6px;background:var(--gray-200);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:3px;transition:width var(--transition-slow);background:linear-gradient(90deg,var(--primary-500),var(--primary-400))}.progress-bar-fill.success{background:linear-gradient(90deg,var(--success),#34d399)}.progress-bar-fill.warning{background:linear-gradient(90deg,var(--warning),#fbbf24)}.progress-bar-fill.danger{background:linear-gradient(90deg,var(--danger),#f87171)}.avatar-group{display:flex}.avatar-group .avatar{width:28px;height:28px;border-radius:50%;border:2px solid #fff;margin-left:-8px;display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);font-weight:600;color:#fff}.avatar-group .avatar:first-child{margin-left:0}.avatar-1{background:var(--primary-500)}.avatar-2{background:#8b5cf6}.avatar-3{background:#ec4899}.avatar-4{background:var(--success)}.avatar-5{background:var(--warning)}.tag-purple{background:#ede9fe;color:#7c3aed}.timeline-dot.active{border-color:var(--primary-500);background:var(--primary-100)}.badge-warning{background:var(--warning-bg);color:var(--warning-text)}.badge-warning .badge-dot{background:var(--warning)}.badge-pending-approval{background:var(--warning-bg);color:var(--warning-text)}.badge-pending-approval .badge-dot{background:var(--warning)}.badge-confirmed{background:var(--success-bg);color:var(--success-text)}.badge-confirmed .badge-dot{background:var(--success)}.badge-in-transit{background:var(--info-bg);color:var(--info-text)}.badge-in-transit .badge-dot{background:var(--info)}.data-table-toolbar select{height:32px;padding:0 var(--space-6) 0 var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-sm);font-family:var(--font-family);background:#fff;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;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 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.reports-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:var(--space-4);gap:var(--space-4);margin-bottom:var(--space-6)}.report-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-xs);transition:all var(--transition-base);display:flex;flex-direction:column}.report-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.report-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.report-card-icon{font-size:1.5rem}.report-card-title{font-size:var(--font-base);font-weight:600;color:var(--gray-800);margin-bottom:var(--space-2)}.report-card-desc{font-size:var(--font-sm);color:var(--gray-500);line-height:1.5;flex:1 1;margin-bottom:var(--space-4)}.report-card-actions{display:flex;gap:var(--space-2)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes pulseGlow{0%,to{opacity:1;box-shadow:0 0 0 0 rgba(139,92,246,.4)}50%{opacity:.6;box-shadow:0 0 0 4px rgba(139,92,246,0)}}.pulse-glow{animation:pulseGlow 2s ease-in-out infinite}.tag-yellow{background:#fef3c7;color:#92400e}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.text-right{text-align:right}.text-center{text-align:center}.text-sm{font-size:var(--font-sm)}.text-xs{font-size:var(--font-xs)}.text-muted{color:var(--gray-500)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:1024px){.sidebar{width:var(--sidebar-collapsed-width)}.sidebar .nav-group-title,.sidebar .nav-item-badge,.sidebar .nav-item-label,.sidebar .sidebar-user-info{display:none}.sidebar .nav-item{justify-content:center;padding:var(--space-3) 0;border-left:none}.main-wrapper{margin-left:var(--sidebar-collapsed-width)}.stats-row{grid-template-columns:repeat(2,1fr)}.charts-row{grid-template-columns:1fr}}@media (max-width:640px){.sidebar{transform:translateX(-100%);width:var(--sidebar-width)}.sidebar.mobile-open{transform:translateX(0)}.main-wrapper{margin-left:0}.page-content{padding:var(--space-4)}.stats-row{grid-template-columns:1fr}.page-header{flex-direction:column;gap:var(--space-3)}.topbar-search input{width:160px}.data-table-toolbar{flex-direction:column;align-items:stretch}.detail-panel{width:100%}}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{gap:10px;padding:12px 20px;border-radius:var(--radius-lg);background:var(--gray-900);color:#fff;font-size:var(--font-sm);font-weight:500;box-shadow:var(--shadow-xl);animation:toastIn .3s ease forwards;pointer-events:auto;min-width:280px;max-width:420px}.toast,.toast-icon{display:flex;align-items:center}.toast-icon{width:22px;height:22px;border-radius:50%;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.toast-success .toast-icon{background:#10b981}.toast-error .toast-icon{background:#ef4444}.toast-info .toast-icon{background:#3b82f6}.toast-warning .toast-icon{background:#f59e0b;color:#000}.toast-message{flex:1 1;line-height:1.4}@keyframes toastIn{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:9000;animation:fadeIn .15s ease}.confirm-dialog{background:#fff;border-radius:var(--radius-xl);padding:28px;max-width:400px;width:90%;box-shadow:var(--shadow-xl)}.confirm-dialog h3{font-size:var(--font-lg);margin-bottom:8px}.confirm-dialog p{font-size:var(--font-sm);color:var(--gray-500);margin-bottom:20px;line-height:1.5}.confirm-dialog-actions{display:flex;gap:10px;justify-content:flex-end}