@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0f172a;color:#f1f5f9}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh;background:#0f172a}.recharts-wrapper,.recharts-surface{background:transparent!important}.recharts-legend-wrapper,.recharts-default-legend,.recharts-legend-item-text{color:#94a3b8!important}.recharts-tooltip-wrapper{outline:none!important}@media(max-width:768px){.bulk-prediction-page{padding:10px}.form-row{flex-direction:column;gap:10px}.form-group{width:100%}.summary-grid{grid-template-columns:1fr 1fr;gap:10px}.products-table{font-size:12px;overflow-x:auto}.products-table th,.products-table td{padding:8px 4px;min-width:80px}.expanded-content{padding:10px}.projection-grid{grid-template-columns:1fr;gap:10px}.monthly-bars-chart{overflow-x:auto;padding-bottom:10px}.page-header h1{font-size:24px}.help-banner{font-size:14px;padding:10px}}@media(max-width:480px){.summary-grid{grid-template-columns:1fr}.products-table{font-size:11px}.btn-primary,.btn-secondary{padding:8px 12px;font-size:14px}.date-shortcuts{flex-wrap:wrap;gap:5px}.btn-date-shortcut{font-size:12px;padding:5px 8px}}.loading-container{display:flex;align-items:center;justify-content:center;min-height:400px;width:100%}.spinner-wrapper{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.spinner{width:60px;height:60px;border:4px solid var(--bg-tertiary);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.loading-message{color:var(--text-muted);font-size:.95rem;font-weight:500}*{box-sizing:border-box}.dashboard-container{padding:1.25rem;max-width:1440px;margin:0 auto;min-height:100vh;background:#0f172a;font-family:Inter,sans-serif}.dashboard-header-new{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1.5rem;flex-wrap:wrap}.header-left h1{font-size:1.6rem;color:#fff;margin:0 0 .3rem;font-weight:800}.header-subtitle{font-size:.85rem;color:#94a3b8;margin:0 0 .6rem}.badge-enhanced{display:inline-block;padding:.3rem .8rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:.7rem;font-weight:700;border-radius:6px;letter-spacing:.5px}.status-pill{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600}.status-pill.online{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.dot{width:8px;height:8px;border-radius:50%;background:#10b981;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.stats-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:linear-gradient(135deg,#1e293b,#162032);border:1px solid #334155;border-radius:12px;padding:1rem 1.25rem;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px #0006}.stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.stat-title{font-size:.8rem;color:#94a3b8;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stat-icon{font-size:1.2rem}.stat-value{font-size:1.5rem;font-weight:800;color:#fff;margin-bottom:.3rem}.stat-value.critical{color:#ef4444}.stat-trend{font-size:.75rem;color:#64748b}.stat-trend.trend-up{color:#10b981}.stat-trend.trend-down{color:#e02121e4}.dashboard-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;background:#1e293b;padding:.4rem;border-radius:12px;border:1px solid #334155;flex-wrap:wrap}.dash-tab{flex:1;min-width:140px;padding:.65rem 1rem;background:transparent;border:none;border-radius:8px;color:#94a3b8;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap}.dash-tab:hover{background:#ffffff0f;color:#e2e8f0}.dash-tab.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f666}.cache-dot{color:#10b981;font-size:.5rem;margin-left:.25rem;vertical-align:super}.chart-card-new{background:#1e293b;border:1px solid #334155;border-radius:14px;padding:1.5rem;margin-bottom:1.5rem}.chart-card-new.full-width{grid-column:1 / -1}.chart-header-new{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.chart-header-new h3{font-size:1rem;font-weight:700;color:#e2e8f0;margin:0}.chart-header-new p{font-size:.8rem;color:#64748b;margin:.25rem 0 0}.chart-period{font-size:.75rem;padding:.3rem .75rem;background:#334155;border-radius:20px;color:#94a3b8;font-weight:600}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}@media(max-width:900px){.charts-grid{grid-template-columns:1fr}}.tab-loading{display:flex;justify-content:center;align-items:center;height:300px;color:#64748b;font-size:.95rem}.tab-error{display:flex;justify-content:center;align-items:center;height:200px;color:#ef4444;font-size:.9rem}.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:#94a3b8;gap:1rem;text-align:center}.error-icon{font-size:3rem}.retry-btn{padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600}.year-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.year-card{background:linear-gradient(135deg,#1e293b,#0f1f35);border:1px solid #334155;border-radius:12px;padding:1.25rem}.year-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.year-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:700;background:#3b82f633;color:#3b82f6;border:1px solid rgba(59,130,246,.3)}.year-card-stats{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.ys-stat label{font-size:.7rem;color:#64748b;text-transform:uppercase;letter-spacing:.4px}.ys-stat .val{font-size:1rem;font-weight:700;color:#e2e8f0;margin-top:.15rem}.ys-stat .val.green{color:#10b981}.peak-badge{margin-top:.75rem;font-size:.75rem;color:#f59e0b;background:#f59e0b1a;padding:.3rem .6rem;border-radius:6px;display:inline-block}.forecast-summary-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.forecast-stat{background:#1e293b;border:1px solid #334155;border-radius:10px;padding:1rem 1.25rem;text-align:center}.forecast-stat .fs-label{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.4px}.forecast-stat .fs-value{font-size:1.5rem;font-weight:800;color:#e2e8f0;margin-top:.3rem}.forecast-stat .fs-value.blue{color:#3b82f6}.forecast-stat .fs-value.green{color:#10b981}.product-search-bar{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.product-search-input{flex:1;min-width:220px;padding:.75rem 1rem;background:#1e293b;border:1px solid #475569;border-radius:10px;color:#e2e8f0;font-size:.9rem;outline:none;transition:border-color .2s}.product-search-input:focus{border-color:#3b82f6}.search-suggestions{position:absolute;z-index:100;background:#1e293b;border:1px solid #475569;border-radius:10px;max-height:220px;overflow-y:auto;width:100%;top:calc(100% + 4px);left:0;box-shadow:0 8px 24px #00000080}.search-wrap{position:relative;flex:1;min-width:220px}.suggestion-item{padding:.65rem 1rem;cursor:pointer;color:#e2e8f0;font-size:.875rem;border-bottom:1px solid #334155}.suggestion-item:hover{background:#334155}.suggestion-item:last-child{border-bottom:none}.analyze-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s}.analyze-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #8b5cf666}.analyze-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.analysis-hero{background:linear-gradient(135deg,#1e293b,#0f172a);border:1px solid #334155;border-radius:14px;padding:1.5rem;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.analysis-hero-left h2{color:#fff;font-size:1.25rem;font-weight:800;margin:0 0 .3rem}.analysis-hero-left p{color:#64748b;font-size:.85rem;margin:0}.analysis-hero-badges{display:flex;gap:.5rem;flex-wrap:wrap}.hero-badge{padding:.3rem .8rem;border-radius:20px;font-size:.75rem;font-weight:700}.hero-badge.cat{background:#3b82f633;color:#3b82f6;border:1px solid rgba(59,130,246,.3)}.hero-badge.grp{background:#8b5cf633;color:#a78bfa;border:1px solid rgba(139,92,246,.3)}.insights-4-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.insight-card{border-radius:12px;padding:1.25rem;border:1px solid}.insight-card.trend{background:#10b98114;border-color:#10b98140}.insight-card.volatility{background:#f59e0b14;border-color:#f59e0b40}.insight-card.seasonal{background:#8b5cf614;border-color:#8b5cf640}.insight-card.range{background:#3b82f614;border-color:#3b82f640}.insight-card-icon{font-size:1.5rem;margin-bottom:.5rem}.insight-card-label{font-size:.7rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.4rem}.insight-card-value{font-size:1.3rem;font-weight:800;color:#e2e8f0;margin-bottom:.3rem}.insight-card-sub{font-size:.78rem;color:#94a3b8}.growing{color:#10b981!important}.declining{color:#ef4444!important}.stable{color:#f59e0b!important}.vol-high{color:#ef4444!important}.vol-med{color:#f59e0b!important}.vol-low{color:#10b981!important}.insights-section-new{background:#fff;border-radius:14px;padding:1.5rem;margin-top:1.5rem}.insights-section-new h3{font-size:1rem;font-weight:700;color:#1f2937;margin:0 0 1rem}.insights-grid-new{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.insight-item{display:flex;gap:.75rem;align-items:flex-start;padding:.75rem;border-radius:8px;background:#f8fafc}.insight-number{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.insight-content h4{font-size:.85rem;font-weight:700;color:#1f2937;margin:0 0 .2rem}.insight-content p{font-size:.8rem;color:#64748b;margin:0}.insight-content code{background:#e5e7eb;padding:.1rem .3rem;border-radius:4px;font-size:.75rem}.empty-analysis{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:#475569;gap:1rem}.empty-analysis-icon{font-size:4rem;opacity:.5}.empty-analysis p{font-size:.95rem}.custom-tooltip{background:#0f172af2;border:1px solid #334155;border-radius:8px;padding:.75rem 1rem;font-size:.8rem}.custom-tooltip .ct-label{color:#94a3b8;margin-bottom:.3rem;font-weight:600}.custom-tooltip .ct-row{color:#e2e8f0;display:flex;gap:.5rem;align-items:center;margin-top:.2rem}.ct-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.seasonality-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:.5rem;padding:.5rem 0}.season-bar-wrap{display:flex;flex-direction:column;align-items:center;gap:.3rem}.season-bar-outer{width:100%;height:80px;background:#0f172a;border-radius:4px;display:flex;align-items:flex-end}.season-bar-inner{width:100%;border-radius:4px 4px 0 0;transition:height .5s ease}.season-label{font-size:.65rem;color:#64748b}.season-factor{font-size:.65rem;font-weight:700}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1.5rem}.summary-card{background:linear-gradient(135deg,#1e293b,#334155);border:1px solid #475569;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease}.summary-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000004d;border-color:#3b82f6}.card-icon{font-size:2.5rem;opacity:.9}.card-label{font-size:.875rem;color:#94a3b8;margin-bottom:.25rem}.card-value{font-size:2rem;font-weight:700;color:#fff;line-height:1.2}.card-detail{font-size:.75rem;color:#cbd5e1;margin-top:.5rem;display:flex;gap:.75rem;flex-wrap:wrap}.critical-badge{background:#ef444433;color:#fca5a5;padding:.125rem .5rem;border-radius:4px;font-weight:600}.low-badge{background:#fbbf2433;color:#fcd34d;padding:.125rem .5rem;border-radius:4px;font-weight:600}.summary-card.skeleton{background:linear-gradient(90deg,#1e293b 25%,#334155,#1e293b 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite}.skeleton-text{height:60px;background:#ffffff0d;border-radius:8px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:768px){.summary-cards{grid-template-columns:1fr}.card-value{font-size:1.5rem}}.filters-bar{background:#1e293b;border:1px solid #475569;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.filters-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;align-items:end}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;color:#94a3b8;font-weight:500}.date-input,.search-input,.filter-select{padding:.625rem;background:#0f172a;border:1px solid #475569;border-radius:8px;color:#fff;font-size:.875rem;transition:all .2s ease}.budget-input{padding:.625rem;background:#0f172a;border:1px solid #10b981;border-radius:8px;color:#fff;font-size:.875rem;transition:all .2s ease}.budget-input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.budget-info{font-size:.75rem;color:#86efac;margin-top:.25rem;font-weight:600}.date-input:focus,.search-input:focus,.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-input::placeholder{color:#64748b}.sort-order-btn{padding:.625rem;background:#0f172a;border:1px solid #475569;border-radius:8px;color:#fff;font-size:1.25rem;cursor:pointer;transition:all .2s ease;width:100%}.sort-order-btn:hover{background:#1e293b;border-color:#3b82f6}.export-btn{padding:.625rem 1rem;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%}.export-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.export-btn:active{transform:translateY(0)}.results-info{margin-top:1rem;padding-top:1rem;border-top:1px solid #475569;font-size:.875rem;color:#94a3b8;text-align:center}.budget-summary{display:block;margin-top:.5rem;color:#10b981;font-weight:600}@media(max-width:1024px){.filters-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media(max-width:768px){.filters-row{grid-template-columns:1fr}}.expanded-details{padding:2rem;background:#0f172a;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}.detail-section{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1.5rem}.detail-section h4{font-size:1.125rem;color:#fff;margin-bottom:.5rem}.section-subtitle{font-size:.875rem;color:#94a3b8;margin-bottom:1.5rem}.forecast-values{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.forecast-item{text-align:center;padding:1rem;background:#0f172a;border:1px solid #334155;border-radius:8px}.forecast-item.highlight{background:linear-gradient(135deg,#3b82f61a,#2563eb1a);border-color:#3b82f6}.forecast-label{display:block;font-size:.75rem;color:#94a3b8;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.forecast-value{display:block;font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:.25rem}.forecast-value.main{font-size:2rem;color:#3b82f6}.forecast-sublabel{display:block;font-size:.75rem;color:#64748b}.historical-context{padding:1rem;background:#3b82f60d;border:1px solid rgba(59,130,246,.2);border-radius:8px;font-size:.875rem;color:#cbd5e1;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.historical-context strong{color:#fff}.yearly-values{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.yearly-item{text-align:center;padding:1rem;background:#0f172a;border:1px solid #334155;border-radius:8px}.yearly-label{display:block;font-size:.75rem;color:#94a3b8;margin-bottom:.5rem}.yearly-value{display:block;font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:.25rem}.yearly-sublabel{display:block;font-size:.75rem;color:#64748b}.insights-list{list-style:none;padding:0;margin:0}.insights-list li{padding:.75rem;margin-bottom:.5rem;background:#0f172a;border-left:3px solid #3b82f6;border-radius:4px;font-size:.875rem;color:#cbd5e1}.insights-list li strong{color:#fff;margin-right:.5rem}.history-section{grid-column:1 / -1}.history-table-wrapper{overflow-x:auto}.history-table{width:100%;border-collapse:collapse}.history-table thead{background:#0f172a}.history-table th{padding:.75rem;text-align:left;font-size:.75rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #334155}.history-table td{padding:.75rem;font-size:.875rem;color:#e2e8f0;border-bottom:1px solid #334155}.history-table tr.recent-row{background:#3b82f60d}.units-cell{font-weight:600}.badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;margin-right:.5rem}.recent-badge{background:#3b82f633;color:#93c5fd}.above-badge{background:#22c55e33;color:#86efac}.below-badge{background:#fbbf2433;color:#fcd34d}@media(max-width:1024px){.details-grid,.forecast-values,.yearly-values{grid-template-columns:1fr}}.product-row{position:relative}.product-row.critical{border-left:3px solid #ef4444}.product-row.low{border-left:3px solid #f59e0b}.product-row.adequate{border-left:3px solid #10b981}.status-indicator{font-size:1.25rem;display:inline-block}.product-name{font-weight:600;color:#fff}.category-badge{padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase}.category-badge.grocery{background:#22c55e33;color:#86efac}.category-badge.liquor{background:#a855f733;color:#c084fc}.stock-value,.demand-value{font-weight:600;font-size:1rem}.trend-badge{padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;display:inline-flex;align-items:center;gap:.25rem}.trend-badge.increasing{background:#22c55e33;color:#86efac}.trend-badge.stable{background:#3b82f633;color:#93c5fd}.trend-badge.decreasing{background:#ef444433;color:#fca5a5}.order-badge{padding:.25rem .75rem;border-radius:6px;font-size:.875rem;font-weight:700}.order-badge.urgent,.order-badge.high{background:#ef444433;color:#fca5a5}.order-badge.medium{background:#fbbf2433;color:#fcd34d}.order-badge.low,.order-badge.none{background:#64748b33;color:#cbd5e1}.confidence-badge{padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600}.confidence-badge.very-high,.confidence-badge.high{background:#22c55e33;color:#86efac}.confidence-badge.medium{background:#3b82f633;color:#93c5fd}.confidence-badge.low,.confidence-badge.very-low{background:#fbbf2433;color:#fcd34d}.expand-btn{padding:.5rem .75rem;background:#334155;border:1px solid #475569;border-radius:6px;color:#fff;cursor:pointer;transition:all .2s ease;font-size:.875rem}.expand-btn:hover{background:#3b82f6;border-color:#3b82f6}.products-table-container{background:#1e293b;border:1px solid #475569;border-radius:12px;overflow-x:auto}.products-table{width:100%;min-width:1000px;border-collapse:collapse}.products-table thead{background:#0f172a;position:sticky;top:0;z-index:10}.products-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #475569}.products-table tbody tr{border-bottom:1px solid #334155;transition:background .2s ease}.products-table tbody tr:hover{background:#3b82f60d}.products-table td{padding:1rem;color:#e2e8f0;font-size:.875rem}.no-results{padding:4rem 2rem;text-align:center;color:#94a3b8}.no-results-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.no-results h3{font-size:1.5rem;color:#e2e8f0;margin-bottom:.5rem}.no-results p{font-size:1rem;color:#64748b}@media(max-width:1024px){.products-table-container{overflow-x:auto}.products-table{min-width:1000px}}.bulk-prediction-page{padding:1rem;max-width:100%;margin:0 auto;min-height:100vh;background:transparent}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{font-size:2rem;color:#f1f5f9;margin-bottom:.5rem}.page-subtitle{font-size:1rem;color:#94a3b8}.refresh-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.error-banner{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;padding:1rem 1.5rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem;color:#fca5a5}.error-icon{font-size:1.5rem}.retry-btn{margin-left:auto;padding:.5rem 1rem;background:#ef444433;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#fca5a5;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-btn:hover{background:#ef44444d}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#94a3b8}.loading-spinner{width:48px;height:48px;border:4px solid #334155;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{font-size:1rem;color:#64748b}@media(max-width:768px){.bulk-prediction-page{padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.page-header h1{font-size:1.5rem}.refresh-btn{width:100%}}.prediction-actions{display:flex;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:#1e293b80;border-radius:12px;border:1px solid rgba(148,163,184,.1)}.prediction-btn{flex:1;padding:1rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.previous-years-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.previous-years-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #8b5cf666}.last-n-months-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.last-n-months-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #10b98166}.prediction-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#1e293b;border-radius:16px;padding:2rem;max-width:500px;width:90%;border:1px solid rgba(148,163,184,.2);box-shadow:0 20px 40px #00000080}.modal-content h2{color:#f1f5f9;margin-bottom:.5rem;font-size:1.5rem}.modal-content p{color:#cbd5e1;margin-bottom:1.5rem;font-size:.875rem}.modal-input-group{margin-bottom:1.5rem}.modal-input-group label{display:block;color:#cbd5e1;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.date-input{width:100%;padding:.75rem;background:#0f172a;border:1px solid rgba(148,163,184,.2);border-radius:8px;color:#f1f5f9;font-size:1rem}.date-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.month-spinner{display:flex;align-items:center;gap:.5rem}.spinner-btn{width:40px;height:40px;background:#334155;border:1px solid rgba(148,163,184,.2);border-radius:8px;color:#f1f5f9;font-size:1.25rem;font-weight:600;cursor:pointer;transition:all .2s ease}.spinner-btn:hover{background:#475569}.spinner-btn:active{transform:scale(.95)}.month-input{flex:1;padding:.75rem;background:#0f172a;border:1px solid rgba(148,163,184,.2);border-radius:8px;color:#f1f5f9;font-size:1rem;text-align:center}.month-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem}.btn-primary{flex:1;padding:.75rem 1.5rem;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #6366f166}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;background:#475569}.btn-secondary{padding:.75rem 1.5rem;background:transparent;border:1px solid rgba(148,163,184,.3);border-radius:8px;color:#cbd5e1;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:#94a3b81a}.prediction-results-section{margin-top:2rem}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1.5rem;background:#1e293b80;border-radius:12px;border:1px solid rgba(148,163,184,.1)}.results-info-banner{padding:1rem;margin-bottom:1rem;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:8px;color:#cbd5e1;text-align:center;font-size:.875rem;font-weight:600}.results-header h2{color:#f1f5f9;font-size:1.5rem;margin:0}.results-actions{display:flex;gap:1rem}.btn-export{padding:.75rem 1.5rem;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-export:hover{transform:translateY(-2px);box-shadow:0 8px 16px #10b98166}.btn-back{padding:.75rem 1.5rem;background:#94a3b81a;border:1px solid rgba(148,163,184,.3);border-radius:8px;color:#cbd5e1;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-back:hover{background:#94a3b833}.prediction-results-table-container{background:#1e293b80;border-radius:12px;border:1px solid rgba(148,163,184,.1);overflow:hidden}.prediction-results-table{width:100%;border-collapse:collapse}.prediction-results-table thead{background:#0f172acc}.prediction-results-table th{padding:1rem;text-align:left;color:#cbd5e1;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid rgba(148,163,184,.1)}.prediction-results-table tbody tr{border-bottom:1px solid rgba(148,163,184,.05);transition:background .2s ease}.prediction-results-table tbody tr:hover{background:#3b82f60d}.prediction-results-table td{padding:1rem;color:#e2e8f0;font-size:.875rem}.item-name-cell{font-weight:600;color:#f1f5f9}.prediction-cell{font-weight:700;color:#6366f1;font-size:1rem}.trend-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.trend-badge.increasing{background:#10b98133;color:#34d399}.trend-badge.stable{background:#3b82f633;color:#60a5fa}.trend-badge.decreasing{background:#ef444433;color:#f87171}.confidence-badge{display:inline-block;padding:.25rem .75rem;background:#8b5cf633;border-radius:12px;color:#a78bfa;font-size:.75rem;font-weight:600}.view-details-btn{padding:.5rem 1rem;background:#6366f133;border:1px solid rgba(99,102,241,.3);border-radius:6px;color:#818cf8;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease}.view-details-btn:hover{background:#6366f14d;transform:translateY(-1px)}.view-details-btn:active{transform:translateY(0)}.infinite-scroll-trigger{padding:2rem;text-align:center;min-height:60px}.scroll-sentinel{padding:1rem;text-align:center}.loading-more{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#94a3b8}.loading-spinner-small{width:32px;height:32px;border:3px solid #334155;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite}.all-loaded-message{padding:2rem;text-align:center;color:#10b981;font-weight:600;font-size:1rem}.load-more-results{padding:2rem;text-align:center}.btn-load-more{padding:1rem 2rem;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-load-more:hover{transform:translateY(-2px);box-shadow:0 8px 16px #6366f166}.btn-load-more:active{transform:translateY(0)}@media(max-width:768px){.prediction-actions{flex-direction:column}.results-header{flex-direction:column;align-items:flex-start;gap:1rem}.results-actions{width:100%;flex-direction:column}.btn-export,.btn-back{width:100%}.prediction-results-table-container{overflow-x:auto}.prediction-results-table{min-width:800px}.modal-content{width:95%;padding:1.5rem}.modal-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.expand-btn{background:transparent;border:none;color:#94a3b8;font-size:.875rem;cursor:pointer;padding:.25rem .5rem;transition:all .2s ease}.expand-btn:hover{color:#6366f1}.prediction-results-table tbody tr.expanded{background:#6366f10d}.expanded-row{background:#0f172a!important}.expanded-row td{padding:0!important}.prediction-details-panel{padding:2rem;background:#0f172a;border-top:2px solid rgba(99,102,241,.3)}.prediction-details-panel h3{color:#f1f5f9;font-size:1.25rem;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid rgba(148,163,184,.2)}.prediction-details-panel h4{color:#cbd5e1;font-size:1rem;margin:1.5rem 0 1rem}.stats-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#1e293b80;border:1px solid rgba(148,163,184,.1);border-radius:8px;padding:1rem;text-align:center}.stat-label{font-size:.75rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.stat-value{font-size:1.5rem;font-weight:700;color:#6366f1}.data-breakdown{margin-top:2rem}.breakdown-table-container{overflow-x:auto;margin-bottom:2rem}.breakdown-table{width:100%;border-collapse:collapse;background:#1e293b4d;border-radius:8px;overflow:hidden}.breakdown-table thead{background:#0f172acc}.breakdown-table th{padding:.75rem;text-align:left;color:#cbd5e1;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid rgba(148,163,184,.1)}.breakdown-table tbody tr{border-bottom:1px solid rgba(148,163,184,.05);transition:background .2s ease}.breakdown-table tbody tr:hover{background:#6366f10d}.breakdown-table td{padding:.75rem;color:#e2e8f0;font-size:.875rem}.simple-chart{background:#1e293b4d;border:1px solid rgba(148,163,184,.1);border-radius:8px;padding:1.5rem;margin-top:1.5rem}.simple-chart h4{margin-top:0;margin-bottom:1.5rem}.chart-bars{display:flex;flex-direction:column;gap:.75rem}.chart-bar-item{display:flex;align-items:center;gap:1rem}.chart-bar-label{min-width:80px;font-size:.875rem;color:#cbd5e1;font-weight:600}.chart-bar-container{flex:1;height:32px;background:#0f172acc;border-radius:4px;overflow:hidden;position:relative}.chart-bar-fill{height:100%;background:linear-gradient(135deg,#6366f1,#4f46e5);display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;transition:width .3s ease;min-width:60px}.chart-bar-value{color:#fff;font-size:.75rem;font-weight:600}@media(max-width:768px){.stats-summary{grid-template-columns:repeat(2,1fr)}.prediction-details-panel{padding:1rem}.chart-bar-label{min-width:60px;font-size:.75rem}.breakdown-table{font-size:.75rem}.breakdown-table th,.breakdown-table td{padding:.5rem}}.confidence-analysis{background:#1e293b80;border:1px solid rgba(148,163,184,.1);border-radius:8px;padding:1.5rem;margin-top:1.5rem}.confidence-analysis h4{margin-top:0;margin-bottom:1rem}.confidence-details{display:flex;flex-direction:column;gap:1rem}.confidence-score{display:flex;align-items:center;gap:1rem;padding:1rem;background:#0f172a80;border-radius:6px}.confidence-label{font-size:1rem;color:#cbd5e1;font-weight:600}.confidence-value{font-size:1.5rem;font-weight:700;padding:.25rem .75rem;border-radius:6px}.confidence-value.high{color:#10b981;background:#10b9811a}.confidence-value.medium{color:#f59e0b;background:#f59e0b1a}.confidence-value.low{color:#ef4444;background:#ef44441a}.confidence-explanation{color:#cbd5e1;font-size:.875rem;line-height:1.6}.confidence-explanation p{margin:.5rem 0}.confidence-explanation strong{color:#f1f5f9}.confidence-note{color:#94a3b8;font-size:.8125rem;font-style:italic;padding:.75rem;background:#0f172a4d;border-left:3px solid #6366f1;margin-top:.75rem}.confidence-recommendation{color:#fbbf24;padding:.75rem;background:#fbbf241a;border-left:3px solid #fbbf24;margin-top:.75rem}.analytics-page{padding:1.5rem;max-width:100%;margin:0 auto;min-height:100vh;background:#0f172a}.analytics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.analytics-header h1{font-size:1.75rem;color:#fff;margin-bottom:.5rem}.subtitle{font-size:.875rem;color:#94a3b8;line-height:1.5}.refresh-btn{padding:.625rem 1.25rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.refresh-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #3b82f666}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.product-count-badge{padding:.4rem .875rem;background:#3b82f626;border:1px solid rgba(59,130,246,.3);border-radius:20px;font-size:.75rem;font-weight:700;color:#93c5fd;letter-spacing:.3px}.search-panel{position:relative;margin-bottom:1.5rem;z-index:50}.search-panel-inner{display:flex;align-items:center;gap:0;background:#1e293b;border:2px solid #334155;border-radius:16px;padding:.25rem .5rem;transition:all .3s ease;box-shadow:0 4px 16px #0003}.search-panel-inner:focus-within{border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f626,0 8px 32px #0000004d}.search-icon-wrap{display:flex;align-items:center;justify-content:center;padding:0 .75rem;opacity:.6}.search-main-input{flex:1;background:transparent;border:none;outline:none;color:#e2e8f0;font-size:1rem;font-weight:500;padding:.875rem .5rem;font-family:inherit}.search-main-input::placeholder{color:#64748b;font-weight:400}.search-clear-btn{background:#94a3b826;border:none;color:#94a3b8;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.search-clear-btn:hover{background:#ef444433;color:#ef4444}.search-cached-badge{padding:.25rem .625rem;background:#10b98126;border:1px solid rgba(16,185,129,.3);border-radius:20px;font-size:.7rem;font-weight:700;color:#10b981;white-space:nowrap;flex-shrink:0;margin-left:.5rem}.search-results-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#1e293b;border:1px solid #475569;border-radius:16px;max-height:420px;overflow-y:auto;box-shadow:0 16px 48px #0009;animation:dropdownSlide .2s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.search-results-dropdown::-webkit-scrollbar{width:6px}.search-results-dropdown::-webkit-scrollbar-thumb{background:#475569;border-radius:3px}.search-section{padding:.5rem 0}.search-section-title{padding:.5rem 1rem;font-size:.7rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.search-empty{padding:2rem 1rem;text-align:center}.search-empty-icon{font-size:2rem;display:block;margin-bottom:.75rem;opacity:.5}.search-empty p{color:#94a3b8;margin:.25rem 0;font-size:.875rem}.search-empty-hint{font-size:.75rem!important;color:#64748b!important}.product-suggestion-card{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;cursor:pointer;transition:all .15s ease;border-left:3px solid transparent}.product-suggestion-card:hover{background:#3b82f614;border-left-color:#3b82f6}.product-suggestion-card.active{background:#3b82f61f;border-left-color:#3b82f6}.psc-left{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.psc-icon{font-size:1.25rem;width:36px;height:36px;border-radius:10px;background:#3b82f61a;display:flex;align-items:center;justify-content:center;flex-shrink:0}.psc-info{min-width:0;flex:1}.psc-name{font-size:.875rem;font-weight:600;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.psc-meta{display:flex;align-items:center;gap:.5rem;margin-top:.2rem}.psc-cat{font-size:.65rem;font-weight:700;padding:.1rem .5rem;border-radius:10px;letter-spacing:.3px}.psc-cat.grocery{background:#10b98126;color:#10b981}.psc-cat.liquor{background:#f59e0b26;color:#f59e0b}.psc-stat{font-size:.7rem;color:#64748b}.psc-right{text-align:right;flex-shrink:0;padding-left:1rem}.psc-total{font-size:1rem;font-weight:800;color:#e2e8f0}.psc-label{font-size:.6rem;color:#64748b;text-transform:uppercase;letter-spacing:.3px}.psc-monthly{font-size:.7rem;color:#94a3b8;margin-top:.1rem}.search-highlight{background:#3b82f64d;color:#93c5fd;border-radius:2px;padding:0 1px}.analyzing-strip{display:flex;align-items:center;gap:.75rem;padding:.625rem 1.25rem;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:10px;margin-bottom:1.5rem;font-size:.85rem;color:#94a3b8;flex-wrap:wrap}.analyzing-dot{width:8px;height:8px;border-radius:50%;background:#3b82f6;animation:pulse 2s infinite;flex-shrink:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.analyzing-strip strong{color:#e2e8f0}.analyzing-cat,.analyzing-grp{font-size:.7rem;font-weight:700;padding:.15rem .6rem;border-radius:12px}.analyzing-cat{background:#10b98126;color:#10b981}.analyzing-grp{background:#8b5cf626;color:#a78bfa}.analytics-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}.summary-card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1.25rem;display:flex;gap:1rem;transition:all .3s ease}.summary-card:hover{border-color:#3b82f6;box-shadow:0 8px 16px #0000004d;transform:translateY(-2px)}.card-icon{font-size:2rem;min-width:50px;text-align:center}.card-content{flex:1}.card-label{font-size:.8125rem;color:#94a3b8;font-weight:500;margin-bottom:.5rem}.card-value{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:.5rem;line-height:1.2}.card-detail{font-size:.8125rem;color:#64748b}.chart-card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1.25rem;margin-bottom:1.5rem;transition:all .3s ease;overflow:hidden}.chart-card:hover{border-color:#3b82f6;box-shadow:0 8px 16px #0000004d}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #334155;flex-wrap:wrap;gap:.5rem}.chart-header h2{font-size:1.125rem;color:#fff;margin:0}.chart-badge{padding:.25rem .75rem;background:#3b82f633;border:1px solid rgba(59,130,246,.3);border-radius:6px;font-size:.75rem;font-weight:600;color:#93c5fd;white-space:nowrap}.chart-description{font-size:.8125rem;color:#94a3b8;margin-bottom:1.25rem;line-height:1.5}.yearwise-bars{display:flex;gap:1.5rem;padding:1.5rem 0;overflow-x:auto;min-height:300px;align-items:flex-end}.year-bar-container{flex:1;min-width:120px;display:flex;flex-direction:column;align-items:center;gap:.75rem}.year-bar-wrapper{width:100%;height:200px;display:flex;align-items:flex-end;justify-content:center}.year-bar{width:80%;background:linear-gradient(180deg,#3b82f6,#2563eb);border-radius:8px 8px 0 0;position:relative;transition:all .3s ease;display:flex;align-items:flex-start;justify-content:center;padding-top:.5rem;min-height:40px}.year-bar:hover{background:linear-gradient(180deg,#60a5fa,#3b82f6);transform:scaleY(1.05)}.bar-value{font-size:.75rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.year-label{font-size:.9375rem;font-weight:700;color:#3b82f6;text-align:center}.year-details{display:flex;flex-direction:column;gap:.375rem;width:100%;padding:.75rem;background:#0f172a80;border:1px solid #334155;border-radius:8px}.detail-row{display:flex;justify-content:space-between;font-size:.75rem}.detail-label{color:#94a3b8}.detail-value{color:#fff;font-weight:600}.month-selector{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.month-selector label{font-weight:600;color:#fff;min-width:100px}.month-select{padding:.6rem 1rem;border:1px solid #475569;border-radius:8px;background:#0f172a;color:#fff;font-size:.9rem;cursor:pointer;outline:none;transition:all .2s}.month-select:hover,.month-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.no-data{text-align:center;padding:3rem 1rem;color:#64748b;font-size:.9375rem;background:#0f172a4d;border-radius:8px;border:1px dashed #334155}.recharts-wrapper{max-width:100%;background:transparent!important}.recharts-surface{background:transparent!important}.recharts-cartesian-grid-bg{fill:transparent!important}.recharts-cartesian-axis-tick-value{fill:#94a3b8;font-size:.75rem}.recharts-legend-item-text{color:#94a3b8!important}.recharts-tooltip-wrapper{outline:none}.recharts-default-tooltip{background:#0f172af2!important;border:1px solid #3b82f6!important;border-radius:8px!important}.insights-card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1.25rem;transition:all .3s ease}.insights-card:hover{border-color:#3b82f6;box-shadow:0 8px 16px #0000004d}.insights-card h2{font-size:1.125rem;color:#fff;margin-bottom:1.25rem}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.insight-item{display:flex;gap:1rem;padding:1.25rem;background:#0f172a80;border-radius:8px;border-left:4px solid #3b82f6;transition:all .3s ease}.insight-item:hover{background:#0f172acc;transform:translate(4px)}.insight-icon{font-size:1.5rem;min-width:40px;text-align:center}.insight-item h4{font-size:.9375rem;color:#fff;margin-bottom:.5rem;font-weight:600}.insight-item p{font-size:.8125rem;color:#94a3b8;line-height:1.6}.insight-item strong{color:#fff;font-weight:600}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:1rem;color:#fca5a5;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}@media(min-width:1200px){.analytics-page{padding:2rem;max-width:1600px}.analytics-header h1{font-size:2rem}.subtitle{font-size:1rem}}@media(max-width:768px){.analytics-page{padding:1rem}.analytics-header{flex-direction:column;align-items:flex-start}.analytics-header h1{font-size:1.5rem}.refresh-btn{width:100%}.analytics-summary{grid-template-columns:1fr}.selector-content{flex-direction:column;align-items:flex-start}.item-select,.month-select{width:100%}.insights-grid{grid-template-columns:1fr}.yearwise-bars{gap:1rem}.year-bar-container{min-width:100px}.chart-card{padding:1rem}.chart-header h2{font-size:1rem}}@media(max-width:480px){.yearwise-bars{gap:.75rem}.year-bar-container{min-width:80px}.year-details{padding:.5rem}.detail-row,.bar-value{font-size:.6875rem}}.budget-page{padding:1rem;max-width:100%;margin:0 auto;min-height:100vh;background:#0f172a}.budget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.budget-header h1{font-size:1.75rem;color:#fff;margin:0 0 .5rem}.budget-header .subtitle{font-size:.875rem;color:#94a3b8}.budget-input-panel{background:linear-gradient(135deg,#1e293b,#0f172a);border:2px solid #334155;border-radius:16px;padding:2rem;margin-bottom:2rem;transition:border-color .3s}.budget-input-panel:focus-within{border-color:#3b82f6}.budget-input-row{display:flex;align-items:flex-end;gap:1.5rem;flex-wrap:wrap}.budget-field{flex:1;min-width:200px}.budget-field label{display:block;font-size:.75rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.budget-currency-input{display:flex;align-items:center;background:#0f172a;border:1px solid #475569;border-radius:12px;overflow:hidden;transition:border-color .2s}.budget-currency-input:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.currency-symbol{padding:0 1rem;font-size:1.25rem;font-weight:800;color:#10b981;background:#10b98114;height:100%;display:flex;align-items:center}.budget-amount-input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-size:1.5rem;font-weight:700;padding:1rem;font-family:inherit}.budget-amount-input::placeholder{color:#475569;font-weight:400}.budget-select{width:100%;padding:.875rem 1rem;background:#0f172a;border:1px solid #475569;border-radius:12px;color:#fff;font-size:.9rem;cursor:pointer;outline:none;transition:border-color .2s}.budget-select:focus{border-color:#3b82f6}.allocate-btn{padding:1rem 2.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:12px;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap;min-height:54px}.allocate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.allocate-btn:disabled{opacity:.5;cursor:not-allowed}.budget-summary-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.bs-card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1.25rem;text-align:center;transition:all .3s}.bs-card:hover{border-color:#3b82f6;transform:translateY(-2px)}.bs-label{font-size:.7rem;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.bs-value{font-size:1.5rem;font-weight:800;color:#fff}.bs-value.green{color:#10b981}.bs-value.blue{color:#3b82f6}.bs-value.amber{color:#f59e0b}.bs-sub{font-size:.7rem;color:#94a3b8;margin-top:.25rem}.budget-charts-row{display:grid;grid-template-columns:380px 1fr;gap:1.5rem;margin-bottom:2rem}@media(max-width:900px){.budget-charts-row{grid-template-columns:1fr}}.pie-card,.bar-card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1.5rem}.pie-card h3,.bar-card h3{font-size:1rem;color:#fff;margin:0 0 .25rem}.pie-card .chart-sub,.bar-card .chart-sub{font-size:.8rem;color:#94a3b8;margin-bottom:1rem}.group-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1.25rem;margin-bottom:2rem}.group-card{background:#1e293b;border:1px solid #334155;border-radius:14px;padding:1.5rem;transition:all .3s;position:relative;overflow:hidden}.group-card:hover{border-color:#3b82f6;box-shadow:0 8px 24px #0000004d}.group-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px}.group-card:nth-child(1):before{background:#3b82f6}.group-card:nth-child(2):before{background:#10b981}.group-card:nth-child(3):before{background:#f59e0b}.group-card:nth-child(4):before{background:#8b5cf6}.group-card:nth-child(5):before{background:#ef4444}.group-card:nth-child(6):before{background:#ec4899}.gc-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.gc-title{font-size:.95rem;font-weight:700;color:#fff}.gc-badge{font-size:.65rem;font-weight:700;padding:.15rem .6rem;border-radius:12px;letter-spacing:.3px}.gc-badge.grocery{background:#10b98126;color:#10b981}.gc-badge.liquor{background:#f59e0b26;color:#f59e0b}.gc-amount{font-size:1.75rem;font-weight:800;color:#fff;margin-bottom:.25rem}.gc-pct{font-size:.85rem;color:#94a3b8;margin-bottom:1rem}.gc-progress-bar{height:6px;background:#ffffff0d;border-radius:3px;margin-bottom:1rem;overflow:hidden}.gc-progress-fill{height:100%;border-radius:3px;transition:width .5s ease}.gc-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem;margin-bottom:1rem;padding:.75rem;background:#0f172a80;border-radius:8px}.gc-stat-label{font-size:.65rem;color:#64748b;text-transform:uppercase}.gc-stat-val{font-size:.9rem;font-weight:700;color:#e2e8f0;margin-top:.15rem}.gc-top-title{font-size:.7rem;color:#64748b;text-transform:uppercase;letter-spacing:.3px;margin-bottom:.5rem}.gc-top-item{display:flex;justify-content:space-between;align-items:center;padding:.35rem 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:.8rem}.gc-top-item:last-child{border-bottom:none}.gc-top-name{color:#94a3b8;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:.5rem}.gc-top-sold{color:#e2e8f0;font-weight:600;white-space:nowrap}.export-row{display:flex;justify-content:flex-end;gap:1rem;margin-bottom:1.5rem}.export-btn{padding:.625rem 1.5rem;background:#10b98126;border:1px solid rgba(16,185,129,.3);border-radius:10px;color:#10b981;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.export-btn:hover{background:#10b98140;transform:translateY(-1px)}.custom-pie-container{display:flex;flex-direction:column;align-items:center}.pie-legend{margin-top:1rem;display:flex;flex-direction:column;gap:.4rem}.pie-legend-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#94a3b8}.pie-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}@media(max-width:768px){.budget-page{padding:1rem}.budget-input-row{flex-direction:column;align-items:stretch}.budget-amount-input{font-size:1.25rem}.group-cards-grid{grid-template-columns:1fr}.budget-summary-strip{grid-template-columns:1fr 1fr}}.data-upload-page{padding:1rem;max-width:100%;margin:0 auto;min-height:100vh;background:#0f172a}.page-header{margin-bottom:2rem}.page-header h1{font-size:1.75rem;color:#fff;margin-bottom:.5rem}.subtitle{color:#94a3b8;font-size:.875rem;line-height:1.5}.model-health-card{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;border-radius:12px;margin-bottom:1.5rem;border:1px solid #334155;background:#1e293b;flex-wrap:wrap;gap:1rem}.model-health-card.healthy{border-color:#10b981;background:#10b9810d}.model-health-card.unhealthy{border-color:#ef4444;background:#ef44440d}.health-content{display:flex;align-items:center;gap:1rem;flex:1;min-width:300px}.health-icon{font-size:2rem;flex-shrink:0}.health-info h3{font-size:1rem;margin:0 0 .25rem;color:#fff;font-weight:600}.health-info p{margin:0;font-size:.875rem;color:#94a3b8}.model-health-card.healthy .health-info p{color:#86efac}.model-health-card.unhealthy .health-info p{color:#fca5a5}.health-time{display:block;font-size:.75rem;color:#64748b;margin-top:.25rem}.btn-primary,.btn-secondary{padding:.625rem 1.25rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #3b82f666}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:transparent;border:1px solid #475569;color:#94a3b8}.btn-secondary:hover:not(:disabled){background:#3b82f61a;border-color:#3b82f6;color:#fff}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-small{padding:.5rem 1rem;font-size:.8125rem}.btn-large{padding:.875rem 1.75rem;font-size:1rem;width:100%}.format-preview-card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1.25rem;margin-bottom:1.5rem;transition:all .3s ease}.format-preview-card:hover{border-color:#3b82f6}.format-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.format-header h2{font-size:1.125rem;color:#fff;margin:0}.format-content{display:flex;flex-direction:column;gap:1.5rem}.format-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.info-box{background:#0f172a80;border:1px solid #334155;border-radius:8px;padding:1rem}.info-box h3{font-size:.9375rem;color:#fff;margin-bottom:.75rem;font-weight:600}.info-box ul{list-style:none;padding:0;margin:0}.info-box li{font-size:.8125rem;color:#94a3b8;margin-bottom:.5rem;line-height:1.5}.info-box strong{color:#fff}.columns-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.column-item{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:6px;padding:.75rem}.column-item strong{color:#fff;font-size:.8125rem}.column-type{display:block;font-size:.7rem;color:#93c5fd;margin-top:.25rem}.column-item p{font-size:.75rem;color:#94a3b8;margin:.5rem 0 0}.sample-data-section{background:#0f172a80;border:1px solid #334155;border-radius:8px;padding:1rem}.sample-data-section h3{font-size:.9375rem;color:#fff;margin-bottom:.75rem;font-weight:600}.sample-table-wrapper{overflow-x:auto}.sample-table{width:100%;border-collapse:collapse;font-size:.8125rem}.sample-table th{background:#3b82f633;color:#fff;padding:.75rem;text-align:left;font-weight:600;border:1px solid #334155}.sample-table td{color:#94a3b8;padding:.75rem;border:1px solid #334155}.important-notes{background:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:1rem}.important-notes h3{font-size:.9375rem;color:#fca5a5;margin-bottom:.75rem;font-weight:600}.important-notes ul{list-style:none;padding:0;margin:0}.important-notes li{font-size:.8125rem;color:#94a3b8;margin-bottom:.5rem;line-height:1.5}.upload-section-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:1.5rem}.upload-card,.retrain-card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1.25rem;transition:all .3s ease}.upload-card:hover,.retrain-card:hover{border-color:#3b82f6;box-shadow:0 8px 16px #0000004d}.upload-card h2,.retrain-card h2{font-size:1.125rem;color:#fff;margin-bottom:.5rem}.card-description{font-size:.8125rem;color:#94a3b8;margin-bottom:1rem;line-height:1.5}.upload-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.8125rem;font-weight:600;color:#fff}.form-input{padding:.625rem .75rem;border:1px solid #475569;border-radius:6px;background:#0f172a;color:#fff;font-size:.8125rem;cursor:pointer;transition:all .2s}.form-input:hover{border-color:#3b82f6}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.upload-info-banner{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:6px;font-size:.8125rem;color:#93c5fd}.info-icon{font-size:1rem;flex-shrink:0}.upload-area{position:relative;border:2px dashed #475569;border-radius:8px;padding:2rem 1rem;text-align:center;transition:all .3s;cursor:pointer}.upload-area:hover{border-color:#3b82f6;background:#3b82f60d}.file-input{display:none}.file-label{display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer}.upload-icon{font-size:2rem}.upload-text{font-size:.9375rem;font-weight:600;color:#fff}.upload-hint{display:block;font-size:.75rem;color:#64748b}.file-info{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:6px;gap:1rem;flex-wrap:wrap}.file-details{display:flex;align-items:center;gap:.75rem;flex:1}.file-name{font-size:.8125rem;color:#fff;font-weight:600}.file-size{font-size:.75rem;color:#94a3b8}.result-box{padding:1rem;border-radius:8px;margin-top:1rem}.result-box.success{background:#10b9811a;border:1px solid rgba(16,185,129,.3)}.result-box.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3)}.result-box h3{font-size:.9375rem;margin:0 0 .75rem;font-weight:600}.result-box.success h3{color:#86efac}.result-box.error h3{color:#fca5a5}.result-details{display:flex;flex-direction:column;gap:.5rem}.result-details p{font-size:.8125rem;margin:0;color:#94a3b8}.success-message{color:#86efac!important;font-weight:600}.error-message{color:#fca5a5!important;font-weight:600}.note-message{font-size:.75rem;color:#64748b;font-style:italic}.statistics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-top:.75rem}.stat-item{display:flex;flex-direction:column;gap:.25rem;padding:.5rem;background:#3b82f61a;border-radius:4px}.stat-label{font-size:.7rem;color:#94a3b8}.stat-value{font-size:.9375rem;font-weight:700;color:#fff}.stat-value.critical{color:#fca5a5}.retrain-info{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.info-item{display:flex;gap:.75rem;padding:.75rem;background:#0f172a80;border:1px solid #334155;border-radius:6px}.info-item .info-icon{font-size:1.5rem;flex-shrink:0}.info-item h4{font-size:.8125rem;color:#fff;margin:0 0 .25rem;font-weight:600}.info-item ul{list-style:none;padding:0;margin:0}.info-item li{font-size:.75rem;color:#94a3b8;margin-bottom:.25rem}.info-item p{font-size:.75rem;color:#94a3b8;margin:0;line-height:1.5}.instructions-card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.instructions-card h2{font-size:1.125rem;color:#fff;margin-bottom:1rem}.instructions-content{display:flex;flex-direction:column;gap:1rem}.instruction-step{display:flex;gap:1rem;padding:1rem;background:#0f172a80;border:1px solid #334155;border-radius:8px}.step-number{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;color:#fff;font-weight:700;flex-shrink:0}.instruction-step h3{font-size:.9375rem;color:#fff;margin:0 0 .5rem;font-weight:600}.instruction-step p{font-size:.8125rem;color:#94a3b8;margin:0;line-height:1.6}.instruction-step strong{color:#fff}.tips-card{background:#1e293b;border:1px solid #334155;border-radius:12px;padding:1.25rem}.tips-card h2{font-size:1.125rem;color:#fff;margin-bottom:1rem}.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.tip-item{display:flex;gap:.75rem;padding:1rem;background:#0f172a80;border:1px solid #334155;border-radius:8px;transition:all .3s}.tip-item:hover{background:#0f172acc;border-color:#3b82f6;transform:translateY(-2px)}.tip-icon{font-size:1.5rem;flex-shrink:0}.tip-item h4{font-size:.8125rem;color:#fff;margin:0 0 .25rem;font-weight:600}.tip-item p{font-size:.75rem;color:#94a3b8;margin:0;line-height:1.5}@media(max-width:768px){.data-upload-page{padding:1rem}.page-header h1{font-size:1.5rem}.upload-section-grid,.form-row{grid-template-columns:1fr}.file-info{flex-direction:column;align-items:flex-start}.btn-large{width:100%}.instructions-content{gap:.75rem}.instruction-step{padding:.75rem}.tips-grid{grid-template-columns:1fr}}@media(max-width:480px){.format-header,.model-health-card{flex-direction:column;align-items:flex-start}.health-content{min-width:auto}.columns-grid{grid-template-columns:1fr}.statistics-grid{grid-template-columns:repeat(2,1fr)}}.retrain-progress{margin-top:1rem;padding:1rem;background:#3b82f60d;border:1px solid rgba(59,130,246,.2);border-radius:8px}.progress-info{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}.progress-info p{font-size:.8125rem;color:#94a3b8;margin:0;padding-left:1.5rem;position:relative}.progress-info p:last-child{color:#fbbf24;font-weight:600;margin-top:.5rem}.sidebar{position:fixed;left:0;top:0;width:220px;height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border)}.logo{display:flex;align-items:center;gap:.75rem}.logo-icon{font-size:1.75rem}.logo-text{font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.logo-subtitle{font-size:.75rem;color:var(--text-muted);margin-top:.25rem;font-weight:500}.sidebar-nav{flex:1;padding:1rem 0;display:flex;flex-direction:column;gap:0;overflow-y:auto}.nav-section{padding:.5rem 0}.nav-section-title{padding:.75rem 1rem;font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:.95rem;text-align:left;margin:0 .5rem;border-radius:8px}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--primary);color:#fff}.nav-icon{font-size:1.25rem;min-width:24px}.sidebar-footer{padding:1rem;border-top:1px solid var(--border)}.system-status{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-tertiary);border-radius:8px}.status-indicator{width:8px;height:8px;border-radius:50%;background:#ef4444}.status-indicator.online{background:#10b981;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{flex:1}.status-label{font-size:.75rem;color:var(--text-muted);font-weight:600}.status-value{font-size:.9rem;color:var(--text-primary);font-weight:600}@media(max-width:768px){.sidebar{width:70px}.logo-text,.logo-subtitle,.nav-label,.nav-section-title,.status-text{display:none}.sidebar-header{padding:1rem}.nav-item{justify-content:center;padding:.75rem;margin:.25rem}}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100vw;background:radial-gradient(circle at top left,#1e293b,#0f172a);position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;top:-20%;left:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(76,175,80,.15) 0%,transparent 70%);border-radius:50%;z-index:0}.auth-card{background:#1e293bb3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:0 25px 50px -12px #00000080;position:relative;z-index:1}.auth-header{text-align:center;margin-bottom:30px}.auth-header h2{font-size:28px;font-weight:700;color:#f8fafc;margin-bottom:8px}.auth-header p{color:#94a3b8;font-size:14px}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:12px;border-radius:8px;font-size:14px;margin-bottom:20px;text-align:center}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px;text-align:left}.form-group label{font-size:13px;font-weight:500;color:#cbd5e1}.form-group input{background:#0f172a99;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px 16px;color:#f1f5f9;font-size:15px;transition:all .2s ease;outline:none}.form-group input:focus{border-color:#4caf50;box-shadow:0 0 0 2px #4caf5033}.form-group input::placeholder{color:#64748b}.help-text{font-size:12px;color:#64748b;margin-top:4px}.auth-submit-btn{background:linear-gradient(135deg,#4caf50,#43a047);color:#fff;border:none;border-radius:8px;padding:14px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .1s ease,box-shadow .2s ease;margin-top:10px}.auth-submit-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4caf504d}.auth-submit-btn:active{transform:translateY(0)}.auth-toggle{margin-top:24px;text-align:center;font-size:14px;color:#94a3b8}.auth-toggle button{background:none;border:none;color:#4caf50;font-weight:600;margin-left:6px;cursor:pointer;padding:0;font-family:inherit;font-size:inherit}.auth-toggle button:hover{text-decoration:underline}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #6366f1;--primary-dark: #4f46e5;--secondary: #8b5cf6;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border: #334155}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6}.app-container{display:flex;min-height:100vh}.main-content{flex:1;margin-left:220px;padding:1.5rem;background:var(--bg-primary)}@media(max-width:768px){.main-content{margin-left:0;padding:1rem}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border)}
