:root{--bg: #0f0f1a;--bg-card: #1a1a2e;--bg-card-hover: #222240;--text: #e8e8f0;--text-muted: #8888aa;--accent: #6c5ce7;--accent-light: #a29bfe;--green: #00b894;--red: #e17055;--radius: 16px;--radius-sm: 10px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;-webkit-font-smoothing:antialiased}#root{min-height:100dvh}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;gap:16px}.spinner{width:40px;height:40px;border:3px solid var(--bg-card);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page{max-width:600px;margin:0 auto;padding:20px;min-height:100dvh}.home-hero{text-align:center;padding:40px 0 30px}.home-hero h1{font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--accent-light),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--text-muted);margin-top:12px;font-size:1rem;line-height:1.5}.home-content h2{font-size:1.2rem;margin-bottom:12px}.search-input{width:100%;padding:14px 18px;background:var(--bg-card);border:2px solid transparent;border-radius:var(--radius-sm);color:var(--text);font-size:1rem;outline:none;transition:border-color .2s}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--text-muted)}.commune-list{display:flex;flex-direction:column;gap:8px;margin-top:16px;max-height:50vh;overflow-y:auto;padding-right:4px}.commune-card{display:flex;align-items:center;gap:8px;padding:14px 18px;background:var(--bg-card);border:none;border-radius:var(--radius-sm);color:var(--text);font-size:1rem;cursor:pointer;text-align:left;transition:background .15s}.commune-card:hover{background:var(--bg-card-hover)}.commune-name{font-weight:600}.commune-dept{color:var(--text-muted);font-size:.9rem}.empty-state{color:var(--text-muted);text-align:center;padding:40px 20px}.vote-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.vote-header h2{flex:1;font-size:1.1rem}.counter{color:var(--text-muted);font-size:.9rem;font-variant-numeric:tabular-nums}.back-btn{background:var(--bg-card);border:none;color:var(--text-muted);padding:8px 14px;border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;transition:background .15s}.back-btn:hover{background:var(--bg-card-hover);color:var(--text)}.progress-bar{height:4px;background:var(--bg-card);border-radius:2px;margin-bottom:24px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.card-container{display:flex;align-items:center;justify-content:center;min-height:300px;padding:20px 0;touch-action:pan-y}.measure-card{background:var(--bg-card);border-radius:var(--radius);padding:32px 24px;width:100%;min-height:200px;display:flex;flex-direction:column;justify-content:center;cursor:grab;-webkit-user-select:none;user-select:none;position:relative;border:2px solid transparent;transition:border-color .15s}.measure-card.drag-right{border-color:var(--green)}.measure-card.drag-left{border-color:var(--red)}.measure-card:active{cursor:grabbing}.measure-text{font-size:1.15rem;line-height:1.6;text-align:center;font-weight:500}.drag-hints{display:flex;justify-content:space-between;margin-top:24px;font-size:.8rem;color:var(--text-muted);opacity:.5}.hint-left{color:var(--red)}.hint-right{color:var(--green)}.vote-buttons{display:flex;gap:16px;justify-content:center;padding:20px 0}.vote-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 32px;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .15s,opacity .15s}.vote-btn:active{transform:scale(.95)}.vote-icon{font-size:1.5rem}.vote-no{background:#e1705526;color:var(--red)}.vote-no:hover{background:#e1705540}.vote-yes{background:#00b89426;color:var(--green)}.vote-yes:hover{background:#00b89440}.already-voted{text-align:center;padding:60px 20px;display:flex;flex-direction:column;gap:20px;align-items:center}.btn-primary{background:var(--accent);color:#fff;border:none;padding:14px 28px;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-primary:hover{opacity:.9}.results-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.results-header h2{flex:1;font-size:1.1rem}.color-reveal{text-align:center;padding:30px 0}.color-badge{display:inline-block;padding:16px 36px;border-radius:var(--radius);font-size:1.5rem;font-weight:800}.color-label{color:#fff}.color-summary{margin-top:16px;color:var(--text-muted)}.spectrum-section{margin:30px 0}.spectrum-section h3{font-size:1rem;margin-bottom:16px}.spectrum-bar{position:relative;height:24px;border-radius:12px;overflow:visible;margin-bottom:8px}.spectrum-gradient{position:absolute;inset:0;border-radius:12px;background:linear-gradient(to right,#b71c1c,#e91e63,#ff9800,#ffc107,#ff9800,#1565c0,#0d47a1);opacity:.8}.spectrum-marker{position:absolute;top:-4px;width:32px;height:32px;background:#fff;border-radius:50%;transform:translate(-50%);box-shadow:0 2px 8px #0006;z-index:1}.spectrum-labels{display:flex;justify-content:space-between;margin-top:12px;font-size:.8rem;color:var(--text-muted)}.breakdown-section{margin:30px 0}.breakdown-section h3{font-size:1rem;margin-bottom:16px}.party-bars{display:flex;flex-direction:column;gap:14px}.party-bar-row{display:flex;flex-direction:column;gap:6px}.party-bar-label{display:flex;align-items:center;gap:8px;font-size:.85rem}.party-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.party-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.party-bar-track{height:8px;background:var(--bg-card);border-radius:4px;overflow:hidden}.party-bar-fill{height:100%;border-radius:4px;min-width:2px}.party-bar-pct{font-size:.8rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.community-section{margin:30px 0 40px}.community-section h3{font-size:1rem;margin-bottom:16px}.community-list{display:flex;flex-direction:column;gap:12px}.community-card{display:flex;gap:12px;padding:14px;background:var(--bg-card);border-radius:var(--radius-sm)}.community-rank{font-size:1.2rem;font-weight:800;color:var(--accent-light);min-width:36px;display:flex;align-items:flex-start;justify-content:center;padding-top:2px}.community-content{flex:1;min-width:0}.community-measure{font-size:.95rem;line-height:1.5;margin-bottom:8px}.community-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.party-tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.community-score{font-size:.8rem;color:var(--text-muted)}.theme-group{margin-top:8px}.theme-header{margin-bottom:16px}.theme-title{font-size:1.3rem;font-weight:700;color:var(--accent-light)}.theme-desc{color:var(--text-muted);font-size:.85rem;margin-top:4px}.theme-instruction{color:var(--text-muted);font-size:.9rem;margin-top:12px}.measures-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.measure-option{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:var(--bg-card);border:2px solid transparent;border-radius:var(--radius-sm);color:var(--text);font-size:.95rem;line-height:1.5;text-align:left;cursor:pointer;transition:border-color .15s,background .15s}.measure-option:hover{background:var(--bg-card-hover)}.measure-option.selected{border-color:var(--green);background:#00b89414}.check-indicator{width:24px;height:24px;min-width:24px;border-radius:6px;border:2px solid var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:var(--green);margin-top:1px;transition:border-color .15s,background .15s}.measure-option.selected .check-indicator{border-color:var(--green);background:#00b89433}.measure-option.disabled{opacity:.35;cursor:not-allowed}.measure-option.disabled:hover{background:var(--bg-card)}.measure-option-text{flex:1}.selection-counter{display:flex;align-items:center;gap:10px;margin-top:8px;margin-bottom:4px}.selection-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.85rem;font-weight:700;background:var(--bg-card);color:var(--text-muted);font-variant-numeric:tabular-nums;transition:background .2s,color .2s}.selection-badge.full{background:#00b89433;color:var(--green)}.selections-remaining{font-size:.8rem;color:var(--text-muted)}.theme-actions{display:flex;gap:12px;justify-content:center;padding:10px 0 30px}.btn-skip{background:var(--bg-card);color:var(--text-muted);border:none;padding:14px 24px;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-skip:hover{background:var(--bg-card-hover);color:var(--text)}.app-footer{text-align:center;padding:24px 20px;font-size:.8rem;color:var(--text-muted)}.app-footer a{color:var(--accent-light);text-decoration:none}.app-footer a:hover{text-decoration:underline}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-card-hover);border-radius:3px}@media(max-width:480px){.page{padding:16px}.home-hero h1{font-size:1.6rem}.measure-text{font-size:1.05rem}.vote-btn{padding:14px 24px}.color-badge{font-size:1.2rem;padding:14px 24px}}
