@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{box-sizing:border-box;flex-direction:column;width:100%;min-height:100svh;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.dash{--dash-bg-base:#0b0e14;--dash-bg-elevated:#131722;--dash-bg-raised:#1a1f2e;--dash-border-subtle:#1f2533;--dash-border-strong:#2a3142;--dash-text-primary:#e8ecf4;--dash-text-secondary:#8b93a7;--dash-text-muted:#5a6275;--dash-accent-primary:#6366f1;--dash-accent-success:#10b981;--dash-accent-warning:#f59e0b;--dash-accent-danger:#ef4444;--dash-accent-ai:#a78bfa;--dash-gradient-hero:linear-gradient(135deg, #6366f11f, #a78bfa0f);--dash-gradient-glow:radial-gradient(circle at top right, #a78bfa26, transparent 70%);--dash-s-1:4px;--dash-s-2:8px;--dash-s-3:12px;--dash-s-4:16px;--dash-s-6:24px;--dash-s-8:32px;--dash-s-12:48px;--dash-radius:12px;background:var(--dash-bg-base);color:var(--dash-text-primary);min-height:100vh;padding:var(--dash-s-8);font-feature-settings:"ss01", "cv11";font-family:Inter,system-ui,Segoe UI,Roboto,sans-serif}.dash *,.dash :before,.dash :after{box-sizing:border-box}.dash h1,.dash h2,.dash h3,.dash h4{color:var(--dash-text-primary);margin:0;font-weight:600}.dash p{margin:0}.dash .num,.dash .dash-num{font-variant-numeric:tabular-nums}.dash-tier{margin-bottom:var(--dash-s-8)}.dash-tier:last-child{margin-bottom:0}.dash-card{background:var(--dash-bg-elevated);border:1px solid var(--dash-border-subtle);border-radius:var(--dash-radius);padding:var(--dash-s-6)}.dash-card[data-interactive=true]{cursor:pointer;transition:border-color .12s}.dash-card[data-interactive=true]:hover{border-color:var(--dash-border-strong);box-shadow:inset 0 0 0 1px var(--dash-border-strong)}.dash-label{letter-spacing:.08em;text-transform:uppercase;color:var(--dash-text-muted);font-size:11px;font-weight:600}.dash a:focus-visible,.dash button:focus-visible,.dash [tabindex]:focus-visible{outline:2px solid var(--dash-accent-primary);outline-offset:2px;border-radius:4px}@media (prefers-reduced-motion:reduce){.dash *,.dash :before,.dash :after{transition-duration:0s!important;animation-duration:0s!important;animation-iteration-count:1!important}}@media print{.dash{color:#000;background:#fff}.dash-card{background:#fff;border-color:#ccc}.dash-live-strip{display:none!important}}.dash-too-narrow{display:none}@media (width<=1023px){.dash>:not(.dash-too-narrow){display:none!important}.dash-too-narrow{text-align:center;min-height:60vh;color:var(--dash-text-secondary);justify-content:center;align-items:center;gap:var(--dash-s-4);flex-direction:column;display:flex}}.dash-skeleton{background:linear-gradient(90deg, var(--dash-bg-raised) 0%, var(--dash-border-strong) 50%, var(--dash-bg-raised) 100%);background-size:200% 100%;animation:1.4s ease-in-out infinite dash-skeleton-sweep;display:inline-block}@keyframes dash-skeleton-sweep{0%{background-position:200% 0}to{background-position:-200% 0}}.dash-dotscale{align-items:center;gap:6px;height:60px;display:flex}.dash-dot{background:var(--dash-bg-raised);border:1px solid var(--dash-border-strong);border-radius:50%;width:12px;height:12px}.dash-dot--filled{background:var(--dash-accent-primary);border-color:var(--dash-accent-primary)}.dash-dot--alert{background:var(--dash-accent-warning);border-color:var(--dash-accent-warning)}.dash-scoreboard{gap:var(--dash-s-4);margin-bottom:var(--dash-s-4);grid-template-columns:repeat(4,1fr);display:grid}.dash-scorecard{background:var(--dash-bg-elevated);background-image:var(--dash-gradient-hero);gap:var(--dash-s-2);flex-direction:column;min-height:180px;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 32px #00000052}.dash-scorecard-accent-line{background:var(--dash-card-accent,var(--dash-accent-primary));height:3px;position:absolute;top:0;left:0;right:0}.dash-scorecard-value{letter-spacing:-.01em;color:var(--dash-text-primary);margin-top:4px;font-size:28px;font-weight:600;line-height:1.1}.dash-scorecard-delta{margin-bottom:var(--dash-s-2);align-items:center;gap:4px;font-size:12px;font-weight:600;display:flex}.dash-scorecard-visual{margin-top:auto}.dash-hero-header{margin-bottom:var(--dash-s-4);justify-content:space-between;align-items:center;display:flex}.dash-hero-greeting{color:var(--dash-text-secondary);font-size:15px}.dash-hero-month{color:var(--dash-text-muted)}.dash-hero-header-right{align-items:center;gap:var(--dash-s-3);display:flex}.dash-period-selector{position:relative}.dash-period-btn{background:var(--dash-bg-elevated);border:1px solid var(--dash-border-subtle);color:var(--dash-text-primary);font:inherit;cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:8px 12px;font-size:13px;display:inline-flex}.dash-period-btn:hover{border-color:var(--dash-border-strong)}.dash-period-menu{background:var(--dash-bg-elevated);border:1px solid var(--dash-border-strong);z-index:10;border-radius:8px;min-width:160px;margin-top:4px;padding:4px;list-style:none;position:absolute;top:100%;right:0}.dash-period-option{cursor:pointer;color:var(--dash-text-primary);border-radius:6px;padding:8px 12px;font-size:13px}.dash-period-option:hover{background:var(--dash-bg-raised)}.dash-period-option.is-active{color:var(--dash-accent-primary)}.dash-live-pill{background:var(--dash-bg-elevated);border:1px solid var(--dash-border-subtle);color:var(--dash-text-secondary);border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;display:inline-flex}.dash-live-icon{animation:4s ease-in-out infinite dash-live-pulse}@keyframes dash-live-pulse{0%,90%,to{opacity:1;transform:rotate(0)}95%{opacity:.4;transform:rotate(180deg)}}.dash-live-strip{background:var(--dash-bg-elevated);background-image:var(--dash-gradient-glow);border:1px solid var(--dash-border-subtle);border-radius:var(--dash-radius);align-items:center;gap:24px;min-height:64px;padding:16px 20px;display:flex;position:relative;overflow:hidden}.dash-live-strip-label{letter-spacing:.12em;color:var(--dash-text-muted);white-space:nowrap;font-size:10px;font-weight:700}.dash-live-flow{flex:1;align-items:center;gap:12px;display:flex}.dash-live-node-wrap{flex:1;align-items:center;display:flex}.dash-live-node{background:var(--dash-bg-raised);border:1px solid var(--dash-border-strong);border-radius:8px;flex-direction:column;align-items:center;min-width:96px;padding:4px 8px;display:flex;position:relative}.dash-live-node.is-active{border-color:var(--dash-accent-ai);animation:2s ease-in-out infinite dash-ai-pulse;box-shadow:0 0 #a78bfa99}@keyframes dash-ai-pulse{0%,to{box-shadow:0 0 #a78bfa8c}50%{box-shadow:0 0 0 8px #a78bfa00}}.dash-live-count{color:var(--dash-text-primary);font-size:16px;font-weight:700}.dash-live-name{color:var(--dash-text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.dash-live-link{background-image:linear-gradient(to right, var(--dash-accent-ai) 0, var(--dash-accent-ai) 6px, transparent 6px, transparent 12px);background-repeat:repeat-x;background-size:12px 2px;flex:1;height:2px;margin:0 8px;animation:3s linear infinite dash-flow}@keyframes dash-flow{0%{background-position:0 0}to{background-position:24px 0}}.dash-live-tooltip{background:var(--dash-bg-base);border:1px solid var(--dash-border-strong);color:var(--dash-text-primary);white-space:nowrap;z-index:5;border-radius:6px;padding:6px 10px;font-size:11px;position:absolute;top:-52px;left:50%;transform:translate(-50%)}.dash-live-status{align-items:center;gap:6px;font-size:12px;font-weight:600;display:inline-flex}.dash-live-status.is-ok{color:var(--dash-accent-success)}.dash-live-status.is-degraded{color:var(--dash-accent-warning)}.dash-live-status-dot{background:currentColor;border-radius:50%;width:8px;height:8px;box-shadow:0 0 6px}.dash-card-header{margin-bottom:var(--dash-s-4);justify-content:space-between;align-items:center;display:flex}.dash-pill{color:var(--dash-text-secondary);background:var(--dash-bg-raised);border-radius:999px;padding:2px 10px;font-size:11px;font-weight:600}.dash-card-footer{margin-top:var(--dash-s-3);padding-top:var(--dash-s-3);border-top:1px solid var(--dash-border-subtle)}.dash-link{color:var(--dash-accent-primary);cursor:pointer;font-size:12px;font-weight:600;text-decoration:none}.dash-link:hover{text-decoration:underline}.dash-attention-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.dash-attention-row{align-items:center;gap:var(--dash-s-3);background:var(--dash-bg-raised);border-left:3px solid var(--dash-border-strong);border-radius:10px;padding:12px 14px;transition:background .12s;display:flex}.dash-attention-row:hover{background:#20263a}.dash-attention-row.is-warning{border-left-color:var(--dash-accent-warning)}.dash-attention-row.is-danger{border-left-color:var(--dash-accent-danger)}.dash-attention-tag{letter-spacing:.06em;text-transform:uppercase;color:var(--dash-text-secondary);flex-shrink:0;align-items:center;gap:6px;width:110px;font-size:11px;font-weight:700;display:inline-flex}.dash-attention-row.is-warning .dash-attention-tag{color:var(--dash-accent-warning)}.dash-attention-row.is-danger .dash-attention-tag{color:var(--dash-accent-danger)}.dash-attention-body{flex:1;min-width:0}.dash-attention-title{color:var(--dash-text-primary);font-size:14px;font-weight:500}.dash-attention-sub{color:var(--dash-text-secondary);margin-top:2px;font-size:12px}.dash-attention-action{border:1px solid var(--dash-border-strong);color:var(--dash-text-primary);font:inherit;cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600}.dash-attention-action:hover{background:var(--dash-accent-primary);border-color:var(--dash-accent-primary)}.dash-attention-empty{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:28px 16px;display:flex}.dash-attention-empty p{color:var(--dash-text-secondary);font-size:14px}.dash-recos-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.dash-recos-row{align-items:center;gap:var(--dash-s-3);cursor:pointer;background:0 0;border-radius:8px;padding:10px 12px;transition:background .12s;display:flex}.dash-recos-row:hover{background:var(--dash-bg-raised)}.dash-recos-rank{background:var(--dash-accent-primary);color:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:inline-flex}.dash-recos-body{flex:1;min-width:0}.dash-recos-supplier{color:var(--dash-text-primary);font-size:13px;font-weight:600}.dash-recos-product{color:var(--dash-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.dash-recos-score{font-size:20px;font-weight:700}.dash-recos-score-suffix{color:var(--dash-text-muted);margin-left:2px;font-size:11px;font-weight:500}.dash-trend-header{align-items:center;gap:var(--dash-s-4);margin-bottom:var(--dash-s-3);flex-wrap:wrap;display:flex}.dash-trend-tabs,.dash-trend-periods{background:var(--dash-bg-raised);border-radius:8px;gap:2px;padding:3px;display:inline-flex}.dash-trend-tabs{margin-right:auto}.dash-trend-tab,.dash-trend-period{color:var(--dash-text-secondary);font:inherit;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600}.dash-trend-tab.is-active,.dash-trend-period.is-active{background:var(--dash-bg-elevated);color:var(--dash-text-primary);box-shadow:inset 0 0 0 1px var(--dash-border-strong)}.dash-trend-summary{align-items:baseline;gap:var(--dash-s-3);margin-bottom:var(--dash-s-3);display:flex}.dash-trend-summary-value{color:var(--dash-text-primary);font-size:24px;font-weight:700}.dash-trend-summary-delta{font-size:12px;font-weight:600}.dash-trend-tooltip{background:var(--dash-bg-base);border:1px solid var(--dash-border-strong);color:var(--dash-text-primary);border-radius:8px;padding:8px 12px;font-size:12px}.dash-trend-tooltip-date{color:var(--dash-text-muted);margin-bottom:2px;font-size:11px}.dash-trend-tooltip-value{font-size:16px;font-weight:700}.dash-trend-tooltip-meta{color:var(--dash-text-secondary);margin-top:2px;font-size:11px}.dash-cats-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.dash-cats-row{grid-template-columns:130px 1fr 90px;align-items:center;gap:12px;font-size:13px;display:grid}.dash-cats-name{color:var(--dash-text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.dash-cats-bar-track{background:var(--dash-bg-raised);border-radius:4px;height:6px;display:block;overflow:hidden}.dash-cats-bar-fill{background:linear-gradient(90deg, var(--dash-accent-primary), #8b91f4);border-radius:4px;height:100%;display:block}.dash-cats-amount{text-align:right;color:var(--dash-text-primary);font-weight:600}.dash-pipeline-flow{align-items:center;margin:8px 0 4px;display:flex}.dash-pipeline-stage-wrap{flex:1;align-items:center;display:flex}.dash-pipeline-stage{background:var(--dash-bg-raised);border:1px solid var(--dash-border-strong);cursor:pointer;min-width:86px;font:inherit;color:inherit;border-radius:10px;flex-direction:column;align-items:center;padding:10px 14px;display:flex}.dash-pipeline-stage:hover{border-color:var(--dash-accent-primary)}.dash-pipeline-stage.is-bottleneck{border-color:var(--dash-accent-warning);box-shadow:0 0 0 2px #f59e0b26}.dash-pipeline-stage-count{color:var(--dash-text-primary);font-size:18px;font-weight:700}.dash-pipeline-stage-label{color:var(--dash-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-size:11px}.dash-pipeline-track{background:var(--dash-border-subtle);flex:1;height:2px;margin:0 6px}.dash-pipeline-callout{color:var(--dash-accent-warning);margin-top:12px;font-size:12px}.dash-suppliers-table{border-collapse:collapse;width:100%;font-size:13px}.dash-suppliers-table th{text-align:left;letter-spacing:.08em;text-transform:uppercase;color:var(--dash-text-muted);border-bottom:1px solid var(--dash-border-subtle);padding:8px 10px;font-size:10px;font-weight:700}.dash-suppliers-table td{border-bottom:1px solid var(--dash-border-subtle);color:var(--dash-text-primary);vertical-align:middle;padding:12px 10px}.dash-suppliers-table tr:last-child td{border-bottom:none}.dash-suppliers-name{font-weight:600}.dash-suppliers-email{color:var(--dash-text-muted);margin-top:2px;font-size:11px}.dash-tag{background:var(--dash-bg-raised);border:1px solid var(--dash-border-strong);color:var(--dash-text-secondary);border-radius:999px;padding:2px 8px;font-size:11px;display:inline-block}.dash-suppliers-bar-track{background:var(--dash-bg-raised);border-radius:3px;height:5px;overflow:hidden}.dash-suppliers-bar-fill{background:var(--dash-accent-primary);height:100%}.dash-suppliers-bar-label{color:var(--dash-text-secondary);margin-top:4px;font-size:11px}.dash-suppliers-last{color:var(--dash-text-secondary);font-size:12px}.dash-suppliers-chev{border:1px solid var(--dash-border-strong);color:var(--dash-text-secondary);cursor:pointer;background:0 0;border-radius:6px;width:28px;height:28px;font-size:14px}.dash-suppliers-chev:hover{background:var(--dash-accent-primary);border-color:var(--dash-accent-primary);color:#fff}.dash-grid-2-1{gap:var(--dash-s-6);grid-template-columns:2fr 1fr;display:grid}.dash-grid-3-2{gap:var(--dash-s-6);grid-template-columns:3fr 2fr;display:grid}body:has(.dash){background:var(--dash-bg-base)}body:has(.dash) .main-content{background:var(--dash-bg-base)}body:has(.dash) .top-header{background:var(--dash-bg-base);border-bottom:1px solid var(--dash-border-subtle);box-shadow:none}body:has(.dash) .top-header h1{color:var(--dash-text-primary)}body:has(.dash) .live-dot{background:var(--dash-accent-success);box-shadow:0 0 6px var(--dash-accent-success)}body:has(.dash) .page-content{padding:0;padding-top:var(--navbar-height)}:root{--sidebar-width:250px;--header-height:60px;--navbar-height:60px;--bg-primary:#f0f7f7;--bg-card:#fff;--bg-sidebar:linear-gradient(180deg, #1b3a6b 0%, #0a3050 100%);--bg-sidebar-hover:#40e0d01a;--bg-sidebar-active:#40e0d026;--text-primary:#1b3a6b;--text-secondary:#2c3e50;--text-muted:#95a5a6;--text-sidebar:#ffffffa6;--text-sidebar-active:#fff;--turq:#40e0d0;--turq2:#2bc5b4;--turq3:#20a99a;--blue:#1b3a6b;--blue2:#2a4f8f;--gold:#f5a623;--accent:#40e0d0;--accent-light:#5ce8da;--accent-bg:#40e0d014;--success:#27ae60;--success-bg:#d5f5e3;--warning:#f5a623;--warning-bg:#fef9e7;--danger:#e74c3c;--danger-bg:#fadbd8;--info:#3498db;--info-bg:#d6eaf8;--border:#e0f5f3;--border-light:#f0f7f7;--shadow-sm:0 2px 10px #0000000a;--shadow-md:0 4px 15px #0000000f;--shadow-lg:0 10px 30px #0000001a;--shadow-turq:0 5px 20px #40e0d033;--radius-sm:8px;--radius-md:14px;--radius-lg:18px;--transition:.2s cubic-bezier(.4,0,.2,1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;max-width:100%;overflow-x:hidden}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--turq2);border-radius:3px}.app-layout{width:100%;min-height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);color:#fff;z-index:100;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:3px 0 15px #0000001a}.sidebar-header{border-bottom:1px solid #ffffff14;padding:24px 20px 18px}.sidebar-logo{align-items:center;gap:12px;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--turq), var(--blue2));color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:20px;font-weight:800;display:flex;box-shadow:0 4px 15px #40e0d04d}.sidebar-header h2{letter-spacing:.3px;color:#fff;font-size:16px;font-weight:800}.sidebar-subtitle{color:#ffffff59;text-transform:uppercase;letter-spacing:1.2px;margin-top:2px;font-size:10px;font-weight:600;display:block}.sidebar nav{flex-direction:column;flex:1;gap:1px;padding:14px 12px;display:flex;overflow-y:auto}.nav-section-label{text-transform:uppercase;letter-spacing:1.5px;color:#ffffff4d;padding:18px 12px 8px;font-size:10px;font-weight:700}.nav-link{color:var(--text-sidebar);transition:var(--transition);border-left:3px solid #0000;border-radius:0;align-items:center;gap:11px;padding:11px 16px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex;position:relative}.nav-link:hover{color:#fff;background:var(--bg-sidebar-hover);border-left-color:var(--turq)}.nav-link.active{color:#fff;background:var(--bg-sidebar-active);border-left-color:var(--turq)}.nav-link.active:before{display:none}.nav-badge{background:var(--danger);color:#fff;text-align:center;border-radius:10px;min-width:18px;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:700}.sidebar-footer{color:#ffffff4d;border-top:1px solid #ffffff14;padding:16px 20px;font-size:11px}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-width:0;min-height:100vh;display:flex}.top-header{height:var(--navbar-height);background:linear-gradient(135deg, var(--blue) 0%, #0d5c6b 100%);top:0;left:var(--sidebar-width);z-index:50;justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:fixed;right:0;box-shadow:0 2px 20px #00000026}.top-header-left{align-items:center;gap:14px;display:flex}.top-header-left h1{color:#fff;letter-spacing:.3px;margin:0;font-size:16px;font-weight:700}.top-header-right{align-items:center;gap:12px;display:flex}.page-content{padding:0;padding-top:var(--navbar-height);flex:1;min-width:0;overflow-x:hidden}.page{padding:24px 32px}.page h1{color:var(--text-primary);letter-spacing:-.3px;align-items:center;gap:10px;margin-bottom:22px;font-size:20px;font-weight:700;display:flex}.page-loading,.page-error{height:300px;color:var(--text-muted);justify-content:center;align-items:center;font-size:15px;display:flex}.page-error{color:var(--danger)}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px;display:grid}.kpi-card{background:var(--bg-card);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);border:none;border-top:4px solid var(--kpi-color,var(--turq));min-width:0;padding:14px 16px;transition:all .2s;position:relative;overflow:hidden}.kpi-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px #40e0d026}.kpi-card:before{display:none}.kpi-icon{background:linear-gradient(135deg,#40e0d026,#1b3a6b14);border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:0;display:flex}.kpi-value{letter-spacing:-.3px;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:clamp(1.1rem,1.8vw,1.5rem);font-weight:700;line-height:1.1;overflow:hidden}.kpi-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-top:2px;font-size:10px;font-weight:600}.kpi-subtitle{color:var(--text-muted);margin-top:6px;font-size:11px}.kpi-trend{border-radius:20px;align-items:center;gap:4px;margin-top:8px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-flex}.kpi-trend.up{color:var(--success);background:var(--success-bg)}.kpi-trend.down{color:var(--danger);background:var(--danger-bg)}.charts-row{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px;display:grid}.chart-card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:none;padding:24px}.chart-card h3{color:var(--text-primary);letter-spacing:-.2px;align-items:center;gap:8px;margin-bottom:20px;font-size:14px;font-weight:700;display:flex}.table-wrapper{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:none;overflow:auto hidden}.data-table{border-collapse:collapse;width:100%}.data-table th{background:linear-gradient(135deg, var(--blue), #0d5c6b);text-align:left;color:#fff;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-bottom:none;padding:13px 16px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:middle;padding:13px 16px;font-size:13.5px}.data-table tbody tr{transition:var(--transition)}.data-table tbody tr:hover{cursor:pointer;background:#40e0d00a}.data-table tbody tr.selected{background:var(--accent-bg)}.data-table tbody tr:last-child td{border-bottom:none}.data-table.small th,.data-table.small td{padding:8px 12px;font-size:12.5px}.td-title{color:var(--text-primary);font-weight:600}.empty-row{text-align:center;color:var(--text-muted);padding:40px!important}.empty-text{text-align:center;color:var(--text-muted);padding:40px}.status-badge{letter-spacing:.3px;white-space:nowrap;border-radius:20px;align-items:center;padding:4px 12px;font-size:11px;font-weight:600;display:inline-flex}.status-completed,.status-delivered{background:var(--success-bg);color:#1e8449}.status-evaluated,.status-evaluation_sent{color:#1e8449;background:#d5f5e3}.status-pending{color:#566573;background:#f2f3f4}.status-analyzing,.status-sourcing{color:#0d7377;background:#e0f9f7}.status-rfqs_sent,.status-contacting{color:#1a5276;background:#d6eaf8}.status-offers_received,.status-awaiting_responses{background:var(--warning-bg);color:#9a7d0a}.status-awaiting_decision{color:#6c3483;background:#e8daef}.status-po_generated{background:var(--success-bg);color:#1e8449}.status-failed,.status-rejected{background:var(--danger-bg);color:#922b21}.stage-row{align-items:center;gap:6px;display:flex}.stage-item{align-items:center;gap:3px;display:flex}.stage-label{color:var(--text-muted);font-size:11px}.detail-panel{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:none;border-top:3px solid var(--turq);padding:24px}.detail-panel h2{color:var(--text-primary);letter-spacing:-.2px;margin-bottom:16px;font-size:17px;font-weight:700}.detail-grid{gap:20px;display:grid}.detail-section h3{color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:13px;font-weight:700}.detail-section ul{padding:0;list-style:none}.detail-section li{color:var(--text-secondary);border-bottom:1px solid var(--border);padding:6px 0;font-size:13.5px}.detail-section li:last-child{border-bottom:none}.activity-timeline{flex-direction:column;gap:0;display:flex}.activity-item{border-bottom:1px solid var(--border);transition:var(--transition);gap:16px;padding:14px 0;display:flex}.activity-item:hover{border-radius:var(--radius-sm);background:#40e0d00a;margin:0 -8px;padding-left:8px;padding-right:8px}.activity-item:last-child{border-bottom:none}.activity-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:6px;box-shadow:0 0 0 3px #40e0d026}.activity-content{flex:1}.activity-header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.activity-agent{color:var(--text-primary);font-size:13px;font-weight:700}.activity-type{text-transform:uppercase;letter-spacing:.3px;border-radius:20px;padding:2px 8px;font-size:10px;font-weight:600}.type-info{background:var(--info-bg);color:#1a5276}.type-success{background:var(--success-bg);color:#1e8449}.type-warning{background:var(--warning-bg);color:#9a7d0a}.type-error{background:var(--danger-bg);color:#922b21}.activity-time{color:var(--text-muted);margin-left:auto;font-size:12px}.activity-message{color:var(--text-secondary);font-size:13.5px;line-height:1.5}.activity-request{color:var(--turq2);font-size:12px;font-weight:600}.event-list{padding:0;list-style:none}.event-list li{border-bottom:1px solid var(--border);gap:10px;padding:8px 0;font-size:13px;display:flex}.event-list li:last-child{border-bottom:none}.event-time{color:var(--text-muted);font-family:SF Mono,Fira Code,monospace;font-size:12px}.event-agent{color:var(--text-primary);font-weight:700}.score-bar{align-items:center;gap:10px;display:flex}.score-fill{background:linear-gradient(to right, var(--turq), var(--blue));border-radius:3px;min-width:4px;height:6px;transition:width .6s}.score-bar span{color:var(--text-primary);font-size:13px;font-weight:600}.filters{align-items:center;gap:12px;margin-bottom:20px;display:flex}.filter-input,.filters select,.filters input{border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-primary);transition:var(--transition);padding:9px 14px;font-family:inherit;font-size:13.5px}.filter-input:focus,.filters select:focus,.filters input:focus{border-color:var(--turq);outline:none;box-shadow:0 0 0 3px #40e0d026}.search-wrapper{flex:1;position:relative}.search-wrapper svg{color:var(--text-muted);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-wrapper input{border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);width:100%;color:var(--text-primary);transition:var(--transition);padding:9px 14px 9px 38px;font-family:inherit;font-size:13.5px}.search-wrapper input:focus{border-color:var(--turq);outline:none;box-shadow:0 0 0 3px #40e0d026}.blacklist-form{flex-wrap:wrap;gap:12px;margin-bottom:24px;display:flex}.blacklist-form input{border:2px solid var(--border);border-radius:var(--radius-sm);min-width:160px;transition:var(--transition);flex:1;padding:10px 14px;font-family:inherit;font-size:13.5px}.blacklist-form input:focus{border-color:var(--turq);outline:none;box-shadow:0 0 0 3px #40e0d026}.blacklist-form button{background:linear-gradient(135deg, var(--danger), #c0392b);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:none;padding:10px 20px;font-family:inherit;font-size:13.5px;font-weight:600}.blacklist-form button:hover{transform:translateY(-1px);box-shadow:0 3px 10px #e74c3c4d}.blacklist-form button:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:none;align-items:center;gap:6px;padding:9px 18px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg, var(--turq), var(--blue));color:#fff}.btn-primary:hover{box-shadow:var(--shadow-turq)}.btn-success{color:#fff;background:linear-gradient(135deg,#2ecc71,#27ae60)}.btn-success:hover{box-shadow:0 5px 15px #27ae604d}.btn-warning{background:linear-gradient(135deg, var(--gold), #e09a1a);color:#fff}.btn-danger{background:linear-gradient(135deg, var(--danger), #c0392b);color:#fff}.btn-danger:hover{box-shadow:0 5px 15px #e74c3c4d}.btn-ghost{color:var(--text-secondary);border:2px solid var(--border);background:0 0}.btn-ghost:hover{border-color:var(--turq);background:#40e0d00a}.btn-sm{padding:5px 12px;font-size:12px}.notification-bell{cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);color:#fff;background:#ffffff1a;border:none;padding:8px;position:relative}.notification-bell:hover{background:#fff3}.notification-count{background:var(--danger);color:#fff;border:2px solid #0000;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;display:flex;position:absolute;top:2px;right:2px}.notification-dropdown{background:var(--bg-card);border-radius:var(--radius-md);width:380px;max-height:480px;box-shadow:var(--shadow-lg);border:1px solid var(--border);z-index:200;animation:.15s slideDown;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.notification-dropdown-header{border-bottom:1px solid var(--border);color:var(--text-primary);justify-content:space-between;align-items:center;padding:14px 16px;font-size:14px;font-weight:700;display:flex}.notification-dropdown-header button{color:var(--turq2);cursor:pointer;background:0 0;border:none;font-size:12px;font-weight:600}.notification-list{max-height:400px;overflow-y:auto}.notification-item{border-bottom:1px solid var(--border);cursor:pointer;transition:var(--transition);gap:12px;padding:12px 16px;display:flex}.notification-item:hover{background:#40e0d00a}.notification-item.unread{background:var(--accent-bg)}.notification-item.unread:hover{background:#40e0d01f}.notification-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.notification-item-content{flex:1;min-width:0}.notification-item-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:13px;font-weight:600;overflow:hidden}.notification-item-desc{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.notification-item-time{color:var(--text-muted);white-space:nowrap;margin-top:2px;font-size:11px}.notification-empty{text-align:center;color:var(--text-muted);padding:40px 16px;font-size:13px}.live-dot{background:var(--turq);border-radius:50%;width:8px;height:8px;animation:2s infinite livePulse;display:inline-block}@keyframes livePulse{0%,to{opacity:1;box-shadow:0 0 #40e0d066}50%{opacity:.8;box-shadow:0 0 0 6px #40e0d000}}.toast-container{z-index:1000;flex-direction:column;gap:8px;display:flex;position:fixed;top:80px;right:24px}.toast{background:var(--bg-card);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);border:1px solid var(--border);border-left:4px solid var(--turq);cursor:pointer;align-items:center;gap:12px;min-width:320px;max-width:420px;padding:14px 18px;animation:.3s toastIn;display:flex}.toast.toast-exit{animation:.2s forwards toastOut}@keyframes toastIn{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{to{opacity:0;transform:translate(30px)}}.toast-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.toast-body{flex:1;min-width:0}.toast-title{color:var(--text-primary);font-size:13px;font-weight:700}.toast-message{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;font-size:12px;overflow:hidden}@media (width<=1024px){.charts-row{grid-template-columns:1fr}}@media (width<=768px){.sidebar{width:64px}.sidebar-header h2,.sidebar-subtitle,.nav-link span,.nav-section-label,.sidebar-footer{display:none}.sidebar-logo-icon{width:32px;height:32px;font-size:14px}.sidebar-header{padding:16px 12px}.nav-link{border-left:none;justify-content:center;padding:12px}.main-content{margin-left:64px}.page-content{padding:0;padding-top:var(--navbar-height)}.page{padding:16px}.top-header{padding:0 16px;left:64px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:8px}}.auth-page{background:linear-gradient(135deg,#0a2a4a 0%,#1b3a6b 40%,#0d7377 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative}.auth-page:before{content:"";pointer-events:none;background:radial-gradient(at 20%,#40e0d014 0%,#0000 50%),radial-gradient(at 80% 20%,#1b3a6b4d 0%,#0000 50%);width:100%;height:100%;position:fixed;top:0;left:0}.auth-card{z-index:1;background:#fffffff7;border-radius:20px;width:100%;max-width:460px;padding:40px;position:relative;box-shadow:0 25px 60px #00000059,0 0 0 1px #40e0d026}.auth-header{text-align:center;margin-bottom:28px}.auth-logo{background:linear-gradient(135deg, var(--turq), var(--blue));color:#fff;border-radius:14px;justify-content:center;align-items:center;width:54px;height:54px;margin:0 auto 16px;display:flex;box-shadow:0 4px 20px #40e0d066}.auth-header h1{color:var(--blue);margin:0 0 4px;font-size:24px;font-weight:800}.auth-header p{color:var(--text-muted);margin:0;font-size:14px}.auth-separator{background:linear-gradient(to right, var(--turq), var(--blue));border-radius:2px;width:50px;height:3px;margin:0 auto 24px}.auth-error{background:var(--danger-bg);color:#922b21;border:1px solid #f1948a;border-radius:10px;align-items:center;gap:8px;margin-bottom:20px;padding:12px 16px;font-size:13px;display:flex}.auth-form{flex-direction:column;gap:18px;display:flex}.auth-field label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.auth-input-wrapper{border:2px solid var(--border);background:#f7fafc;border-radius:10px;align-items:center;gap:10px;padding:0 14px;transition:all .2s;display:flex}.auth-input-wrapper:focus-within{border-color:var(--turq);background:#fff;box-shadow:0 0 0 3px #40e0d026}.auth-input-wrapper svg{color:var(--text-muted);flex-shrink:0}.auth-input-wrapper input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;padding:12px 0;font-family:inherit;font-size:14px}.auth-input-wrapper input::placeholder{color:#bdc3c7}.auth-btn{background:linear-gradient(135deg, var(--turq), var(--blue));color:#fff;cursor:pointer;letter-spacing:.5px;border:none;border-radius:10px;margin-top:4px;padding:13px;font-family:inherit;font-size:15px;font-weight:700;transition:all .3s}.auth-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #40e0d066}.auth-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-footer{text-align:center;color:var(--text-muted);margin-top:24px;font-size:13px}.auth-footer a{color:var(--turq2);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-switch-btn{color:var(--turq2);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;font-weight:600;text-decoration:none}.auth-switch-btn:hover{text-decoration:underline}.auth-role-hint{text-align:center;color:var(--text-muted);margin:16px 0 0;font-size:12px}.auth-system-info{z-index:1;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:22px;display:flex;position:relative}.auth-sys-badge{color:#ffffff80;background:#ffffff14;border:1px solid #ffffff1f;border-radius:20px;align-items:center;gap:5px;padding:4px 12px;font-size:12px;display:flex}.auth-sys-dot{background:var(--turq);border-radius:50%;width:6px;height:6px}.auth-brand-footer{text-align:center;color:#ffffff59;z-index:1;margin-top:18px;font-size:12px;position:relative}.sidebar-user{align-items:center;gap:10px;width:100%;display:flex}.sidebar-user-avatar{width:36px;height:36px;color:var(--turq);background:linear-gradient(135deg,#40e0d033,#1b3a6b4d);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-info{flex-direction:column;flex:1;min-width:0;display:flex}.sidebar-user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.sidebar-user-role{color:#fff6;white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-logout{color:#fff6;cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:6px;transition:color .2s,background .2s}.sidebar-logout:hover{color:var(--danger);background:#e74c3c26}.detail-back-btn{border:2px solid var(--border);background:var(--bg-card);width:36px;height:36px;color:var(--turq);cursor:pointer;transition:var(--transition);border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.detail-back-btn:hover{background:var(--turq);color:#fff;border-color:var(--turq)}.detail-row{gap:20px;display:flex}@media (width<=900px){.detail-row{flex-direction:column}.detail-col{flex:1!important}}.detail-col{min-width:0}.detail-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}.detail-card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.detail-card-header h3{color:var(--text-primary);align-items:center;gap:8px;margin:0;font-size:14px;font-weight:700;display:flex}.detail-info-table{border-collapse:collapse;width:100%}.detail-info-table tr{border-bottom:1px solid var(--border-light)}.detail-info-table tr:last-child{border-bottom:none}.stat-badge{color:#0d7377;background:#e0f9f7;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.timeline{position:relative}.timeline-item{gap:12px;padding:8px 0;display:flex;position:relative}.timeline-item:not(:last-child):after{content:"";background:var(--border);width:2px;position:absolute;top:24px;bottom:-8px;left:5px}.timeline-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px;margin-top:4px}.timeline-dot.done{background:var(--turq)}.timeline-dot.error{background:var(--danger)}.timeline-dot.warning{background:var(--warning)}.logs-viewer{border-radius:0 0 var(--radius-md) var(--radius-md);background:#0d1117;max-height:300px;padding:16px;overflow-y:auto}.log-line{margin-bottom:6px;font-family:Courier New,monospace;font-size:12px;display:flex}.log-time{color:#484f58;flex-shrink:0;width:65px;margin-right:8px}.log-agent{flex-shrink:0;width:130px;margin-right:8px;font-weight:700}.log-info{color:var(--turq)}.log-error{color:#ff7b72}.log-warning{color:#e3b341}.log-message{color:#e6edf3}.btn-download{background:linear-gradient(135deg, var(--turq), var(--blue));color:#fff;transition:var(--transition);border-radius:9px;align-items:center;gap:6px;padding:10px 24px;font-size:13px;font-weight:700;text-decoration:none;display:inline-flex}.btn-download:hover{box-shadow:var(--shadow-turq);transform:translateY(-1px)}.btn-sm-action{border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);cursor:pointer;transition:var(--transition);border-radius:7px;align-items:center;gap:4px;padding:5px 12px;font-size:12px;font-weight:600;display:inline-flex}.btn-sm-action:hover{background:var(--turq);color:#fff;border-color:var(--turq)}.btn-sm-action.primary{background:linear-gradient(135deg, var(--turq), var(--blue));color:#fff;border-color:#0000;text-decoration:none}.btn-sm-action.primary:hover{box-shadow:var(--shadow-turq)}.info-grid{grid-template-columns:repeat(3,1fr);gap:16px;padding:20px;display:grid}@media (width<=900px){.info-grid{grid-template-columns:1fr}}.info-box{border-left:4px solid var(--turq);background:#f0f9f7;border-radius:12px;padding:16px}.info-box-title{color:var(--text-primary);margin-bottom:6px;font-size:14px;font-weight:700}.info-box-text{color:#95a5a6;font-size:13px;line-height:1.7}.workflow-grid{grid-template-columns:repeat(3,1fr);gap:16px;padding:20px;display:grid}@media (width<=900px){.workflow-grid{grid-template-columns:1fr}}.workflow-card{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);border-top:4px solid var(--wf-color,var(--turq));padding:16px}.workflow-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.workflow-phase-name{color:var(--text-primary);font-size:15px;font-weight:700}.workflow-phase-count{color:var(--wf-color,var(--turq));font-size:22px;font-weight:800}.workflow-progress-bar{background:var(--border-light);border-radius:3px;height:6px;margin-bottom:14px;overflow:hidden}.workflow-progress-fill{border-radius:3px;height:100%;transition:width .6s}.workflow-states{flex-direction:column;gap:6px;display:flex}.workflow-state-row{align-items:center;gap:8px;font-size:13px;display:flex}.workflow-state-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.workflow-state-label{color:var(--text-secondary);flex:1}.workflow-state-count{color:var(--text-primary);text-align:right;min-width:24px;font-weight:700}.supplier-kpi-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.supplier-kpi-card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);align-items:center;gap:16px;padding:20px;display:flex}.supplier-kpi-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.supplier-kpi-info{flex-direction:column;display:flex}.supplier-kpi-value{color:var(--text-primary);font-size:24px;font-weight:800;line-height:1.1}.supplier-kpi-unit{color:var(--text-muted);margin-left:2px;font-size:14px;font-weight:500}.supplier-kpi-label{color:var(--text-muted);margin-top:2px;font-size:12px;font-weight:500}.supplier-tabs{background:var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--border);border-radius:12px;gap:4px;width:fit-content;margin-bottom:20px;padding:4px;display:flex}.supplier-tab{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:500;display:flex}.supplier-tab:hover{color:var(--text-primary);background:var(--accent-bg)}.supplier-tab.active{background:linear-gradient(135deg, var(--turq), var(--blue));color:#fff;box-shadow:var(--shadow-turq)}.btn-export{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:var(--transition);border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;display:flex}.btn-export:hover{border-color:var(--turq);color:var(--turq3)}.supplier-cell{align-items:center;gap:10px;display:flex}.supplier-avatar{background:linear-gradient(135deg, var(--turq), var(--blue));color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.supplier-avatar.small{border-radius:8px;width:28px;height:28px;font-size:11px}.td-subtitle{color:var(--text-muted);margin-top:1px;font-size:11px}.tag-pill{background:var(--accent-bg);color:var(--turq3);letter-spacing:.3px;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.score-bar-inline{align-items:center;gap:8px;display:flex}.score-bar-track{background:#f1f5f9;border-radius:3px;width:70px;height:6px;overflow:hidden}.score-bar-fill{border-radius:3px;height:100%;transition:width .4s}.score-bar-val{color:var(--text-secondary);min-width:32px;font-size:12px;font-weight:600}.status-badge.status-active{background:var(--success-bg);color:var(--success)}.status-badge.status-blacklisted{background:var(--danger-bg);color:var(--danger)}.status-badge.status-no-response{background:var(--warning-bg);color:var(--warning)}.row-blacklisted{opacity:.6}.reviews-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.review-card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:24px}.review-card-warn{border-left:4px solid var(--warning)}.review-card-success{border-left:4px solid var(--success)}.review-card-info{border-left:4px solid var(--turq)}.review-card-danger{border-left:4px solid var(--danger)}.review-card-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.review-card-header h3{color:var(--text-primary);flex:1;margin:0;font-size:15px;font-weight:700}.review-count{background:var(--accent-bg);color:var(--turq3);border-radius:10px;padding:2px 8px;font-size:12px;font-weight:700}.review-desc{color:var(--text-muted);margin:0 0 14px;font-size:12px;line-height:1.4}.review-list{flex-direction:column;gap:6px;display:flex}.review-item{background:var(--border-light);transition:var(--transition);border-radius:8px;align-items:center;gap:10px;padding:8px 10px;display:flex}.review-item:hover{background:var(--accent-bg)}.review-item-info{flex-direction:column;flex:1;display:flex}.review-item-name{color:var(--text-primary);font-size:13px;font-weight:600}.review-item-detail{color:var(--text-muted);font-size:11px}.review-rank{text-align:center;width:28px;color:var(--text-muted);font-size:14px;font-weight:700}.review-score{text-align:right;min-width:36px;font-size:14px;font-weight:800}.review-empty{color:var(--text-muted);margin:0;font-size:12px;font-style:italic}@media (width<=900px){.supplier-kpi-grid{grid-template-columns:repeat(2,1fr)}.reviews-grid{grid-template-columns:1fr}}
