:root{font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;font-weight:400;color-scheme:light;color:#2d3748;background-color:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:#f5f7fa}html,body,#root{height:100%}a{font-weight:500;color:#667eea;text-decoration:inherit;transition:color .3s ease}a:hover{color:#764ba2}button{border-radius:8px;border:none;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f9f9f9;cursor:pointer;transition:all .3s ease}button:hover{border-color:#667eea}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#764ba2,#667eea)}.navbar{background:linear-gradient(135deg,#667eea,#764ba2);padding:1.2rem 0;box-shadow:0 8px 32px #667eea4d;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1)}.navbar-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:0 2rem}.navbar-logo{font-size:1.6rem;font-weight:700;color:#fff;text-decoration:none;letter-spacing:.5px;background:linear-gradient(135deg,#fff,#f0f0f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:transform .3s ease}.navbar-logo:hover{transform:scale(1.05)}.nav-menu{display:flex;list-style:none;gap:2.5rem;margin:0;padding:0}.nav-item{position:relative}.nav-link{color:#f0f0f0;text-decoration:none;font-weight:600;font-size:.95rem;transition:all .3s ease;padding:.6rem 1rem;border-radius:6px;position:relative}.nav-link:before{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background-color:#fff;transition:all .3s ease;transform:translate(-50%)}.nav-link:hover{color:#fff;background-color:#ffffff1a}.nav-link:hover:before{width:100%;left:50%}.app-wrapper{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.main-content{flex:1;padding:3rem 0;background:linear-gradient(135deg,#f5f7fa,#e9eef5)}.container{max-width:1200px;margin:0 auto;padding:0 2rem}h1{color:#2d3748;margin-bottom:2.5rem;font-size:2.5rem;text-align:center;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{color:#2d3748;margin-bottom:1.5rem;font-size:1.6rem;font-weight:700;position:relative;padding-bottom:.5rem}h2:after{content:"";position:absolute;bottom:0;left:0;width:60px;height:4px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px}h3{color:#2d3748;margin:.5rem 0;font-weight:600}.btn{padding:.85rem 2rem;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);text-decoration:none;display:inline-block;text-align:center;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff80;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn:active:before{width:300px;height:300px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea66}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 25px #667eea99}.btn-secondary{background:linear-gradient(135deg,#a8a8a8,#7f7f7f);color:#fff;box-shadow:0 4px 15px #8080804d}.btn-secondary:hover{transform:translateY(-3px);box-shadow:0 8px 25px #80808080}.btn-success{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;box-shadow:0 4px 15px #11998e66}.btn-success:hover{transform:translateY(-3px);box-shadow:0 8px 25px #11998e99}.btn-danger{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;box-shadow:0 4px 15px #f5576c66}.btn-danger:hover{transform:translateY(-3px);box-shadow:0 8px 25px #f5576c99}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.form-input,.form-select{width:100%;padding:.9rem 1.2rem;margin:.75rem 0;border:2px solid #e0e0e0;border-radius:10px;font-size:1rem;font-family:inherit;background-color:#fff;transition:all .3s ease}.form-input:focus,.form-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;transform:translateY(-2px)}p{color:#555;line-height:1.6}.info-message{background:linear-gradient(135deg,#d5f4e6,#c8f1e4);color:#11998e;padding:1.5rem;border-radius:10px;text-align:center;margin-top:1rem;font-weight:500;box-shadow:0 4px 15px #11998e33}.success-message{background:linear-gradient(135deg,#d5f4e6,#c8f1e4);padding:3rem 2rem;border-radius:12px;text-align:center;min-height:300px;display:flex;flex-direction:column;justify-content:center;align-items:center;box-shadow:0 8px 32px #11998e33}.success-message h2{color:#11998e}@media(max-width:768px){.navbar-container,.nav-menu{flex-direction:column;gap:1rem}.container{padding:0 1rem}h1{font-size:1.8rem}.btn{width:100%;margin-bottom:.5rem}}.active-elections-page{min-height:calc(100vh - 80px)}.active-elections-page .hero-section{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:24px;padding:3rem;margin-bottom:3rem;display:flex;justify-content:space-between;align-items:center;position:relative;overflow:hidden}.active-elections-page .hero-section:before{content:"";position:absolute;top:-50%;right:-20%;width:400px;height:400px;background:#ffffff1a;border-radius:50%}.active-elections-page .hero-section:after{content:"";position:absolute;bottom:-30%;left:10%;width:200px;height:200px;background:#ffffff0d;border-radius:50%}.active-elections-page .hero-content{position:relative;z-index:1}.active-elections-page .hero-content h1{color:#fff;font-size:2.5rem;margin:0 0 .5rem;font-weight:700}.active-elections-page .hero-content h1:after{display:none}.active-elections-page .hero-content p{color:#ffffffe6;font-size:1.1rem;margin:0}.active-elections-page .hero-stats{position:relative;z-index:1}.active-elections-page .hero-stat{background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:1.5rem 2.5rem;text-align:center;border:1px solid rgba(255,255,255,.3)}.active-elections-page .hero-stat .stat-number{display:block;font-size:3rem;font-weight:800;color:#fff;line-height:1}.active-elections-page .hero-stat .stat-text{display:block;color:#ffffffe6;font-size:.9rem;text-transform:uppercase;letter-spacing:1px;margin-top:.5rem}.active-elections-page .elections-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:2rem}.active-elections-page .election-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 24px #00000014;transition:all .3s ease;border:1px solid #e2e8f0;display:flex;flex-direction:column}.active-elections-page .election-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px #667eea33;border-color:#667eea}.active-elections-page .card-header{background:linear-gradient(135deg,#f8f9ff,#eef1ff);padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e2e8f0}.active-elections-page .live-badge{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;padding:.4rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.active-elections-page .live-dot{width:8px;height:8px;background:#fff;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.active-elections-page .election-code{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.4rem 1rem;border-radius:8px;font-size:.8rem;font-weight:700;letter-spacing:.5px}.active-elections-page .card-body{padding:1.5rem;flex:1}.active-elections-page .election-title{font-size:1.3rem;color:#2d3748;margin:0 0 1.5rem;font-weight:600;line-height:1.4}.active-elections-page .election-title:after{display:none}.active-elections-page .candidates-section{background:#f8f9ff;border-radius:12px;padding:1rem}.active-elections-page .section-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e2e8f0}.active-elections-page .section-icon{font-size:1.1rem}.active-elections-page .section-title{font-weight:600;color:#4a5568;font-size:.9rem}.active-elections-page .candidates-list{display:flex;flex-direction:column;gap:.75rem}.active-elections-page .candidate-item{display:flex;align-items:center;gap:.75rem;background:#fff;padding:.75rem 1rem;border-radius:10px;border:1px solid #e2e8f0;transition:all .2s ease}.active-elections-page .candidate-item:hover{border-color:#667eea;transform:translate(4px)}.active-elections-page .candidate-avatar{width:36px;height:36px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}.active-elections-page .candidate-name{font-weight:500;color:#2d3748;font-size:.95rem}.active-elections-page .card-footer{padding:1.5rem;border-top:1px solid #e2e8f0}.active-elections-page .vote-button{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.active-elections-page .vote-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.active-elections-page .vote-button:hover:before{left:100%}.active-elections-page .vote-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.active-elections-page .vote-button .btn-icon{font-size:1.2rem}.active-elections-page .vote-button .btn-arrow{opacity:0;transform:translate(-10px);transition:all .3s ease}.active-elections-page .vote-button:hover .btn-arrow{opacity:1;transform:translate(0)}.active-elections-page .empty-state{text-align:center;padding:5rem 2rem;background:#fff;border-radius:20px;box-shadow:0 4px 24px #0000000f}.active-elections-page .empty-icon{font-size:5rem;margin-bottom:1.5rem}.active-elections-page .empty-state h2{font-size:1.5rem;color:#2d3748;margin:0 0 .5rem}.active-elections-page .empty-state h2:after{display:none}.active-elections-page .empty-state p{color:#718096;font-size:1.1rem;margin:0}.active-elections-page .loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:2rem}.active-elections-page .spinner{width:50px;height:50px;border:4px solid rgba(102,126,234,.2);border-top:4px solid #667eea;border-radius:50%;animation:spinActive 1s linear infinite}@keyframes spinActive{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.active-elections-page .loading-spinner p{color:#667eea;font-weight:600;font-size:1.1rem}.active-elections-page .error-message{background:linear-gradient(135deg,#fed7d7,#feb2b2);border-left:4px solid #e53e3e;color:#c53030;padding:1.25rem 1.5rem;border-radius:12px;margin-bottom:2rem;display:flex;align-items:center;gap:.75rem}.active-elections-page .error-icon{font-size:1.25rem}.active-elections-page .error-message p{margin:0;font-weight:500}.active-elections-page .modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeInModal .2s ease}@keyframes fadeInModal{0%{opacity:0}to{opacity:1}}.active-elections-page .modal-content{background:#fff;border-radius:20px;box-shadow:0 25px 80px #0000004d;position:relative;animation:slideInModal .3s ease;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}@keyframes slideInModal{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.active-elections-page .modal-close{position:absolute;top:1rem;right:1rem;width:28px;height:28px;border:none;background:#ff5f57;border-radius:50%;font-size:14px;line-height:1;cursor:pointer;z-index:10;padding:0;box-shadow:0 0 0 1px #0000001a;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600}.active-elections-page .modal-close:hover{background:#ff3b30}.active-elections-page .modal-header{padding:2rem 2rem 1.5rem;text-align:center;border-bottom:1px solid #e2e8f0}.active-elections-page .modal-header h2{font-size:1.5rem;color:#2d3748;margin:0 0 .5rem}.active-elections-page .modal-header h2:after{display:none}.active-elections-page .modal-header p{color:#718096;margin:0;font-size:.95rem}.active-elections-page .modal-loading{padding:4rem 2rem;text-align:center}.active-elections-page .modal-loading .spinner{margin:0 auto 1rem}.active-elections-page .modal-loading p{color:#667eea;font-weight:500}.active-elections-page .voting-modal{width:95%;max-width:750px}.active-elections-page .voting-form{padding:2rem 10%;overflow-y:auto;max-height:calc(90vh - 120px)}.active-elections-page .form-section{margin-bottom:1.75rem}.active-elections-page .form-label{display:block;font-weight:600;color:#4a5568;margin-bottom:.85rem;font-size:1rem}.active-elections-page .candidate-options{display:flex;flex-direction:column;gap:1rem}.active-elections-page .candidate-option{position:relative;cursor:pointer}.active-elections-page .candidate-option input{position:absolute;opacity:0;pointer-events:none}.active-elections-page .candidate-option .option-content{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:#f8f9ff;border:2px solid #e2e8f0;border-radius:14px;transition:all .2s ease}.active-elections-page .candidate-option:hover .option-content{border-color:#667eea;background:#eef1ff}.active-elections-page .candidate-option.selected .option-content{border-color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2)}.active-elections-page .candidate-option .option-avatar{width:48px;height:48px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;flex-shrink:0}.active-elections-page .candidate-option.selected .option-avatar{background:#fff;color:#667eea}.active-elections-page .candidate-option .option-name{flex:1;font-weight:600;color:#2d3748;font-size:1.1rem;transition:all .2s ease}.active-elections-page .candidate-option.selected .option-name{color:#fff}.active-elections-page .form-select,.active-elections-page .form-input{width:100%;padding:1.1rem 1.25rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1.05rem;transition:all .2s ease;box-sizing:border-box;background:#fff}.active-elections-page .form-select:focus,.active-elections-page .form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea26}.active-elections-page .form-select:disabled{background:#f5f5f5;cursor:not-allowed;color:#a0aec0}.active-elections-page .form-hint{display:block;font-size:.85rem;color:#a0aec0;margin-top:.6rem}.active-elections-page .submit-button{width:100%;padding:1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:14px;font-size:1.1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .3s ease;margin-top:1rem}.active-elections-page .submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.active-elections-page .submit-button:disabled{opacity:.6;cursor:not-allowed}.active-elections-page .btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spinActive .8s linear infinite}.active-elections-page .result-modal{width:100%;max-width:400px}.active-elections-page .result-content{padding:3rem 2rem;text-align:center}.active-elections-page .result-icon{font-size:4rem;margin-bottom:1.5rem}.active-elections-page .result-content h2{font-size:1.8rem;margin:0 0 1rem}.active-elections-page .result-content h2:after{display:none}.active-elections-page .result-content.success h2{color:#38a169}.active-elections-page .result-content.error h2{color:#e53e3e}.active-elections-page .result-content p{color:#718096;font-size:1rem;margin:0 0 2rem;line-height:1.5}.active-elections-page .result-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 3rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.active-elections-page .result-content.success .result-btn{background:linear-gradient(135deg,#48bb78,#38a169)}.active-elections-page .result-content.error .result-btn{background:linear-gradient(135deg,#e53e3e,#c53030)}.active-elections-page .result-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0003}@media(max-width:900px){.active-elections-page .hero-section{flex-direction:column;text-align:center;gap:2rem;padding:2rem}.active-elections-page .hero-content h1{font-size:2rem}.active-elections-page .elections-grid{grid-template-columns:1fr}.active-elections-page .modal-overlay{padding:.5rem;align-items:flex-end}.active-elections-page .modal-content{max-height:95vh;border-radius:20px 20px 0 0;margin-bottom:0}.active-elections-page .voting-modal{max-width:100%}.active-elections-page .voting-form{padding:1.5rem}.active-elections-page .modal-header{padding:1.5rem 1.5rem 1rem}.active-elections-page .modal-header h2{font-size:1.3rem}}@media(max-width:480px){.active-elections-page .hero-section{padding:1.5rem}.active-elections-page .hero-content h1{font-size:1.6rem}.active-elections-page .hero-stat{padding:1rem 1.5rem}.active-elections-page .hero-stat .stat-number{font-size:2.5rem}.active-elections-page .card-header{flex-direction:column;gap:.75rem;align-items:flex-start}.active-elections-page .election-title{font-size:1.1rem}.active-elections-page .vote-button{padding:.9rem 1.5rem;font-size:1rem}.active-elections-page .modal-overlay{padding:0}.active-elections-page .modal-content{border-radius:16px 16px 0 0}.active-elections-page .voting-form{padding:1rem 1.25rem 1.5rem}.active-elections-page .form-section{margin-bottom:1.25rem}.active-elections-page .form-label{font-size:.9rem;margin-bottom:.5rem}.active-elections-page .candidate-options{gap:.5rem}.active-elections-page .candidate-option .option-content{padding:.85rem}.active-elections-page .candidate-option .option-avatar{width:36px;height:36px;font-size:.9rem}.active-elections-page .candidate-option .option-name{font-size:.95rem}.active-elections-page .form-select,.active-elections-page .form-input{padding:.8rem 1rem;font-size:16px}.active-elections-page .submit-button{padding:.9rem;font-size:1rem}.active-elections-page .result-modal{max-width:100%}.active-elections-page .result-content{padding:2.5rem 1.5rem}.active-elections-page .result-icon{font-size:3rem;margin-bottom:1rem}.active-elections-page .result-content h2{font-size:1.5rem}.active-elections-page .result-content p{font-size:.95rem}.active-elections-page .result-btn{width:100%;padding:.9rem}}.all-elections-page .page-header{text-align:center;margin-bottom:3rem}.all-elections-page .page-header h1{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:2.5rem;margin-bottom:.5rem}.all-elections-page .page-header h1:after{display:none}.all-elections-page .page-subtitle{color:#718096;font-size:1.1rem;margin:0}.all-elections-page .elections-grid{display:flex;flex-direction:column;gap:1rem;margin-bottom:3rem}.all-elections-page .election-card{background:#fff;border-radius:16px;padding:0;box-shadow:0 4px 20px #00000014;transition:all .3s ease;overflow:hidden;border:2px solid transparent;cursor:pointer}.all-elections-page .election-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px #667eea33;border-color:#667eea}.all-elections-page .election-card.selected{border-color:#667eea;box-shadow:0 8px 30px #667eea40;border-radius:16px 16px 0 0}.all-elections-page .election-card.inactive{opacity:.9}.all-elections-page .election-card.inactive:hover{border-color:#a0aec0;box-shadow:0 8px 30px #0000001f}.all-elections-page .election-card.inactive.selected{border-color:#718096}.all-elections-page .card-content{display:flex;align-items:stretch;position:relative}.all-elections-page .status-side{width:100px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem 1rem;gap:.8rem}.all-elections-page .status-side.active{background:linear-gradient(135deg,#667eea,#764ba2)}.all-elections-page .status-side.inactive{background:linear-gradient(135deg,#718096,#4a5568)}.all-elections-page .status-indicator{width:16px;height:16px;border-radius:50%;border:3px solid rgba(255,255,255,.5)}.all-elections-page .status-indicator.active{background:#48bb78;box-shadow:0 0 12px #48bb7899}.all-elections-page .status-indicator.inactive{background:#fc8181;box-shadow:0 0 12px #fc818199}.all-elections-page .status-text{color:#fff;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}.all-elections-page .election-code-badge{background:#fff3;color:#fff;padding:.4rem .8rem;border-radius:6px;font-size:.7rem;font-weight:700;text-align:center;line-height:1.2}.all-elections-page .main-content-area{flex:1;padding:1.5rem 2rem;display:flex;flex-direction:column;justify-content:center}.all-elections-page .election-title{font-size:1.25rem;color:#2d3748;margin:0 0 .5rem;font-weight:600;line-height:1.4}.all-elections-page .election-title:after{display:none}.all-elections-page .election-dates-inline{display:flex;gap:2rem;font-size:.85rem;color:#718096}.all-elections-page .date-item{display:flex;align-items:center;gap:.4rem}.all-elections-page .date-item strong{color:#4a5568}.all-elections-page .stats-section{display:flex;gap:0;border-left:1px solid #e2e8f0}.all-elections-page .stat-box{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem 2rem;min-width:100px;border-right:1px solid #e2e8f0;background:#fafbfc}.all-elections-page .stat-box:last-child{border-right:none}.all-elections-page .stat-number{font-size:1.75rem;font-weight:700;color:#667eea;line-height:1}.all-elections-page .stat-label{font-size:.7rem;color:#a0aec0;text-transform:uppercase;letter-spacing:.5px;margin-top:.4rem;font-weight:600}.all-elections-page .click-indicator{width:50px;min-width:50px;display:flex;align-items:center;justify-content:center;background:#f8f9ff;border-left:1px solid #e2e8f0;color:#a0aec0;font-size:1rem;transition:all .3s ease}.all-elections-page .election-card:hover .click-indicator,.all-elections-page .election-card.selected .click-indicator{color:#667eea;background:#eef1ff}.all-elections-page .action-panel{background:linear-gradient(135deg,#f8f9ff,#eef1ff);border:2px solid #667eea;border-top:none;border-radius:0 0 16px 16px;padding:1.5rem;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.all-elections-page .action-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.all-elections-page .action-btn{display:flex;align-items:center;gap:.6rem;padding:.9rem 1.8rem;border:none;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000001a}.all-elections-page .action-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.all-elections-page .action-btn:disabled{opacity:.6;cursor:not-allowed}.all-elections-page .action-btn .btn-icon{font-size:1.1rem}.all-elections-page .action-btn.activate{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff}.all-elections-page .action-btn.activate:hover:not(:disabled){box-shadow:0 6px 20px #48bb7866}.all-elections-page .action-btn.deactivate{background:linear-gradient(135deg,#ed8936,#dd6b20);color:#fff}.all-elections-page .action-btn.deactivate:hover:not(:disabled){box-shadow:0 6px 20px #ed893666}.all-elections-page .action-btn.end{background:linear-gradient(135deg,#e53e3e,#c53030);color:#fff}.all-elections-page .action-btn.end:hover:not(:disabled){box-shadow:0 6px 20px #e53e3e66}.all-elections-page .action-btn.results{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.all-elections-page .action-btn.results:hover:not(:disabled){box-shadow:0 6px 20px #667eea66}.all-elections-page .action-loading{display:flex;align-items:center;justify-content:center;gap:.8rem;margin-top:1rem;color:#667eea;font-weight:500}.all-elections-page .mini-spinner{width:20px;height:20px;border:3px solid rgba(102,126,234,.2);border-top:3px solid #667eea;border-radius:50%;animation:allElectionsSpin .8s linear infinite}.all-elections-page .elections-summary{display:flex;justify-content:center;gap:4rem;padding:2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;margin-top:2rem}.all-elections-page .summary-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.all-elections-page .summary-count{font-size:3rem;font-weight:800;color:#fff;line-height:1}.all-elections-page .summary-count.active{color:#9ae6b4}.all-elections-page .summary-count.inactive{color:#feb2b2}.all-elections-page .summary-label{color:#ffffffe6;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px}.all-elections-page .empty-state{text-align:center;padding:5rem 2rem;background:linear-gradient(135deg,#f8f9ff,#f0f4ff);border-radius:16px;margin:2rem 0}.all-elections-page .empty-icon{font-size:4rem;margin-bottom:1.5rem}.all-elections-page .empty-state p{color:#718096;font-size:1.2rem;margin:0}.all-elections-page .loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:2rem}.all-elections-page .spinner{width:50px;height:50px;border:4px solid rgba(102,126,234,.2);border-top:4px solid #667eea;border-radius:50%;animation:allElectionsSpin 1s linear infinite}@keyframes allElectionsSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.all-elections-page .loading-spinner p{color:#667eea;font-weight:600;font-size:1.1rem}.all-elections-page .error-message{background:linear-gradient(135deg,#fed7d7,#feb2b2);border-left:4px solid #e53e3e;color:#c53030;padding:1.5rem;border-radius:12px;margin-bottom:2rem}.all-elections-page .error-message p{margin:0;font-weight:500}@media(max-width:900px){.all-elections-page .card-content{flex-direction:column}.all-elections-page .status-side{width:100%;flex-direction:row;padding:1rem 1.5rem;justify-content:flex-start;gap:1rem}.all-elections-page .stats-section{border-left:none;border-top:1px solid #e2e8f0}.all-elections-page .stat-box{flex:1;padding:1rem;min-width:auto}.all-elections-page .stat-number{font-size:1.5rem}.all-elections-page .election-dates-inline{flex-direction:column;gap:.5rem}.all-elections-page .elections-summary{flex-direction:column;gap:2rem;padding:2rem}.all-elections-page .summary-count{font-size:2.5rem}.all-elections-page .page-header h1{font-size:2rem}.all-elections-page .click-indicator{display:none}.all-elections-page .action-buttons{flex-direction:column}.all-elections-page .action-btn{width:100%;justify-content:center}}@media(max-width:480px){.all-elections-page .main-content-area{padding:1rem 1.25rem}.all-elections-page .election-title{font-size:1.1rem}.all-elections-page .stat-box{padding:.8rem .5rem}.all-elections-page .stat-number{font-size:1.25rem}.all-elections-page .stat-label{font-size:.6rem}.all-elections-page .action-panel{padding:1rem}.all-elections-page .action-btn{padding:.8rem 1.2rem;font-size:.9rem}}.all-elections-page .modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.all-elections-page .modal-content{background:#fff;border-radius:20px;box-shadow:0 25px 80px #0000004d;position:relative;animation:modalSlideIn .3s ease;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.all-elections-page .modal-close{position:absolute;top:1rem;right:1rem;width:28px;height:28px;border:none;background:#ff5f57;border-radius:50%;font-size:14px;line-height:1;cursor:pointer;z-index:10;padding:0;box-shadow:0 0 0 1px #0000001a;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600}.all-elections-page .modal-close:hover{background:#ff3b30}.all-elections-page .modal-header{padding:2.5rem 2rem 1.5rem;text-align:center;border-bottom:1px solid #e2e8f0}.all-elections-page .modal-header h2{font-size:1.5rem;color:#2d3748;margin:0 0 .5rem}.all-elections-page .modal-header h2:after{display:none}.all-elections-page .modal-header p{color:#718096;margin:0;font-size:.95rem}.all-elections-page .login-modal{width:100%;max-width:420px}.all-elections-page .login-form{padding:2rem}.all-elections-page .form-group{margin-bottom:1.5rem}.all-elections-page .form-group label{display:block;font-weight:600;color:#4a5568;margin-bottom:.5rem;font-size:.9rem}.all-elections-page .form-group input{width:100%;padding:.9rem 1rem;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;transition:all .2s ease;box-sizing:border-box}.all-elections-page .form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.all-elections-page .form-group input::placeholder{color:#a0aec0}.all-elections-page .login-error{background:linear-gradient(135deg,#fed7d7,#feb2b2);color:#c53030;padding:1rem;border-radius:10px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;font-weight:500;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.all-elections-page .login-submit{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.6rem;transition:all .3s ease}.all-elections-page .login-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.all-elections-page .login-submit:disabled{opacity:.7;cursor:not-allowed}.all-elections-page .btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:allElectionsSpin .8s linear infinite}.all-elections-page .results-modal{width:100%;max-width:900px}.all-elections-page .results-content{padding:2rem;overflow-y:auto;max-height:calc(90vh - 120px)}.all-elections-page .results-summary{display:flex;gap:2rem;justify-content:center;margin-bottom:2rem}.all-elections-page .summary-stat{background:linear-gradient(135deg,#667eea,#764ba2);padding:1.5rem 3rem;border-radius:16px;text-align:center;color:#fff}.all-elections-page .summary-stat .stat-value{font-size:2.5rem;font-weight:800;display:block;line-height:1}.all-elections-page .summary-stat .stat-title{font-size:.85rem;opacity:.9;text-transform:uppercase;letter-spacing:1px;margin-top:.5rem;display:block}.all-elections-page .candidate-results{margin-bottom:2rem}.all-elections-page .candidate-results h3{font-size:1.1rem;color:#2d3748;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.all-elections-page .candidate-results h3:after{display:none}.all-elections-page .candidate-bars{display:flex;flex-direction:column;gap:1rem}.all-elections-page .candidate-bar{background:#f8f9ff;border-radius:12px;padding:1rem 1.5rem;border:1px solid #e2e8f0}.all-elections-page .candidate-bar.winner{background:linear-gradient(135deg,#f0fff4,#c6f6d5);border-color:#48bb78}.all-elections-page .candidate-info{display:flex;align-items:center;gap:1rem;margin-bottom:.8rem}.all-elections-page .candidate-rank{width:32px;height:32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}.all-elections-page .candidate-bar.winner .candidate-rank{background:linear-gradient(135deg,#48bb78,#38a169)}.all-elections-page .candidate-name{flex:1;font-weight:600;color:#2d3748;font-size:1.05rem}.all-elections-page .candidate-votes{font-weight:700;color:#667eea;font-size:1.1rem}.all-elections-page .candidate-bar.winner .candidate-votes{color:#38a169}.all-elections-page .candidate-percentage{background:#667eea;color:#fff;padding:.3rem .8rem;border-radius:20px;font-weight:700;font-size:.9rem}.all-elections-page .candidate-bar.winner .candidate-percentage{background:#48bb78}.all-elections-page .bar-container{background:#e2e8f0;border-radius:10px;height:12px;overflow:hidden}.all-elections-page .bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:10px;transition:width .6s ease}.all-elections-page .candidate-bar.winner .bar-fill{background:linear-gradient(90deg,#48bb78,#38a169)}.all-elections-page .votes-table-container{margin-top:2rem}.all-elections-page .votes-table-container h3{font-size:1.1rem;color:#2d3748;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.all-elections-page .votes-table-container h3:after{display:none}.all-elections-page .no-votes{text-align:center;color:#718096;padding:2rem;background:#f8f9ff;border-radius:12px}.all-elections-page .votes-table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid #e2e8f0}.all-elections-page .votes-table{width:100%;border-collapse:collapse;font-size:.9rem}.all-elections-page .votes-table th{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem;text-align:left;font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.5px}.all-elections-page .votes-table td{padding:.9rem 1rem;border-bottom:1px solid #e2e8f0;color:#4a5568}.all-elections-page .votes-table tr:last-child td{border-bottom:none}.all-elections-page .votes-table tr:nth-child(2n){background:#f8f9ff}.all-elections-page .votes-table tr:hover{background:#eef1ff}.all-elections-page .votes-table .vote-choice{font-weight:600;color:#667eea}.all-elections-page .success-modal{width:100%;max-width:400px;text-align:center}.all-elections-page .success-content{padding:3rem 2rem}.all-elections-page .success-icon{font-size:4rem;margin-bottom:1.5rem}.all-elections-page .success-content h2{font-size:1.8rem;color:#2d3748;margin:0 0 1rem}.all-elections-page .success-content h2:after{display:none}.all-elections-page .success-content p{color:#718096;font-size:1rem;margin:0 0 2rem;line-height:1.5}.all-elections-page .success-btn{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;padding:1rem 3rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.all-elections-page .success-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #48bb7866}@media(max-width:768px){.all-elections-page .modal-content{margin:.5rem;max-height:95vh}.all-elections-page .modal-header{padding:1.5rem 1.5rem 1rem}.all-elections-page .login-form,.all-elections-page .results-content{padding:1.5rem}.all-elections-page .results-summary{flex-direction:column;gap:1rem}.all-elections-page .summary-stat{padding:1rem 2rem}.all-elections-page .summary-stat .stat-value{font-size:2rem}.all-elections-page .candidate-info{flex-wrap:wrap;gap:.5rem}.all-elections-page .candidate-name{width:100%;order:2}.all-elections-page .candidate-rank{order:1}.all-elections-page .candidate-votes,.all-elections-page .candidate-percentage{order:3}.all-elections-page .votes-table{font-size:.8rem}.all-elections-page .votes-table th,.all-elections-page .votes-table td{padding:.7rem .5rem}}.voting-form{background:#fff;border-radius:14px;padding:3rem;max-width:900px;margin:2rem auto;box-shadow:0 8px 32px #0000001a;border:1px solid rgba(102,126,234,.1)}.form-section{margin-bottom:2.5rem;padding-bottom:2.5rem;border-bottom:2px solid #f0f0f0}.form-section:last-of-type{border-bottom:none}.form-section h2{color:#2d3748;margin-bottom:1.5rem;font-size:1.3rem}.candidates-preview{display:flex!important;flex-direction:column!important;gap:1.5rem;margin-bottom:2rem;background:#fff;border-radius:14px;padding:2rem;box-shadow:0 4px 12px #00000014;order:1}.candidates-badges{display:flex;flex-wrap:wrap;gap:1rem;order:1}.candidate-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.8rem 1.5rem;border-radius:20px;font-weight:600;font-size:.95rem;box-shadow:0 4px 12px #667eea4d;transition:all .3s ease}.candidate-badge:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.candidates-count{color:#667eea;font-size:1.1rem;font-weight:600;margin:0;text-align:center;order:2}.candidates{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-bottom:1.5rem}.candidate-card{border:2px solid #e8e8f0;border-radius:12px;padding:1.8rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;gap:1rem;position:relative;background:linear-gradient(135deg,#f9f9ff,#f0f0f8)}.candidate-card:hover{border-color:#667eea;box-shadow:0 8px 24px #667eea33;transform:translateY(-4px)}.candidate-card input[type=radio]:checked~.candidate-info{color:#667eea}.candidate-card input[type=radio]{display:none}.candidate-photo{width:100%;height:200px;object-fit:cover;border-radius:8px;background:linear-gradient(135deg,#667eea,#764ba2);background-color:#e8e8f0}.candidate-info h3{margin:0 0 .5rem;color:#2d3748;font-size:1.15rem}.candidate-info p{margin:0;font-size:.9rem;color:#718096}.radio-label{display:flex;align-items:center;justify-content:center;gap:.6rem;cursor:pointer;font-weight:600;color:#667eea;padding:.8rem 1.2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;transition:all .3s ease}.radio-label:hover{transform:scale(1.02);box-shadow:0 4px 12px #667eea4d}.candidate-card input[type=radio]{appearance:none;width:20px;height:20px;border:2px solid #667eea;border-radius:50%;cursor:pointer;transition:all .3s ease}.candidate-card input[type=radio]:checked{background:#667eea;box-shadow:0 0 0 2px #fff,0 0 0 4px #667eea}.form-select{max-width:100%}.form-hint{display:block;margin-top:.5rem;font-size:.85rem;color:#718096}.form-actions{display:flex;gap:1.5rem;margin-top:2.5rem}.form-actions .btn{flex:1}@media(max-width:768px){.voting-form{padding:1.5rem}.candidates{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:90%;overflow:hidden;animation:modalSlideIn .4s cubic-bezier(.34,1.56,.64,1)}@keyframes modalSlideIn{0%{transform:scale(.9) translateY(-30px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.modal-header{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;padding:2rem;border-bottom:none;text-align:center}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600;letter-spacing:.5px}.modal-body{padding:2.5rem 2rem;text-align:center}.modal-body p{margin:0;color:#2d3748;font-size:1.05rem;line-height:1.7;font-weight:500}.modal-footer{padding:1.5rem 2rem;border-top:1px solid #f0f0f0;display:flex;justify-content:center;gap:1rem;background:#f9fafb}.modal-footer .btn{min-width:140px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.modal-footer .btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.modal-footer .btn:active{transform:translateY(0)}.result-modal{max-width:400px}.result-content{padding:2.5rem 2rem;text-align:center}.result-content .result-icon{font-size:4rem;margin-bottom:1rem}.result-content h2{margin:0 0 1rem;font-size:1.5rem;font-weight:600}.result-content p{margin:0 0 1.5rem;color:#4a5568;font-size:1.05rem;line-height:1.6}.result-content.success h2{color:#38a169}.result-content.error h2{color:#e53e3e}.result-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.85rem 2.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.result-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.result-btn:active{transform:translateY(0)}
