*,*::before,*::after{box-sizing:border-box!important}
html{margin:0;padding:0;height:100%;font-size:calc(16px * var(--font-zoom, 1))}
body{margin:0;padding:0;height:100%;font-family:'Source Sans 3',sans-serif;background:linear-gradient(180deg,#f0f4ff 0%,#fef9f0 50%,#f5f0ff 100%);min-height:100vh;color:#1a1a2e;-webkit-font-smoothing:antialiased;font-size:1rem}
a{color:#2563eb}
.header{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);padding:32px 20px 28px;text-align:center;position:relative;overflow:hidden}
.header::before{content:'';position:absolute;top:-60px;right:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(196,30,58,.15),transparent 70%)}
.header::after{content:'';position:absolute;bottom:-40px;left:-30px;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,rgba(65,105,225,.12),transparent 70%)}
.header .medal{font-size:2.25rem;margin-bottom:8px;position:relative;z-index:1}
.header h1{margin:0 0 4px;font-family:'Playfair Display',serif;font-weight:900;font-size:1.5rem;color:#fff;line-height:1.2;letter-spacing:-.5px;position:relative;z-index:1}
.header .city{margin:0;font-size:0.875rem;color:rgba(255,255,255,.6);font-weight:600;letter-spacing:2px;text-transform:uppercase;position:relative;z-index:1}
.badge{margin-top:16px;display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.1);backdrop-filter:blur(8px);padding:6px 14px;border-radius:20px;font-size:0.75rem;color:rgba(255,255,255,.8);position:relative;z-index:1}
.badge .dot{width:6px;height:6px;border-radius:50%;background:#10b981}
.wrap{max-width:640px;margin:0 auto;padding:20px 16px 8px}
.wrap2{max-width:640px;margin:0 auto;padding:12px 16px 24px}
.card{background:#fff;border-radius:20px;padding:22px 18px;box-shadow:0 1px 8px rgba(0,0,0,.06);border:1px solid #f0f0f5;margin-bottom:16px}
.card h2{margin:0;font-family:'Playfair Display',serif;font-weight:800;font-size:1.125rem;color:#1a1a2e;line-height:1.2}
.card .sub{font-size:0.8125rem;color:#9ca3af}
.intro h2{font-size:1.1875rem;margin-bottom:10px;line-height:1.3}
.intro p{margin:0 0 10px;font-size:0.875rem;line-height:1.65;color:#374151}
.intro .cta{margin:0;font-size:0.875rem;line-height:1.65;color:#C41E3A;font-weight:700;font-family:'Playfair Display',serif}
.accordion-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 18px;margin-top:12px;background:#fff;border:1px solid #f0f0f5;border-radius:16px;cursor:pointer;font-size:0.9375rem;font-weight:700;color:#1a1a2e;font-family:'Playfair Display',serif;transition:all .3s;box-shadow:0 1px 6px rgba(0,0,0,.05)}
.accordion-btn.open{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;border:none;border-radius:16px 16px 0 0;box-shadow:0 4px 20px rgba(26,26,46,.15)}
.accordion-btn .icon-wrap{width:28px;height:28px;border-radius:8px;background:#f0f4ff;display:flex;align-items:center;justify-content:center;font-size:0.875rem}
.accordion-btn.open .icon-wrap{background:rgba(255,255,255,.15)}
.accordion-btn .arrow{transition:transform .3s;font-size:0.6875rem;opacity:.6}
.accordion-btn.open .arrow{transform:rotate(180deg)}
.accordion-body{background:#fff;border-radius:0 0 16px 16px;padding:16px 18px 20px;border:1px solid #f0f0f5;border-top:none;font-size:0.875rem;line-height:1.6;color:#4b5563;box-shadow:0 4px 20px rgba(0,0,0,.06);display:none}
.accordion-body.open{display:block}
.info-green{display:flex;align-items:center;gap:10px;padding:12px 14px;margin-bottom:12px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:12px;border:1px solid #bbf7d0;font-size:0.8125rem;color:#166534}
.info-paper{padding:14px;background:#f8fafc;border-radius:12px;margin-bottom:12px;border:1px solid #e2e8f0}
.info-paper .title{font-family:'Playfair Display',serif;font-weight:700;font-size:0.8125rem;color:#1a1a2e;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.info-paper p{margin:0 0 10px;font-size:0.8125rem;color:#4b5563;line-height:1.55}
.place-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#fff;border-radius:8px;font-size:0.8125rem;color:#374151;border:1px solid #f1f5f9;margin-bottom:6px}
.place-item:last-child{margin-bottom:0}
.place-icon{font-size:0.9375rem;width:20px;text-align:center}
.info-warn{display:flex;align-items:center;gap:10px;padding:10px 14px;margin-bottom:12px;background:linear-gradient(135deg,#fef2f2,#fee2e2);border-radius:10px;border:1px solid #fca5a5;font-size:0.75rem;color:#991b1b;font-weight:600}
.info-blue{padding:14px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:12px;margin-bottom:12px;border:1px solid #93c5fd}
.info-blue .title{font-family:'Playfair Display',serif;font-weight:700;font-size:0.8125rem;color:#1e3a5f;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.rule-step{display:flex;align-items:flex-start;gap:8px;padding:6px 10px;background:rgba(255,255,255,.7);border-radius:8px;font-size:0.8125rem;color:#1e3a5f;line-height:1.45;margin-bottom:6px}
.rule-step:last-child{margin-bottom:0}
.step-num{width:22px;min-width:22px;height:22px;border-radius:50%;background:#2563eb;color:#fff;display:flex;align-items:center;justify-content:center;font-size:0.6875rem;font-weight:700;margin-top:1px}
.info-gold{padding:14px;background:linear-gradient(135deg,#fefce8,#fef9c3);border-radius:12px;border:1px solid #fde68a}
.info-gold .title{font-family:'Playfair Display',serif;font-weight:700;font-size:0.8125rem;color:#713f12;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.info-gold p{margin:0 0 10px;font-size:0.8125rem;color:#713f12;line-height:1.55}
.info-gold .boxes{display:flex;gap:8px;flex-wrap:wrap}
.info-gold .box{flex:1;min-width:140px;padding:8px 12px;background:rgba(255,255,255,.7);border-radius:8px;border:1px solid #fde68a}
.info-gold .box .lbl{font-size:0.6875rem;color:#a16207;font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.info-gold .box .val{font-size:0.875rem;color:#713f12;font-weight:700;margin-top:2px}
.info-gold .box .val.sm{font-size:0.75rem;font-weight:400;line-height:1.4}
.info-gold .thanks{margin:12px 0 0;font-size:0.8125rem;color:#92400e;font-weight:700;text-align:center;font-family:'Playfair Display',serif}
.cat-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.cat-header .icon{font-size:1.375rem}
.cat-counter{display:flex;align-items:center;gap:6px;margin:8px 0 14px;padding:6px 10px;background:#f8f9fc;border-radius:8px;font-size:0.75rem;color:#6b7280}
.cat-counter.full{background:#ecfdf5;color:#065f46}
.cand{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;border:2px solid transparent;border-radius:14px;background:#fff;cursor:pointer;text-align:left;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px rgba(0,0,0,.06);margin-bottom:6px;-webkit-tap-highlight-color:transparent}
.cand:last-child{margin-bottom:0}
.cand.selected{background:var(--sel-bg);border-color:var(--sel-color)}
.cand.disabled{opacity:.45;cursor:not-allowed}
.cand .avatar{width:44px;height:44px;min-width:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Playfair Display',serif;font-weight:700;font-size:1rem;letter-spacing:1px}
.cand .name{font-family:'Playfair Display',serif;font-weight:700;font-size:0.9375rem;color:#1a1a2e;line-height:1.2}
.cand .club{font-size:0.75rem;color:#6b7280;margin-top:2px;display:flex;align-items:center;gap:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cand .check{width:26px;height:26px;min-width:26px;border-radius:8px;border:2px solid #d1d5db;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.cand.selected .check{border-color:var(--sel-color);background:var(--sel-color)}
.field label{display:block;font-size:0.75rem;font-weight:600;color:#374151;margin-bottom:5px;letter-spacing:.3px}
.field label .req{color:#C41E3A}
.field input{width:100%;padding:12px 14px;border-radius:12px;border:2px solid #e5e7eb;background:#f9fafb;font-size:0.9375rem;font-family:'Source Sans 3',sans-serif;color:#1a1a2e;outline:none;transition:border-color .2s}
.field input:focus{border-color:#4169E1}
.field input.err{border-color:#ef4444;background:#fef2f2}
.field .err-msg{font-size:0.75rem;color:#ef4444;margin-top:4px;display:none}
.field .err-msg.show{display:block}
.gdpr-section{padding:16px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px;border:1px solid #e2e8f0;margin-top:12px}
.gdpr-section.err-border{border:2px solid #ef4444}
.gdpr-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.gdpr-header .title{font-family:'Playfair Display',serif;font-weight:700;font-size:0.9375rem;color:#1a1a2e}
.gdpr-header .sub{font-size:0.6875rem;color:#9ca3af}
.gdpr-card{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;background:#fff;border-radius:10px;border:1px solid #e5e7eb;margin-bottom:8px}
.gdpr-card:last-of-type{margin-bottom:0}
.gdpr-card .gi{font-size:0.875rem;margin-top:1px;width:20px;min-width:20px;text-align:center}
.gdpr-card .gt{font-size:0.75rem;font-weight:700;color:#1a1a2e;margin-bottom:2px}
.gdpr-card .gd{font-size:0.6875rem;color:#6b7280;line-height:1.45}
.gdpr-consent{display:flex;align-items:flex-start;gap:10px;padding:12px;background:#fff;border-radius:10px;border:2px solid #d1d5db;transition:border-color .2s;cursor:pointer;margin-top:14px}
.gdpr-consent.checked{border-color:#10b981}
.gdpr-consent .cb{width:22px;min-width:22px;height:22px;border-radius:6px;border:2px solid #d1d5db;display:flex;align-items:center;justify-content:center;transition:all .2s;margin-top:1px;flex-shrink:0}
.gdpr-consent.checked .cb{border-color:#10b981;background:#10b981}
.gdpr-consent .ct{font-size:0.75rem;line-height:1.5;color:#374151}
.sticky-bar{position:sticky;bottom:0;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-top:1px solid #e5e7eb;padding:12px 16px;display:flex;align-items:center;justify-content:center;gap:16px;z-index:100}
.sticky-bar .count{font-size:0.8125rem;color:#6b7280}
.sticky-bar .count strong{color:#1a1a2e}
.btn-submit{padding:12px 36px;border-radius:12px;border:none;background:#d1d5db;color:#9ca3af;font-family:'Playfair Display',serif;font-weight:700;font-size:1rem;cursor:not-allowed;letter-spacing:.5px;transition:all .3s}
.btn-submit.active{background:linear-gradient(135deg,#C41E3A,#e63946);color:#fff;cursor:pointer;box-shadow:0 4px 16px rgba(196,30,58,.3)}
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center;z-index:9999;padding:20px}
.modal-overlay.show{display:flex}
.modal{background:#fff;border-radius:20px;padding:28px 24px;max-width:380px;width:100%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.modal h3{font-family:'Playfair Display',serif;font-weight:800;font-size:1.25rem;color:#1a1a2e;margin:0 0 8px}
.modal p{font-size:0.875rem;color:#6b7280;margin:0 0 8px;line-height:1.5}
.modal .warn{font-size:0.75rem;color:#d97706;padding:6px 10px;background:#fffbeb;border-radius:8px;margin-bottom:8px}
.modal .note{font-size:0.75rem;color:#9ca3af;margin-bottom:20px}
.modal .btns{display:flex;gap:10px}
.modal .btns button{flex:1;padding:12px;border-radius:12px;font-size:0.875rem;font-weight:600;cursor:pointer;font-family:'Source Sans 3',sans-serif}
.modal .btn-back{border:1px solid #e5e7eb;background:#fff;color:#6b7280}
.modal .btn-confirm{border:none;background:linear-gradient(135deg,#C41E3A,#e63946);color:#fff;font-weight:700;box-shadow:0 4px 12px rgba(196,30,58,.3)}
.thankyou{min-height:100vh;display:none;flex-direction:column;align-items:center;justify-content:center;padding:32px;text-align:center;background:linear-gradient(180deg,#f0f4ff,#fef9f0)}
.thankyou.show{display:flex}
.thankyou .circle{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);display:flex;align-items:center;justify-content:center;margin-bottom:24px;box-shadow:0 8px 32px rgba(16,185,129,.3);animation:popIn .5s cubic-bezier(.175,.885,.32,1.275)}
@keyframes popIn{0%{transform:scale(0)}100%{transform:scale(1)}}
.thankyou h1{font-family:'Playfair Display',serif;font-weight:800;font-size:1.75rem;color:#1a1a2e;margin:0 0 12px}
.thankyou .desc{font-size:1rem;color:#6b7280;line-height:1.6;max-width:380px;margin:0 0 32px}
.thankyou .cta2{font-family:'Playfair Display',serif;font-size:1.125rem;font-weight:700;color:#C41E3A;margin:0}
.cookies-bar{position:fixed;bottom:0;left:0;right:0;z-index:9998;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:16px 20px;box-shadow:0 -4px 24px rgba(0,0,0,.2);border-top:1px solid rgba(255,255,255,.1);display:none}
.cookies-bar.show{display:block}
.cookies-inner{max-width:640px;margin:0 auto}
.cookies-bar .ct{font-family:'Playfair Display',serif;font-weight:700;font-size:0.875rem;color:#fff;margin-bottom:4px}
.cookies-bar .cd{font-size:0.75rem;line-height:1.55;color:rgba(255,255,255,.7);margin:0}
.cookies-btns{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}
.cookies-btns button{padding:8px 20px;border-radius:10px;font-size:0.75rem;font-weight:600;cursor:pointer;font-family:'Source Sans 3',sans-serif}
.cookies-btns .btn-info{border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:rgba(255,255,255,.8)}
.cookies-btns .btn-accept{border:none;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-weight:700;box-shadow:0 2px 8px rgba(16,185,129,.3)}
.alert-box{max-width:640px;margin:20px auto;padding:20px;border-radius:16px;text-align:center;width:calc(100% - 32px)}
.alert-box.closed{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fca5a5;color:#991b1b}
.alert-box.voted{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #93c5fd;color:#1e3a5f}
.alert-box .ai{font-size:2.5rem;margin-bottom:8px}
.alert-box h3{font-family:'Playfair Display',serif;font-size:1.125rem;margin-bottom:4px}
.alert-box p{font-size:0.875rem;margin:0}
.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Font size toggle button ── */
.font-toggle{position:absolute;top:12px;right:12px;z-index:2;display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:20px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.1);backdrop-filter:blur(8px);color:rgba(255,255,255,.9);cursor:pointer;font-family:'Source Sans 3',sans-serif;font-size:0.75rem;font-weight:600;transition:background .2s,border-color .2s,transform .15s}
.font-toggle:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.4)}
.font-toggle:focus-visible{outline:2px solid #fff;outline-offset:2px}
.font-toggle:active{transform:scale(.96)}
.ft-icon{font-family:'Playfair Display',serif;font-size:1rem;font-weight:800;line-height:1}
.ft-label{font-size:0.6875rem;opacity:.8}
@media (prefers-reduced-motion:reduce){.font-toggle{transition:none}.font-toggle:active{transform:none}}

/* ── Test mode strip ── */
.test-strip{background:linear-gradient(90deg,#dc2626,#ef4444);color:#fff;text-align:center;padding:6px 16px;font-size:0.75rem;font-weight:700;letter-spacing:1px;text-transform:uppercase}
