.landing-container{max-width:480px;margin:0 auto;background:#fff;height:100vh;font-family:Arial,sans-serif;display:flex;flex-direction:column;overflow:hidden}.landing-hero{width:100%;line-height:0;flex-shrink:0}.hero-banner-img{width:100%;display:block;object-fit:cover}.landing-cta-section{padding:.7rem 1rem .8rem;background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:.65rem}.cta-headline{font-size:1.25rem;font-weight:900;color:#1a1a1a;text-align:center;margin:0;letter-spacing:.5px;text-transform:uppercase}.cta-vote-btn-full{display:block;width:100%;background:#dc2626;color:#fff;border:none;border-radius:10px;padding:.75rem 1.5rem;font-size:1rem;font-weight:800;cursor:pointer;text-align:center;letter-spacing:.3px;transition:background .2s,transform .1s;box-shadow:0 4px 12px #dc26264d}.cta-vote-btn-full:hover{background:#b91c1c;transform:translateY(-1px)}.cta-vote-btn-full:active{transform:translateY(0)}.social-links{display:flex;flex-direction:row;justify-content:center;gap:.9rem}.social-link{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;color:#fff;text-decoration:none;transition:opacity .2s,transform .15s;flex-shrink:0}.social-link:hover{opacity:.85;transform:translateY(-2px) scale(1.08)}.social-icon{width:22px;height:22px}.social-youtube{background:red}.social-facebook{background:#1877f2}.social-instagram{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}.social-tiktok{background:#010101}.landing-tips{padding:.8rem 1rem 0;background:#fff;flex-shrink:0}.landing-social{padding:.55rem 1rem .8rem;background:#fff;flex-shrink:0;text-align:center}.social-title{font-size:.82rem;color:#6b7280;margin:0 0 .5rem;font-weight:500}.tips-title{font-size:.82rem;font-weight:800;color:#1a1a1a;margin:0 0 .55rem}.tips-title:before{content:"✔ ";color:#dc2626}.tip-item{margin-bottom:.5rem}.tip-number{font-size:.78rem;font-weight:700;color:#1a1a1a;display:block;margin-bottom:.1rem}.tip-item p{font-size:.74rem;color:#4b5563;margin:0;line-height:1.4}.landing-footer{width:100%;flex:1;background:#fff;min-height:0;display:flex}.landing-footer-img{width:100%;display:block;object-fit:cover;object-position:center;min-height:0}.share-card-wrapper{position:fixed;top:-9999px;left:-9999px;width:900px;z-index:-1;pointer-events:none}.share-card{width:900px;min-height:1200px;background:#fff;display:flex;flex-direction:column;font-family:Segoe UI,system-ui,-apple-system,sans-serif;overflow:hidden}.share-card-hero{width:100%;background:#dc2626;display:flex;align-items:center;justify-content:center;padding:60px 40px}.share-card-hero-text{display:flex;flex-direction:column;align-items:center}.share-card-hero-line1{color:#fff;font-size:42px;font-weight:800;margin:0;letter-spacing:8px;text-transform:uppercase;line-height:1.2;text-align:center}.share-card-hero-line2{color:#fff;font-size:80px;font-weight:900;margin:4px 0 0;letter-spacing:8px;text-transform:uppercase;line-height:1;text-align:center;text-shadow:0 3px 12px rgba(0,0,0,.15)}.share-card-hero-line3{color:#fffffff2;font-size:88px;font-weight:900;margin:8px 0 0;letter-spacing:16px;line-height:1;text-align:center;text-shadow:0 3px 12px rgba(0,0,0,.15)}.share-card-body{flex:1;padding:36px 48px 40px;display:flex;flex-direction:column;gap:20px;background:#fff}.share-card-row{background:#f8fafc;border-radius:16px;display:flex;align-items:stretch;overflow:hidden;border:2px solid #e2e8f0}.share-row-label{width:260px;flex-shrink:0;padding:28px 24px;background:#1e293b;display:flex;align-items:center}.share-category-name{color:#fff;font-size:20px;font-weight:700;text-transform:uppercase;letter-spacing:1px;line-height:1.3}.share-row-party{flex:1;display:flex;align-items:center;gap:20px;padding:24px 28px}.share-party-accent{width:6px;align-self:stretch;border-radius:3px;flex-shrink:0}.share-party-logo{width:64px;height:64px;object-fit:contain;flex-shrink:0}.share-party-logo-placeholder{width:64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:700;flex-shrink:0}.share-party-details{display:flex;flex-direction:column;gap:6px}.share-party-name{font-size:24px;font-weight:700;color:#1e293b;line-height:1.2}.share-preferential{font-size:17px;color:#64748b;font-weight:600}.share-card-footer{background:#1e293b;padding:32px 48px;display:flex;align-items:center;justify-content:space-between;margin-top:auto}.share-footer-text{color:#fff;font-size:20px;font-weight:700;letter-spacing:4px}.share-footer-url{color:#ffffff80;font-size:17px;font-weight:500;letter-spacing:1px}.voting-container{max-width:100vw;height:100vh;margin:0;background:#f5f5f5;display:flex;flex-direction:column;overflow:hidden}.voting-header{background:linear-gradient(135deg,#dc2626,#b91c1c);padding:.75rem 1.5rem;display:flex;justify-content:flex-start;align-items:center;gap:1.25rem;border-bottom:6px solid #7f1d1d;flex-shrink:0;box-shadow:0 6px 12px #0003}.header-left{flex-shrink:0}.home-logo-btn{background:none;border:none;padding:0;cursor:pointer;display:block;border-radius:8px;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 2px 8px #0000004d}.home-logo-btn:hover{transform:scale(1.05);box-shadow:0 4px 16px #0006}.home-logo-img{height:60px;width:auto;display:block;object-fit:contain;border-radius:6px}.main-title{flex:1;text-align:left}.onpe-logo img{height:50px;width:auto}.voting-header h1{font-size:2rem;font-weight:900;text-align:left;margin:0;text-transform:uppercase;color:#fff;text-shadow:3px 3px 8px rgba(0,0,0,.5);letter-spacing:1px;line-height:1.2}.voting-header .subtitle,.header-right,.election-level{display:none}.ballot-columns-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;padding:.5rem;flex:1;overflow:hidden;height:calc(100vh - 150px)}.ballot-column{background:#fff;border:2px solid #000;border-radius:4px;display:flex;flex-direction:column;overflow:hidden}.ballot-column:nth-child(1){background:#eef5ff}.ballot-column:nth-child(2){background:#fff0f0}.ballot-column:nth-child(3){background:#f0fdf4}.ballot-column:nth-child(4){background:#f0fbff}.ballot-column:nth-child(5){background:#fffdf0}.column-header{background:linear-gradient(135deg,#475569,#334155);border-bottom:2px solid #1e293b;padding:.5rem;text-align:center;flex-shrink:0;height:auto;display:flex;flex-direction:column;justify-content:flex-start;gap:.25rem}.column-header h2{font-size:1.05rem;font-weight:800;margin:0;text-transform:uppercase;line-height:1.3;color:#fff;letter-spacing:.3px}.column-header h3{font-size:.9rem;font-weight:600;margin:0;text-transform:uppercase;line-height:1.3;color:#cbd5e1}.instruction-text{font-size:.87rem;line-height:1.45;padding:.35rem .4rem;background:#e2e8f0;border:1px solid #cbd5e1;border-radius:3px;text-align:center;font-weight:500;color:#334155;word-break:break-word}.instruction-preferential{font-size:.85rem;line-height:1.45;padding:.35rem .4rem;background:#e2e8f0;border:1px solid #cbd5e1;border-radius:3px;text-align:center;font-weight:600;color:#1e293b;word-break:break-word}.instruction-hint{font-size:.82rem;line-height:1.45;padding:.3rem .4rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:3px;text-align:center;font-weight:500;color:#475569;word-break:break-word}.vote-validity-badge{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.25rem .5rem;border-radius:3px;text-align:center;width:100%;box-sizing:border-box}.validity-label{font-size:.75rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.validity-reason{font-size:.7rem;font-weight:400;text-transform:none;letter-spacing:0;line-height:1.4;opacity:.95}.vote-validity-valid{background-color:#16a34a;color:#fff;border:1px solid #15803d}.vote-validity-invalid{background-color:#dc2626;color:#fff;border:1px solid #b91c1c}.column-parties{flex:1;overflow-y:auto;overflow-x:hidden}.party-option-compact{border-bottom:1px solid #ddd;padding:.5rem;cursor:pointer;transition:all .15s;background:transparent;display:flex;align-items:center;gap:.4rem;min-height:70px}.party-option-compact:hover{background:#f9fafb}.party-option-compact.selected{background:#fef3c7;border-left:4px solid #f59e0b;border-right:4px solid #f59e0b}.party-option-compact.disabled{opacity:.4;pointer-events:none}.disabled-logo,.disabled-photo{opacity:.5;cursor:not-allowed}.party-option-compact.disabled .number-input{background:#f5f5f5;cursor:not-allowed}.party-option-compact:last-child{border-bottom:none}.party-name-compact{font-size:.98rem;font-weight:700;text-transform:uppercase;line-height:1.2;flex:1;min-width:60px;color:#000}.logo-compact{width:50px;height:50px;border:1px solid #333;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:2px;flex-shrink:0;overflow:hidden;font-size:.5rem;font-weight:700;color:#fff}.logo-compact img{width:auto;height:100%;object-fit:contain}.presidente-logo,.presidente-photo,.clickable-logo{position:relative;cursor:pointer}.presidente-logo:hover,.presidente-photo:hover,.clickable-logo:hover{transform:scale(1.05);transition:transform .15s}.vote-mark-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:10}.vote-mark-overlay:before,.vote-mark-overlay:after{content:"";position:absolute;width:141.42%;height:5px;background-color:#000;top:50%;left:50%;box-shadow:0 0 3px #fffc}.vote-mark-overlay:before{transform:translate(-50%,-50%) rotate(45deg)}.vote-mark-overlay:after{transform:translate(-50%,-50%) rotate(-45deg)}.photo-compact{width:auto;height:50px;border:1px solid #333;display:flex;align-items:center;justify-content:center;background:#fafafa;border-radius:2px;flex-shrink:0;font-size:1.25rem;opacity:.4}.presidente-photo{position:relative;border:1px solid #333;display:flex;align-items:center;justify-content:center;background:#fafafa;border-radius:2px;flex-shrink:0;cursor:pointer;overflow:hidden;width:50px;height:50px}.presidente-photo img{width:auto;height:100%;object-fit:contain;display:block}.presidente-photo span:not(.vote-mark-overlay){font-size:1.25rem;opacity:.4}.vote-boxes-compact{display:flex;gap:.3rem;flex-shrink:0}.vote-box-compact{width:50px;height:50px;border:2px solid #333;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:2px;flex-shrink:0}.party-option-compact.selected .vote-box-compact{border-color:#f59e0b;border-width:3px}.vote-mark{font-size:1.25rem;font-weight:700;color:#000}.number-input{width:100%;height:100%;border:none;background:transparent;text-align:center;font-size:.9rem;font-weight:700;color:#000;outline:none;padding:0}.number-input:focus{background:#fef3c7}.voting-actions{background:#fff;padding:.75rem 1rem;border-top:2px solid #ddd;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-shrink:0}.vote-summary p{font-size:.95rem;font-weight:600;color:#1e293b;margin:0}.actions-right{display:flex;align-items:center;gap:.75rem}.btn-submit{padding:.625rem 1.5rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;transition:all .2s;box-shadow:0 2px 8px #10b9814d;cursor:pointer}.btn-admin{padding:.3rem .7rem;background:transparent;color:#94a3b8;border:1px solid #cbd5e1;border-radius:4px;font-size:.72rem;font-weight:400;cursor:pointer;transition:all .2s;opacity:.6}.btn-admin:hover{opacity:1;color:#64748b;border-color:#94a3b8}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.btn-submit:active:not(:disabled){transform:translateY(0)}.submitted-container{display:flex;flex-direction:column;align-items:center;min-height:100vh;padding:0;background:#f1f5f9;overflow-y:auto}.submitted-card{background:#fff;border-radius:0;box-shadow:none;text-align:center;max-width:480px;width:100%;overflow:hidden}.submitted-banner{width:100%;background:#c00000;overflow:hidden;line-height:0}.submitted-banner-img{width:100%;height:auto;display:block;object-fit:cover}.submitted-success-block{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#c00000,#e81010);border-bottom:4px solid #9a0000}.submitted-check-icon{width:48px;height:48px;background:#ffffff26;border:2px solid rgba(255,255,255,.5);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.submitted-check-icon svg{width:24px;height:24px}.submitted-title-group{text-align:left}.submitted-card h2{color:#fff;font-size:1.6rem;margin:0 0 .15rem;font-weight:800;text-transform:uppercase;letter-spacing:1px}.vote-success-text{color:#ffffffd9;font-size:.875rem;margin:0;font-weight:500}.vote-summary-results{background:#f8fafc;border:none;border-radius:0;padding:1rem 1.25rem;margin:0;text-align:left}.vote-summary-results h3{font-size:1.25rem;color:#1e293b;margin-bottom:1rem;text-align:center}.results-list{display:flex;flex-direction:column;gap:.75rem}.result-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px}.result-item-card{background:#fff;border:none;border-left:4px solid #c00000;border-radius:6px;padding:.875rem 1rem;display:flex;flex-direction:column;gap:.5rem;box-shadow:0 1px 4px #00000014}.result-header h4{font-size:.75rem;color:#9a0000;text-transform:uppercase;font-weight:700;margin:0;letter-spacing:.8px}.result-subtitle{font-size:.7rem;color:#94a3b8;font-weight:400}.result-party-info{display:flex;align-items:center;gap:.75rem}.result-logo{width:44px;height:44px;object-fit:contain;border:1px solid #e2e8f0;border-radius:4px;background:#fff;padding:3px;flex-shrink:0}.result-logo-placeholder{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:4px;color:#fff;font-weight:700;font-size:.9rem;flex-shrink:0}.result-name{font-weight:700;color:#1e293b;font-size:1rem;line-height:1.3}.result-preferential{background:#fef3c7;border:1px solid #fbbf24;border-radius:6px;padding:.5rem .75rem;display:flex;flex-direction:column;gap:.25rem}.preferential-label{font-size:.75rem;color:#92400e;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.preferential-numbers{font-size:1rem;color:#78350f;font-weight:700}.result-category{display:flex;flex-direction:column;gap:.25rem;flex:1}.result-category strong{font-size:.9rem;color:#1e293b;text-transform:uppercase}.result-party{display:flex;align-items:center;gap:.5rem}.share-actions{display:flex;gap:.75rem;justify-content:center;padding:1.25rem;background:#fff;border-top:1px solid #e2e8f0;flex-wrap:wrap}.btn-share{padding:.75rem 1.25rem;border:none;border-radius:8px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem;flex:1;justify-content:center;min-width:100px}.btn-share-image{background:linear-gradient(135deg,#c00000,#e81010);color:#fff;box-shadow:0 2px 8px #c000004d}.btn-share-image:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #c0000066}.btn-share-image:disabled{opacity:.6;cursor:not-allowed}.btn-download{background:linear-gradient(135deg,#c00000,#e81010);color:#fff;box-shadow:0 4px 6px #c0000059}.btn-download:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #c0000073}.btn-download:disabled{opacity:.6;cursor:not-allowed}.btn-whatsapp{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;box-shadow:0 2px 8px #25d3664d}.btn-whatsapp:hover{transform:translateY(-2px);box-shadow:0 4px 12px #25d36666}.navigation-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-primary,.btn-secondary{display:inline-block;padding:1rem 2.5rem;margin:.5rem;border-radius:8px;font-size:1.15rem;font-weight:700;text-decoration:none;transition:all .2s;cursor:pointer}.btn-primary{background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;border:none;box-shadow:0 4px 6px #2563eb66}.btn-secondary{background:#f1f5f9;color:#1e3a8a;border:2px solid #cbd5e1}.btn-primary:hover,.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.loading{text-align:center;padding:3rem;font-size:1.25rem;color:#64748b}@media (max-width: 1600px){.column-header h2{font-size:.92rem}.column-header h3{font-size:.78rem}.party-name-compact{font-size:.85rem}.logo-compact,.presidente-photo,.vote-box-compact{width:45px;height:45px}}@media (max-width: 1400px){.ballot-columns-grid{gap:.4rem;padding:.4rem}.column-header{padding:.4rem}.party-option-compact{padding:.4rem;gap:.3rem;min-height:50px}.party-name-compact{font-size:.82rem;min-width:50px}}@media (max-width: 1200px) and (min-width: 769px){.ballot-columns-grid{grid-template-columns:repeat(3,1fr);height:auto;overflow-y:auto}.column-parties{max-height:300px}}.mobile-progress{background:#fff;padding:1rem;border-bottom:2px solid #e2e8f0}.progress-info{text-align:center;font-size:.875rem;font-weight:600;color:#475569;margin-bottom:.5rem}.progress-bar{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(135deg,#3b82f6,#1e3a8a);transition:width .3s ease}.mobile-step-view .ballot-column{display:flex;flex-direction:column;flex:1 1 0%;min-height:0;height:0}.mobile-step-view .ballot-column .column-parties{flex:1 1 0%;min-height:0;height:0;overflow-y:auto}.mobile-step-view .mobile-hidden{display:none!important}.mobile-navigation{background:#fff;padding:1rem;border-top:2px solid #ddd;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-shrink:0}.btn-nav{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;font-size:.95rem;transition:all .2s;cursor:pointer}.btn-prev{background:#f1f5f9;color:#475569;border:2px solid #cbd5e1}.btn-prev:disabled{opacity:.4;cursor:not-allowed}.btn-prev:hover:not(:disabled){background:#e2e8f0}.btn-next{background:linear-gradient(135deg,#c00000,#e81010);color:#fff;box-shadow:0 2px 8px #c0000059}.btn-next:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #c0000073}.btn-next:disabled{background:linear-gradient(135deg,#94a3b8,#64748b);box-shadow:none;cursor:not-allowed;opacity:.6}.mobile-step-info{font-size:.95rem;font-weight:600;color:#64748b}.summary-container{padding:1.5rem;flex:1;overflow-y:auto}.summary-container h2{font-size:1.5rem;color:#1e293b;margin-bottom:1.5rem;text-align:center}.summary-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.summary-item{background:#fff;border:2px solid #e2e8f0;border-radius:10px;padding:1rem}.summary-category{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.summary-category strong{font-size:.95rem;color:#1e293b;text-transform:uppercase}.summary-subtitle{font-size:.8rem;color:#64748b}.summary-selection{padding:.75rem;background:#f8fafc;border-radius:6px;border:1px solid #e2e8f0}.selected-party{font-weight:600;color:#10b981;font-size:.95rem}.no-selection{color:#94a3b8;font-style:italic;font-size:.9rem}.summary-actions{display:flex;flex-direction:column;gap:1rem;position:sticky;bottom:0;background:#fff;padding:1rem 0;border-top:2px solid #e2e8f0}.btn-back{padding:.875rem 1.75rem;background:#f1f5f9;color:#475569;border:2px solid #cbd5e1;border-radius:8px;font-weight:600;font-size:1rem;transition:all .2s;cursor:pointer}.btn-back:hover{background:#e2e8f0}.submitted-social{max-width:480px;width:100%;padding:1.25rem 1.5rem;background:#fff;text-align:center}.submitted-social-title{font-size:.85rem;color:#6b7280;margin:0 0 .75rem;font-weight:500}.submitted-social .social-links{display:flex;flex-direction:row;justify-content:center;gap:.9rem}.submitted-social .social-link{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;color:#fff;text-decoration:none;transition:opacity .2s,transform .15s;flex-shrink:0}.submitted-social .social-link:hover{opacity:.85;transform:translateY(-2px) scale(1.08)}.submitted-social .social-icon{width:22px;height:22px}.submitted-social .social-youtube{background:red}.submitted-social .social-facebook{background:#1877f2}.submitted-social .social-instagram{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}.submitted-social .social-tiktok{background:#010101}.submitted-footer{max-width:480px;width:100%;line-height:0}.submitted-footer-img{width:100%;display:block;object-fit:cover}@media (max-width: 768px){.voting-container.mobile-view{height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden}.voting-header{padding:.5rem;flex-shrink:0}.onpe-logo img{height:35px}.voting-header h1{font-size:.95rem}.mobile-progress{flex-shrink:0}.mobile-view .ballot-columns-grid.mobile-step-view{display:flex!important;flex-direction:column!important;flex:1 1 0%!important;height:0!important;min-height:0!important;overflow:hidden!important;padding:0!important;grid-template-columns:none!important}.mobile-view .ballot-column:not(.mobile-hidden){flex:1 1 0%!important;height:0!important;min-height:0!important;max-height:none!important;border:none;border-radius:0;display:flex!important;flex-direction:column!important;overflow:hidden!important}.mobile-view .ballot-column.mobile-hidden{display:none!important}.mobile-view .column-header{flex-shrink:0;padding:.3rem .5rem}.mobile-view .column-header h2{font-size:.85rem}.mobile-view .column-parties{flex:1 1 0%!important;height:0!important;min-height:0!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch}.party-option-compact{flex-wrap:nowrap;min-height:0;padding:.25rem .4rem;gap:.3rem}.party-name-compact{width:auto;margin-bottom:0;font-size:.8rem;line-height:1.15}.logo-compact,.presidente-photo,.photo-compact,.vote-box-compact{width:38px;height:38px}.mobile-navigation{flex-shrink:0}.summary-container{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column}.summary-list{flex:1;overflow-y:visible}.summary-actions{flex-shrink:0;position:sticky;bottom:0}}.results-container{max-width:1400px;margin:0 auto}.results-header{text-align:center;margin-bottom:2rem;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.results-header h2{font-size:2rem;color:#1e3a8a;margin-bottom:.5rem}.results-header p{color:#64748b;font-size:1.1rem}.category-filter{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.filter-btn{padding:.75rem 1.5rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-weight:600;color:#475569;transition:all .2s}.filter-btn:hover{border-color:#3b82f6;color:#3b82f6}.filter-btn.active{background:linear-gradient(135deg,#3b82f6,#1e3a8a);color:#fff;border-color:transparent}.results-grid{display:flex;flex-direction:column;gap:2rem}.result-section{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.result-section-header{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;padding:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.result-section-header h3{font-size:1.25rem;margin:0;font-weight:600}.total-votes{font-size:1rem;opacity:.95;font-weight:500}.no-votes{padding:3rem;text-align:center;color:#94a3b8}.results-table{padding:1.5rem}.table-row-wrapper{border-bottom:1px solid #f1f5f9}.table-row-wrapper.leader{border-left:4px solid #f59e0b;background:linear-gradient(90deg,#fef3c7 0%,transparent 100%)}.table-header,.table-row{display:grid;grid-template-columns:60px 1fr 100px 80px 200px 80px;gap:1rem;align-items:center;padding:.75rem}.table-header{font-weight:700;color:#475569;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e2e8f0;padding-bottom:1rem}.table-row{transition:all .2s}.table-row:hover{background:#f8fafc}.table-row.leader{padding-left:calc(.75rem - 4px)}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:#f1f5f9;border-radius:50%;font-weight:700;color:#475569;font-size:1rem}.table-row.leader .rank-badge{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;box-shadow:0 2px 8px #f59e0b4d}.party-cell{display:flex;align-items:center;gap:.75rem}.party-logo-small{width:40px;height:40px;border-radius:6px;object-fit:cover;flex-shrink:0}.party-logo-small.placeholder{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem}.party-name{font-weight:600;color:#1e293b;font-size:.95rem}.vote-count{font-weight:700;font-size:1.125rem;color:#1e293b}.percentage{font-weight:700;color:#3b82f6;font-size:1rem}.progress-bar{width:100%;height:24px;background:#f1f5f9;border-radius:12px;overflow:hidden;position:relative}.progress-fill{height:100%;background:#3b82f6;transition:width .5s ease;border-radius:12px;position:relative}.table-row-wrapper.leader .progress-fill{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.btn-pref-toggle{padding:.3rem .6rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;font-size:.75rem;font-weight:600;color:#475569;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-pref-toggle:hover{background:#e2e8f0;color:#1e293b}.btn-pref-toggle.expanded{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.pref-row{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;padding:.6rem .75rem .75rem 4.5rem;background:#f8fafc;border-top:1px dashed #e2e8f0}.pref-row-label{font-size:.78rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.pref-detail{display:flex;flex-wrap:wrap;gap:.4rem}.pref-chip{background:#fff;border:1px solid #cbd5e1;border-radius:20px;padding:.2rem .65rem;font-size:.8rem;color:#334155}.pref-chip strong{color:#1d4ed8}@media (max-width: 1024px){.table-header,.table-row{grid-template-columns:50px 1fr 80px 70px 150px 70px;gap:.75rem;font-size:.875rem}.party-logo-small{width:32px;height:32px}.rank-badge{width:32px;height:32px;font-size:.875rem}}@media (max-width: 768px){.table-header,.table-row{grid-template-columns:40px 1fr 60px 60px;gap:.5rem}.col-percent,.col-bar{display:none}.pref-row{padding-left:1rem}.results-header h2{font-size:1.5rem}.category-filter{gap:.5rem}.filter-btn{padding:.5rem 1rem;font-size:.875rem}}.admin-login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.admin-login-card{background:#fff;border-radius:16px;padding:2.5rem;width:100%;max-width:380px;box-shadow:0 20px 60px #0000004d}.admin-login-header{text-align:center;margin-bottom:2rem}.admin-icon{font-size:2.5rem;margin-bottom:.75rem}.admin-login-header h2{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.admin-login-header p{font-size:.9rem;color:#64748b;margin:0}.admin-login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.875rem;font-weight:600;color:#374151}.form-group input{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .2s;outline:none;color:#1e293b}.form-group input:focus{border-color:#3b82f6}.admin-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:8px;padding:.6rem 1rem;font-size:.875rem;margin:0;text-align:center}.admin-login-btn{padding:.85rem;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .1s}.admin-login-btn:hover{opacity:.92;transform:translateY(-1px)}.admin-login-btn:active{transform:translateY(0)}.admin-panel-gate{position:relative;min-height:100vh;background:#f1f5f9}.back-to-ballot{position:absolute;top:1.5rem;left:1.5rem;z-index:1100;padding:.6rem 1.25rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-weight:600;color:#475569;font-size:.9rem;cursor:pointer;transition:all .2s}.back-to-ballot:hover{border-color:#3b82f6;color:#3b82f6}.admin-panel{min-height:100vh;background:#f1f5f9;display:flex;flex-direction:column}.admin-panel-topbar{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.admin-panel-title{display:flex;align-items:center;gap:1rem}.admin-panel-title h1{font-size:1.35rem;font-weight:700;margin:0}.admin-badge{background:#fff3;border:1px solid rgba(255,255,255,.4);border-radius:6px;padding:.25rem .6rem;font-size:.75rem;font-weight:800;letter-spacing:.08em}.admin-panel-actions{display:flex;gap:.75rem}.btn-logout{padding:.55rem 1.1rem;background:#ffffff26;border:1px solid rgba(255,255,255,.35);border-radius:8px;color:#fff;font-weight:600;font-size:.875rem;cursor:pointer;transition:background .2s}.btn-logout:hover{background:#ffffff40}.btn-clear-votes{padding:.55rem 1.1rem;background:#ef444433;border:1px solid rgba(239,68,68,.5);border-radius:8px;color:#fca5a5;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s}.btn-clear-votes:hover{background:#ef444459;color:#fff}.clear-msg{text-align:center;padding:.75rem 1.5rem;font-weight:600;font-size:.9rem}.clear-msg--success{background:#dcfce7;color:#166534}.clear-msg--error{background:#fee2e2;color:#991b1b}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:2000}.confirm-dialog{background:#fff;border-radius:12px;padding:2rem;max-width:420px;width:90%;box-shadow:0 20px 60px #00000040}.confirm-dialog h2{font-size:1.15rem;font-weight:700;color:#1e293b;margin:0 0 .75rem}.confirm-dialog p{font-size:.9rem;color:#475569;line-height:1.5;margin:0 0 1.5rem}.confirm-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-cancel{padding:.6rem 1.25rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;color:#475569;font-weight:600;font-size:.875rem;cursor:pointer;transition:background .2s}.btn-cancel:hover:not(:disabled){background:#e2e8f0}.btn-confirm-delete{padding:.6rem 1.25rem;background:#ef4444;border:none;border-radius:8px;color:#fff;font-weight:600;font-size:.875rem;cursor:pointer;transition:background .2s}.btn-confirm-delete:hover:not(:disabled){background:#dc2626}.btn-confirm-delete:disabled,.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.admin-results-wrapper{flex:1;padding:2rem;max-width:1400px;width:100%;margin:0 auto}@media (max-width: 768px){.admin-panel-topbar{flex-direction:column;align-items:flex-start;padding:1rem}.admin-results-wrapper{padding:1rem}}.app{min-height:100vh;display:flex;flex-direction:column}.navbar{display:none}.nav-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.nav-content h1{font-size:1.5rem;font-weight:700;margin:0}.nav-links{display:flex;gap:1.5rem}.nav-link{color:#fff;text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:background-color .2s}.nav-link:hover{background-color:#ffffff1a}.main-content{flex:1;padding:0;max-width:none;margin:0;width:100%;height:100vh}@media (max-width: 768px){.nav-content{flex-direction:column;align-items:flex-start}.nav-content h1{font-size:1.25rem}.main-content{padding:1rem}}*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}button{cursor:pointer;font-family:inherit}button:disabled{cursor:not-allowed;opacity:.6}
