:root{--bg: #ffffff;--bg-secondary: #f6f8fa;--bg-tertiary: #edf0f2;--bg-overlay: rgba(0, 0, 0, .05);--text-primary: #1f2328;--text-secondary: #656d76;--text-tertiary: #8b949e;--border-default: #d0d7de;--border-subtle: #e8ecf0;--border-emphasis: #0D4723;--green-700: #093618;--green-600: #0D4723;--green-400: #2DA950;--green-100: rgba(13, 71, 35, .12);--green-50: rgba(13, 71, 35, .06);--amber-600: #9A6700;--amber-100: rgba(154, 103, 0, .12);--red-600: #A1232B;--red-100: rgba(161, 35, 43, .12);--blue-600: #1A5276;--blue-100: rgba(26, 82, 118, .12)}*,*:before,*:after{box-sizing:border-box}body{font-family:Inter,sans-serif;font-size:14px;font-weight:400;line-height:1.5;color:var(--text-primary);background-color:var(--bg-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.type-h1{font-size:28px;font-weight:700;line-height:1.25;color:var(--text-primary);letter-spacing:-.3px}.type-h2{font-size:22px;font-weight:700;line-height:1.3;color:var(--text-primary);letter-spacing:-.2px}.type-h3{font-size:18px;font-weight:700;line-height:1.35;color:var(--text-primary)}.type-label{font-size:12px;font-weight:600;line-height:1.4;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.type-body{font-size:14px;font-weight:400;line-height:1.5;color:var(--text-primary)}.type-caption{font-size:11px;font-weight:400;line-height:1.4;color:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-fadeIn{animation:fadeIn .3s ease-out forwards}.rounded-card{border-radius:8px}.rounded-input{border-radius:6px}*{box-sizing:border-box}html,body{overflow-x:hidden;max-width:100%}.interactive-pillars{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:0;padding-bottom:1rem;margin:0;width:100%;position:relative;overflow-x:hidden;overflow-y:visible;min-width:320px;display:flex;flex-direction:column}.top-filter-section{position:static;display:flex;flex-direction:column;width:100%;padding:1rem 1rem .5rem;margin-bottom:.5rem;background-color:#fff;border-bottom:1px solid #f1f5f9}.filter-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.filter-dropdown-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;font-size:.85rem;color:#475569;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;box-shadow:0 1px 2px #0000000d;align-self:flex-end;margin-bottom:.5rem;margin-right:0;z-index:5}.filter-dropdown-button:hover{background-color:#f1f5f9;transform:translateY(-1px);box-shadow:0 2px 4px #00000014}.filter-dropdown-button.active{background-color:#eff6ff;border-color:#bfdbfe;color:#1e40af}.filter-dropdown-button.has-filters{background-color:#f0f9ff;border-color:#bae6fd;color:#0369a1}.filter-count-badge{position:absolute;top:-8px;right:-8px;background-color:#ef4444;color:#fff;font-size:.7rem;font-weight:600;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 4px #0003}.upload-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;background-color:#10b981;border:1px solid #059669;border-radius:.5rem;font-size:.85rem;color:#fff;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.upload-button:hover{background-color:#059669;transform:translateY(-1px);box-shadow:0 2px 4px #00000014}.data-selector-container{position:relative}.data-selector-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;font-size:.85rem;color:#475569;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.data-selector-button:hover{background-color:#f1f5f9;transform:translateY(-1px);box-shadow:0 2px 4px #00000014}.data-selector-button.active{background-color:#eff6ff;border-color:#bfdbfe;color:#1e40af}.data-selector-dropdown{position:absolute;top:100%;left:0;min-width:200px;max-width:300px;background-color:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a;z-index:50;margin-top:.25rem}.data-option{padding:.75rem 1rem;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f1f5f9}.data-option:last-child{border-bottom:none}.data-option:hover{background-color:#f8fafc}.data-option.active{background-color:#eff6ff;color:#1e40af;font-weight:500}.data-option span{font-size:.85rem}.heatmap-container{position:relative}.heatmap-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;background-color:#fef3c7;border:1px solid #fbbf24;border-radius:.5rem;font-size:.85rem;color:#92400e;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.heatmap-button:hover{background-color:#fde68a;transform:translateY(-1px);box-shadow:0 2px 4px #00000014}.heatmap-button.active{background-color:#fed7aa;border-color:#fb923c;color:#ea580c}.heatmap-dropdown{position:absolute;top:100%;left:0;min-width:180px;max-width:250px;background-color:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a;z-index:50;margin-top:.25rem;max-height:200px;overflow-y:auto}.heatmap-option{padding:.75rem 1rem;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f1f5f9;font-size:.85rem}.heatmap-option:last-child{border-bottom:none}.heatmap-option:hover{background-color:#fef3c7;color:#92400e}.heartbeat-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;background-color:#fce7f3;border:1px solid #f472b6;border-radius:.5rem;font-size:.85rem;color:#be185d;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.heartbeat-button:hover:not(:disabled){background-color:#fbcfe8;transform:translateY(-1px);box-shadow:0 2px 4px #00000014}.heartbeat-button.processing{background-color:#e0e7ff;border-color:#a5b4fc;color:#4f46e5;cursor:not-allowed}.heartbeat-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.full-width-filter-panel{width:100%;background-color:#fff;border-radius:.5rem;box-shadow:0 4px 15px -2px #0000001a;border:1px solid #e5e7eb;z-index:10;overflow:visible;display:flex;flex-direction:column;padding:.75rem;margin-bottom:.75rem;position:relative}.filter-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;border-bottom:1px solid #e5e7eb;padding-bottom:.5rem}.filter-panel-header h3{margin:0;font-size:.9rem;color:#1f2937;font-weight:600}.close-dropdown{display:flex;align-items:center;justify-content:center;background:none;border:none;width:28px;height:28px;border-radius:50%;color:#6b7280;cursor:pointer;transition:all .2s ease}.close-dropdown:hover{background-color:#e5e7eb;color:#1f2937}.filter-dropdown-content{overflow-y:auto;padding:1rem;flex:1;display:flex;flex-direction:column;gap:1rem}.filter-categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;width:100%}.filter-category-box{border:1px solid #e5e7eb;border-radius:.5rem;padding:.5rem;background-color:#f9fafb}.filter-category-title{margin:0 0 .5rem;padding-bottom:.25rem;border-bottom:1px solid #e5e7eb;font-size:.75rem;color:#1f2937;font-weight:600}.filter-options-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.filter-options-grid{display:flex;flex-wrap:wrap;gap:.35rem}.filter-chip{display:flex;align-items:center;gap:.3rem;padding:.25rem .5rem;background-color:#fff;border:1px solid #e2e8f0;border-radius:1rem;font-size:.7rem;color:#475569;cursor:pointer;transition:all .2s ease}.filter-chip:hover{background-color:#f1f5f9;border-color:#cbd5e1}.filter-chip input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:14px;height:14px;border:1px solid #cbd5e1;border-radius:3px;margin:0;position:relative;transition:all .2s ease}.filter-chip input[type=checkbox]:checked{background-color:#3b82f6;border-color:#3b82f6}.filter-chip input[type=checkbox]:checked:after{content:"";position:absolute;top:2px;left:4px;width:3px;height:6px;border:solid white;border-width:0 1.5px 1.5px 0;transform:rotate(45deg)}.filter-section{margin-bottom:.75rem}.filter-section h4{margin:0 0 .5rem;font-size:.8rem;color:#4b5563;font-weight:600}.saved-views-section{margin-bottom:.5rem}.saved-views-row{display:flex;flex-wrap:wrap;gap:.5rem;width:100%}.view-chip{display:flex;align-items:center;padding:.4rem .75rem;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:1rem;color:#475569;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s}.view-chip:hover{background-color:#f1f5f9;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.view-chip.active{background-color:#eff6ff;color:#1e40af;border-color:#bfdbfe;font-weight:600}.view-chip.with-close{padding-right:2.5rem;position:relative}.view-close{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);width:18px;height:18px;border-radius:50%;background-color:#0000000d;border:none;display:flex;align-items:center;justify-content:center;color:inherit;cursor:pointer}.view-close:hover{background-color:#ef444426;color:#ef4444}.filter-divider{height:1px;background-color:#e5e7eb;margin:.5rem 0;width:100%}.dropdown-section h4{margin:0 0 .75rem;font-size:.9rem;color:#4b5563;font-weight:600}.dropdown-divider{height:1px;background-color:#e5e7eb;margin:.5rem 0}.tooltip{position:absolute;z-index:100;background-color:#1f2937;color:#fff;padding:.75rem;border-radius:.375rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;max-width:300px;font-size:.75rem;line-height:1.5;pointer-events:none;opacity:0;transition:opacity .2s ease}.tooltip.visible{opacity:1}.tooltip-title{font-weight:600;margin-bottom:.25rem;font-size:.8rem}.tooltip:after{content:"";position:absolute;bottom:-5px;left:50%;margin-left:-5px;border-width:5px 5px 0;border-style:solid;border-color:#1f2937 transparent transparent transparent}.tabs-container{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;border-bottom:1px solid #e5e7eb;padding-bottom:.75rem}.tabs-scroll{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.25rem;flex:1}.tab{padding:.6rem .8rem;border-radius:.5rem;font-size:.75rem;font-weight:500;background-color:#f8fafc;color:#475569;border:1px solid #e2e8f0;cursor:pointer;white-space:normal;overflow-wrap:break-word;word-break:break-word;-webkit-hyphens:auto;hyphens:auto;transition:all .2s ease;width:100%;min-height:2.5rem;line-height:1.2;position:relative;overflow:visible;height:auto!important;box-sizing:border-box;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;text-align:left;max-width:100%}.tab:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:transparent;transition:background-color .2s ease}.tab:hover{background-color:#f1f5f9;transform:translateY(-1px);box-shadow:0 3px 5px #0000000a;border-color:#cbd5e1}.tab.active{background-color:#eff6ff;color:#1e40af;border-color:#bfdbfe;box-shadow:0 3px 5px #3b82f61a;font-weight:600}.tab:hover:before{background-color:#cbd5e1}.tab.active:before{background-color:#3b82f6}.tab.with-close{position:relative;padding-right:35px;min-height:2.6rem}.tab.with-close span .tab.with-close span{display:block;width:100%;word-wrap:break-word;white-space:normal;overflow:visible;text-overflow:initial;-webkit-box-orient:vertical}.tab-close{background-color:#0000001a;border:none;color:inherit;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.8;border-radius:50%;width:22px;height:22px;position:absolute;right:6px;top:.5rem;z-index:2;transition:all .15s ease}.tab-close:hover{opacity:1;background-color:#ef444426;color:#ef4444}.tab.active .tab-close{color:#1e40af;background-color:#ffffff4d}.tab.active .tab-close:hover{color:#ef4444;background-color:#ef444426}.custom-tab{background-color:#fef3c7;color:#92400e;border-color:#fbbf24;box-shadow:0 2px 5px #f59e0b26;font-weight:600}.custom-tab:before{background-color:#f59e0b}.filter-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:9999px;font-size:.575rem;font-weight:500;background-color:#f3f4f6;color:#4b5563;border:none;cursor:pointer;transition:all .2s}.filter-toggle:hover{background-color:#e5e7eb}.filter-toggle.active-filters{background-color:#f59e0b;color:#fff}.filter-toggle.active-filters:hover{background-color:#d97706}.filter-count{display:inline-flex;align-items:center;justify-content:center;background-color:#fff;color:#f59e0b;border-radius:9999px;min-width:20px;height:20px;padding:0 .25rem;font-size:.75rem;font-weight:600;margin-left:.25rem}.filter-panel{background-color:#f9fafb;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid #e5e7eb}.filter-panel.always-visible{height:100%;margin-bottom:0}.filter-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.filter-panel-header h3{margin:0;font-size:1.25rem;color:#1f2937}.close-panel{background:none;border:none;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.25rem;border-radius:9999px}.close-panel:hover{background-color:#e5e7eb}.filter-categories{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.filter-category h4{margin-top:0;margin-bottom:.75rem;font-size:1rem;color:#4b5563}.filter-options{display:flex;flex-direction:column;gap:.65rem}.filter-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;position:relative;padding:.25rem .5rem;border-radius:.375rem;transition:background-color .15s ease}.filter-option:hover{background-color:#f1f5f9}.filter-option input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:18px;height:18px;border:2px solid #cbd5e1;border-radius:4px;cursor:pointer;position:relative;transition:all .2s ease;background-color:#fff}.filter-option input[type=checkbox]:checked{background-color:#3b82f6;border-color:#3b82f6}.filter-option input[type=checkbox]:checked:after{content:"";position:absolute;top:2px;left:5px;width:5px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.filter-option input[type=checkbox]:focus{outline:2px solid rgba(59,130,246,.3);outline-offset:1px}.filter-option span{transition:color .15s ease}.filter-option:hover span{color:#1f2937}.filter-option input[type=checkbox]:checked+span{font-weight:500;color:#1f2937}.save-filter-set{display:flex;flex-direction:column;gap:.9rem;margin-top:1.5rem;background:linear-gradient(145deg,#f8fafc,#eff6ff);padding:1.25rem;border-radius:.65rem;border:1px solid #e2e8f0;box-shadow:0 2px 8px #00000008;position:relative;transition:all .2s ease}.save-filter-set:hover{box-shadow:0 4px 12px #0000000d;border-color:#cbd5e1}.save-filter-set h4{margin:0 0 .25rem;font-size:.95rem;color:#1e40af;font-weight:600;display:flex;align-items:center;gap:.5rem}.save-filter-set h4:before{content:"";display:inline-block;width:18px;height:18px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233B82F6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11l5 5v11a2 2 0 0 1-2 2z'%3E%3C/path%3E%3Cpolyline points='17 21 17 13 7 13 7 21'%3E%3C/polyline%3E%3Cpolyline points='7 3 7 8 15 8'%3E%3C/polyline%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat}.save-filters-box{min-width:200px}.save-filter-form{display:flex;flex-direction:column;gap:.5rem;width:100%}.filter-name-input{width:100%;padding:.4rem .65rem;border-radius:.35rem;border:1px solid #cbd5e1;font-size:.75rem;background-color:#fff;transition:all .2s ease;box-shadow:0 1px 2px #00000008 inset}.filter-name-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.filter-name-input::placeholder{color:#94a3b8}.save-filter-button{display:flex;align-items:center;justify-content:center;gap:.3rem;padding:.4rem .65rem;background-color:#3b82f6;color:#fff;border:none;border-radius:.35rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 1px 2px #3b82f64d;position:relative;overflow:hidden;width:100%}.save-filter-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,#fff0,#fff3,#fff0);transition:all .5s ease}.save-filter-button:hover{background-color:#2563eb;transform:translateY(-2px);box-shadow:0 4px 8px #3b82f666}.save-filter-button:hover:before{left:100%}.save-filter-button:active{transform:translateY(0);box-shadow:0 2px 4px #3b82f64d}.save-filter-button:disabled{background-color:#93c5fd;cursor:not-allowed;transform:none;box-shadow:none;opacity:.7}.save-filter-button:disabled:before{display:none}.interactive-pillars{position:relative;transition:padding-left .3s ease;width:100%;max-width:100%}.interactive-pillars{position:relative}.pillars-layout{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:.5rem;width:100%;max-width:100%;transition:all .3s ease;margin-top:5px;padding:0 1rem;overflow:visible}.pillars-layout.filters-collapsed{grid-template-columns:1.5fr repeat(3,1fr);overflow-x:hidden;margin-left:0}.filters-column{position:relative;max-height:90vh;overflow-y:auto;transition:all .3s ease;border-right:1px solid #e5e7eb;background-color:#fff;padding:1.25rem;border-radius:.75rem;box-shadow:0 4px 16px #00000014;min-width:250px;z-index:10;scrollbar-width:thin;scrollbar-color:#cbd5e1 #f1f5f9}.filters-column::-webkit-scrollbar{width:6px}.filters-column::-webkit-scrollbar-track{background:#f1f5f9;border-radius:8px}.filters-column::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:8px}.filters-column h3{font-size:1.15rem;color:#1f2937;margin-top:0;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid #f1f5f9;letter-spacing:.015em}.filters-column.collapsed{width:0;min-width:0;overflow:hidden;opacity:0;visibility:hidden;position:absolute;left:-300px;transition:all .3s ease;z-index:-1;pointer-events:none;height:0}.toggle-filters{position:absolute;left:250px;top:1.5rem;width:40px;height:40px;background-color:#fff;border:1px solid #e5e7eb;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:40;box-shadow:0 3px 6px #0000001a;transition:all .25s cubic-bezier(.4,0,.2,1);color:#6b7280}.toggle-filters:hover{transform:scale(1.1) rotate(-5deg);box-shadow:0 4px 8px #0000001f;color:#3b82f6;border-color:#bfdbfe}.toggle-filters:active{transform:scale(.95)}.toggle-filters.collapsed{left:15px;top:15px;background-color:#3b82f6;color:#fff;box-shadow:0 4px 10px #3b82f680;width:44px;height:44px}.toggle-filters.collapsed:hover{background-color:#2563eb;transform:scale(1.1) rotate(5deg)}@keyframes pulse{0%{box-shadow:0 0 #3b82f6b3}70%{box-shadow:0 0 0 8px #3b82f600}to{box-shadow:0 0 #3b82f600}}.toggle-filters.collapsed{animation:pulse 2s infinite}.filter-badge{position:absolute;top:-5px;right:-5px;background-color:#ef4444;color:#fff;font-size:.7rem;font-weight:600;min-width:20px;height:20px;border-radius:9999px;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 4px #0003}.results-column{grid-column:1;display:flex;flex-direction:column;gap:.5rem;max-height:none;transition:all .3s ease}.pillars-layout.filters-collapsed .results-column{grid-column:1;margin-left:0;width:100%}.pillar-column{display:flex;flex-direction:column;gap:.5rem;max-height:none;padding:.5rem;margin:0}.community-column,.environment-column,.livelihood-column{border:1px solid #e5e7eb;border-radius:.5rem}.collapsible-section{border:1px solid #e5e7eb;border-radius:.6rem;overflow:hidden;margin-bottom:1rem;transition:all .2s ease;box-shadow:0 1px 3px #00000005}.collapsible-section:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000a}.collapsible-header{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1rem;background-color:#f8fafc;cursor:pointer;border-bottom:1px solid #e5e7eb;transition:background-color .2s ease}.collapsible-header:hover{background-color:#f1f5f9}.collapsible-header h4{margin:0;font-size:.95rem;color:#1f2937;font-weight:500;display:flex;align-items:center;gap:.5rem}.collapsible-header h4:before{content:"";display:inline-block;width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='22 3 2 3 10 12.46 10 19 14 21 14 12.46 22 3'%3E%3C/polygon%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;opacity:.7}.collapsible-header button{background:none;border:none;display:flex;align-items:center;justify-content:center;color:#6b7280;cursor:pointer;transition:all .2s ease;width:24px;height:24px;border-radius:50%}.collapsible-header button:hover{background-color:#e5e7eb;color:#4b5563}.collapsible-header button.rotate{transform:rotate(180deg);color:#3b82f6}.collapsible-content{padding:0;background-color:#fff;max-height:0;overflow:hidden;transition:all .3s ease}.collapsible-content.expanded{max-height:300px;padding:1rem;border-top:1px solid #f1f5f9;overflow-y:auto}.pillar-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem}.pillar-components{display:flex;flex-direction:column;gap:.75rem}.component-card{background-color:#fff;border-radius:.4rem;box-shadow:0 1px 2px #0000000d;padding:.5rem;cursor:pointer;transition:all .2s ease;border:1px solid #e5e7eb;font-size:.8rem}.component-card:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.component-card.active{box-shadow:0 4px 6px #0000001a;border-width:2px;position:relative;overflow:visible}.component-card.active:after{content:"✓ Selected";position:absolute;top:-10px;right:-10px;background-color:#10b981;color:#fff;padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:700;box-shadow:0 2px 4px #0000001a}.component-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.component-header h4{margin:0;font-size:.7rem;font-weight:600;color:#1f2937;display:flex;align-items:center;justify-content:space-between;width:100%}.component-score{display:flex;justify-content:flex-end;align-items:center;font-size:.7rem;margin-top:.1rem}.component-score .responses{color:#6b7280;font-size:.65rem}.results-column-content{background-color:#fff;border-radius:.4rem;padding:.75rem;box-shadow:0 1px 2px #0000000d;border:1px solid #e5e7eb;height:100%}.selected-component-details{margin-bottom:.75rem}.selected-component-details h3{font-size:.9rem;color:#1f2937;margin-top:0;margin-bottom:.5rem}.selected-component-details p{font-size:.75rem;color:#4b5563;line-height:1.4;margin:0}.overall-instructions{display:flex;align-items:center;justify-content:center;padding:1rem;color:#6b7280;font-style:italic;text-align:center;font-size:.75rem}.results-data{margin-top:.75rem}.results-data h4{font-size:.8rem;color:#1f2937;margin-top:0;margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid #e5e7eb}.results-list{list-style:none;padding:0;margin:0}.no-selection-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;text-align:center;background-color:#f9fafb;border-radius:.4rem;border:1px dashed #d1d5db;margin:.5rem 0}.no-selection{color:#6b7280;font-size:.75rem;margin-top:.5rem}.selected-component-result{background-color:#f8fafc;border-radius:.4rem;padding:.75rem;border:1px solid #e2e8f0;box-shadow:0 1px 2px #00000008;margin:.25rem 0 .75rem}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.35rem;border-bottom:1px solid #e5e7eb}.result-title{font-size:.8rem;font-weight:600;color:#1f2937}.result-value{font-size:.9rem;font-weight:700;color:#1f2937;background-color:#f1f5f9;padding:2px 8px;border-radius:.35rem;display:flex;align-items:center;justify-content:center}.stats-details{display:flex;flex-direction:column;gap:.5rem;font-size:.75rem}.stat-item{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;padding:.5rem 0}.stat-label{font-size:.85rem;font-weight:500;color:#4b5563;min-width:140px}.stat-value{font-size:.95rem;font-weight:600;color:#1f2937}.stat-difference{display:flex;align-items:center;font-size:.95rem;font-weight:600;padding:.25rem .75rem;border-radius:.25rem}.stat-difference.positive{color:#10b981;background-color:#ecfdf5}.stat-difference.negative{color:#ef4444;background-color:#fef2f2}.statistical-significance{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;padding:.5rem 0;margin-top:.5rem}.significance-badge{display:flex;align-items:center;padding:.25rem .75rem;border-radius:.25rem;font-size:.85rem;font-weight:600}.significance-badge.positive{background-color:#ecfdf5;color:#10b981}.significance-badge.negative{background-color:#fef2f2;color:#ef4444}.significance-badge.neutral{background-color:#f3f4f6;color:#6b7280}.significance-explanation{display:flex;align-items:center;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.375rem;padding:.75rem;font-size:.85rem;color:#4b5563;margin-top:.5rem;line-height:1.4}.significance-explanation.warning{background-color:#fffbeb;border-color:#fcd34d;color:#92400e}.sample-size-warning{display:flex;align-items:center;gap:.375rem;color:#f59e0b;font-size:.75rem;background-color:#fffbeb;padding:.25rem .5rem;border-radius:.25rem;margin-left:.5rem}.result-statistics{display:flex;align-items:center;gap:8px}.significance-indicator{display:flex;align-items:center;justify-content:center}.significance-indicator.positive{color:#10b981}.significance-indicator.negative{color:#ef4444}.statistical-warning{display:flex;align-items:center;justify-content:center;margin-left:5px;color:#f59e0b}.overall-summary{background-color:#fff;border-radius:.5rem;padding:.75rem;margin-bottom:.5rem;border:1px solid #e5e7eb;text-align:center}.overall-summary h3{margin-top:0;margin-bottom:.5rem;color:#1f2937;font-size:.9rem}.overall-score{display:flex;flex-direction:column;align-items:center}.overall-score .score-value{font-size:1.5rem;font-weight:700;color:#1f2937}.overall-score .score-label{color:#6b7280;font-size:.75rem}.pillar-card{border-radius:.5rem;background-color:#fff;border:2px solid #e5e7eb;overflow:hidden;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column}.pillar-card:hover{transform:translateY(-5px);box-shadow:0 4px 12px #00000026}.pillar-card.active{box-shadow:0 4px 12px #00000026}.pillar-card.all{border-color:#6b7280;text-align:center;padding:1.5rem}.pillar-header{display:flex;align-items:center;gap:.75rem;padding:.75rem;color:#fff;border-radius:.5rem;margin-bottom:.5rem;cursor:pointer;transition:all .2s ease;position:relative;z-index:1}.pillar-header:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0003}.pillar-header.active{border:2px solid #fff;box-shadow:0 4px 12px #0000004d}.pillar-column .pillar-header{margin-bottom:.25rem}.pillar-card.community{border-color:#3b82f6}.pillar-card.environment{border-color:#10b981}.pillar-card.livelihood{border-color:#8b5cf6}.pillar-icon{display:flex;align-items:center;justify-content:center;background-color:#fff3;border-radius:9999px;width:32px;height:32px}.pillar-header h3{margin:0;font-size:1.125rem;font-weight:600}.pillar-column .pillar-header h3{font-size:1rem}.pillar-score{text-align:center;padding:.75rem .5rem}.pillar-column .pillar-score{padding:.5rem 0}.pillar-card .score-value{display:block;font-size:2rem;font-weight:700;color:#1f2937;line-height:1}.pillar-column .score-value{font-size:1.5rem}.pillar-card .score-label{display:block;margin-top:.25rem;color:#6b7280;font-size:.875rem}.pillar-column .score-label{font-size:.75rem}.filter-applied-tag{display:inline-block;background-color:#f59e0b;color:#fff;font-size:.7rem;font-weight:500;padding:.125rem .5rem;border-radius:9999px;margin-top:.5rem;text-transform:uppercase;letter-spacing:.05em}.pillar-card p{margin-top:0;padding:0 1rem 1.25rem;color:#6b7280;font-size:.875rem;line-height:1.5}.pillar-card.all h3{margin-top:0;margin-bottom:1rem;color:#1f2937}.pillar-elements{padding:0 1rem 1rem;flex:1;overflow-y:auto;max-height:260px}.pillar-element{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #e5e7eb;font-size:.875rem}.pillar-element:last-child{border-bottom:none}.element-name{color:#4b5563;font-weight:500}.element-score{display:flex;align-items:center;gap:.5rem;color:#1f2937;font-weight:600}.diff-indicator{display:flex;align-items:center;gap:.25rem;padding:.125rem .375rem;border-radius:9999px;font-size:.7rem}.diff-indicator.positive{background-color:#10b9811a;color:#10b981}.diff-indicator.negative{background-color:#ef44441a;color:#ef4444}.component-selection{margin-bottom:2rem}.component-selection h3{margin-top:0;margin-bottom:1rem;font-size:1.25rem;color:#1f2937}.component-buttons{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.component-button{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:.5rem;background-color:#fff;font-size:.875rem;cursor:pointer;transition:all .2s}.component-button:hover{transform:translateY(-2px);box-shadow:0 2px 8px #0000000d}.component-button.active{font-weight:500}.component-icon{display:flex;align-items:center;justify-content:center}.component-description{background-color:#f9fafb;border-radius:.5rem;padding:1rem}.component-description p{margin:0;color:#4b5563;font-size:.875rem;line-height:1.6}.chart-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.control-group{display:flex;align-items:center;gap:.75rem}.control-group label{font-weight:500;color:#4b5563;font-size:.875rem}.chart-type-select{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;background-color:#fff}.chart-actions{display:flex;gap:.75rem}.toggle-insights,.toggle-personas{padding:.5rem 1rem;border:none;border-radius:.375rem;background-color:#f3f4f6;color:#4b5563;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.toggle-insights:hover,.toggle-personas:hover{background-color:#e5e7eb}.toggle-insights.active{background-color:#3b82f6;color:#fff}.toggle-personas.active{background-color:#8b5cf6;color:#fff}.toggle-flags{position:relative}.toggle-flags.active{background-color:#f97316;color:#fff}.button-icon{display:flex;align-items:center;justify-content:center}.personas-count,.flags-count{display:inline-flex;align-items:center;justify-content:center;background-color:#fff;border-radius:9999px;min-width:18px;height:18px;padding:0 .25rem;font-size:.7rem;font-weight:600;margin-left:.25rem}.personas-count{color:#8b5cf6}.flags-count{color:#f97316}.personas-panel{background-color:#f9fafb;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid #e5e7eb;position:relative;z-index:10}.personas-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;border-bottom:1px solid #e5e7eb;padding-bottom:.75rem}.personas-panel-header h3{margin:0;font-size:1.25rem;color:#1f2937;display:flex;align-items:center;gap:.5rem}.personas-section{margin-bottom:1.5rem}.personas-section-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;margin-top:0;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.personas-section-title.positive{color:#10b981}.personas-section-title.negative{color:#ef4444}.personas-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.persona-card{background-color:#fff;border-radius:.5rem;padding:1rem;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .2s;border-top:3px solid #e5e7eb}.persona-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.persona-card.urgent{border-top-color:#ef4444}.persona-card.high{border-top-color:#f97316}.persona-card.medium{border-top-color:#3b82f6}.persona-card.low{border-top-color:#6b7280}.persona-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.persona-badge{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:600;color:#fff}.persona-badge.strength{background-color:#10b981}.persona-badge.risk{background-color:#ef4444}.persona-badge.opportunity{background-color:#f97316}.persona-badge.insight{background-color:#3b82f6}.persona-badge.influence{background-color:#8b5cf6}.persona-badge.focus{background-color:#0ea5e9}.persona-card h5{margin:0;font-size:.9rem;color:#1f2937}.persona-description{margin:.5rem 0;font-size:.8rem;color:#4b5563;line-height:1.4}.persona-insight{margin:.5rem 0 1rem;font-size:.8rem;font-weight:500;color:#1f2937;line-height:1.4;font-style:italic;border-left:2px solid #e5e7eb;padding-left:.5rem}.persona-action{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.375rem;border:none;background-color:#f3f4f6;color:#4b5563;font-size:.75rem;font-weight:500;border-radius:.375rem;cursor:pointer;transition:all .2s}.persona-action:hover{background-color:#e5e7eb}.personas-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid #e5e7eb;padding-top:1rem;margin-top:1rem}.personas-footer p{margin:0;font-size:.75rem;color:#6b7280}.add-to-tabs-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#8b5cf6;color:#fff;border:none;border-radius:.375rem;font-size:.8rem;font-weight:500;cursor:pointer;transition:background-color .2s}.add-to-tabs-button:hover{background-color:#7c3aed}.flags-panel{background-color:#f9fafb;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid #e5e7eb;position:relative;z-index:10}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;border-bottom:1px solid #e5e7eb;padding-bottom:.75rem}.panel-header h3{margin:0;font-size:1.25rem;color:#1f2937;display:flex;align-items:center;gap:.5rem}.header-actions{display:flex;gap:.5rem}.save-button,.cancel-button{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:.375rem;border:none;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.save-button{background-color:#10b981;color:#fff}.save-button:hover{background-color:#059669}.cancel-button{background-color:#e5e7eb;color:#4b5563}.cancel-button:hover{background-color:#d1d5db}.flag-edit-form{background-color:#fff;border-radius:.5rem;padding:1rem;border:1px solid #e5e7eb}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#4b5563;font-size:.875rem}.flag-note-textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-family:inherit;font-size:.875rem;resize:vertical}.priority-options{display:flex;gap:.75rem}.priority-option{display:flex;align-items:center;gap:.375rem;cursor:pointer}.priority-option input{position:absolute;opacity:0;width:0;height:0}.priority-label{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;background-color:#f3f4f6;transition:all .2s}.priority-option.selected .priority-label{color:#fff}.priority-label.high{color:#dc2626}.priority-option.selected .priority-label.high{background-color:#dc2626}.priority-label.medium{color:#f97316}.priority-option.selected .priority-label.medium{background-color:#f97316}.priority-label.low{color:#3b82f6}.priority-option.selected .priority-label.low{background-color:#3b82f6}.flags-list{display:flex;flex-direction:column;gap:.75rem;max-height:500px;overflow-y:auto}.flag-item{background-color:#fff;border-radius:.5rem;padding:1rem;border-left:4px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .2s}.flag-item:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.flag-item.high{border-left-color:#dc2626}.flag-item.medium{border-left-color:#f97316}.flag-item.low{border-left-color:#3b82f6}.flag-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.flag-title{display:flex;align-items:center;gap:.5rem}.flag-title h4{margin:0;font-size:.9rem;color:#1f2937}.priority-badge{display:inline-block;padding:.125rem .5rem;border-radius:9999px;font-size:.65rem;font-weight:600;text-transform:uppercase;color:#fff}.priority-badge.high{background-color:#dc2626}.priority-badge.medium{background-color:#f97316}.priority-badge.low{background-color:#3b82f6}.flag-actions{display:flex;gap:.25rem}.flag-action{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:none;background-color:#f3f4f6;color:#6b7280;cursor:pointer;transition:all .2s}.flag-action:hover{background-color:#e5e7eb;color:#1f2937}.flag-note{background-color:#f9fafb;border-radius:.375rem;padding:.75rem;margin-bottom:.75rem}.flag-note p{margin:0;font-size:.8rem;color:#4b5563;line-height:1.5;white-space:pre-line}.flag-context{font-size:.7rem;color:#6b7280;font-style:italic}.flag-icon{color:#6b7280}.flag-icon.high{color:#dc2626}.flag-icon.medium{color:#f97316}.flag-icon.low{color:#3b82f6}.no-flags{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;color:#6b7280}.no-flags p{max-width:400px;margin-top:1rem;font-size:.875rem;line-height:1.5}.insights-panel{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;border:1px solid #e5e7eb;display:flex;flex-direction:column;flex:1;overflow-y:auto}.insights-panel h3{margin-top:0;margin-bottom:1rem;font-size:1.25rem;color:#1f2937;border-bottom:1px solid #e5e7eb;padding-bottom:.5rem}.insights-list{display:flex;flex-direction:column;gap:1rem;flex:1;overflow-y:auto}.insight-card{background-color:#f9fafb;border-radius:.5rem;padding:1rem;cursor:pointer;transition:all .2s;border-left:3px solid #3B82F6;margin-bottom:.75rem}.insight-card:hover{background-color:#f3f4f6;transform:translateY(-2px)}.insight-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.insight-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background-color:#3b82f61a;border-radius:50%;color:#3b82f6}.insight-card h4{margin:0;font-size:.875rem;color:#1f2937;font-weight:600}.insight-card p{margin:0 0 .75rem;font-size:.75rem;color:#4b5563;line-height:1.5}.insight-footer{display:flex;align-items:center;justify-content:space-between}.insight-action{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;border:none;background-color:#e5e7eb;border-radius:9999px;font-size:.75rem;color:#4b5563;cursor:pointer}.insight-action:hover{background-color:#d1d5db}.insight-flag{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;border:none;background-color:#f3f4f6;color:#9ca3af;cursor:pointer;transition:all .2s}.insight-flag:hover{background-color:#e5e7eb;color:#f97316}.insight-flag.flagged{background-color:#f97316;color:#fff}.insight-summary{border-left-color:#3b82f6;background-color:#eff6ff}.insight-summary .insight-icon{background-color:#3b82f61a;color:#3b82f6}.insight-warning{border-left-color:#f59e0b;background-color:#fffbeb}.insight-warning .insight-icon{background-color:#f59e0b1a;color:#f59e0b}.insight-critical{border-left-color:#ef4444;background-color:#fef2f2}.insight-critical .insight-icon{background-color:#ef44441a;color:#ef4444}.insight-strength{border-left-color:#10b981;background-color:#ecfdf5}.insight-strength .insight-icon{background-color:#10b9811a;color:#10b981}.insight-opportunity{border-left-color:#f97316;background-color:#fff7ed}.insight-opportunity .insight-icon{background-color:#f973161a;color:#f97316}.insight-info{border-left-color:#6b7280;background-color:#f9fafb}.insight-info .insight-icon{background-color:#6b72801a;color:#6b7280}.insight-demographic{border-left-color:#8b5cf6;background-color:#f5f3ff}.insight-demographic .insight-icon{background-color:#8b5cf61a;color:#8b5cf6}.insight-metric{border-left-color:#0ea5e9;background-color:#f0f9ff}.insight-metric .insight-icon{background-color:#0ea5e91a;color:#0ea5e9}.insight-recommendation{border-left-color:#ec4899;background-color:#fdf2f8}.insight-recommendation .insight-icon{background-color:#ec48991a;color:#ec4899}.no-insights,.no-data-message{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:#6b7280;font-size:.875rem;text-align:center;padding:2rem;gap:.75rem}.ai-attribution{margin-top:auto;padding-top:.75rem;border-top:1px solid #e5e7eb;font-size:.75rem;color:#6b7280;text-align:center}.loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.25rem;color:#6b7280}.warning-banner{background-color:#fff8e1;border-left:4px solid #ffab00;padding:.75rem 1rem;margin-bottom:1.5rem;border-radius:0 4px 4px 0;display:flex;justify-content:space-between;align-items:center}.warning-message{color:#b45309;margin:0;font-size:.875rem}.retry-button{background-color:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-weight:500}.calculations-loading{display:flex;align-items:center;justify-content:center;padding:1rem;background-color:#f9fafbcc;border-radius:.5rem}.calculations-status{display:flex;align-items:center;padding:.5rem .75rem;background-color:#eff6ff;border-radius:.5rem;font-size:.75rem;color:#1e40af;margin-top:.5rem}.spinner{width:24px;height:24px;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;animation:spin 1s linear infinite;margin-right:.5rem}.spinner.small{width:16px;height:16px;border-width:2px}.term-with-tooltip{position:relative;text-decoration:underline dotted;text-decoration-color:#9ca3af;cursor:help;display:inline-block;font-size:.75rem;color:#6b7280;margin-left:.25rem}.show-more-button{width:100%;padding:.5rem;background-color:#f3f4f6;border:1px dashed #d1d5db;border-radius:.25rem;font-size:.75rem;color:#4b5563;cursor:pointer;margin:.5rem 0;text-align:center}.show-more-button:hover{background-color:#e5e7eb}.saved-tabs-section{margin-bottom:1.75rem;background-color:#f8fafc;padding:1.25rem;border-radius:.65rem;border:1px solid #e2e8f0;box-shadow:0 2px 6px #0f172a0a;transition:all .2s ease;overflow:visible}.saved-tabs-section:hover{box-shadow:0 3px 10px #0f172a0f;border-color:#cbd5e1}.saved-tabs-section h4{margin:0 0 1rem;color:#334155;font-size:.95rem;font-weight:600;border-bottom:1px solid #e2e8f0;padding-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.saved-tabs-section h4:before{content:"";display:inline-block;width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233B82F6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19 21l-7-5-7 5V5a2 2 0 0 1 2-2h10a2 2 0 0 1 2 2z'%3E%3C/path%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat}.saved-tabs-list{display:flex;flex-direction:column;gap:.6rem;max-height:350px;overflow-y:auto;padding:.25rem .5rem .5rem .25rem;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.saved-tabs-list::-webkit-scrollbar{width:4px}.saved-tabs-list::-webkit-scrollbar-track{background:transparent}.saved-tabs-list::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:4px}.saved-tabs-list .tab{flex-shrink:0;min-width:0}.component-details{background-color:#fff;border-radius:.5rem;padding:1.25rem;border:1px solid #e5e7eb;margin-bottom:1.5rem}.component-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.component-header h4{margin:0;font-size:1.25rem;font-weight:600}.component-description p{color:#4b5563;line-height:1.5;margin-bottom:1.25rem}.component-score-panel{background-color:#f9fafb;border-radius:.5rem;padding:1rem;margin-bottom:1.5rem}.score-header h5{margin-top:0;margin-bottom:.5rem;font-size:.9rem;color:#4b5563}.score-display{display:flex;align-items:center;justify-content:space-between}.score-value{font-size:2rem;font-weight:700}.score-detail p{margin:0;font-size:.8rem;color:#6b7280}.demographic-breakdown{margin-bottom:1.5rem}.demographic-breakdown h5{margin-top:0;margin-bottom:1rem;font-size:.9rem;color:#4b5563;border-bottom:1px solid #e5e7eb;padding-bottom:.5rem}.demographic-section{margin-bottom:1.25rem}.demographic-section h6{margin-top:0;margin-bottom:.5rem;font-size:.8rem;color:#6b7280}.demographic-bars{display:flex;flex-direction:column;gap:.75rem}.demo-bar-item{display:grid;grid-template-columns:1fr 2fr .5fr;align-items:center;gap:.75rem;font-size:.8rem}.demo-bar-label{color:#4b5563}.demo-bar-container{height:8px;background-color:#e5e7eb;border-radius:9999px;overflow:hidden}.demo-bar-fill{height:100%;border-radius:9999px}.demo-bar-value{text-align:right;font-weight:600;color:#1f2937}.pillar-elements-list{background-color:#fff;border-radius:.5rem;padding:1.25rem;border:1px solid #e5e7eb}.pillar-elements-list p{color:#6b7280;font-size:.875rem;font-style:italic;margin-top:0;margin-bottom:1rem}.overall-summary{background-color:#fff;border-radius:.5rem;padding:1.25rem;border:1px solid #e5e7eb}.overall-summary h3{margin-top:0;margin-bottom:1rem;color:#1f2937}.overall-summary>p{color:#4b5563;line-height:1.5;margin-bottom:1.5rem}.pillar-summary{display:grid;grid-template-columns:1fr;gap:1.25rem;margin-bottom:1.5rem}.pillar-summary-item{background-color:#f9fafb;border-radius:.5rem;padding:1rem;border:1px solid #e5e7eb}.summary-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.summary-icon{display:flex;align-items:center;justify-content:center}.summary-header h4{margin:0;font-size:1.1rem;font-weight:600}.pillar-summary-item p{color:#4b5563;font-size:.875rem;margin-bottom:1rem;line-height:1.5}.summary-score{text-align:right;font-size:1.5rem;font-weight:700;color:#1f2937}.framework-note{background-color:#f9fafb;border-radius:.5rem;padding:1rem;border:1px solid #e5e7eb}.framework-note h5{margin-top:0;margin-bottom:.75rem;color:#4b5563;font-size:.9rem}.framework-note ul{padding-left:1.5rem;margin:0}.framework-note li{color:#4b5563;font-size:.875rem;margin-bottom:.5rem;line-height:1.4}.error-state{padding:1.5rem;background-color:#fee2e2;border-left:4px solid #ef4444;border-radius:0 .25rem .25rem 0;margin-bottom:1rem;display:flex;align-items:flex-start;gap:.75rem}.error-message{color:#b91c1c;margin:0;font-size:.875rem;flex:1}.retry-button{background-color:#ef4444;color:#fff;border:none;padding:.375rem .75rem;border-radius:.25rem;cursor:pointer;font-weight:500;font-size:.75rem}.retry-button:hover{background-color:#dc2626}@media (max-width: 1024px){.pillars-layout{grid-template-columns:1fr}.pillar-cards{grid-template-columns:1fr 1fr}.filter-categories{grid-template-columns:repeat(2,1fr)}.insights-panel{height:auto}}@media (max-width: 768px){.interactive-pillars{padding:0;margin:0;overflow-x:hidden}.top-filter-section{padding:.5rem .5rem .25rem}.pillars-layout{padding:0 .5rem}.pillars-layout{display:flex;flex-direction:column;gap:.5rem}.filter-options-header{flex-direction:column;align-items:flex-start;gap:.5rem}.pillar-cards{grid-template-columns:1fr}.component-buttons{flex-direction:column}.chart-controls{flex-direction:column;align-items:flex-start;gap:1rem}.full-width-filter-panel{padding:1rem .75rem}.filter-categories-grid{grid-template-columns:1fr;gap:1rem}.filter-options-grid{max-height:none}.saved-views-row{flex-direction:column;gap:.5rem}.view-chip{width:100%}.save-filter-form{flex-direction:column;padding:1rem}.save-filter-button{width:100%}.pillar-column{flex:0 0 auto;margin:.25rem 0;width:100%;max-height:none;overflow-y:visible}.pillar-header{padding:.5rem}.pillar-components{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem}.component-card{margin-bottom:0;padding:.5rem}.component-header h4{font-size:.8rem}.component-score{font-size:.7rem}.component-icon svg{width:18px;height:18px}.results-column{padding:.5rem}.results-column-content{padding:.75rem}}.upload-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.upload-modal{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.upload-modal-header{display:flex;align-items:center;justify-content:space-between;padding:2rem 2rem 1rem;border-bottom:1px solid #f1f5f9;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px 16px 0 0}.upload-modal-header h2{margin:0;font-size:1.5rem;font-weight:600;display:flex;align-items:center;gap:.75rem}.close-modal{background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:50%;padding:.5rem;cursor:pointer;transition:all .2s ease;color:#fff;display:flex;align-items:center;justify-content:center}.close-modal:hover{background:#ffffff4d;transform:rotate(90deg)}.upload-modal-content{padding:2rem}.upload-intro{background:linear-gradient(135deg,#ebf4ff,#f0f9ff);border:1px solid #bfdbfe;border-radius:12px;padding:1.5rem;margin-bottom:2rem;position:relative}.upload-intro:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:12px 12px 0 0}.upload-intro p{margin:0;color:#1e40af;font-weight:500;line-height:1.6}.client-name-section{margin-bottom:2rem}.client-name-section h3{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.1rem;color:#374151}.client-name-input{width:100%;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;transition:all .2s ease;background:#fafafa}.client-name-input:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.files-section{display:grid;gap:2rem;margin-bottom:2rem}.upload-section{background:#fafafa;border:1px solid #e5e7eb;border-radius:16px;padding:1.5rem;transition:all .2s ease}.upload-section:hover{background:#f8fafc;border-color:#d1d5db;box-shadow:0 4px 6px -1px #0000000d}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-header h3{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1.1rem;color:#374151}.download-sample-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:#3b82f6;color:#fff;text-decoration:none;border-radius:8px;font-size:.875rem;font-weight:500;transition:all .2s ease;box-shadow:0 2px 4px #3b82f633}.download-sample-btn:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d;text-decoration:none;color:#fff}.file-requirements{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1rem;margin-bottom:1.5rem}.requirements-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:#374151;font-weight:500}.requirements-list{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.8rem;background:#f9fafb;padding:.75rem;border-radius:8px;border:1px solid #e5e7eb;color:#374151;line-height:1.4;word-break:break-all}.requirements-note{margin-top:.75rem;font-size:.875rem;color:#6b7280;font-style:italic}.upload-area{position:relative;border:2px dashed #d1d5db;border-radius:12px;padding:2rem;text-align:center;transition:all .3s ease;background:linear-gradient(135deg,#f9fafb,#fff)}.upload-area:hover{border-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#fff)}.upload-area.has-file{border-color:#10b981;background:linear-gradient(135deg,#ecfdf5,#fff)}.upload-area input[type=file]{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer}.upload-label{display:flex;flex-direction:column;align-items:center;gap:.75rem;cursor:pointer;color:#6b7280;transition:all .2s ease}.upload-area:hover .upload-label{color:#3b82f6}.upload-area.has-file .upload-label{color:#10b981}.upload-success-icon{color:#10b981!important}.file-name{font-weight:600;color:#374151}.file-size{font-size:.875rem;color:#6b7280}.upload-hint{font-size:.875rem;color:#9ca3af}.upload-progress{margin-top:1rem;display:flex;align-items:center;gap:1rem}.progress-bar{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:4px;transition:width .3s ease}.upload-errors{background:#fef2f2;border:1px solid #fecaca;border-radius:12px;padding:1rem;margin-bottom:2rem;display:flex;align-items:flex-start;gap:.75rem;color:#dc2626}.upload-errors h4{margin:0 0 .5rem;font-size:.9rem}.error-message{font-size:.875rem;margin-bottom:.25rem}.upload-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:1px solid #f1f5f9}.cancel-button{padding:.75rem 1.5rem;background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;color:#374151;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-button:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.upload-submit-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 2rem;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px -1px #0000001a}.upload-submit-button:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#7c3aed);transform:translateY(-1px);box-shadow:0 6px 10px -1px #00000026}.upload-submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.upload-modal{margin:.5rem;max-height:95vh}.upload-modal-header,.upload-modal-content{padding:1.5rem}.files-section{gap:1.5rem}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.download-sample-btn{align-self:flex-start}.upload-actions{flex-direction:column-reverse}.upload-actions button{width:100%;justify-content:center}}.heartbeat-button.applied{background-color:#dcfce7;border-color:#16a34a;color:#15803d}.reset-data-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;background-color:#fee2e2;border:1px solid #fca5a5;border-radius:.5rem;font-size:.85rem;color:#dc2626;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.reset-data-button:hover{background-color:#fecaca;transform:translateY(-1px);box-shadow:0 2px 4px #00000014}.bias-indicator{font-size:.7rem;color:#be185d;font-weight:400;padding:.2rem .5rem;background-color:#fce7f3;border-radius:.25rem;margin-left:.5rem}.bias-adjustment-indicator{color:#16a34a;font-size:.7rem;margin-left:.25rem;font-weight:700}.bias-correction-info{border:1px solid #f472b6}
