:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{margin:0;padding:0;box-sizing:border-box}.app{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#0f172a,#1e293b);color:#e2e8f0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app-header{background:linear-gradient(135deg,#1e293b,#334155);border-bottom:1px solid #475569;color:#f8fafc;padding:1.5rem 2rem;box-shadow:0 4px 20px #0000004d}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.logo-section{display:flex;align-items:center;gap:1rem}.logo-section h1{font-size:1.8rem;font-weight:700;margin:0;background:linear-gradient(45deg,#60a5fa,#34d399);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.logo-section p{font-size:.9rem;opacity:.8;margin:.25rem 0 0;color:#94a3b8}.header-controls{display:flex;gap:2rem;align-items:center}.business-type-selector{display:flex;flex-direction:column;gap:.5rem}.business-type-selector label{font-size:.8rem;font-weight:500;color:#cbd5e1}.business-type-selector select{padding:.75rem 1rem;border:1px solid #475569;border-radius:.75rem;background:#334155;color:#f8fafc;font-weight:500;min-width:200px;transition:all .3s ease}.business-type-selector select:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}.business-type-selector select:hover{border-color:#64748b}.boycott-toggle{display:flex;align-items:center;gap:.75rem}.boycott-text{font-size:.9rem;font-weight:500;color:#f8fafc}.switch{position:relative;display:inline-block;width:60px;height:30px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background:#475569;transition:.3s;border-radius:30px;border:1px solid #64748b}.slider:before{position:absolute;content:"";height:22px;width:22px;left:4px;bottom:3px;background:#f8fafc;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}input:checked+.slider{background:linear-gradient(45deg,#ef4444,#dc2626)}input:checked+.slider:before{transform:translate(28px)}.main-content{flex:1;max-width:1400px;margin:0 auto;width:100%;padding:1.5rem}.dashboard{display:grid;grid-template-columns:320px 1fr;grid-template-rows:1fr auto;gap:1.5rem;min-height:calc(100vh - 140px);height:auto}.sidebar{background:linear-gradient(135deg,#1e293b,#334155);border:1px solid #475569;border-radius:1rem;padding:1.5rem;box-shadow:0 4px 20px #0003;overflow-y:auto;max-height:calc(100vh - 180px)}.filter-section h3,.stats-section h3,.insights-section h3{margin:0 0 1rem;color:#60a5fa;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.filter-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#cbd5e1;font-size:.9rem}.filter-group select{width:100%;padding:.75rem;border:1px solid #475569;border-radius:.5rem;background:#334155;color:#f8fafc;font-size:.9rem;transition:all .3s ease}.filter-group select:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}.filter-group select:hover{border-color:#64748b}.boycott-alert-section{background:linear-gradient(135deg,#7f1d1d,#991b1b);border:1px solid #dc2626;border-radius:.75rem;padding:1rem;margin:1rem 0}.boycott-alert-section h4{margin:0 0 .75rem;color:#fecaca;font-size:.9rem;font-weight:600}.boycott-legend{display:flex;flex-direction:column;gap:.5rem}.legend-item{display:flex;align-items:center;gap:.75rem;font-size:.8rem;color:#f1f5f9}.color-box{width:14px;height:14px;border-radius:3px;box-shadow:0 1px 3px #0003}.color-box.red{background:linear-gradient(45deg,#ef4444,#dc2626)}.color-box.yellow{background:linear-gradient(45deg,#f59e0b,#d97706)}.color-box.green{background:linear-gradient(45deg,#10b981,#059669)}.stats-section{border-top:1px solid #475569;padding-top:1rem;margin-top:1rem}.stat-card{background:linear-gradient(135deg,#334155,#475569);border:1px solid #64748b;border-radius:.75rem;padding:1rem;margin-bottom:.75rem;text-align:center;transition:transform .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.stat-number{font-size:2.2rem;font-weight:700;background:linear-gradient(45deg,#60a5fa,#34d399);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stat-label{font-size:.8rem;color:#94a3b8;margin-top:.25rem;font-weight:500}.stat-change{font-size:.75rem;color:#94a3b8;margin-top:.25rem;font-weight:500}.insights-section{border-top:1px solid #475569;padding-top:1rem;margin-top:1rem}.insight-item{background:linear-gradient(135deg,#1e3a8a,#1e40af);border-left:4px solid #60a5fa;padding:.75rem;margin-bottom:.75rem;border-radius:0 .5rem .5rem 0;font-size:.8rem;line-height:1.4;color:#dbeafe;transition:all .2s ease}.insight-item:hover{transform:translate(4px);background:linear-gradient(135deg,#1e40af,#2563eb)}.map-container{background:linear-gradient(135deg,#1e293b,#334155);border:1px solid #475569;border-radius:1rem;overflow:hidden;box-shadow:0 4px 20px #0003;display:flex;flex-direction:column;min-height:500px}.map-placeholder{height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#374151,#4b5563)}.map-content{text-align:center;color:#9ca3af;padding:2rem}.map-content h2{font-size:2rem;margin-bottom:1rem;color:#d1d5db;background:linear-gradient(45deg,#60a5fa,#34d399);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.map-info{background:#1e293bcc;border:1px solid #475569;border-radius:.75rem;padding:1rem;margin-top:1rem;box-shadow:0 2px 8px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.map-info p{margin:.25rem 0;font-size:.9rem;color:#cbd5e1}.analytics-panel{grid-column:1 / -1;background:linear-gradient(135deg,#1e293b,#334155);border:1px solid #475569;border-radius:1rem;padding:1.5rem;box-shadow:0 4px 20px #0003}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.analytics-card{background:linear-gradient(135deg,#334155,#475569);border:1px solid #64748b;border-radius:.75rem;padding:1.5rem;transition:transform .2s ease}.analytics-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.analytics-card h4{margin:0 0 1rem;color:#60a5fa;font-size:1.1rem;font-weight:600}.chart-placeholder{height:150px;background:linear-gradient(135deg,#4b5563,#6b7280);border:1px solid #6b7280;border-radius:.5rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease;padding:1rem}.chart-placeholder:hover{background:linear-gradient(135deg,#6b7280,#9ca3af);transform:translateY(-2px);box-shadow:0 8px 25px #0003}.chart-content{text-align:center;color:#f3f4f6}.chart-value{font-size:2.5rem;font-weight:700;background:linear-gradient(45deg,#60a5fa,#34d399);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1;margin-bottom:.5rem}.chart-label{font-size:.9rem;color:#d1d5db;margin-bottom:.75rem;font-weight:500}.chart-trend{font-size:.8rem;font-weight:600;padding:.25rem .75rem;border-radius:1rem;display:inline-block}.chart-trend.positive{background:#22c55e33;color:#86efac;border:1px solid rgba(34,197,94,.3)}.chart-trend.negative{background:#ef444433;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.chart-trend.neutral{background:#9ca3af33;color:#d1d5db;border:1px solid rgba(156,163,175,.3)}.analysis-summary{background:linear-gradient(135deg,#1e293b,#334155);border:1px solid #475569;border-radius:1rem;padding:1.5rem;margin-top:1.5rem;box-shadow:0 4px 20px #0003;overflow:visible}.summary-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.summary-header h3{margin:0;color:#60a5fa;font-size:1.2rem;font-weight:600}.summary-filters{display:flex;flex-wrap:wrap;gap:.5rem}.filter-tag{padding:.5rem 1rem;border-radius:1.5rem;font-size:.8rem;font-weight:600;border:1px solid transparent;transition:all .3s ease}.filter-tag.business{background:linear-gradient(45deg,#3b82f6,#1e40af);color:#fff;border-color:#3b82f6}.filter-tag.area{background:linear-gradient(45deg,#10b981,#059669);color:#fff;border-color:#10b981}.filter-tag.price{background:linear-gradient(45deg,#f59e0b,#d97706);color:#fff;border-color:#f59e0b}.filter-tag.boycott{background:linear-gradient(45deg,#ef4444,#dc2626);color:#fff;border-color:#ef4444;animation:pulse-glow 2s infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 5px #ef444480}50%{box-shadow:0 0 20px #ef4444cc}}.summary-content{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#33415599;border-radius:.75rem;border-left:4px solid #60a5fa;transition:all .3s ease;min-height:60px}.summary-item:hover{background:#334155cc;transform:translate(4px)}.summary-item.boycott-warning{border-left-color:#ef4444;background:#7f1d1d4d}.summary-item strong{color:#cbd5e1;font-weight:600;min-width:150px}.summary-item span{color:#f8fafc;text-align:right;flex:1}.summary-item.boycott-warning span{color:#fecaca}.app-footer{background:linear-gradient(135deg,#0f172a,#1e293b);border-top:1px solid #475569;color:#94a3b8;text-align:center;padding:1.5rem;font-size:.9rem}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem}.header-controls{flex-direction:column;gap:1rem;width:100%}.dashboard{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}.analytics-grid{grid-template-columns:1fr}.summary-header{flex-direction:column;gap:1rem}.summary-filters{justify-content:flex-start}.summary-item{flex-direction:column;align-items:flex-start;gap:.5rem}.summary-item strong{min-width:auto}.summary-item span{text-align:left}.chart-value{font-size:2rem}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#1e293b}::-webkit-scrollbar-thumb{background:#475569;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#64748b}.filter-section h3,.stats-section h3,.insights-section h3{display:flex;align-items:center;gap:.5rem;margin:0 0 1.5rem;color:#60a5fa;font-size:1.1rem;font-weight:600;border-bottom:2px solid #334155;padding-bottom:.5rem}.filter-section h3 span,.stats-section h3 span,.insights-section h3 span{background:linear-gradient(45deg,#60a5fa,#34d399);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.filter-group{margin-bottom:1.5rem}.filter-group label{display:block;margin-bottom:.75rem;font-weight:600;color:#cbd5e1;font-size:.9rem;display:flex;align-items:center;gap:.5rem}.filter-select{width:100%;padding:.75rem 1rem;border:1px solid #475569;border-radius:.75rem;background:linear-gradient(135deg,#334155,#475569);color:#f8fafc;font-size:.9rem;font-weight:500;transition:all .3s ease;cursor:pointer}.filter-select:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa33;transform:translateY(-1px)}.filter-select:hover{border-color:#64748b;background:linear-gradient(135deg,#475569,#64748b)}.filter-select optgroup{background:#1e293b;color:#94a3b8;font-weight:600;padding:.5rem}.filter-select option{background:#334155;color:#f8fafc;padding:.5rem}.range-container{margin-top:.5rem}.range-slider{width:100%;height:6px;border-radius:3px;background:#475569;outline:none;-webkit-appearance:none;transition:all .3s ease}.range-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:linear-gradient(45deg,#60a5fa,#34d399);cursor:pointer;box-shadow:0 2px 6px #0000004d;transition:all .2s ease}.range-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 12px #60a5fa66}.range-labels{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.8rem;color:#94a3b8}.boycott-alert-section{background:linear-gradient(135deg,#7f1d1d,#991b1b);border:1px solid #dc2626;border-radius:1rem;padding:1.5rem;margin:1.5rem 0;box-shadow:0 4px 20px #dc262633}.boycott-alert-section h4{margin:0 0 1rem;color:#fecaca;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.boycott-legend{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.legend-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:.5rem;background:#ffffff1a;transition:all .2s ease}.legend-item:hover{background:#ffffff26;transform:translate(4px)}.legend-text{display:flex;flex-direction:column;gap:.25rem}.legend-text strong{color:#f1f5f9;font-size:.85rem;font-weight:600}.legend-text span{color:#cbd5e1;font-size:.75rem}.color-box{width:16px;height:16px;border-radius:4px;box-shadow:0 2px 4px #0000004d;flex-shrink:0}.boycott-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:1rem}.boycott-stat{text-align:center;padding:.5rem;background:#ffffff1a;border-radius:.5rem}.boycott-stat .stat-number{display:block;font-size:1.2rem;font-weight:700;color:#fecaca}.boycott-stat .stat-label{font-size:.7rem;color:#cbd5e1;margin-top:.25rem}.stat-card{display:flex;align-items:center;gap:1rem;background:linear-gradient(135deg,#334155,#475569);border:1px solid #64748b;border-radius:1rem;padding:1rem;margin-bottom:1rem;transition:all .3s ease;cursor:pointer}.stat-card:hover{transform:translateY(-2px) translate(4px);box-shadow:0 8px 25px #0000004d}.stat-card.primary{border-left:4px solid #60a5fa;background:linear-gradient(135deg,#1e40af,#3730a3)}.stat-card.secondary{border-left:4px solid #34d399;background:linear-gradient(135deg,#059669,#047857)}.stat-card.tertiary{border-left:4px solid #fbbf24;background:linear-gradient(135deg,#d97706,#b45309)}.stat-card.warning{border-left:4px solid #f87171;background:linear-gradient(135deg,#dc2626,#b91c1c)}.stat-icon{font-size:2rem;opacity:.8}.stat-content{flex:1}.stat-number{font-size:1.8rem;font-weight:700;color:#f8fafc;line-height:1}.stat-label{font-size:.8rem;color:#cbd5e1;margin:.25rem 0;font-weight:500}.stat-change{font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:1rem;display:inline-block}.stat-change.positive{background:#22c55e33;color:#86efac}.stat-change.negative{background:#ef444433;color:#fca5a5}.stat-change.neutral{background:#9ca3af33;color:#d1d5db}.insights-section{border-top:1px solid #475569;padding-top:1.5rem;margin-top:1.5rem}.insight-item{display:flex;align-items:flex-start;gap:1rem;background:linear-gradient(135deg,#1e3a8a,#1e40af);border:1px solid #3730a3;border-radius:.75rem;padding:1rem;margin-bottom:1rem;transition:all .3s ease;cursor:pointer}.insight-item:hover{transform:translate(6px);box-shadow:0 6px 20px #1e3a8a4d}.insight-item.high-opportunity{background:linear-gradient(135deg,#059669,#047857);border-color:#10b981}.insight-item.student-market{background:linear-gradient(135deg,#7c3aed,#6d28d9);border-color:#8b5cf6}.insight-item.boycott-impact{background:linear-gradient(135deg,#dc2626,#b91c1c);border-color:#ef4444}.insight-item.trend-alert{background:linear-gradient(135deg,#d97706,#b45309);border-color:#f59e0b}.insight-icon{font-size:1.5rem;opacity:.9;margin-top:.25rem}.insight-content{flex:1}.insight-content strong{color:#f8fafc;font-size:.9rem;font-weight:600;display:block;margin-bottom:.5rem}.insight-content p{color:#cbd5e1;font-size:.8rem;line-height:1.4;margin:0}.quick-actions{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem}.action-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:none;border-radius:.75rem;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .3s ease}.action-btn.primary{background:linear-gradient(45deg,#60a5fa,#3b82f6);color:#fff}.action-btn.secondary{background:linear-gradient(45deg,#34d399,#10b981);color:#fff}.action-btn.tertiary{background:linear-gradient(45deg,#fbbf24,#f59e0b);color:#fff}.action-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.action-btn:active{transform:translateY(0)}.map-wrapper{position:relative;width:100%;height:500px;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #0000004d;z-index:1}.map-container{width:100%;height:100%;position:relative;z-index:1}.mapboxgl-map{width:100%!important;height:100%!important;z-index:1!important}.map-container.loading{opacity:.3}.map-container.loaded{opacity:1;transition:opacity .5s ease}.loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0f172ae6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:20px}.spinner{width:50px;height:50px;border:4px solid rgba(59,130,246,.3);border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner p{color:#e2e8f0;font-size:16px;font-weight:500;margin:0;text-align:center}.error-state{display:flex;align-items:center;justify-content:center;background:#0f172ae6;border-radius:12px}.error-message{text-align:center;color:#ef4444;padding:40px}.error-message h3{color:#ef4444;margin-bottom:16px}.error-message button{background:#3b82f6;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;margin-top:16px}.error-message button:hover{background:#2563eb}.map-controls{position:absolute;top:16px;right:16px;display:flex;flex-direction:column;gap:8px;z-index:100}.control-btn{background:#0f172ae6;border:1px solid rgba(59,130,246,.3);color:#e2e8f0;width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.control-btn:hover{background:#3b82f633;border-color:#3b82f6;transform:translateY(-2px)}.style-controls{display:flex;flex-direction:column;gap:4px}.style-btn{background:#0f172ae6;border:1px solid rgba(59,130,246,.3);color:#e2e8f0;padding:8px 12px;border-radius:6px;font-size:12px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.style-btn:hover{background:#3b82f633;border-color:#3b82f6}.style-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.legend-panel{position:absolute;top:16px;left:16px;background:#0f172af2;border:1px solid rgba(59,130,246,.3);border-radius:12px;padding:0;max-width:280px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;box-shadow:0 8px 32px #0000004d}.legend-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(59,130,246,.2)}.legend-header h3{color:#e2e8f0;font-size:16px;font-weight:600;margin:0}.close-legend{background:none;border:none;color:#94a3b8;font-size:18px;cursor:pointer;padding:4px;border-radius:4px;transition:all .3s ease}.close-legend:hover{color:#ef4444;background:#ef44441a}.legend-content{padding:20px}.legend-section{margin-bottom:24px}.legend-section h4{color:#3b82f6;font-size:14px;font-weight:600;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.legend-items{display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:12px}.legend-color{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.3);flex-shrink:0}.legend-item span{color:#e2e8f0;font-size:13px;font-weight:500}.legend-stats,.map-info{border-top:1px solid rgba(59,130,246,.2);padding-top:16px;margin-top:16px}.legend-stats h4,.map-info h4{color:#3b82f6;font-size:14px;font-weight:600;margin:0 0 8px}.legend-stats p,.map-info p{color:#94a3b8;font-size:13px;margin:4px 0}.map-status{position:absolute;bottom:16px;left:16px;z-index:100}.status-indicator{background:#0f172ae6;border:1px solid rgba(59,130,246,.3);color:#94a3b8;padding:8px 16px;border-radius:20px;font-size:12px;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.status-indicator.active{color:#22c55e;border-color:#22c55e4d}.status-indicator.loading{color:#eab308;border-color:#eab3084d}.custom-marker{cursor:pointer;transition:all .3s ease}.custom-marker:hover{transform:scale(1.2);box-shadow:0 4px 12px #0006!important}.custom-popup{padding:16px;min-width:200px}.custom-popup h3{color:#1e293b;font-size:16px;font-weight:600;margin:0 0 12px;border-bottom:2px solid #e2e8f0;padding-bottom:8px}.custom-popup p{color:#475569;font-size:13px;margin:6px 0}.custom-popup .boycott-status{padding:4px 8px;border-radius:4px;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;margin-top:8px}.custom-popup .boycott-status.boycott{background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.3)}.custom-popup .boycott-status.neutral{background:#eab3081a;color:#ca8a04;border:1px solid rgba(234,179,8,.3)}.custom-popup .boycott-status.support{background:#22c55e1a;color:#16a34a;border:1px solid rgba(34,197,94,.3)}@media (max-width: 768px){.legend-panel{max-width:240px;font-size:12px}.map-controls{top:12px;right:12px;gap:6px}.control-btn{width:36px;height:36px;font-size:16px}.style-btn{padding:6px 8px;font-size:10px}}.chart-container{background:linear-gradient(135deg,#334155,#475569);border:1px solid #64748b;border-radius:.75rem;padding:1.5rem;transition:transform .2s ease;height:100%;display:flex;flex-direction:column}.chart-container:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.chart-title h4{margin:0 0 .25rem;color:#60a5fa;font-size:1.1rem;font-weight:600}.chart-subtitle{margin:0;color:#94a3b8;font-size:.8rem;font-weight:400}.saturation-indicator,.density-indicator,.score-indicator{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.saturation-level,.density-value,.score-value{font-size:1.8rem;font-weight:700;line-height:1}.saturation-status,.density-unit,.score-max{font-size:.7rem;color:#94a3b8;font-weight:500}.density-indicator{align-items:center;flex-direction:row;gap:.5rem}.density-icon{font-size:1.5rem}.density-info{display:flex;flex-direction:column;align-items:flex-end}.score-indicator{align-items:center;flex-direction:row;gap:.5rem}.score-icon{font-size:1.5rem}.score-info{display:flex;align-items:baseline;gap:.25rem}.chart-content{flex:1;display:flex;align-items:center;justify-content:center;margin:.5rem 0}.radial-chart-container{position:relative;width:100%;height:160px}.radial-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}.center-score{font-size:2rem;font-weight:700;line-height:1}.center-label{font-size:.8rem;color:#94a3b8;font-weight:500;margin-top:.25rem}.chart-legend{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #475569}.chart-legend.horizontal{flex-direction:row;justify-content:space-around;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem}.legend-color{width:12px;height:12px;border-radius:2px;flex-shrink:0}.legend-text{color:#cbd5e1;flex:1}.legend-value{color:#f8fafc;font-weight:600;margin-left:auto}.chart-insights{margin-top:1rem;padding-top:1rem;border-top:1px solid #475569}.insight-text{font-size:.8rem;line-height:1.4;margin-bottom:.5rem}.insight-success{color:#86efac;background:#22c55e1a;padding:.25rem .5rem;border-radius:.25rem;border:1px solid rgba(34,197,94,.2)}.insight-good{color:#93c5fd;background:#3b82f61a;padding:.25rem .5rem;border-radius:.25rem;border:1px solid rgba(59,130,246,.2)}.insight-warning{color:#fca5a5;background:#ef44441a;padding:.25rem .5rem;border-radius:.25rem;border:1px solid rgba(239,68,68,.2)}.insight-neutral{color:#fbbf24;background:#f59e0b1a;padding:.25rem .5rem;border-radius:.25rem;border:1px solid rgba(245,158,11,.2)}.insight-description{font-size:.75rem;color:#94a3b8;font-style:italic}.boycott-bonus{color:#a78bfa}.score-breakdown{margin-top:1rem;padding-top:1rem;border-top:1px solid #475569}.score-breakdown h5{margin:0 0 .75rem;color:#cbd5e1;font-size:.9rem;font-weight:600}.breakdown-items{display:flex;flex-direction:column;gap:.5rem}.breakdown-item{display:flex;align-items:center;gap:.75rem;font-size:.75rem}.breakdown-label{color:#94a3b8;min-width:80px;font-weight:500}.breakdown-bar{flex:1;height:6px;background:#374151;border-radius:3px;overflow:hidden;position:relative}.breakdown-fill{height:100%;border-radius:3px;transition:width 1s ease-in-out}.breakdown-value{color:#f8fafc;font-weight:600;min-width:30px;text-align:right}.chart-tooltip{background:#0f172af2;border:1px solid #475569;border-radius:.5rem;padding:.75rem;box-shadow:0 4px 15px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tooltip-label{color:#f8fafc;font-size:.8rem;font-weight:600;margin:0 0 .25rem}.tooltip-value{color:#cbd5e1;font-size:.75rem;margin:0;display:flex;align-items:center;gap:.25rem}@media (max-width: 768px){.chart-header{flex-direction:column;gap:.5rem}.saturation-indicator,.density-indicator,.score-indicator{align-items:flex-start;flex-direction:row;gap:.5rem}.chart-legend.horizontal{flex-direction:column}.breakdown-item{font-size:.7rem}.breakdown-label{min-width:70px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chart-container{animation:fadeInUp .6s ease-out}.chart-container:nth-child(1){animation-delay:.1s}.chart-container:nth-child(2){animation-delay:.2s}.chart-container:nth-child(3){animation-delay:.3s}
