*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f8fafc;color:#1e293b}.app{max-width:1400px;margin:0 auto;padding:24px}.header{margin-bottom:24px}.header-content{display:flex;justify-content:space-between;align-items:center;gap:24px}.header h1{margin:0 0 8px;font-size:28px;font-weight:700;color:#0f172a}.subtitle{margin:0;color:#64748b;font-size:14px}.header-logo{height:40px;width:auto}.header-right{display:flex;align-items:flex-start;gap:20px}.refresh-container{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.refresh-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#2563eb;border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.refresh-btn:hover:not(:disabled){background:#1d4ed8}.refresh-btn:disabled{background:#94a3b8;cursor:not-allowed}.refresh-btn.refreshing{background:#64748b}.last-refreshed{font-size:11px;color:#94a3b8}.refresh-error{font-size:11px;color:#dc2626;cursor:help}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;color:#64748b}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0}.stat-value{font-size:24px;font-weight:700;color:#0f172a;margin-bottom:4px}.stat-label{font-size:13px;color:#64748b}.filters{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:6px;flex:1;min-width:180px}.filter-group label{font-size:13px;font-weight:500;color:#475569;display:flex;align-items:center;gap:6px}.filter-group select,.filter-group input{padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff;color:#1e293b}.filter-group select:focus,.filter-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.clear-btn{padding:10px 20px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;cursor:pointer;color:#475569;transition:all .2s}.clear-btn:hover{background:#e2e8f0}.tabs{display:flex;gap:8px;margin-bottom:24px}.tab{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;background:#fff;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;color:#64748b;transition:all .2s;border:1px solid #e2e8f0}.tab:hover{background:#f8fafc}.tab.active{background:#2563eb;color:#fff;border-color:#2563eb}.content{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0}.chart-container h2{margin:0 0 8px;font-size:18px;font-weight:600}.chart-subtitle{margin:0 0 12px;color:#64748b;font-size:14px}.trends-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.trends-header h2{margin:0 0 8px;font-size:18px;font-weight:600}.time-range-selector{display:flex;align-items:center;gap:4px;padding:4px;background:#f1f5f9;border-radius:8px;border:1px solid #e2e8f0}.time-range-selector svg{margin:0 8px 0 4px;color:#64748b}.time-range-btn{padding:8px 12px;background:transparent;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;color:#64748b;transition:all .2s}.time-range-btn:hover{background:#e2e8f0;color:#1e293b}.time-range-btn.active{background:#fff;color:#2563eb;box-shadow:0 1px 3px #0000001a}.date-range-info{margin:0 0 16px;font-size:12px;color:#94a3b8}.date-range-info .active-range{color:#2563eb;font-weight:500}.no-data-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background:#f8fafc;border-radius:8px;border:1px dashed #e2e8f0;color:#64748b;text-align:center}.no-data-message p{margin:4px 0}.no-data-message p:first-child{font-size:16px;font-weight:500;color:#475569}.unit-info{margin-bottom:20px;padding:12px 16px;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;font-size:13px;color:#92400e}.unit-info strong{color:#78350f}.unit-badge{display:inline-block;margin-left:8px;padding:4px 10px;background:#fff;border:1px solid #fcd34d;border-radius:4px;font-size:12px}.unit-badge small{color:#a3a3a3;margin-left:4px}.table-container h2{margin:0 0 4px;font-size:18px;font-weight:600}.table-subtitle{margin:0 0 16px;font-size:13px;color:#64748b}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}th,td{padding:12px 16px;text-align:left;border-bottom:1px solid #e2e8f0}th{background:#f8fafc;font-weight:600;color:#475569;position:sticky;top:0}tr:hover{background:#f8fafc}.price-avg{font-weight:600;color:#16a34a}.unit-col{background:#fef3c7!important}.unit-cell{background:#fffbeb;font-size:12px;color:#92400e;font-weight:500}.table-note{margin-top:16px;font-size:13px;color:#64748b;text-align:center}.perplant-container h2{margin:0 0 8px;font-size:18px;font-weight:600}.perplant-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.settings-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;font-size:13px;cursor:pointer;color:#475569;transition:all .2s}.settings-btn:hover{background:#e2e8f0}.settings-btn.active{background:#dbeafe;border-color:#2563eb;color:#1d4ed8}.conversion-editor{margin-bottom:24px;padding:20px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px}.conversion-editor h3{margin:0 0 8px;font-size:16px;font-weight:600}.editor-note{margin:0 0 16px;font-size:13px;color:#64748b}.conversion-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.conversion-item{padding:12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px}.conversion-item.custom{background:#fffbeb;border-color:#fcd34d}.conversion-commodity{font-size:13px;font-weight:600;color:#0f172a;margin-bottom:8px}.conversion-input-group{display:flex;align-items:center;gap:8px;margin-bottom:6px}.conversion-input-group label{font-size:12px;color:#64748b}.conversion-input-group input{width:70px;padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px}.conversion-input-group input:focus{outline:none;border-color:#2563eb}.reset-btn{padding:4px 8px;background:#fee2e2;border:1px solid #fecaca;border-radius:4px;font-size:11px;color:#dc2626;cursor:pointer}.reset-btn:hover{background:#fecaca}.conversion-note{font-size:11px;color:#64748b}.perplant-chart{margin-bottom:32px}.chart-click-hint{font-size:12px;color:#64748b;margin-bottom:12px;font-style:italic}.tooltip-click{margin-top:8px!important;color:#2563eb;font-weight:500}.perplant-table{margin-top:24px}.perplant-table h3{margin:0 0 16px;font-size:16px;font-weight:600}.highlight-col{background:#dcfce7!important}.price-perplant{font-weight:700;color:#16a34a;font-size:14px}.notes-cell{font-size:11px;color:#64748b}.custom-row{background:#fffbeb!important}.custom-tooltip{background:#fff;padding:12px 16px;border-radius:8px;box-shadow:0 4px 12px #00000026;border:1px solid #e2e8f0;font-size:13px}.tooltip-title{font-weight:600;margin:0 0 8px;color:#0f172a}.custom-tooltip p{margin:4px 0}.tooltip-note{font-size:11px;color:#64748b;font-style:italic;margin-top:8px!important}.stat-card.highlight-card{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-color:#22c55e}.stat-card.highlight-card .stat-value{color:#15803d}.crop-link{display:flex;align-items:center;gap:4px;background:none;border:none;color:#2563eb;font-size:13px;font-weight:500;cursor:pointer;padding:0;text-align:left}.crop-link:hover{color:#1d4ed8;text-decoration:underline}.detail-btn{padding:4px 10px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;font-size:11px;color:#475569;cursor:pointer}.detail-btn:hover{background:#e2e8f0}.back-btn{display:flex;align-items:center;gap:6px;background:none;border:none;color:#2563eb;font-size:14px;cursor:pointer;padding:0;margin-bottom:8px}.back-btn:hover{color:#1d4ed8;text-decoration:underline}.detail-stats{margin-bottom:16px}.conversion-info-box{padding:12px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;font-size:13px;color:#475569;margin-bottom:24px}.edit-conversion-inline{margin-left:16px;padding:4px 10px;background:#dbeafe;border:1px solid #2563eb;border-radius:4px;font-size:12px;color:#1d4ed8;cursor:pointer}.edit-conversion-inline:hover{background:#bfdbfe}.detail-section{margin-bottom:24px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:24px;margin-bottom:24px}.organic-comparison{display:flex;gap:16px;margin-top:16px}.organic-card{flex:1;padding:20px;border-radius:12px;text-align:center}.organic-card.organic{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border:1px solid #22c55e}.organic-card.conventional{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border:1px solid #cbd5e1}.organic-label{font-size:12px;font-weight:600;text-transform:uppercase;color:#475569;margin-bottom:8px}.organic-price{font-size:28px;font-weight:700;color:#0f172a}.organic-count{font-size:12px;color:#64748b;margin-top:4px}.organic-premium{text-align:center;margin-top:16px;font-size:14px;color:#16a34a;font-weight:500}.package-badges{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}.package-badge{display:flex;flex-direction:column;padding:12px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;min-width:150px}.package-name{font-size:12px;color:#475569;margin-bottom:4px}.package-price{font-size:18px;font-weight:600;color:#0f172a}.package-count{font-size:11px;color:#94a3b8}.distributor-container{display:flex;flex-direction:column;gap:24px}.distributor-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.distributor-header h2{margin:0 0 8px;font-size:18px;font-weight:600}.add-quote-btn{display:flex;align-items:center;gap:6px;padding:10px 20px;background:#16a34a;border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.add-quote-btn:hover{background:#15803d}.distributor-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.distributor-sources{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.source-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.source-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#fff;border-bottom:1px solid #e2e8f0}.source-header h3{display:flex;align-items:center;gap:8px;margin:0;font-size:15px;font-weight:600}.source-count{font-size:12px;color:#64748b;background:#f1f5f9;padding:4px 10px;border-radius:12px}.source-badge{font-size:11px;font-weight:600;padding:4px 10px;border-radius:12px;text-transform:uppercase}.source-badge.free{background:#dcfce7;color:#15803d}.source-badge.premium{background:#dbeafe;color:#1d4ed8}.source-body{padding:16px}.source-description{margin:0 0 12px;font-size:13px;color:#64748b}.empty-state{text-align:center;padding:24px 16px;color:#64748b}.empty-state p{margin:0 0 12px}.add-first-btn{display:inline-flex;align-items:center;gap:4px;padding:8px 16px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;color:#475569;cursor:pointer}.add-first-btn:hover{background:#f8fafc;border-color:#cbd5e1}.quotes-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.quote-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:13px}.quote-main{display:flex;align-items:center;gap:10px}.distributor-badge{padding:3px 8px;border-radius:4px;color:#fff;font-size:10px;font-weight:600;text-transform:uppercase}.distributor-badge-small{padding:2px 6px;border-radius:4px;color:#fff;font-size:10px;font-weight:600}.quote-product{font-weight:500;color:#0f172a}.quote-details{display:flex;align-items:center;gap:12px}.quote-price{font-weight:600;color:#16a34a}.quote-date{font-size:12px;color:#94a3b8}.delete-quote-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:none;border:none;color:#94a3b8;cursor:pointer;border-radius:4px}.delete-quote-btn:hover{background:#fee2e2;color:#dc2626}.api-search{display:flex;gap:8px;margin-bottom:12px}.api-search input{flex:1;padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px}.api-search input:focus{outline:none;border-color:#2563eb}.search-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer}.search-btn:hover{background:#1d4ed8}.search-btn:disabled{background:#94a3b8;cursor:not-allowed}.api-results{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.api-result-item{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:12px}.result-info{display:flex;flex-direction:column;gap:2px}.result-name{font-weight:500;color:#0f172a}.result-price{color:#16a34a;font-weight:600}.import-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#f0fdf4;border:1px solid #22c55e;border-radius:4px;font-size:11px;color:#15803d;cursor:pointer}.import-btn:hover{background:#dcfce7}.api-error{margin:8px 0;padding:10px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;font-size:12px;color:#dc2626}.configure-api-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;color:#475569;cursor:pointer}.configure-api-btn:hover{background:#f8fafc}.api-config{margin-top:12px;display:flex;flex-direction:column;gap:8px}.api-config input{padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px}.api-docs-link{font-size:12px;color:#2563eb}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e2e8f0}.modal-header h3{display:flex;align-items:center;gap:8px;margin:0;font-size:16px;font-weight:600}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;color:#64748b;cursor:pointer;border-radius:6px}.modal-close:hover{background:#f1f5f9;color:#0f172a}.modal-body{padding:20px;display:flex;flex-direction:column;gap:16px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid #e2e8f0}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:500;color:#475569}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.cancel-btn{padding:10px 20px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#475569;cursor:pointer}.cancel-btn:hover{background:#e2e8f0}.save-btn{padding:10px 20px;background:#2563eb;border:none;border-radius:8px;font-size:14px;font-weight:500;color:#fff;cursor:pointer}.save-btn:hover{background:#1d4ed8}.distributor-comparison{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px}.distributor-comparison h3{margin:0 0 20px;font-size:16px;font-weight:600}.quotes-table-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px}.quotes-table-section h3{margin:0 0 16px;font-size:16px;font-weight:600}.delete-btn-small{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:1px solid #e2e8f0;border-radius:4px;color:#94a3b8;cursor:pointer}.delete-btn-small:hover{background:#fee2e2;border-color:#fecaca;color:#dc2626}.insights-container{display:flex;flex-direction:column;gap:24px}.insights-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.insights-header h2{margin:0 0 8px;font-size:18px;font-weight:600}.insights-updated{color:#16a34a;font-weight:500}.refresh-insights-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#8b5cf6;border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.refresh-insights-btn:hover:not(:disabled){background:#7c3aed}.refresh-insights-btn:disabled{background:#94a3b8;cursor:not-allowed}.insight-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:6px;background:#dc2626;border-radius:9px;font-size:11px;font-weight:600;color:#fff}.tab.active .insight-badge{background:#fff;color:#dc2626}.no-insights{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#64748b}.no-insights svg{margin-bottom:16px;opacity:.5}.no-insights h3{margin:0 0 8px;font-size:18px;color:#475569}.no-insights p{margin:0}.insights-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.insight-stat{display:flex;align-items:center;gap:12px;padding:16px;background:#fff;border:1px solid #e2e8f0;border-radius:12px}.insight-stat-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px}.insight-stat-info{flex:1}.insight-stat-value{font-size:24px;font-weight:700;color:#0f172a}.insight-stat-label{font-size:12px;color:#64748b}.insights-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.insights-section h3{display:flex;align-items:center;gap:8px;margin:0 0 16px;font-size:16px;font-weight:600;color:#0f172a}.critical-section{border-color:#fecaca;background:#fef2f2}.critical-section h3{color:#dc2626}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.insight-card{display:flex;flex-direction:column;gap:12px;padding:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;transition:all .2s}.insight-card:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000d}.insight-card.severity-high{background:#fff;border-color:#fecaca;border-left:4px solid #dc2626}.insight-card.severity-medium{background:#fff;border-left:4px solid #f59e0b}.insight-card.severity-info{background:#fff;border-left:4px solid #8b5cf6}.insight-card-wide{grid-column:span 2}.insight-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.insight-content{flex:1}.insight-content h4{margin:0 0 6px;font-size:14px;font-weight:600;color:#0f172a}.insight-content p{margin:0;font-size:13px;color:#64748b;line-height:1.5}.insight-change{display:inline-block;margin-top:8px;padding:4px 10px;border-radius:12px;font-size:13px;font-weight:600}.insight-change.up{background:#fee2e2;color:#dc2626}.insight-change.down{background:#dcfce7;color:#16a34a}.insight-savings{margin-top:8px;font-size:13px;color:#16a34a}.insight-savings strong{font-size:16px}.insight-mini-chart{margin-top:12px;padding:8px;background:#fff;border-radius:6px}.insight-action{align-self:flex-start;padding:6px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;font-weight:500;color:#2563eb;cursor:pointer;transition:all .2s}.insight-action:hover{background:#eff6ff;border-color:#2563eb}.section-description{margin:-8px 0 16px;font-size:13px;color:#64748b}.top-earners-table{display:flex;flex-direction:column;gap:0;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.earners-header{display:grid;grid-template-columns:60px 1fr 100px 140px 80px;gap:12px;padding:12px 16px;background:#f8fafc;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.earners-row{display:grid;grid-template-columns:60px 1fr 100px 140px 80px;gap:12px;padding:14px 16px;background:#fff;border-top:1px solid #f1f5f9;align-items:center;transition:background .15s}.earners-row:hover{background:#f8fafc}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:32px;height:24px;border-radius:4px;font-size:12px;font-weight:600}.rank-badge.rank-1{background:#fef3c7;color:#b45309}.rank-badge.rank-2{background:#f1f5f9;color:#475569}.rank-badge.rank-3{background:#fed7aa;color:#c2410c}.rank-badge.rank-4,.rank-badge.rank-5,.rank-badge.rank-6,.rank-badge.rank-7,.rank-badge.rank-8,.rank-badge.rank-9,.rank-badge.rank-10{background:#f1f5f9;color:#64748b}.earners-crop{font-size:14px;font-weight:500;color:#0f172a}.earners-price{font-size:14px;color:#16a34a}.earners-range{font-size:13px;color:#64748b}.insight-action-btn{padding:6px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;font-weight:500;color:#2563eb;cursor:pointer;transition:all .2s}.insight-action-btn:hover{background:#eff6ff;border-color:#2563eb}.price-movement{margin-top:4px;font-size:12px;color:#94a3b8}.insight-card.severity-low{background:#fff;border-left:4px solid #16a34a}.demand-card{padding:20px}.demand-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.demand-crop{font-size:15px;font-weight:600;color:#0f172a}.demand-price{font-size:14px;font-weight:600;color:#16a34a}.demand-indicator{margin-bottom:12px}.demand-bar{display:flex;height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden;margin-bottom:8px}.demand-fill{height:100%}.demand-fill.very-light{background:#f97316}.demand-fill.light{background:#fbbf24}.demand-labels{display:flex;gap:16px;font-size:11px}.demand-label{display:flex;align-items:center;gap:4px;color:#64748b}.demand-label .dot{width:8px;height:8px;border-radius:50%}.demand-label .dot.very-light{background:#f97316}.demand-label .dot.light{background:#fbbf24}.demand-note{margin:0;font-size:12px;color:#64748b;font-style:italic}.favorites-section{background:linear-gradient(135deg,#fef3c7,#fef9c3);border:1px solid #fcd34d}.favorites-section h3{color:#92400e}.favorite-selector{margin-bottom:16px}.favorite-selector select{width:100%;max-width:300px;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff;cursor:pointer}.favorite-selector select:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.favorite-card{position:relative;background:#fff!important;border:2px solid #fcd34d!important}.favorite-remove{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.favorite-remove:hover{background:#fef3c7}.favorite-toggle{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;opacity:.5}.favorite-toggle:hover{opacity:1;background:#fef3c7}.favorite-toggle.active{opacity:1}.no-favorites-message{padding:20px;text-align:center;color:#92400e;background:#ffffff80;border-radius:8px}.no-favorites-message p{margin:0;font-size:14px}.best-markets-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.market-premium-card{padding:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;transition:all .2s}.market-premium-card:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000d}.market-premium-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.mpc-crop{font-size:14px;font-weight:600;color:#0f172a}.mpc-premium{padding:4px 10px;background:#dcfce7;border-radius:12px;font-size:12px;font-weight:600;color:#16a34a}.market-comparison{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:8px;margin-bottom:12px}.market-best,.market-worst{flex:1;text-align:center}.market-label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;margin-bottom:4px}.market-name{display:block;font-size:13px;font-weight:500;color:#0f172a;margin-bottom:2px}.market-best .market-price{font-size:16px;font-weight:700;color:#16a34a}.market-worst .market-price{font-size:14px;color:#64748b}.market-arrow{color:#cbd5e1;font-size:18px}.other-markets{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:12px}.other-markets-label{font-size:11px;color:#94a3b8}.other-market-badge{padding:3px 8px;background:#fff;border:1px solid #e2e8f0;border-radius:4px;font-size:11px;color:#64748b}.activity-list{display:flex;flex-direction:column;gap:0;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.activity-item{display:grid;grid-template-columns:50px 1fr 180px 80px 70px;gap:12px;padding:12px 16px;background:#fff;border-top:1px solid #f1f5f9;align-items:center}.activity-item:first-child{border-top:none}.activity-item:hover{background:#f8fafc}.activity-rank{font-size:13px;font-weight:600;color:#64748b}.activity-crop{font-size:14px;font-weight:500;color:#0f172a}.activity-stats{display:flex;gap:16px}.activity-reports,.activity-markets{font-size:12px;color:#64748b}.activity-price{font-size:14px;font-weight:600;color:#16a34a}.insight-action-sm{padding:4px 10px;background:#fff;border:1px solid #e2e8f0;border-radius:4px;font-size:11px;font-weight:500;color:#2563eb;cursor:pointer;transition:all .2s}.insight-action-sm:hover{background:#eff6ff;border-color:#2563eb}.watchlist-section{background:#fef2f2;border-color:#fecaca}.watchlist-section h3{color:#dc2626}.insight-change.up{background:#dcfce7;color:#16a34a}.insight-change.down{background:#fee2e2;color:#dc2626}.best-value-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}.best-value-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s;text-align:left}.best-value-item:hover{border-color:#8b5cf6;background:#faf5ff}.bv-rank{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#f1f5f9;border-radius:6px;font-size:11px;font-weight:700;color:#64748b}.bv-name{flex:1;font-size:13px;font-weight:500;color:#0f172a}.bv-price{font-size:14px;font-weight:600;color:#16a34a}.regional-focus-bar{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:20px;flex-wrap:wrap}.regional-toggle{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s}.regional-toggle:hover{border-color:#cbd5e1}.regional-toggle.active{background:#2563eb;border-color:#2563eb;color:#fff}.region-selector{display:flex;gap:8px;flex-wrap:wrap}.region-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;color:#475569;cursor:pointer;transition:all .2s}.region-btn:hover{border-color:#2563eb;background:#eff6ff}.region-btn.active{background:#dbeafe;border-color:#2563eb;color:#1d4ed8}.region-markets{font-size:11px;color:#94a3b8}.region-btn.active .region-markets{color:#60a5fa}.export-buttons{display:flex;gap:8px;margin-left:auto}.export-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;font-weight:500;color:#475569;cursor:pointer;transition:all .2s}.export-btn:hover{background:#f8fafc;border-color:#cbd5e1}.compare-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:6px;background:#2563eb;border-radius:9px;font-size:11px;font-weight:600;color:#fff}.tab.active .compare-badge{background:#fff;color:#2563eb}.seasonality-container{display:flex;flex-direction:column;gap:24px}.seasonality-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.seasonality-header h2{margin:0 0 8px;font-size:18px;font-weight:600}.fetch-historical-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#8b5cf6;border:none;border-radius:8px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.fetch-historical-btn:hover:not(:disabled){background:#7c3aed}.fetch-historical-btn:disabled{background:#a78bfa;cursor:not-allowed}.fetch-historical-btn.large{padding:14px 24px;font-size:14px;margin-top:16px}.fetch-historical-btn.loading svg{animation:spin 1s linear infinite}.data-coverage-banner{padding:16px 20px;border-radius:10px;border:1px solid}.data-coverage-banner.complete{background:#f0fdf4;border-color:#86efac}.data-coverage-banner.partial{background:#fefce8;border-color:#fde047}.data-coverage-banner.insufficient{background:#fef2f2;border-color:#fecaca}.coverage-info{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}.coverage-label{font-size:13px;font-weight:600;color:#475569}.coverage-value{font-size:14px;font-weight:700;color:#0f172a}.coverage-range{font-size:12px;color:#64748b}.coverage-bar{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.coverage-fill{height:100%;border-radius:4px;transition:width .5s ease}.data-coverage-banner.complete .coverage-fill{background:#16a34a}.data-coverage-banner.partial .coverage-fill{background:#eab308}.data-coverage-banner.insufficient .coverage-fill{background:#dc2626}.coverage-note{margin:10px 0 0;font-size:12px;color:#64748b}.seasonality-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.seasonality-section h3{display:flex;align-items:center;gap:8px;margin:0 0 8px;font-size:16px;font-weight:600}.seasonal-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:16px}.seasonal-card{display:flex;flex-direction:column;gap:12px;padding:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px}.seasonal-card-header{display:flex;justify-content:space-between;align-items:center}.seasonal-crop{font-size:14px;font-weight:600;color:#0f172a}.seasonal-variation{padding:4px 10px;background:#dbeafe;border-radius:12px;font-size:12px;font-weight:600;color:#2563eb}.seasonal-chart{background:#fff;border-radius:8px;padding:8px}.seasonal-insights{display:flex;gap:16px;font-size:12px}.seasonal-best{color:#16a34a}.seasonal-worst{color:#dc2626}.seasonal-insights .label{font-weight:600}.monthly-table{overflow-x:auto;margin-top:16px}.monthly-header,.monthly-row{display:grid;grid-template-columns:140px repeat(12,1fr);gap:4px;min-width:800px}.monthly-header{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.monthly-row{padding:10px 0;border-bottom:1px solid #f1f5f9;font-size:12px}.monthly-crop{font-weight:500;color:#0f172a}.monthly-cell{text-align:center;padding:4px;border-radius:4px}.monthly-cell.no-data{color:#cbd5e1}.monthly-cell.best{background:#dcfce7;color:#16a34a;font-weight:600}.monthly-cell.worst{background:#fee2e2;color:#dc2626}.organic-container{display:flex;flex-direction:column;gap:24px}.organic-header h2{margin:0 0 8px;font-size:18px;font-weight:600}.organic-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.organic-stat{display:flex;flex-direction:column;align-items:center;padding:20px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;text-align:center}.organic-stat.highlight{background:#f0fdf4;border-color:#86efac}.organic-stat-value{font-size:28px;font-weight:700;color:#16a34a}.organic-stat-label{font-size:12px;color:#64748b;margin-top:4px}.organic-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.organic-section h3{display:flex;align-items:center;gap:8px;margin:0 0 16px;font-size:16px;font-weight:600}.organic-chart,.organic-table{margin-top:16px}.organic-table-header,.organic-table-row{display:grid;grid-template-columns:1fr 100px 100px 100px 100px;gap:12px;padding:12px 16px}.organic-table-header{background:#f8fafc;border-radius:8px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase}.organic-table-row{border-bottom:1px solid #f1f5f9;font-size:14px}.ot-crop{font-weight:500;color:#0f172a}.ot-conv,.ot-org{text-align:right}.ot-premium{text-align:right;font-weight:600}.ot-premium.high{color:#16a34a}.ot-premium.medium{color:#22c55e}.ot-premium.low{color:#86efac}.ot-data{text-align:right;color:#64748b;font-size:12px}.compare-container{display:flex;flex-direction:column;gap:24px}.compare-header h2{margin:0 0 8px;font-size:18px;font-weight:600}.compare-selector{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.compare-selector h3{margin:0 0 16px;font-size:14px;font-weight:600;color:#475569}.compare-crop-grid{display:flex;flex-wrap:wrap;gap:8px}.compare-crop-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;color:#475569;cursor:pointer;transition:all .2s}.compare-crop-btn:hover:not(:disabled){border-color:#2563eb;background:#eff6ff}.compare-crop-btn.selected{background:#2563eb;border-color:#2563eb;color:#fff}.compare-crop-btn:disabled{opacity:.5;cursor:not-allowed}.compare-crop-btn .check{font-weight:700}.clear-comparison{margin-top:12px;padding:8px 16px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;color:#dc2626;cursor:pointer}.clear-comparison:hover{background:#fef2f2;border-color:#fecaca}.comparison-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.comparison-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;border-top:4px solid;overflow:hidden}.comparison-card-header{padding:14px 16px;color:#fff}.comparison-card-header h4{margin:0;font-size:14px;font-weight:600}.comparison-card-body{padding:16px;display:flex;flex-direction:column;gap:10px}.comparison-metric{display:flex;justify-content:space-between;align-items:center}.metric-label{font-size:12px;color:#64748b}.metric-value{font-size:14px;font-weight:600;color:#0f172a}.metric-value.highlight{color:#16a34a}.metric-value.warning{color:#f59e0b}.metric-value.organic{color:#16a34a}.metric-value.small{font-size:12px}.comparison-detail-btn{width:100%;padding:12px;background:#f8fafc;border:none;border-top:1px solid #e2e8f0;font-size:13px;font-weight:500;color:#2563eb;cursor:pointer;transition:background .2s}.comparison-detail-btn:hover{background:#eff6ff}.comparison-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.comparison-section h3{margin:0 0 16px;font-size:16px;font-weight:600}.radar-chart-container{margin-top:16px}.no-comparison{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:12px}.no-comparison svg{margin-bottom:16px;opacity:.5}.no-comparison h3{margin:0 0 8px;font-size:18px;color:#475569}.no-comparison p{margin:0}.footer{display:flex;flex-direction:column;margin-top:32px;padding:16px 20px;color:#64748b;font-size:13px;border-top:1px solid #e2e8f0;gap:12px}.footer-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.footer-left{flex-shrink:0}.footer strong{color:#e91e8c}.footer-disclaimer{font-size:10px;color:#94a3b8;line-height:1.4;padding-top:8px;border-top:1px solid #f1f5f9}.footer-disclaimer strong{color:#64748b}.footer-status{display:flex;align-items:center;gap:16px}.status-item{display:flex;align-items:center;gap:6px}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.online{background:#16a34a;box-shadow:0 0 6px #16a34a80}.status-dot.offline{background:#dc2626;box-shadow:0 0 6px #dc262680}.status-dot.warning{background:#f59e0b;box-shadow:0 0 6px #f59e0b80}.status-dot.checking{background:#94a3b8;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.status-label{color:#94a3b8;font-size:12px}.status-value{font-weight:500;font-size:12px}.status-value.online{color:#16a34a}.status-value.offline{color:#dc2626}.status-value.warning{color:#f59e0b}.status-help{display:flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:50%;font-size:10px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.status-help:hover{background:#e2e8f0;color:#475569}.status-refresh{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:1px solid #e2e8f0;border-radius:4px;color:#94a3b8;cursor:pointer;transition:all .2s}.status-refresh:hover{background:#f8fafc;color:#64748b;border-color:#cbd5e1}@media(max-width:768px){.app{padding:16px}.header-content{flex-direction:column;align-items:flex-start}.header-right{width:100%;flex-direction:row-reverse;justify-content:space-between}.refresh-container{align-items:flex-start}.refresh-btn{padding:8px 12px;font-size:13px}.header-logo{height:32px}.stats-grid{grid-template-columns:repeat(2,1fr)}.filters{flex-direction:column}.filter-group{width:100%}.tabs{flex-wrap:wrap}.tab{flex:1;justify-content:center}.trends-header{flex-direction:column}.time-range-selector{width:100%;justify-content:space-between}.time-range-btn{flex:1;padding:8px 6px;font-size:12px}.distributor-header{flex-direction:column}.distributor-sources,.form-row{grid-template-columns:1fr}.insights-header{flex-direction:column}.insights-grid{grid-template-columns:1fr}.insight-card-wide{grid-column:span 1}.insights-summary{grid-template-columns:repeat(2,1fr)}}
