:root{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:rgba(37,99,235,0.1);--bg-main:#f8fafc;--bg-surface:#ffffff;--text-main:#0f172a;--text-muted:#64748b;--text-on-primary:#ffffff;--border-base:#e2e8f0;--border-hover:#cbd5e1;--sidebar-bg:#0f172a;--sidebar-text:#94a3b8;--sidebar-active-bg:rgba(255,255,255,0.08);--sidebar-active-text:#ffffff;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--info:#3b82f6;--radius-sm:0.375rem;--radius-md:0.625rem;--radius-lg:1rem;--radius-xl:1.5rem;--radius-premium:2.5rem;--shadow-sm:0 1px 2px 0 rgb(0 0 0 / 0.05);--shadow-md:0 4px 6px -1px rgb(0 0 0 / 0.1),0 2px 4px -2px rgb(0 0 0 / 0.1);--shadow-lg:0 10px 15px -3px rgb(0 0 0 / 0.1),0 4px 6px -2px rgb(0 0 0 / 0.1);--sidebar-width:280px;--sidebar-collapsed-width:80px}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}.spinner{display:none;animation:spin 0.85s linear infinite}.btn-content{display:inline-flex;align-items:center;justify-content:center;gap:inherit}.htmx-request.btn .spinner,.htmx-request .spinner,.btn.htmx-request .spinner{display:inline-block!important;width:1.25rem;height:1.25rem}.htmx-request.btn .btn-content,.htmx-request .btn-content,.btn.htmx-request .btn-content{display:none!important}.htmx-request.btn,.htmx-request .btn{pointer-events:none;opacity:0.7;cursor:not-allowed}*{margin:0;padding:0;box-sizing:border-box}body{font-family:'Inter',sans-serif;background-color:var(--bg-main);color:var(--text-main);display:flex;min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden}body:has(.modal-backdrop){overflow:hidden!important}h1,h2,h3,h4{font-weight:700;letter-spacing:-0.02em}p{line-height:1.6}.sidebar{width:var(--sidebar-width);background-color:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;position:fixed;height:100vh;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);z-index:1000;border-right:1px solid rgba(255,255,255,0.05);overflow-y:auto;overflow-x:hidden}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:10px}.sidebar:hover::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.2)}.sidebar-header{padding:2rem 1.5rem;display:flex;align-items:center;gap:0.75rem}.sidebar-header h1{font-size:1.5rem;font-weight:850;color:#fff;letter-spacing:-0.05em}.nav-list{list-style:none;padding:0 1rem;display:flex;flex-direction:column;gap:0.25rem;flex:1}.nav-label{padding:1.5rem 1rem 0.5rem 1rem;font-size:0.75rem;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:0.1em}.nav-item{padding:0.75rem 1rem;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;gap:0.875rem;transition:all 0.2s;text-decoration:none;color:var(--sidebar-text);font-weight:500;font-size:0.9375rem}.nav-item i{width:1.25rem;height:1.25rem;stroke-width:2}.nav-item:hover{background-color:var(--sidebar-active-bg);color:#fff;transform:translateX(4px)}.nav-item.active{background-color:var(--primary);color:var(--text-on-primary);font-weight:700;box-shadow:0 4px 12px -2px rgba(0,0,0,0.4)}.nav-item.active i{color:inherit;transform:scale(1.1)}.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(4px);z-index:999;display:none}.main-wrapper{flex:1;display:flex;flex-direction:column;min-height:100vh;margin-left:var(--sidebar-width);transition:margin 0.3s cubic-bezier(0.4,0,0.2,1)}.main-content{flex:1;padding:2.5rem;max-width:100%}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}@media (max-width:640px){.header{flex-direction:column;align-items:stretch;gap:1rem;margin-bottom:1.5rem}.header .flex{width:100%;justify-content:flex-start;flex-wrap:nowrap;gap:0.75rem}.header h2{font-size:1.5rem;width:auto;flex:1;margin:0}.header .btn{flex:1;justify-content:center}.header .btn-sm{flex:initial;width:auto;padding:0.5rem}}.header h2{font-size:1.75rem;color:var(--text-main)}.card{background:var(--bg-surface);border:1px solid var(--border-base);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm);transition:box-shadow 0.2s}.card:hover{box-shadow:var(--shadow-md)}.btn{padding:0.75rem 1.5rem;border-radius:var(--radius-md);border:1px solid transparent;font-weight:600;cursor:pointer;transition:all 0.2s;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:0.625rem;font-size:0.875rem;white-space:nowrap;border-radius:1rem}.btn-primary{background-color:var(--primary);color:var(--text-on-primary)}.btn-primary:hover{background-color:var(--primary-hover)}.btn-secondary{background-color:#e3e6eb;color:#334155}.btn-secondary:hover{background-color:#d4dae2}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:#f1f5f9;color:var(--text-main)}.btn-danger{background-color:var(--danger);color:white}.btn-danger:hover{background-color:#dc2626}.btn-success{background-color:var(--success);color:white}.btn-success:hover{background-color:#059669}.btn-warning{background-color:var(--warning);color:white}.btn-warning:hover{background-color:#d97706}.btn-info{background-color:var(--info);color:white}.btn-info:hover{background-color:#1d4ed8}.btn-sm{padding:0.375rem 0.75rem;font-size:0.75rem}.badge{padding:0.25rem 0.625rem;border-radius:9999px;font-size:0.75rem;font-weight:700;display:inline-flex;align-items:center;gap:0.375rem}.badge-success{background-color:#dcfce7;color:#15803d}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-info{background-color:#e0f2fe;color:#075985}.table-container{overflow-x:auto;border:1px solid var(--border-base);border-radius:var(--radius-md);background:#fff}table{width:100%;border-collapse:collapse}th{text-align:left;padding:0.875rem 1.25rem;background:#f8fafc;color:var(--text-muted);font-weight:600;text-transform:uppercase;font-size:0.7rem;letter-spacing:0.05em;border-bottom:1px solid var(--border-base)}td{padding:1rem 1.25rem;border-bottom:1px solid var(--border-base);font-size:0.9rem;color:var(--text-main)}@media (max-width:640px){th,td{padding:0.75rem 0.875rem;font-size:0.8125rem}.table-container{margin:0 -1rem;width:calc(100% + 2rem);border-radius:0;border-left:none;border-right:none}}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:0.5rem;font-weight:600;font-size:0.875rem;color:#334155}.form-control{width:100%;padding:0.625rem 0.875rem;border:1px solid var(--border-base);border-radius:var(--radius-md);outline:none;transition:all 0.2s;font-size:0.9rem;font-family:inherit;background:#fff}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,0.6);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1.5rem 1rem;overflow-y:auto;animation:fadeIn 0.3s ease-out forwards}.modal-backdrop.closing{animation:fadeOut 0.2s ease-in forwards}.modal-card{background:var(--bg-surface);border-radius:var(--radius-premium);box-shadow:0 25px 50px -12px rgba(0,0,0,0.3);width:100%;max-width:500px;margin:auto;display:flex;flex-direction:column;overflow:hidden;animation:slideUp 0.4s cubic-bezier(0.16,1,0.3,1) forwards;border:none}.modal-card.closing{animation:slideDown 0.3s cubic-bezier(0.4,0,1,1) forwards}.modal-header{padding:2rem 2.5rem 1rem;border-bottom:none;display:flex;justify-content:center;align-items:center;position:relative}.modal-header .btn-ghost{position:absolute;right:1.5rem;top:1.5rem;width:38px;height:38px;padding:0;border-radius:50%}.modal-body{padding:2.5rem 2rem;overflow-y:auto}.alert-icon-container{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}.alert-icon-container.danger{background:#fff1f2;color:var(--danger)}.alert-icon-container.primary{background:#eff6ff;color:var(--primary)}.alert-icon-container.warning{background:#fefce8;color:var(--warning)}.alert-icon-container.success{background:#f0fdf4;color:var(--success)}.alert-icon-container i{width:40px;height:40px}.modal-footer{padding:1.5rem 2.5rem 2.5rem;border-top:none;display:flex;justify-content:center;gap:1rem;background:transparent}.modal-footer .btn{min-width:140px;padding:1rem 2rem;border-radius:1.25rem;font-size:0.9375rem;font-weight:800;text-transform:uppercase;letter-spacing:0.025em}.modal-footer .btn-secondary{background:#f1f5f9}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes slideUp{from{opacity:0;transform:translateY(30px) scale(0.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideDown{from{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(20px) scale(0.98)}}.tabs{display:flex;gap:1.5rem;border-bottom:1px solid var(--border-base);margin-bottom:2rem}.tab-btn{padding:1rem 0;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-weight:600;font-size:0.875rem;cursor:pointer;transition:all 0.2s}.tab-btn:hover{color:var(--text-main)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.responsive-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}@media (max-width:640px){.responsive-grid{grid-template-columns:1fr!important}}@media (max-width:1024px){.sidebar{width:var(--sidebar-collapsed-width)}.sidebar-header h1,.nav-item span,.nav-label{display:none}.nav-item{justify-content:center;padding:1rem}.main-wrapper{margin-left:var(--sidebar-collapsed-width)}}@media (max-width:640px){.sidebar{transform:translateX(-100%);width:280px}.sidebar.open{transform:translateX(0)}.main-wrapper{margin-left:0;max-width:100vw;overflow-x:hidden}.mobile-header{display:flex!important;box-shadow:0 2px 10px rgba(0,0,0,0.2)}.main-content{padding:1rem}.sidebar-header h1,.nav-item span,.nav-label{display:block}.nav-item{justify-content:flex-start}.modal-card{max-width:95%!important;margin:1rem auto}.modal-body .grid{grid-template-columns:1fr!important;gap:1rem!important}.modal-footer{flex-direction:column-reverse;gap:0.75rem;padding:1.5rem}.modal-footer .btn{width:100%;padding:0.875rem}}.mobile-header{display:none;height:64px;background:var(--sidebar-bg);padding:0 1.25rem;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:950;border-bottom:1px solid rgba(255,255,255,0.05)}.mobile-header h1{font-size:1.25rem;color:#fff}.segmented-control{display:flex;background:var(--bg-main);padding:0.35rem;border-radius:var(--radius-lg);border:1px solid var(--border-base);position:relative;gap:0.25rem}.segmented-control input{display:none}.segmented-control label{flex:1;padding:0.75rem 1rem;text-align:center;cursor:pointer;font-weight:700;color:var(--text-muted);border-radius:var(--radius-md);transition:all 0.3s cubic-bezier(0.4,0,0.2,1);z-index:1;margin:0;font-size:0.8125rem}.segmented-control input:checked + label{background:#fff;color:var(--primary);box-shadow:var(--shadow-sm)}.segmented-control label:hover{color:var(--text-main)}@media (max-width:480px){.segmented-control{flex-direction:column;background:transparent;border:none;padding:0}.segmented-control label{background:var(--bg-main);border:1px solid var(--border-base);margin-bottom:0.5rem}.segmented-control input:checked + label{border-color:var(--primary);background:var(--primary-light)}}.bg-auth{background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%)!important}.h-screen{height:100vh!important}.glass-card{background:rgba(255,255,255,0.05)!important;backdrop-filter:blur(10px)!important;border:1px solid rgba(255,255,255,0.1)!important;box-shadow:0 25px 50px -12px rgba(0,0,0,0.5)!important}.gradient-primary-text{background:linear-gradient(to right,#60a5fa,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.text-slate-400{color:#94a3b8!important}.auth-form-control{background:rgba(255,255,255,0.05)!important;border:1px solid rgba(255,255,255,0.1)!important;color:#fff!important;padding-left:3rem!important}.auth-form-control:focus{background:rgba(255,255,255,0.08)!important;border-color:#3b82f6!important;box-shadow:0 0 0 4px rgba(59,130,246,0.1)!important}.absolute-icon{position:absolute!important;left:1rem!important;top:50%!important;transform:translateY(-50%)!important;color:#94a3b8!important;width:1.25rem!important;height:1.25rem!important;pointer-events:none!important;z-index:10!important}.bg-danger-soft{background:rgba(239,68,68,0.1)!important;border:1px solid rgba(239,68,68,0.2)!important}.btn-logout{display:flex;align-items:center;gap:0.875rem;padding:0.75rem 1.25rem;background:rgba(239,68,68,0.1)!important;color:#ef4444!important;border:1px solid rgba(239,68,68,0.2)!important;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:0.9375rem;transition:all 0.2s;width:100%;outline:none!important;box-shadow:none!important;margin-bottom:0.25rem}.btn-logout:hover{background:#ef4444!important;color:#fff!important;border-color:#ef4444!important}.checkbox-custom{width:1.25rem;height:1.25rem;border-radius:4px;border:1px solid var(--border-base);cursor:pointer;accent-color:var(--primary)}.dropdown{position:relative;display:inline-block}.dropdown-content{display:none;position:absolute;right:0;top:100%;background-color:var(--bg-surface);min-width:240px;box-shadow:var(--shadow-lg);border:1px solid var(--border-base);border-radius:var(--radius-md);z-index:100;padding:0.5rem 0;border-top:8px solid transparent;background-clip:padding-box;margin-top:-4px}.dropdown:hover .dropdown-content{display:block}.dropdown-item{padding:0.75rem 1rem;display:flex;align-items:center;gap:0.75rem;color:var(--text-main);text-decoration:none;font-size:0.875rem;transition:background 0.2s;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-weight:500;font-family:inherit}.dropdown-item:hover{background-color:var(--bg-main)}.dropdown-item i{color:var(--text-muted)}.bulk-actions-toolbar{display:flex;align-items:center;gap:0.5rem}.bulk-btn{transition:all 0.2s cubic-bezier(0.4,0,0.2,1);opacity:1;transform:scale(1);padding:0.25rem 0.5rem!important;min-width:28px;height:28px}.bulk-btn.hidden{opacity:0;transform:scale(0.8);pointer-events:none;width:0!important;margin:0!important;padding:0!important;border:none!important;overflow:hidden}.min-h-140{min-height:140px}.progress-bar-container{width:100%;background-color:#f1f5f9;border-radius:9999px;height:0.55rem;overflow:hidden;position:relative;box-shadow:inset 0 1px 2px rgba(0,0,0,0.05)}.progress-bar-fill{height:100%;transition:width 0.6s cubic-bezier(0.4,0,0.2,1)}.bg-danger-row{background-color:#fff1f2!important}.bg-success-row{background-color:#f0fdf4!important}.chart-container{position:relative;margin:auto;height:300px;width:100%}.card-sidebar{background:white;border:1px solid var(--border-base);padding:1.25rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);height:100%}.bg-dark-card{background:#0f172a!important;color:#f8fafc!important}.table-container table{width:100%!important;border-collapse:collapse}.icon-xs{width:0.75rem!important;height:0.75rem!important}.icon-sm{width:1rem!important;height:1rem!important}.icon-md{width:1.25rem!important;height:1.25rem!important}.icon-lg{width:1.5rem!important;height:1.5rem!important}.icon-box{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:var(--radius-md);flex-shrink:0}.icon-box-lg{width:3.5rem;height:3.5rem}.icon-box-lg i{width:24px;height:24px}.btn-outline-danger{background:transparent!important;border:1px solid var(--danger)!important;color:var(--danger)!important}.btn-outline-danger:hover{background:var(--danger)!important;color:white!important}.simple-table{width:100%;border-collapse:collapse}.simple-table th,.simple-table td{padding:0.75rem 1rem;border-bottom:1px solid var(--border-base)}.border-base{border:1px solid var(--border-base)!important}.border-t-base{border-top:1px solid var(--border-base)!important}.border-b-base{border-bottom:1px solid var(--border-base)!important}.border-l-base{border-left:1px solid var(--border-base)!important}.border-r-base{border-right:1px solid var(--border-base)!important}.border-radius-base{border-radius:var(--radius-md)}.calendar-card{background:var(--bg-surface);border-radius:var(--radius-xl);border:1px solid var(--border-base);box-shadow:var(--shadow-md);overflow:hidden}.calendar-header{padding:1.5rem;background:#fff;border-bottom:1px solid var(--border-base);display:flex;justify-content:space-between;align-items:center}.calendar-title{font-size:1.25rem;font-weight:800;color:var(--text-main);display:flex;align-items:center;gap:0.75rem}.calendar-nav{display:flex;gap:0.5rem}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);background:var(--border-base);gap:1px}.calendar-weekday{background:#f8fafc;padding:0.75rem;text-align:center;font-size:0.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em}.calendar-day{background:#fff;min-height:120px;padding:0.5rem;display:flex;flex-direction:column;gap:0.25rem;position:relative;transition:background 0.2s}.calendar-day:hover{background:#fdfdfd}.calendar-day.other-month{background:#fcfcfc;color:#cbd5e1}.calendar-day-number{font-size:0.875rem;font-weight:600;margin-bottom:0.5rem}.calendar-day.today .calendar-day-number{color:var(--primary);background:var(--primary-light);width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:6px}.election-event{font-size:0.75rem;padding:0.35rem 0.6rem;border-radius:6px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:all 0.2s;border-left:3px solid transparent;display:flex;align-items:center;gap:0.4rem}.election-event:hover{transform:translateX(2px);filter:brightness(0.95)}.event-running{background:#dcfce7;color:#166534;border-left-color:#22c55e}.event-stopped{background:#f1f5f9;color:#475569;border-left-color:#94a3b8}.event-critical{background:#fee2e2;color:#991b1b;border-left-color:#ef4444;animation:pulse-border 2s infinite}.event-candidacy{background:#e0f2fe;color:#075985;border-left-color:#0ea5e9}@keyframes pulse-border{0%,100%{border-left-color:#ef4444;box-shadow:0 0 0 0 rgba(239,68,68,0.2)}50%{border-left-color:#b91c1c;box-shadow:0 0 0 4px rgba(239,68,68,0.1)}}.critical-pulse{width:8px;height:8px;background:var(--danger);border-radius:50%;display:inline-block;animation:pulse-bg 1.5s infinite}@keyframes pulse-bg{0%{transform:scale(0.95);box-shadow:0 0 0 0 rgba(239,68,68,0.7)}70%{transform:scale(1);box-shadow:0 0 0 10px rgba(239,68,68,0)}100%{transform:scale(0.95);box-shadow:0 0 0 0 rgba(239,68,68,0)}}@media (max-width:768px){.calendar-day{min-height:80px}.calendar-weekday{font-size:0.65rem;padding:0.5rem 0.25rem}.election-event{font-size:0.65rem;padding:0.25rem 0.4rem}}