.city-card{background:var(--card-bg);box-shadow:0 2px 8px var(--shadow-sm);border-radius:8px;padding:1.5rem;transition:transform .2s,box-shadow .2s;position:relative}.city-card:hover{box-shadow:0 4px 12px var(--shadow-md);transform:translateY(-2px)}.city-header{margin-bottom:1rem}.city-header h3{color:var(--text-primary);margin-bottom:.25rem;font-size:1.5rem}.city-card-name-link{color:inherit;text-decoration:none}.city-card-name-link:hover{color:var(--accent-color)}.country{color:var(--text-secondary);font-size:.9rem}.score-badge{color:#fff;border-radius:20px;padding:.5rem .75rem;font-size:.9rem;font-weight:700;position:absolute;top:1rem;right:1rem}.match-badge{color:#fff;letter-spacing:.02em;border-radius:20px;padding:.4rem .8rem;font-size:1rem;font-weight:700;position:absolute;top:1rem;right:1rem;box-shadow:0 2px 8px #0003}.city-description{color:var(--text-secondary);margin-bottom:1rem;line-height:1.5}.city-stats{background:var(--bg-tertiary);border-left:4px solid var(--accent-color);border-radius:8px;margin:1rem 0;padding:1rem}.stats-title{color:var(--text-primary);margin:0 0 .75rem;font-size:.95rem;font-weight:600}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;display:grid}.stat-item{background:var(--bg-secondary);border-radius:6px;align-items:center;gap:.5rem;padding:.5rem;transition:transform .2s;display:flex}.stat-item:hover{transform:scale(1.02)}.stat-icon{flex-shrink:0;font-size:1.5rem}.stat-content{flex-direction:column;min-width:0;display:flex}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;overflow:hidden}.stat-value{color:var(--text-primary);font-size:.95rem;font-weight:700}.ratings-summary{border-top:1px solid var(--border-color);margin-top:1rem;padding-top:1rem}.city-card .view-toggles{gap:.5rem;margin-bottom:1rem;display:flex}.city-card .toggle-view{background:var(--bg-tertiary);color:var(--text-secondary);border:2px solid var(--border-color);cursor:pointer;border-radius:4px;flex:1;padding:.5rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s}.city-card .toggle-view:hover{background:var(--hover-bg)}.city-card .toggle-view.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.chart-container{background:var(--bg-tertiary);border-radius:6px;height:250px;margin-top:.5rem;padding:1rem}.toggle-details{background:var(--accent-color);color:#fff;border:none;border-radius:4px;width:100%;padding:.5rem 1rem;font-size:.9rem;transition:background .2s}.toggle-details:hover{background:#7c3aed}.ratings-list{flex-direction:column;gap:.5rem;margin-top:1rem;display:flex}.ratings-by-category{flex-direction:column;gap:1rem;margin-top:1rem;display:flex}.category-group{background:var(--bg-tertiary);border-radius:6px;padding:.75rem}.city-card .category-header{border-bottom:2px solid var(--border-color);color:inherit;cursor:default;background:0 0;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:0 0 .5rem;display:flex}.category-name{color:var(--accent-color);text-transform:uppercase;letter-spacing:.5px;font-size:.95rem;font-weight:600}.category-info{align-items:center;gap:.5rem;display:flex}.category-score{font-size:1rem;font-weight:700}.category-count{color:var(--text-secondary);font-size:.85rem}.category-properties{flex-direction:column;gap:.5rem;display:flex}.rating-item{background:var(--bg-secondary);border-left:3px solid var(--border-color);border-radius:4px;justify-content:space-between;align-items:center;padding:.5rem;display:flex}.property-name{color:var(--text-primary);font-size:.9rem}.rating-score{font-size:.9rem;font-weight:700}.no-ratings{color:var(--text-tertiary);text-align:center;padding:1rem;font-style:italic}.partial-votes-section{background:linear-gradient(135deg,#fff9e6 0%,#fff4d1 100%);border-left:4px solid #ff9800;border-radius:6px;margin-top:1.5rem;padding:1rem}.partial-votes-header{margin-bottom:.75rem}.partial-votes-title{color:#e65100;font-size:.9rem;font-weight:600;display:inline-block}.partial-votes-list{flex-direction:column;gap:.5rem;display:flex}.partial-vote-item{background:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;justify-content:space-between;align-items:center;padding:.5rem .75rem;font-size:.85rem;display:flex}.partial-property-name{color:var(--text-primary);font-weight:500}.partial-vote-stats{align-items:center;gap:.5rem;display:flex}.partial-vote-result{border-radius:3px;padding:.2rem .5rem;font-weight:600}.partial-vote-result.positive{color:#2e7d32;background:#e8f5e9}.partial-vote-result.negative{color:#c62828;background:#ffebee}.partial-vote-result.neutral{color:var(--text-secondary);background:var(--hover-bg)}.partial-vote-needed{color:var(--text-secondary);font-size:.8rem;font-style:italic}
.city-list h2{color:#333;margin-bottom:1.5rem}.city-grid{grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem;display:grid}.no-results{text-align:center;background:#fff;border-radius:8px;padding:3rem;box-shadow:0 2px 8px #0000001a}.no-results h3{color:#666;margin-bottom:.5rem}.no-results p{color:#999}@media (max-width:768px){.city-grid{grid-template-columns:1fr}}
.filter-panel{background:var(--card-bg);box-shadow:0 2px 8px var(--shadow-sm);border-radius:8px;flex-direction:column;padding:1rem;display:flex}.filter-panel-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.filter-panel h2{color:var(--text-primary);margin-bottom:0;font-size:1.2rem}.wizard-link-btn{background:var(--accent-color);color:#fff;white-space:nowrap;border-radius:20px;padding:.3rem .7rem;font-size:.8rem;text-decoration:none;transition:opacity .15s}.wizard-link-btn:hover{opacity:.85}.filter-section{border-bottom:1px solid var(--border-color);margin-bottom:1rem;padding-bottom:1rem}.collapsible-section{border:1px solid var(--border-color);background:var(--bg-tertiary);border-radius:6px;margin-bottom:.75rem;overflow:hidden}.section-header{cursor:pointer;background:var(--card-bg);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:.75rem;transition:background .2s;display:flex}.section-header:hover{background:var(--hover-bg)}.section-header h3{color:var(--text-primary);align-items:center;gap:.5rem;margin:0;font-size:.95rem;display:flex}.active-badge{color:var(--accent-color);font-size:.8rem;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.toggle-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:1rem;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filter-section label{color:var(--text-primary);flex-direction:column;gap:.5rem;font-weight:500;display:flex}.score-value{font-size:1.1rem;font-weight:700}.score-slider{width:100%}.live-score-slider{appearance:none;border-radius:4px;outline:none;height:8px}.live-score-slider::-webkit-slider-thumb{appearance:none;background:var(--card-bg);border:3px solid var(--accent-color);cursor:pointer;border-radius:50%;width:20px;height:20px;box-shadow:0 2px 4px #0003}.live-score-slider::-moz-range-thumb{background:var(--card-bg);border:3px solid var(--accent-color);cursor:pointer;border-radius:50%;width:20px;height:20px;box-shadow:0 2px 4px #0003}.score-range-labels{justify-content:space-between;margin-top:.25rem;font-size:.75rem;font-weight:600;display:flex}.properties-section{flex-direction:column;display:flex}.properties-section h3{color:var(--text-primary);margin-bottom:.5rem;font-size:1.1rem}.help-text{color:var(--text-secondary);margin-bottom:.75rem;font-size:.8rem}.demographic-filters{background:var(--bg-tertiary);border-radius:6px;padding:1.25rem}.demographic-filters h3{color:var(--text-primary);margin:0 0 .5rem;font-size:1.05rem}.demographic-filter-group{margin-bottom:.75rem}.demographic-filter-group:last-child{margin-bottom:0}.demographic-filter-group label{color:var(--text-secondary);margin-bottom:.4rem;font-size:.9rem;font-weight:500;display:block}.demographic-select{border:2px solid var(--border-color);background:var(--input-bg);width:100%;color:var(--text-primary);cursor:pointer;border-radius:4px;padding:.6rem;font-size:.9rem;transition:border-color .2s}.demographic-select:focus{border-color:var(--accent-color);outline:none}.boolean-preferences-section{border-bottom:1px solid var(--border-color);margin-bottom:1.5rem;padding-bottom:1.5rem}.boolean-preferences-section h3{color:var(--text-primary);margin-bottom:.5rem;font-size:1.1rem}.boolean-properties-grid{grid-template-columns:1fr;gap:.75rem;display:grid}.boolean-property-item{flex-direction:column;gap:.4rem;display:flex}.boolean-property-label{color:var(--text-primary);font-size:.85rem;font-weight:500}.boolean-buttons{gap:.5rem;display:flex}.boolean-btn{border:2px solid var(--border-color);background:var(--card-bg);cursor:pointer;color:var(--text-secondary);border-radius:6px;flex:1;padding:.4rem .3rem;font-size:.8rem;font-weight:500;transition:all .2s}.boolean-btn:hover{border-color:var(--link-color);background:var(--hover-bg);transform:translateY(-1px)}.boolean-btn.active{color:#fff;background:#8b5cf6;border-color:#8b5cf6;font-weight:600}.boolean-btn.boolean-yes.active{background:#10b981;border-color:#10b981}.boolean-btn.boolean-no.active{background:#ef4444;border-color:#ef4444}@media (min-width:768px){.boolean-properties-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1200px){.boolean-properties-grid{grid-template-columns:repeat(3,1fr)}}.section-content{background:var(--card-bg);border-top:1px solid var(--border-color);grid-template-columns:1fr;gap:.5rem;padding:.75rem;animation:.2s ease-out slideDown;display:grid}@media (min-width:768px){.section-content{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.section-content{grid-template-columns:repeat(5,1fr)}}.section-content .boolean-properties-grid{grid-column:1/-1}.section-content .help-text{grid-column:1/-1;margin-bottom:.5rem;font-size:.8rem}.category-group{border:1px solid var(--border-color);border-radius:6px;flex-direction:column;margin-bottom:0;display:flex;overflow:hidden}.filter-panel .category-header{cursor:pointer;background:var(--bg-tertiary);color:inherit;justify-content:space-between;align-items:center;padding:.4rem .5rem;transition:background .2s;display:flex}.filter-panel .category-header:hover{background:var(--hover-bg)}.category-header-always-open{background:var(--bg-tertiary);justify-content:center;align-items:center;padding:.4rem .5rem;display:flex}.category-group h4{color:var(--accent-color);text-transform:uppercase;letter-spacing:.3px;margin:0;font-size:.75rem;line-height:1.2}.category-toggle-btn{color:var(--accent-color);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:.2rem .3rem;font-size:.85rem;transition:transform .2s}.category-toggle-btn:hover{transform:scale(1.2)}.category-properties{background:var(--card-bg);padding:.5rem}.property-item{margin-bottom:.6rem}.property-item:last-child{margin-bottom:0}.property-label{justify-content:space-between;align-items:center;margin-bottom:.25rem;font-weight:400;display:flex}.property-name{color:var(--text-primary);font-size:.75rem;line-height:1.2}.weight-value{color:var(--text-secondary);white-space:nowrap;margin-left:.25rem;font-size:.7rem;font-weight:600}.weight-slider{cursor:pointer;width:100%}.filter-actions{border-top:1px solid var(--border-color);flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}.btn-apply,.btn-reset{border:none;border-radius:4px;padding:.75rem 1rem;font-size:.95rem;font-weight:500;transition:all .2s}.btn-apply{background:var(--accent-color);color:#fff}.btn-apply:hover{background:#5568d3}.btn-reset{background:var(--bg-tertiary);color:var(--text-secondary)}.btn-reset:hover{background:var(--hover-bg)}input[type=range]{appearance:none;background:var(--border-color);border-radius:3px;outline:none;height:6px}input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent-color);cursor:pointer;border-radius:50%;width:16px;height:16px}input[type=range]::-moz-range-thumb{background:var(--accent-color);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px}.filter-section-top-row{border-bottom:1px solid var(--border-color);grid-template-columns:1fr;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;display:grid}@media (min-width:768px){.filter-section-top-row{grid-template-columns:1fr auto;align-items:center}}.score-filter-compact label{color:var(--text-primary);flex-direction:column;gap:.5rem;font-size:.9rem;font-weight:500;display:flex}.demographic-filters-compact{grid-template-columns:1fr;gap:1rem;display:grid}@media (min-width:480px){.demographic-filters-compact{grid-template-columns:repeat(2,1fr)}}.filter-section-full{border-bottom:1px solid var(--border-color);margin-bottom:1rem;padding-bottom:1rem}.filter-section-full h3{color:var(--text-primary);margin:0 0 .75rem;font-size:.95rem;font-weight:600}.bool-icon{margin-right:.15rem;font-size:.9rem;font-weight:700}.boolean-mode-toggle{border:2px solid var(--border-color,#e0e0e0);border-radius:6px;gap:0;width:fit-content;margin-bottom:.75rem;display:flex;overflow:hidden}.mode-btn{background:var(--card-bg,white);color:var(--text-secondary,#666);cursor:pointer;border:none;padding:.35rem .75rem;font-size:.8rem;font-weight:500;transition:all .2s}.mode-btn:first-child{border-right:1px solid var(--border-color,#e0e0e0)}.mode-btn.active{color:#fff;background:#8b5cf6;font-weight:600}.mode-btn:hover:not(.active){background:var(--hover-bg,#f5f5f5)}
.user-profile-widget{flex-shrink:0;position:relative}.profile-toggle{background:var(--card-bg);border:1px solid var(--border-color);cursor:pointer;color:var(--text-secondary);white-space:nowrap;border-radius:20px;align-items:center;gap:.5rem;padding:.4rem .9rem;font-size:.85rem;transition:border-color .2s,color .2s;display:flex}.user-profile-widget.has-profile .profile-toggle,.profile-toggle:hover{border-color:var(--accent-color);color:var(--text-primary)}.profile-active-dot{background:var(--accent-color);border-radius:50%;flex-shrink:0;width:7px;height:7px}.profile-chevron{opacity:.6;font-size:.65rem}.profile-panel{background:var(--card-bg);border:1px solid var(--border-color);box-shadow:0 8px 24px var(--shadow-md);z-index:50;border-radius:12px;min-width:280px;max-width:340px;padding:1rem 1.25rem;position:absolute;top:calc(100% + 8px);right:0}.profile-hint{color:var(--text-secondary);margin:0 0 1rem;font-size:.8rem;line-height:1.4}.profile-section{margin-bottom:.9rem}.profile-section label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:.4rem;font-size:.75rem;font-weight:600;display:block}.profile-pills{flex-wrap:wrap;gap:.4rem;display:flex}.profile-pill{border:1.5px solid var(--border-color);background:var(--bg-secondary);cursor:pointer;color:var(--text-secondary);border-radius:14px;padding:.3rem .7rem;font-size:.82rem;transition:all .15s}.profile-pill:hover{border-color:var(--accent-color);color:var(--text-primary)}.profile-pill.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff;font-weight:600}.profile-clear{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;margin-top:.5rem;padding:0;font-size:.8rem;text-decoration:underline}.profile-clear:hover{color:var(--error-color,#e53e3e)}.personalized-badge{background:var(--accent-color);color:#fff;vertical-align:middle;opacity:.85;border-radius:6px;align-items:center;gap:.2rem;margin-left:.3rem;padding:.1rem .35rem;font-size:.65rem;display:inline-flex}
.email-request{max-width:600px;margin:0 auto;padding:2rem}.email-request-content{background:#fff;border-radius:12px;padding:2.5rem;box-shadow:0 2px 8px #0000001a}.email-request h2{color:#333;text-align:center;margin:0 0 1rem;font-size:2rem}.intro-text{color:#666;text-align:center;margin-bottom:2rem;line-height:1.6}.email-form{margin-bottom:2rem}.email-form .form-group{margin-bottom:1.5rem}.email-form .captcha-group{justify-content:center;margin-bottom:1.5rem;display:flex}.email-form label{color:#333;margin-bottom:.5rem;font-weight:500;display:block}.email-input{box-sizing:border-box;border:2px solid #e0e0e0;border-radius:4px;width:100%;padding:.75rem;font-size:1rem;transition:border-color .2s}.email-input:focus{border-color:#8b5cf6;outline:none}.email-input:disabled{cursor:not-allowed;background-color:#f5f5f5}.btn-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#8b5cf6 0%,#764ba2 100%);border:none;border-radius:4px;width:100%;padding:1rem;font-size:1.1rem;font-weight:500;transition:all .2s}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.message{text-align:center;border-radius:4px;margin-bottom:1.5rem;padding:1rem}.message.success{color:#2e7d32;background-color:#e8f5e9;border:1px solid #4caf50}.message.error{color:#c62828;background-color:#ffebee;border:1px solid #f44336}.info-box{background:#f8f9fa;border-left:4px solid #8b5cf6;border-radius:4px;padding:1.5rem}.info-box h3{color:#333;margin:0 0 .5rem;font-size:1.1rem}.info-box p{color:#666;margin:0;font-size:.95rem;line-height:1.6}
