*,:after,:before{box-sizing:border-box}:root{--primary:#3b82f6;--primary-dark:#2563eb;--primary-light:#60a5fa;--secondary:#10b981;--secondary-dark:#059669;--danger:#ef4444;--danger-dark:#b91c1c;--warning:#f59e0b;--warning-dark:#d97706;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--font-mono:source-code-pro,Menlo,Monaco,Consolas,"Courier New",monospace;--spacing-1:0.25rem;--spacing-2:0.5rem;--spacing-3:0.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--radius-sm:0.125rem;--radius:0.25rem;--radius-md:0.375rem;--radius-lg:0.5rem;--radius-full:9999px}body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;background-color:var(--gray-50);color:#1f2937;color:var(--gray-800);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-family:var(--font-sans);font-size:16px;line-height:1.5;margin:0;padding:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;font-family:var(--font-mono)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.25;margin-bottom:1rem;margin-bottom:var(--spacing-4);margin-top:0}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}p{margin-bottom:1rem;margin-bottom:var(--spacing-4);margin-top:0}a{color:#3b82f6;color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}img{height:auto;max-width:100%}.container{padding-left:var(--spacing-4);padding-right:var(--spacing-4)}@media (min-width:1280px){.container{max-width:1280px}}.min-h-screen{min-height:100vh}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.flex-grow{flex-grow:1}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}.gap-4{gap:1rem;gap:var(--spacing-4)}.p-1{padding:.25rem;padding:var(--spacing-1)}.p-2{padding:.5rem;padding:var(--spacing-2)}.p-3{padding:.75rem;padding:var(--spacing-3)}.p-4{padding:1rem;padding:var(--spacing-4)}.p-6{padding:1.5rem;padding:var(--spacing-6)}.px-2{padding-left:.5rem;padding-left:var(--spacing-2);padding-right:.5rem;padding-right:var(--spacing-2)}.px-3{padding-left:.75rem;padding-left:var(--spacing-3);padding-right:.75rem;padding-right:var(--spacing-3)}.px-4{padding-left:1rem;padding-left:var(--spacing-4);padding-right:1rem;padding-right:var(--spacing-4)}.px-6{padding-left:1.5rem;padding-left:var(--spacing-6);padding-right:1.5rem;padding-right:var(--spacing-6)}.py-1{padding-bottom:.25rem;padding-bottom:var(--spacing-1);padding-top:.25rem;padding-top:var(--spacing-1)}.py-2{padding-bottom:.5rem;padding-bottom:var(--spacing-2);padding-top:.5rem;padding-top:var(--spacing-2)}.py-3{padding-bottom:.75rem;padding-bottom:var(--spacing-3);padding-top:.75rem;padding-top:var(--spacing-3)}.py-4{padding-bottom:1rem;padding-bottom:var(--spacing-4);padding-top:1rem;padding-top:var(--spacing-4)}.py-6{padding-bottom:1.5rem;padding-bottom:var(--spacing-6);padding-top:1.5rem;padding-top:var(--spacing-6)}.m-1{margin:.25rem;margin:var(--spacing-1)}.m-2{margin:.5rem;margin:var(--spacing-2)}.m-3{margin:.75rem;margin:var(--spacing-3)}.m-4{margin:1rem;margin:var(--spacing-4)}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem;margin-bottom:var(--spacing-1)}.mb-2{margin-bottom:.5rem;margin-bottom:var(--spacing-2)}.mb-3{margin-bottom:.75rem;margin-bottom:var(--spacing-3)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:1.5rem;margin-bottom:var(--spacing-6)}.mb-8{margin-bottom:2rem;margin-bottom:var(--spacing-8)}.mt-1{margin-top:.25rem;margin-top:var(--spacing-1)}.mt-2{margin-top:.5rem;margin-top:var(--spacing-2)}.mt-3{margin-top:.75rem;margin-top:var(--spacing-3)}.mt-4{margin-top:1rem;margin-top:var(--spacing-4)}.mt-6{margin-top:1.5rem;margin-top:var(--spacing-6)}.mt-8{margin-top:2rem;margin-top:var(--spacing-8)}.mr-1{margin-right:.25rem;margin-right:var(--spacing-1)}.mr-2{margin-right:.5rem;margin-right:var(--spacing-2)}.mr-3{margin-right:.75rem;margin-right:var(--spacing-3)}.mr-4{margin-right:1rem;margin-right:var(--spacing-4)}.ml-1{margin-left:.25rem;margin-left:var(--spacing-1)}.ml-2{margin-left:.5rem;margin-left:var(--spacing-2)}.ml-3{margin-left:.75rem;margin-left:var(--spacing-3)}.ml-4,.space-x-4>*+*{margin-left:1rem;margin-left:var(--spacing-4)}.space-y-4>*+*{margin-top:1rem;margin-top:var(--spacing-4)}.space-y-6>*+*{margin-top:1.5rem;margin-top:var(--spacing-6)}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-left{text-align:left}.text-right{text-align:right}.text-white{color:#fff}.text-primary{color:#3b82f6;color:var(--primary)}.text-secondary{color:#10b981;color:var(--secondary)}.text-danger{color:#ef4444;color:var(--danger)}.text-warning{color:#f59e0b;color:var(--warning)}.text-gray-500{color:#6b7280;color:var(--gray-500)}.text-gray-600{color:#4b5563;color:var(--gray-600)}.text-gray-700{color:#374151;color:var(--gray-700)}.text-gray-800{color:#1f2937;color:var(--gray-800)}.bg-white{background-color:#fff}.bg-primary{background-color:#3b82f6;background-color:var(--primary)}.bg-primary-dark{background-color:#2563eb;background-color:var(--primary-dark)}.bg-secondary{background-color:#10b981;background-color:var(--secondary)}.bg-secondary-dark{background-color:#059669;background-color:var(--secondary-dark)}.bg-danger{background-color:#ef4444;background-color:var(--danger)}.bg-danger-dark{background-color:#b91c1c;background-color:var(--danger-dark)}.bg-warning{background-color:#f59e0b;background-color:var(--warning)}.bg-gray-50{background-color:#f9fafb;background-color:var(--gray-50)}.bg-gray-100{background-color:#f3f4f6;background-color:var(--gray-100)}.bg-gray-200{background-color:#e5e7eb;background-color:var(--gray-200)}.border{border:1px solid #d1d5db;border:1px solid var(--gray-300)}.border-t{border-top:1px solid #d1d5db;border-top:1px solid var(--gray-300)}.border-r{border-right:1px solid #d1d5db;border-right:1px solid var(--gray-300)}.border-b{border-bottom:1px solid #d1d5db;border-bottom:1px solid var(--gray-300)}.border-l{border-left:1px solid #d1d5db;border-left:1px solid var(--gray-300)}.border-primary{border-color:#3b82f6;border-color:var(--primary)}.border-danger{border-color:#ef4444;border-color:var(--danger)}.border-warning{border-color:#f59e0b;border-color:var(--warning)}.border-gray-200{border-color:#e5e7eb;border-color:var(--gray-200)}.border-gray-300{border-color:#d1d5db;border-color:var(--gray-300)}.rounded{border-radius:.25rem;border-radius:var(--radius)}.rounded-md{border-radius:.375rem;border-radius:var(--radius-md)}.rounded-lg{border-radius:.5rem;border-radius:var(--radius-lg)}.rounded-full{border-radius:9999px;border-radius:var(--radius-full)}.shadow-sm{box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm)}.shadow{box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow)}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg)}.btn{align-items:center;border:1px solid #0000;border-radius:.25rem;border-radius:var(--radius);display:inline-flex;font-size:1rem;justify-content:center;line-height:1.5;padding:.5rem 1rem;padding:var(--spacing-2) var(--spacing-4);transition:background-color .2s,border-color .2s,color .2s,box-shadow .2s}.btn:focus{box-shadow:0 0 0 3px #3b82f680;outline:none}.btn-primary{background-color:#3b82f6;background-color:var(--primary)}.btn-primary:hover{background-color:#2563eb;background-color:var(--primary-dark)}.btn-danger{color:#fff}.btn-warning{background-color:#f59e0b;background-color:var(--warning);color:#fff}.btn-warning:hover{background-color:#d97706;background-color:var(--warning-dark)}.btn-outline{background-color:initial;border-color:#d1d5db;border-color:var(--gray-300);color:#374151;color:var(--gray-700)}.btn-outline:hover{background-color:#f3f4f6;background-color:var(--gray-100)}.btn-sm{font-size:.875rem;padding:.25rem .5rem;padding:var(--spacing-1) var(--spacing-2)}.btn-lg{font-size:1.125rem;padding:.75rem 1.5rem;padding:var(--spacing-3) var(--spacing-6)}.btn-disabled,.btn:disabled{opacity:.65;pointer-events:none}.card{background-color:#fff;border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow);overflow:hidden}.card-body{padding:1.5rem;padding:var(--spacing-6)}.card-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200)}.card-footer,.card-header{background-color:#f9fafb;background-color:var(--gray-50);padding:1rem 1.5rem;padding:var(--spacing-4) var(--spacing-6)}.card-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200)}.form-group{margin-bottom:var(--spacing-4)}.form-label{color:var(--gray-700);display:block;margin-bottom:.5rem;margin-bottom:var(--spacing-2)}.form-control{background-clip:padding-box;background-color:#fff;border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.25rem;border-radius:var(--radius);color:#374151;color:var(--gray-700);display:block;font-size:1rem;line-height:1.5;padding:.5rem .75rem;padding:var(--spacing-2) var(--spacing-3);transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;width:100%}.form-control:focus{border-color:#60a5fa;border-color:var(--primary-light);outline:0}.form-error{color:var(--danger);font-size:.875rem;margin-top:.25rem;margin-top:var(--spacing-1)}.form-control.error{border-color:#ef4444;border-color:var(--danger)}.alert{border:1px solid #0000;border-radius:.25rem;border-radius:var(--radius);margin-bottom:1rem;margin-bottom:var(--spacing-4);padding:.75rem 1rem;padding:var(--spacing-3) var(--spacing-4);position:relative}.alert-primary{background-color:#dbeafe;border-color:#bfdbfe;color:#1e40af}.alert-success{background-color:#d1fae5;border-color:#a7f3d0;color:#065f46}.alert-danger{background-color:#fee2e2;border-color:#fecaca;color:#991b1b}.alert-warning{background-color:#fef3c7;border-color:#fde68a;color:#92400e}.nav{background-color:#3b82f6;background-color:var(--primary);color:#fff;padding:1rem;padding:var(--spacing-4)}.nav-container{align-items:center;display:flex;justify-content:space-between}.nav-brand{color:#fff;font-weight:600;text-decoration:none}.nav-link{border-radius:var(--radius);padding:.5rem .75rem;padding:var(--spacing-2) var(--spacing-3);transition:background-color .2s}.nav-link.active,.nav-link:hover{background-color:#2563eb;background-color:var(--primary-dark)}.spinner{animation:spinner .75s linear infinite;border:.25em solid;border-right:.25em solid #0000;height:2rem;vertical-align:-.125em;width:2rem}@keyframes spinner{to{transform:rotate(1turn)}}.progress{border-radius:var(--radius-full);display:flex;height:1rem}.progress-bar{color:#fff;display:flex;flex-direction:column;justify-content:center;text-align:center;transition:width .6s ease;white-space:nowrap}.d-none{display:none!important}.d-inline{display:inline!important}.d-inline-block{display:inline-block!important}.d-block{display:block!important}.w-full{width:100%}.h-full{height:100%}.object-contain{object-fit:contain}.overflow-hidden{overflow:hidden}.transition{transition-duration:.15s;transition-property:background-color,border-color,color,fill,stroke,opacity,box-shadow,transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.hover\:underline:hover{text-decoration:underline}.hover\:bg-primary-dark:hover{background-color:#2563eb;background-color:var(--primary-dark)}.hover\:bg-gray-50:hover{background-color:#f9fafb;background-color:var(--gray-50)}.policy-statement{min-height:6.25rem}.quiz-actions{display:flex;gap:1rem;gap:var(--spacing-4);justify-content:center;margin-top:1rem;margin-top:var(--spacing-4)}.candidate-result{background-color:#f9fafb;background-color:var(--gray-50);padding:1rem;padding:var(--spacing-4)}.candidate-header{margin-bottom:.5rem;margin-bottom:var(--spacing-2)}.candidate-logo{height:3rem;margin-right:.75rem;margin-right:var(--spacing-3);width:3rem}.alignment-details{margin-top:.5rem;margin-top:var(--spacing-2)}.alignment-bar{display:flex;justify-content:space-between;margin-bottom:.25rem;margin-bottom:var(--spacing-1)}.alignment-progress{background-color:#e5e7eb;background-color:var(--gray-200);border-radius:var(--radius-full);width:100%}.alignment-value{background-color:#3b82f6;background-color:var(--primary)}.quiz-container{box-shadow:0 10px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:42rem;transition:all .3s ease}@media (max-width:768px){.quiz-container{margin:0 1rem}.quiz-actions{flex-direction:column;width:100%}.quiz-actions button{margin:.5rem 0;width:100%}.card-body{padding:1rem;padding:var(--spacing-4)}}.policy-statement{background-color:#f9fafb;background-color:var(--gray-50);border-left:4px solid #3b82f6;border-left:4px solid var(--primary);border-radius:.375rem;border-radius:var(--radius-md);box-shadow:inset 0 2px 4px 0 #0000000f;color:#374151;color:var(--gray-700);font-size:1.125rem;line-height:1.7;margin-top:.5rem;margin-top:var(--spacing-2);min-height:8rem;padding:1rem;padding:var(--spacing-4)}.progress{background-color:#e5e7eb;background-color:var(--gray-200);border-radius:9999px;height:.75rem;margin-bottom:1.5rem;overflow:hidden}.progress-bar{background-color:#3b82f6;background-color:var(--primary);height:100%;transition:width .4s ease}.btn{border-radius:.375rem;font-weight:600;letter-spacing:.01em;padding:.75rem 1.5rem;transition:all .2s ease}.btn:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn-secondary{background-color:#10b981;background-color:var(--secondary)}.btn-secondary:hover{background-color:#059669;background-color:var(--secondary-dark)}.btn-danger{background-color:#ef4444;background-color:var(--danger)}.btn-danger:hover{background-color:#b91c1c;background-color:var(--danger-dark)}.candidate-result{background-color:#fff;border-radius:.5rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:1.5rem;padding:var(--spacing-6);transition:all .3s ease}.candidate-result:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.candidate-logo{border-radius:.25rem;border-radius:var(--radius);box-shadow:0 1px 2px 0 #0000000d;height:4rem;margin-right:1rem;margin-right:var(--spacing-4);object-fit:contain;padding:.25rem;width:4rem}.alignment-progress{border-radius:9999px;height:1rem;margin-top:.5rem;overflow:hidden}.alignment-value{background:linear-gradient(90deg,#3b82f6,#2563eb);background:linear-gradient(90deg,var(--primary) 0,var(--primary-dark) 100%);height:100%;transition:width 1s ease-out}.container{margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem;width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}.nav{background:linear-gradient(90deg,#2563eb,#3b82f6);background:linear-gradient(90deg,var(--primary-dark) 0,var(--primary) 100%);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.nav-brand{font-size:1.25rem;font-weight:700;letter-spacing:.01em}.nav-link{border-radius:.25rem;letter-spacing:.01em;padding:.5rem 1rem}.nav-link.active,.nav-link:hover{background-color:#ffffff1a;transform:translateY(-1px)}.card{animation:fadeIn .4s ease-out}.transition{transition:all .3s ease}.opacity-50{opacity:.5}.opacity-100{opacity:1}.form-control:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f640;outline:none}.animate-fadeIn{animation:fadeIn .3s ease-out forwards}.animate-slideUp{animation:slideUp .5s ease-out forwards}input[type=checkbox]{-webkit-appearance:none;appearance:none;border:1px solid #d1d5db;border-radius:.25rem;color:#3b82f6;cursor:pointer;height:1rem;outline:0;position:relative;transition:all .2s ease;width:1rem}input[type=checkbox]:checked{background-color:#3b82f6;border-color:#3b82f6}input[type=checkbox]:checked:before{border:solid #fff;border-width:0 2px 2px 0;content:"";height:9px;left:4px;position:absolute;top:1px;transform:rotate(45deg);width:5px}input[type=checkbox]:hover{border-color:#9ca3af}input[type=checkbox]:focus{box-shadow:0 0 0 3px #3b82f640}input[type=email],input[type=password],input[type=text]{transition:all .2s ease}input[type=email]:hover,input[type=password]:hover,input[type=text]:hover{border-color:#9ca3af}input[type=email]:focus,input[type=password]:focus,input[type=text]:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f640}button:not(:disabled){transition:all .2s ease}button:not(:disabled):hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}button:not(:disabled):active{transform:translateY(0)}.animate-spin{animation:spin 1s linear infinite}:root{--primary-50:#eff6ff;--primary-100:#dbeafe;--primary-200:#bfdbfe;--primary-300:#93c5fd;--primary-400:#60a5fa;--primary-500:#3b82f6;--primary-600:#2563eb;--primary-700:#1d4ed8;--primary-800:#1e40af;--primary-900:#1e3a8a;--error-50:#fef2f2;--error-100:#fee2e2;--error-500:#ef4444;--error-600:#dc2626;--error-700:#b91c1c}@media (max-width:640px){.grid-cols-2{gap:.75rem;grid-template-columns:1fr}button[type=submit],input[type=email],input[type=password],input[type=text]{font-size:16px;padding:.875rem 1rem}button[type=submit]{padding:.75rem 1rem}}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.focus-ring:focus-visible{box-shadow:0 0 0 3px #3b82f680;outline:none}.close-button{align-items:center;background-color:#ffffff40;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:1.25rem;height:2.5rem;justify-content:center;opacity:.8;transition:all .2s;width:2.5rem}.close-button:hover{background-color:#ffffff59;opacity:1}.login-bg-gradient{background:linear-gradient(135deg,#3b82f6,#1e40af)}.login-bg-pattern{background-color:#f3f4f6;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z' fill='%233b82f6' fill-opacity='.1' fill-rule='evenodd'/%3E%3C/svg%3E")}.glass-effect{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#ffffffe6;border:1px solid #ffffff4d}@media (prefers-color-scheme:dark){.dark-mode-support{--text-primary:#f3f4f6;--bg-primary:#1f2937;--bg-secondary:#111827;--border-color:#374151;--input-bg:#374151;--input-text:#f3f4f6;background-color:var(--bg-primary);color:var(--text-primary)}.dark-mode-support input{background-color:var(--input-bg);border-color:var(--border-color);color:var(--input-text)}.dark-mode-support .card{background-color:var(--bg-secondary)}}.page-transition-wrapper{min-height:100vh;position:relative}.page-enter{opacity:0;transform:translateX(20px)}.page-enter-active{transition:opacity .3s ease-out,transform .3s ease-out}.page-enter-active,.page-exit{opacity:1;transform:translateX(0)}.page-exit-active{opacity:0;transform:translateX(-20px);transition:opacity .3s ease-in,transform .3s ease-in}.mobile-app-mode{overflow-x:hidden}.mobile-app-mode main{padding:0!important}html{scroll-behavior:smooth}.mobile-nav-transition{transition:transform .3s ease-out}@keyframes pageSlideIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.animate-page-in{animation:pageSlideIn .5s ease-out}.touch-feedback{overflow:hidden;position:relative}.touch-feedback:after{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .3s,height .3s;width:0}.touch-feedback:active:after{height:100%;width:100%}@media (max-width:768px){.mobile-only{display:block!important}.desktop-only{display:none!important}.reduce-motion *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (min-width:769px){.mobile-only{display:none!important}.desktop-only{display:block!important}}.safe-area-padding{padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.focus-visible:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.no-select{-webkit-user-select:none;user-select:none}.interactive,a,button,input,select,textarea{transition:all .2s ease-out}.login-container{align-items:center;background:linear-gradient(150deg,#f9fafbe6,#f3f4f6e6);display:flex;flex-direction:column;justify-content:center;min-height:100vh;overflow:hidden;padding:1.25rem;position:relative}.login-container:before{background:radial-gradient(circle at 80% 20%,#3b82f60d,#0000 60%),radial-gradient(circle at 20% 80%,#10b9810a,#0000 60%);content:"";inset:0;opacity:.8;pointer-events:none;position:absolute;z-index:-1}.login-header{animation:fadeSlideDown .8s cubic-bezier(.16,1,.3,1) both;margin-bottom:1.5rem;text-align:center}.login-logo{-webkit-text-fill-color:#0000;text-fill-color:#0000;align-items:center;background:linear-gradient(135deg,#2563eb,#3b82f6);-webkit-background-clip:text;background-clip:text;color:#2563eb;display:flex;font-size:1.6rem;font-weight:700;justify-content:center;margin-bottom:.375rem}.login-logo-icon{filter:drop-shadow(0 2px 4px rgba(59,130,246,.3));margin-right:.375rem}.login-tagline{color:#64748b;font-size:.875rem;font-weight:500;letter-spacing:-.01em}.login-card{animation:fadeSlideUp .8s cubic-bezier(.16,1,.3,1) .1s both;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #e2e8f0e6;border-radius:.875rem;box-shadow:0 12px 25px #0000000f,0 5px 10px #00000005,0 0 0 1px #e2e8f0b3;max-width:24rem;overflow:hidden;position:relative;width:100%}.login-card:before{background:radial-gradient(circle at top right,#3b82f605,#0000 70%),radial-gradient(circle at bottom left,#10b98105,#0000 70%);content:"";inset:0;opacity:.8;position:absolute;z-index:-1}.login-form{padding:1.5rem}.login-title{-webkit-text-fill-color:#0000;text-fill-color:#0000;background:linear-gradient(135deg,#1e293b,#334155);-webkit-background-clip:text;background-clip:text;color:#1e293b;display:inline-block;font-size:1.25rem;font-weight:600;margin-bottom:1.25rem;position:relative}.login-title:after{animation:expandLine 1.2s cubic-bezier(.16,1,.3,1) forwards;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:2px;bottom:-4px;content:"";height:2px;left:0;opacity:0;position:absolute;transform-origin:left;width:35px}.form-group{animation-delay:0s;animation-delay:calc(var(--animation-order, 0)*.05s);margin-bottom:1rem}.form-label{display:flex;justify-content:space-between;margin-bottom:.375rem}.label-text{color:#475569;font-size:.75rem;font-weight:500;transition:all .3s ease}.form-group:focus-within .label-text{color:#3b82f6;transform:translateY(-1px)}.forgot-password{color:#2563eb;font-size:.75rem;text-decoration:none;transition:all .2s ease}.forgot-password:hover{color:#1d4ed8;text-decoration:underline}.form-input{background:#ffffffe6;border:1px solid #cbd5e1cc;box-shadow:0 1px 3px #00000003,inset 0 1px 2px #ffffffb3;display:block;padding:.625rem .875rem;transition:all .3s cubic-bezier(.16,1,.3,1);width:100%}.form-input::placeholder{color:#94a3b8;opacity:.7}.form-input:hover{border-color:#94a3b8cc}.form-input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #3b82f626,inset 0 1px 2px #ffffffb3;transform:translateY(-1px)}.form-input:focus::placeholder{opacity:.5;transform:translateX(3px)}.form-input.error{background:#fef2f2;border-color:#f87171;box-shadow:none;margin-bottom:0}.form-input.error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-input.valid{background:#f0fdf4;border-color:#10b981}.form-input.valid:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.input-wrapper{position:relative}.password-toggle{align-items:center;background:none;border:none;border-radius:.375rem;color:#64748b;cursor:pointer;display:flex;font-size:.875rem;justify-content:center;padding:.25rem;position:absolute;right:.75rem;top:50%;transform:translateY(-50%);transition:all .2s ease}.password-toggle:hover{background:#3b82f60d;color:#3b82f6}.field-error-text{animation:fadeIn .2s ease-out;color:#dc2626;display:block;font-size:.75rem;font-weight:500;margin-top:.25rem}.api-error-message{align-items:center;animation:slideDown .3s ease-out;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.input-field-wrapper{width:100%}.error-message{color:#ef4444;display:none;font-size:.75rem;margin-top:.25rem}.error-icon{flex-shrink:0;height:.875rem;margin-right:.375rem;width:.875rem}.error-banner{animation:fadeSlideUp .4s cubic-bezier(.16,1,.3,1) both;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#fee2e299;border:1px solid #fca5a54d;border-radius:.5rem;box-sizing:border-box;color:#b91c1c;font-size:.75rem;font-weight:500;line-height:1.3;margin-bottom:.5rem;min-height:auto;padding:.5rem .625rem;width:100%}.error-banner svg{flex-shrink:0;height:.875rem;margin-right:.375rem;width:.875rem}.remember-me{align-items:center;display:flex;margin-bottom:1.25rem}.checkbox{accent-color:#3b82f6;height:.875rem;margin-right:.375rem;width:.875rem}.remember-label{color:#475569;font-size:.75rem;font-weight:500}.login-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:.5rem;box-shadow:0 4px 12px #2563eb33,0 2px 5px #2563eb1a,inset 0 1px 0 #ffffff1a;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.25rem;justify-content:center;line-height:1;min-height:2.5rem;overflow:hidden;padding:.625rem .875rem;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1);width:100%}.login-button:before{background:linear-gradient(to bottom right,#fff0,#fff3 50%,#fff0);content:"";height:200%;left:-50%;opacity:0;position:absolute;top:-50%;transform:rotate(45deg) translate(-100%,-100%);transition:all .6s cubic-bezier(.16,1,.3,1);width:200%;z-index:1}.login-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 15px #2563eb40,0 3px 6px #2563eb26,inset 0 1px 0 #ffffff26;transform:translateY(-2px)}.login-button:hover:before{opacity:1;transform:rotate(45deg) translate(100%,100%)}.login-button:active{box-shadow:0 3px 8px #2563eb33;transform:translateY(-1px)}.login-button:disabled{background:linear-gradient(135deg,#93c5fd,#60a5fa);box-shadow:0 2px 6px #2563eb26;cursor:not-allowed;opacity:.7;transform:none}.login-button:focus{box-shadow:0 0 0 3px #3b82f64d,0 4px 12px #2563eb33;outline:none}.spinner-container{align-items:center;display:inline-flex;flex-shrink:0;height:16px;justify-content:center;line-height:0;width:16px}.spinner{animation:spin .8s linear infinite;display:block;height:16px;width:16px}.spinner-track{opacity:.3}.spinner-head{opacity:1}.divider{align-items:center;display:flex;margin:1.25rem 0}.divider-line{background:linear-gradient(90deg,#e2e8f01a,#e2e8f0cc,#e2e8f01a);flex-grow:1;height:1px}.divider-text{color:#94a3b8;font-size:.75rem;font-weight:500;padding:0 .75rem}.social-buttons{grid-gap:.625rem;display:grid;gap:.625rem;grid-template-columns:1fr 1fr}.social-button{align-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#fff9;border:1px solid #e2e8f0cc;border-radius:.5rem;box-shadow:0 1px 3px #00000005,inset 0 1px 0 #ffffff80;color:#475569;cursor:pointer;display:flex;font-size:.75rem;font-weight:500;justify-content:center;padding:.5rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.social-button:hover{background:#ffffffe6;border-color:#cbd5e1e6;box-shadow:0 3px 8px #0000000a;transform:translateY(-1px)}.social-icon{font-size:.875rem;margin-right:.375rem}.register-prompt{animation:fadeSlideUp .8s cubic-bezier(.16,1,.3,1) .3s both;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#ffffffb3;border:1px solid #e2e8f0b3;border-radius:.5rem;box-shadow:0 1px 3px #00000008;margin-top:1.25rem;max-width:24rem;padding:.875rem;text-align:center;width:100%}.register-text{color:#64748b;font-size:.8125rem;margin:0}.register-link{color:#2563eb;font-weight:600;margin-left:.25rem;position:relative;text-decoration:none;transition:all .2s ease}.register-link:after{background:linear-gradient(90deg,#3b82f6,#2563eb);bottom:-1px;content:"";height:1px;left:0;opacity:.8;position:absolute;transition:width .3s cubic-bezier(.16,1,.3,1);width:0}.register-link:hover{color:#1d4ed8}.register-link:hover:after{width:100%}.password-strength{background-color:#f3f4f6;border-radius:1.5px;height:3px;margin-top:.375rem;overflow:hidden}.password-strength-bar{border-radius:1.5px;height:100%;transition:all .3s cubic-bezier(.16,1,.3,1);width:0}.password-strength-bar.weak{background:linear-gradient(90deg,#ef4444,#f87171);width:33%}.password-strength-bar.medium{background:linear-gradient(90deg,#f59e0b,#fbbf24);width:66%}.password-strength-bar.strong{background:linear-gradient(90deg,#10b981,#34d399);width:100%}@media (max-width:640px){.login-form{padding:1.25rem}.login-title{font-size:1.125rem}.login-logo{font-size:1.5rem}}@media (max-width:480px){.login-card{box-shadow:0 8px 16px #0000000d}.login-form{padding:1rem}.social-buttons{grid-template-columns:1fr}.error-message{font-size:.65rem;line-height:1;max-width:95%;min-height:1.2rem;padding:.1rem .25rem}.error-icon{height:.7rem;margin-right:.2rem;width:.7rem}.error-banner{font-size:.75rem;padding:.4rem .5rem}.spinner,.spinner-container{height:16px;width:16px}.login-button{font-size:.8125rem;min-height:2.25rem}}@media (max-width:360px){.error-message{font-size:.6rem;min-height:1rem;padding:.05rem .2rem}.error-icon{height:.6rem;margin-right:.15rem;width:.6rem}.form-label{margin-bottom:.25rem}.form-group{margin-bottom:.75rem}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.policy-pick-container,.policy-pick-list-container{background:linear-gradient(180deg,#f0f9ff,#e0f2fe 50%,#bae6fd);bottom:0;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;left:0;position:fixed;right:0;top:0;z-index:10000}.policy-pick-header{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 10px #2563eb33;display:flex;justify-content:space-between;padding:12px 16px}.policy-pick-nav-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:50%;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s ease;width:44px}.policy-pick-nav-button:hover{background:#ffffff4d;transform:scale(1.05)}.policy-pick-nav-button svg{color:#fff;height:24px;width:24px}.policy-pick-title{color:#fff;font-size:20px;font-weight:700;letter-spacing:-.5px;margin:0}.policy-pick-instruction{padding:16px 20px 8px;text-align:center}.policy-pick-instruction .instruction-text{color:#64748b;font-size:18px;font-weight:600;margin:0}.policy-pick-content{align-items:flex-start;display:flex;flex:1 1;justify-content:center;padding:40px 16px 200px}.policy-pick-card{background:#3b82f6;border:none;border-radius:20px;box-shadow:0 8px 32px #3b82f640;color:#fff;margin-top:20px;max-width:340px;padding:28px 24px;position:relative;transition:all .3s ease;width:100%}.policy-pick-card.selected{animation:selectedPulse .3s ease-out;background:#2563eb;border:3px solid #22c55e;box-shadow:0 12px 48px #2563eb66;padding:25px 21px;position:relative;transform:scale(1.02)}.policy-pick-card.selected:after{background:#22c55e;border-radius:50%;box-shadow:0 2px 8px #22c55e4d;content:""}.policy-pick-card.selected:after,.policy-pick-card.selected:before{align-items:center;display:flex;height:32px;justify-content:center;position:absolute;right:-8px;top:-8px;width:32px}.policy-pick-card.selected:before{color:#fff;content:"✓";font-size:18px;font-weight:700;z-index:1}.policy-pick-card .policy-text{color:#fff!important;font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1.6;margin:0;text-align:center}.policy-pick-card.selected .policy-text{color:#fff!important}.policy-pick-actions{align-items:center;bottom:50px;display:flex;height:100px;justify-content:center;left:0;position:fixed;right:0;z-index:10}.circular-action-buttons{gap:100px;max-width:280px;width:100%}.circular-action-buttons,.circular-btn{align-items:center;display:flex;justify-content:center;padding:0}.circular-btn{background:#0000001a;border:3px solid #fffffff2;border-radius:50%;box-shadow:0 6px 20px #0000001f,0 2px 8px #00000014;cursor:pointer;flex-shrink:0;transition:all .2s ease}.circular-btn.skip-btn{background:#ef4444;background:linear-gradient(135deg,#f87171,#ef4444);height:90px;width:90px}.circular-btn.add-btn{background:#22c55e;background:linear-gradient(135deg,#4ade80,#22c55e);height:90px;width:90px}.circular-btn.add-btn.already-selected{background:#16a34a;background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 8px 24px #22c55e4d;filter:brightness(.9);transform:scale(1.08)}.circular-btn:hover:not(:disabled){filter:brightness(.95);transform:scale(1.08)}.circular-btn:active:not(:disabled){transform:scale(.97)}.circular-btn:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.circular-btn.loading{cursor:not-allowed;opacity:.8}.circular-btn .btn-icon{height:35%;width:35%}.action-btn{align-items:center;border:none;border-radius:16px;cursor:pointer;display:flex;font-size:18px;font-weight:600;gap:8px;justify-content:center;transition:all .2s ease;width:100%}.action-btn svg{height:20px;width:20px}.add-btn{background:#22c55e;box-shadow:0 4px 20px #22c55e4d;color:#fff;height:56px}.add-btn:hover:not(:disabled){background:#16a34a;box-shadow:0 6px 30px #22c55e66;transform:translateY(-2px)}.add-btn:active:not(:disabled){transform:translateY(0)}.add-btn:disabled{cursor:not-allowed;opacity:.7}.add-btn.already-selected{background:#e2e8f0;box-shadow:none;color:#64748b}.skip-btn{background:#e2e8f0;color:#64748b;height:48px}.skip-btn:hover{background:#cbd5e1}.review-btn{background:#3b82f6;box-shadow:0 4px 20px #3b82f64d;color:#fff;font-size:18px;height:60px}.review-btn:hover{background:#2563eb;box-shadow:0 6px 30px #3b82f666;transform:translateY(-2px)}.selected-counter{align-items:center;background:#3b82f6;border:none;border-radius:20px;bottom:170px;box-shadow:0 4px 16px #3b82f640;color:#fff;cursor:pointer;display:flex;font-size:16px;gap:6px;padding:10px 18px;position:fixed;right:50%;transform:translateX(50%);transition:all .2s ease;z-index:100}.selected-counter:hover{box-shadow:0 6px 30px #3b82f666;transform:scale(1.05)}.counter-number{font-size:18px;font-weight:600}.counter-label{font-size:15px;font-weight:500}.drawer-overlay{animation:fadeIn .2s ease;background:#00000080;top:0;z-index:200}.drawer-overlay,.review-drawer{bottom:0;left:0;position:fixed;right:0}.review-drawer{animation:slideUp .3s ease;background:#fff;border-radius:24px 24px 0 0;box-shadow:0 -4px 20px #0000001a;display:flex;flex-direction:column;max-height:80vh;z-index:201}.drawer-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:24px}.drawer-header h2{color:#1e293b;font-size:20px;font-weight:700;margin:0}.drawer-close{align-items:center;background:#f8fafc;border:none;border-radius:50%;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s ease;width:40px}.drawer-close:hover{background:#e2e8f0}.drawer-close svg{color:#64748b;height:20px;width:20px}.drawer-content{flex:1 1;overflow-y:auto;padding:20px}.empty-message{font-size:16px;margin:40px 0;text-align:center}.selected-policies-list{display:flex;flex-direction:column;gap:12px}.selected-policy-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;gap:12px;padding:16px}.selected-policy-text{color:#fff;flex:1 1;font-size:15px;line-height:1.5;margin:0}.remove-btn{align-items:center;background:#fee2e2;border:none;border-radius:50%;cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all .2s ease;width:32px}.remove-btn:hover{background:#fecaca}.remove-btn svg{color:#ef4444;height:16px;width:16px}.drawer-footer{border-top:1px solid #e2e8f0;padding:20px}.submit-btn{background:#3b82f6;box-shadow:0 4px 20px #3b82f64d;height:56px;transition:all .2s ease}.submit-btn:hover{background:#2563eb;box-shadow:0 6px 30px #3b82f666}.loading-spinner{border:2px solid #ffffff4d;border-top-color:#fff;display:inline-block;flex-shrink:0;height:20px;width:20px}.submitting-message{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:16px;justify-content:center}.submitting-message .loading-spinner{border:3px solid #3b82f633;border-top-color:#3b82f6;height:32px;width:32px}.submitting-message p{font-size:18px;font-weight:500;margin:0}@keyframes selectedPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1.02)}}.action-btn.loading{cursor:not-allowed;opacity:.8}.action-btn:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.submit-btn.submitting{cursor:not-allowed;opacity:.8}.submit-btn .loading-spinner{margin-right:8px}.error-message{border:1px solid #fecaca;border-radius:8px;margin-bottom:16px;padding:12px 16px}.error-message p{font-size:14px;font-weight:500}.empty-selection-message{color:#64748b;padding:40px 20px;text-align:center}.empty-selection-message h3{color:#475569;font-size:18px;margin:0 0 8px}.empty-selection-message p{font-size:14px;line-height:1.5;margin:0}.policy-pick-card,.review-drawer{transform:translateZ(0);will-change:transform}@media (max-width:768px){.policy-pick-title{font-size:18px}.policy-pick-card{padding:24px}.policy-pick-card .policy-text{color:#fff!important;font-size:24px}.circular-btn.skip-btn{height:70px;width:70px}.circular-btn.add-btn{height:85px;width:85px}.action-btn{font-size:16px}.loading-spinner{height:14px;width:14px}.policy-pick-actions{bottom:50px}}@media (max-width:480px){.policy-pick-header{padding:12px}.policy-pick-title{font-size:16px}.progress-container{max-width:220px}.progress-text{font-size:12px}.policy-pick-card{max-width:100%;padding:20px}.policy-pick-card .policy-text{color:#fff!important;font-size:20px}.circular-btn.skip-btn{height:60px;width:60px}.circular-btn.add-btn{height:75px;width:75px}.action-btn{font-size:15px}.add-btn{height:52px}.skip-btn{height:44px}.selected-counter{bottom:160px;font-size:15px;padding:8px 16px}.circular-action-buttons{gap:80px;max-width:260px}.policy-pick-actions{bottom:50px}.counter-number{font-size:18px}.counter-label{font-size:12px}}.policy-pick-instructions{background:#fff;border-bottom:1px solid #e5e7eb;margin-bottom:0;padding:12px 20px 8px;text-align:center}.policy-pick-instructions h2{color:#1e293b;font-size:20px;font-weight:700;margin:0 0 4px}.policy-pick-instructions p{color:#64748b;font-size:14px;margin:0}.policy-pick-list{-webkit-overflow-scrolling:touch;background:linear-gradient(180deg,#f0f9ff,#e0f2fe 50%,#bae6fd);flex:1 1;overflow-y:auto;padding:12px 12px 80px;position:relative}.policy-list-card{align-items:center;background:#fff;border:2px solid #0000;border-radius:14px;box-shadow:0 2px 6px #0000000f;cursor:pointer;display:flex;gap:14px;margin-bottom:10px;overflow:hidden;padding:16px 18px;position:relative;transition:all .2s ease}.policy-list-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.policy-list-card:active{transform:translateY(0)}.policy-list-card.selected{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#2563eb;box-shadow:0 4px 16px #3b82f640}.policy-list-card.selected:hover{box-shadow:0 6px 20px #3b82f659;transform:translateY(-2px)}.policy-card-content{flex:1 1}.policy-list-card .policy-text{color:#1e293b;font-size:16px;font-weight:500;line-height:1.5;margin:0}.policy-list-card.selected .policy-text{color:#fff}.policy-card-indicator{align-items:center;background:#f1f5f9;border-radius:50%;display:flex;flex-shrink:0;height:28px;justify-content:center;width:28px}.policy-list-card.selected .policy-card-indicator{background:#fff3}.policy-card-indicator .checkmark{animation:checkmarkPop .3s ease;color:#fff;height:16px;width:16px}@keyframes checkmarkPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.progress-container{max-width:280px}.progress-bar{background:#e5e7eb}.progress-fill{transition:width .3s ease,background .3s ease}.progress-container.complete .progress-fill{background:linear-gradient(90deg,#22c55e,#16a34a)}.progress-container.complete .progress-text{color:#22c55e;font-weight:600}.progress-text{color:#6b7280;font-size:14px;font-weight:500}.policy-pick-submit-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(0deg,#fff 0,#fffffffa);border-top:1px solid #e2e8f0cc;bottom:0;left:0;padding:12px 16px;position:fixed;right:0;z-index:100}.submit-button{align-items:center;border:none;border-radius:12px;box-shadow:0 3px 12px #3b82f640;color:#fff;cursor:pointer;display:flex;font-size:17px;font-weight:600;gap:10px;height:48px;justify-content:center;position:relative;transition:all .2s ease;width:100%}.submit-button,.submit-button:not(:disabled){background:linear-gradient(135deg,#3b82f6,#2563eb)}.submit-button:hover:not(:disabled){box-shadow:0 6px 30px #3b82f666;transform:translateY(-2px)}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button.disabled{background:#e5e7eb;box-shadow:none;cursor:not-allowed}.submit-button.disabled span,.submit-button.disabled svg{color:#9ca3af}.submit-button:not(.disabled):not(.submitting){box-shadow:0 4px 16px #3b82f64d}.submit-button.submitting{cursor:wait;opacity:.8}.submit-hint{color:#64748b;font-size:13px;margin-bottom:0;margin-top:8px;text-align:center}.empty-state{font-size:16px;padding:40px}@media (max-width:768px){.policy-pick-instructions{padding:10px 16px 8px}.policy-pick-instructions h2{font-size:18px;margin:0 0 6px}.policy-list-card{padding:16px}.policy-list-card .policy-text{font-size:15px}.progress-container{max-width:250px}.progress-bar{height:6px}.progress-text{font-size:13px}.policy-pick-counter .counter-number{font-size:16px}.policy-pick-counter .counter-label{font-size:13px}.submit-button{font-size:16px;height:44px}.policy-pick-submit-section{padding:10px 12px}}.palumba-quiz-container{margin:0}.palumba-nav-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.palumba-title{font-size:24px;letter-spacing:-1px}.palumba-instruction{margin-bottom:12px;margin-top:8px;padding:0 16px}.instruction-text{color:#64748b;font-size:18px;font-weight:600}.palumba-policy-section{padding:0 16px 50px}.palumba-policy-box{border:2px solid #3b82f61a;border-radius:32px;box-shadow:0 20px 60px #00000014,0 0 0 1px #0000000a;max-width:600px;overflow:hidden;padding:48px 40px;transform:translateY(-10px)}.palumba-scale-wrapper{align-items:flex-end;bottom:0;display:flex;height:260px;justify-content:center;left:0;position:absolute;right:0}.palumba-scale{height:100%;max-width:500px;position:relative;width:100%}.palumba-scale-segments{border-radius:240px 240px 0 0;bottom:0;display:flex;height:240px;left:50%;overflow:hidden;position:absolute;transform:translateX(-50%);width:450px}.scale-segment{align-items:center;border:none;cursor:pointer;display:flex;flex:1 1;justify-content:center;margin:-10px -5px;min-height:240px;overflow:hidden;padding:10px 5px;position:relative;transition:all .25s ease}.scale-segment.strongly-disagree{background:#fca5a5;background:linear-gradient(135deg,#fecaca,#fca5a5)}.scale-segment.disagree{background:#fdba74;background:linear-gradient(135deg,#fed7aa,#fdba74)}.scale-segment.agree{background:#86efac;background:linear-gradient(135deg,#bbf7d0,#86efac)}.scale-segment.strongly-agree{background:#4ade80;background:linear-gradient(135deg,#86efac,#4ade80)}.scale-segment:not(:first-child){border-left:2px solid #fff6}.scale-segment:hover{filter:brightness(1.15);transform:scaleY(1.08);z-index:1}.scale-segment.selected{box-shadow:inset 0 0 20px #0003;filter:brightness(.85);transform:scaleY(.95)}.segment-icon{color:#fff;font-size:32px;font-weight:700;text-shadow:0 2px 4px #0003}.segment-icon.large{font-size:40px}.neutral-button,.segment-label{display:none}.palumba-policy-box:before{background:linear-gradient(90deg,#3b82f6,#8b5cf6 50%,#3b82f6);border-radius:32px 32px 0 0;height:6px;left:-2px;right:-2px;top:-2px}.neutral-button:active,.scale-segment:active{animation:pulse .3s ease-out}.palumba-policy-section.dragging .palumba-policy-box{transition:transform .1s ease-out}.scale-segment:active:after{animation:ripple .4s ease-out;background:#fff3;content:"";inset:0;position:absolute}@keyframes ripple{0%{opacity:1;transform:scale(0)}to{opacity:0;transform:scale(1)}}@media (max-width:768px){.palumba-title{font-size:24px}.palumba-nav-button{height:44px;width:44px}.palumba-policy-box{padding:30px 24px}.palumba-policy-statement{font-size:20px}.palumba-policy-section{padding-bottom:40px}.palumba-scale-wrapper{height:210px}.palumba-scale-segments{border-radius:190px 190px 0 0;height:190px;width:380px}.scale-segment{min-height:190px}.segment-icon{font-size:30px}.segment-icon.large{font-size:36px}.instruction-text{font-size:18px}}@media (max-width:480px){.palumba-header{padding:16px}.palumba-title{font-size:20px}.palumba-nav-button{height:44px;width:44px}.palumba-nav-button svg{height:20px;width:20px}.palumba-policy-box{border-radius:20px;padding:24px 20px}.palumba-policy-statement{font-size:18px}.palumba-policy-section{padding-bottom:30px}.palumba-scale-wrapper{height:180px}.palumba-scale-segments{border-radius:160px 160px 0 0;height:160px;width:320px}.scale-segment{min-height:160px}.segment-icon{font-size:26px}.segment-icon.large{font-size:32px}.instruction-text{font-size:16px}}body.palumba-quiz-active{overflow:hidden}body.palumba-quiz-active .navbar,body.palumba-quiz-active header,body.palumba-quiz-active nav{display:none!important}body.palumba-quiz-active #root>div{margin:0!important;padding:0!important}.palumba-binary-section{padding-bottom:40px;position:relative}.palumba-binary-options{display:flex;gap:30px;justify-content:center;margin:0 auto;max-width:500px;padding:0 20px}.palumba-binary-btn{border:none;border-radius:20px;box-shadow:0 4px 15px #0000001a;cursor:pointer;flex:1 1;font-size:18px;font-weight:600;max-width:200px;padding:20px 30px;transition:all .3s ease}.palumba-binary-btn.disagree{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:3px solid #ef4444;color:#ef4444}.palumba-binary-btn.agree{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:3px solid #10b981;color:#10b981}.palumba-binary-btn:hover{box-shadow:0 6px 20px #00000026;transform:translateY(-3px)}.palumba-binary-btn.selected.disagree{background:#ef4444;border-color:#ef4444;color:#fff}.palumba-binary-btn.selected.agree{background:#10b981;border-color:#10b981;color:#fff}.binary-label{font-size:inherit;font-weight:inherit}@media (max-width:768px){.palumba-binary-options{flex-direction:column;gap:20px}.palumba-binary-btn{font-size:16px;max-width:100%;padding:18px 24px}}@media (max-width:480px){.palumba-binary-btn{font-size:15px;padding:16px 20px}}.palumba-progress-indicator{display:flex;justify-content:center;margin-bottom:20px}.progress-dots{display:flex;gap:8px}.progress-dot{background:#3b82f633;border-radius:50%;height:8px;transition:all .3s ease;width:8px}.progress-dot.active{background:#3b82f6;transform:scale(1.2)}.swipe-hint{animation:fadeInOut 3s ease-in-out infinite;bottom:20px;color:#64748b;font-size:14px;left:50%;opacity:.7;position:absolute;transform:translateX(-50%)}@keyframes slideIn{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}.palumba-policy-box{animation:fadeIn .5s ease-out}.palumba-policy-box.swipe-left{animation:slideOutLeft .3s ease-out forwards}.palumba-policy-box.swipe-right{animation:slideOutRight .3s ease-out forwards}@keyframes slideOutLeft{to{opacity:0;transform:translateX(-100%) rotate(-5deg)}}@keyframes slideOutRight{to{opacity:0;transform:translateX(100%) rotate(5deg)}}.palumba-binary-options,.palumba-scale{animation:fadeIn .5s ease-out .2s both}.palumba-loading{left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.loading-spinner{border:4px solid #3b82f61a;height:40px;width:40px}.voting-options-container{margin-top:12px;padding:16px}.voting-options-stack{display:flex;flex-direction:column;gap:8px;margin:0 auto;max-width:400px}.voting-option{align-items:center;background:#fff;border:2px solid #0000;border-radius:16px;box-shadow:0 2px 8px #0000000d;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:16px;justify-content:flex-start;min-height:56px;overflow:hidden;padding:16px 20px;position:relative;transition:all .2s ease}.voting-option:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-2px)}.voting-option:active{transform:translateY(0);transition:transform .1s}.option-icon{font-size:20px;font-weight:700;min-width:30px;text-align:center}.option-label{flex:1 1;font-size:16px;letter-spacing:-.01em;text-align:left}.voting-option.strongly-disagree{background:#fef2f2;border-color:#fecaca;color:#dc2626}.voting-option.strongly-disagree:hover{background:#fee2e2;border-color:#fca5a5}.voting-option.strongly-disagree.selected{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#0000;box-shadow:0 4px 16px #ef44444d;color:#fff}.voting-option.disagree{background:#fff7ed;border-color:#fed7aa;color:#ea580c}.voting-option.disagree:hover{background:#fef3c7;border-color:#fdba74}.voting-option.disagree.selected{background:linear-gradient(135deg,#f97316,#ea580c);border-color:#0000;box-shadow:0 4px 16px #f973164d;color:#fff}.voting-option.neutral{background:#f9fafb;border-color:#e5e7eb;color:#6b7280}.voting-option.neutral:hover{background:#f3f4f6;border-color:#d1d5db}.voting-option.neutral.selected{background:linear-gradient(135deg,#9ca3af,#6b7280);border-color:#0000;box-shadow:0 4px 16px #6b72804d;color:#fff}.voting-option.agree{background:#f0fdf4;border-color:#bbf7d0;color:#16a34a}.voting-option.agree:hover{background:#ecfdf5;border-color:#86efac}.voting-option.agree.selected{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#0000;box-shadow:0 4px 16px #22c55e4d;color:#fff}.voting-option.strongly-agree{background:#ecfdf5;border-color:#86efac;color:#15803d}.voting-option.strongly-agree:hover{background:#dcfce7;border-color:#4ade80}.voting-option.strongly-agree.selected{background:linear-gradient(135deg,#16a34a,#15803d);border-color:#0000;box-shadow:0 4px 16px #16a34a4d;color:#fff}.voting-option.selected:after{align-items:center;animation:checkmark .3s ease-out;background:#fff;border-radius:50%;box-shadow:inset 0 0 0 2px #ffffff4d;content:"";display:flex;height:24px;justify-content:center;position:absolute;right:20px;top:50%;transform:translateY(-50%);width:24px}.voting-option.selected:before{color:#fff;content:"✓";font-size:14px;font-weight:700;position:absolute;right:26px;top:50%;transform:translateY(-50%);z-index:1}@keyframes checkmark{0%{opacity:0;transform:translateY(-50%) scale(0)}to{opacity:1;transform:translateY(-50%) scale(1)}}.palumba-scale-wrapper{display:none}.palumba-quiz-container{padding:0}.palumba-policy-section{flex:0 0 auto;margin-bottom:0;padding:8px 0 16px}.palumba-policy-box{margin-bottom:0;padding:24px 20px}.palumba-instruction{margin-bottom:16px;padding:0 20px}.quiz-progress-bar{margin-bottom:20px;padding:0 20px}.progress-bar-container{border-radius:3px;height:6px}.progress-bar-fill{border-radius:3px;box-shadow:0 1px 3px #0000001a;transition:width .5s ease-out}@media (max-width:480px){.voting-option{font-size:15px;min-height:52px;padding:14px 16px}.option-icon{font-size:18px;min-width:26px}.option-label{font-size:15px}.voting-option.selected:after{height:20px;right:16px;width:20px}.voting-option.selected:before{font-size:12px;right:21px}}.swipeable-card{touch-action:pan-y;user-select:none;-webkit-user-select:none}.swipe-bottom-actions{bottom:30px;height:130px;left:0;position:fixed;right:0;z-index:100}.swipe-background-sections{display:none}.swipe-action-buttons{align-items:center;display:flex;inset:0;justify-content:space-around;margin-bottom:5rem;padding:0 20px;position:absolute;z-index:10}.swipe-action-btn{align-items:center;background:#0000001a;border:3px solid #fffffff2;border-radius:50%;box-shadow:0 6px 20px #0000001f,0 2px 8px #00000014;cursor:pointer;display:flex;justify-content:center;padding:0;transition:all .2s ease}.swipe-action-btn.strongly-agree,.swipe-action-btn.strongly-disagree{height:90px;width:90px}.swipe-action-btn.agree,.swipe-action-btn.disagree{height:72px;width:72px}.swipe-action-btn.neutral{height:56px;width:56px}.swipe-action-btn.strongly-disagree{background:#ef4444;background:linear-gradient(135deg,#f87171,#ef4444)}.swipe-action-btn.disagree{background:#f97316;background:linear-gradient(135deg,#fb923c,#f97316)}.swipe-action-btn.neutral{background:#6b7280;background:linear-gradient(135deg,#9ca3af,#6b7280)}.swipe-action-btn.agree{background:#22c55e;background:linear-gradient(135deg,#4ade80,#22c55e)}.swipe-action-btn.strongly-agree{background:#16a34a;background:linear-gradient(135deg,#22c55e,#16a34a)}.swipe-action-btn:hover{filter:brightness(.95);transform:scale(1.08)}.swipe-action-btn:active{transform:scale(.97)}.swipe-action-btn.selected{border-width:4px;box-shadow:0 8px 24px #00000026;filter:brightness(.9);transform:scale(1.12)}.swipe-action-btn .btn-icon{height:40%;width:40%}.swipe-action-btn.strongly-agree .btn-icon,.swipe-action-btn.strongly-disagree .btn-icon{height:35%;width:35%}.swipe-action-btn.neutral .btn-icon{height:50%;width:50%}.palumba-policy-section{align-items:flex-start;justify-content:center;padding:40px 16px 170px}.palumba-policy-box{background:#3b82f6;border:none;box-shadow:0 8px 32px #3b82f640;color:#fff;margin:20px auto 0;max-width:340px;padding:28px 24px;transition:all .3s ease;width:100%}.palumba-policy-box:before{display:none}.palumba-policy-statement{color:#fff;font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1.6}.progress-bar-fill{background:linear-gradient(90deg,#22c55e,#16a34a)}.voting-options-container{display:none}@media (max-width:768px){.swipe-bottom-actions{bottom:20px;height:120px}.swipe-action-btn.strongly-agree,.swipe-action-btn.strongly-disagree{height:80px;width:80px}.swipe-action-btn.agree,.swipe-action-btn.disagree{height:64px;width:64px}.swipe-action-btn.neutral{height:48px;width:48px}.palumba-policy-section{padding-bottom:150px}}@media (max-width:480px){.swipe-bottom-actions{bottom:15px;height:110px}.swipe-action-buttons{padding:0 10px}.swipe-action-btn.strongly-agree,.swipe-action-btn.strongly-disagree{height:70px;width:70px}.swipe-action-btn.agree,.swipe-action-btn.disagree{height:56px;width:56px}.swipe-action-btn.neutral{height:44px;width:44px}.swipe-action-btn{border-width:2px}.palumba-policy-section{padding-bottom:135px}.palumba-policy-statement{font-size:20px}}.quiz-container{background-color:#f7f9fc;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;margin:0 auto;max-width:800px;min-height:calc(100vh - 56px);padding:2rem 1rem;width:100%}.quiz-type-scale .quiz-container{background:linear-gradient(180deg,#e8f3f9 0,#b8d9e8)}body:has(.palumba-quiz-layout) .navbar,body:has(.palumba-quiz-layout) nav{display:none!important}body:has(.palumba-quiz-layout) main{height:100vh!important;padding:0!important}body:has(.palumba-quiz-layout){overflow:hidden}.election-banner{animation:gradientFlow 8s ease infinite,fadeIn .8s ease-out;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:linear-gradient(135deg,#3b82f6,#1e40af);background-size:200% 200%;border:1px solid #fff3;border-radius:1rem;box-shadow:0 8px 24px #2563eb40,0 4px 8px #2563eb26;margin-bottom:2rem;overflow:hidden;padding:1.5rem 2rem;position:relative}@keyframes gradientFlow{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.election-banner:before{animation:shimmer 5s ease-in-out infinite;background:linear-gradient(to bottom right,#fff0,#ffffff0d 50%,#fff0);content:"";height:200%;left:-50%;pointer-events:none;position:absolute;top:-50%;transform:rotate(45deg);width:200%;z-index:1}.election-banner h2{font-size:1.75rem;font-weight:700;letter-spacing:-.01em;margin:0 0 .75rem;position:relative;text-shadow:0 2px 4px #0000001a;z-index:2}.election-meta{align-items:center;animation:fadeIn 1s ease-out .3s forwards;animation-fill-mode:both;font-size:.9rem;gap:1.5rem;margin:0 auto;opacity:0;position:relative;z-index:2}.election-jurisdiction{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#ffffff26;border:1px solid #ffffff4d;border-radius:2rem;box-shadow:0 2px 8px #0000001a;flex-shrink:0;font-size:.8rem;font-weight:700;letter-spacing:.03em;padding:.4rem 1rem;position:relative;text-transform:uppercase;transition:all .3s ease}.election-jurisdiction:hover{background-color:#ffffff40;box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.election-jurisdiction:before{background-color:#10b981;border-radius:50%;box-shadow:0 0 0 2px #10b98133;content:"";display:inline-block;height:8px;margin-right:.5rem;vertical-align:middle;width:8px}.election-date{align-items:center;color:#fff;display:flex;flex-direction:column;font-weight:500;gap:.4rem;transition:all .3s ease}.quiz-label{color:#ffffffe6;font-size:.8rem;font-weight:700;letter-spacing:.05em;position:relative;text-transform:uppercase}.quiz-label:after{background-color:#fff;bottom:-4px;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:width .3s ease;width:0}.election-date:hover .quiz-label:after{width:70%}.date-values{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#ffffff2e;border:1px solid #fff3;border-radius:.6rem;box-shadow:0 2px 8px #0000001a;color:#fff;font-weight:600;padding:.4rem 1rem;transition:all .3s ease}.date-values:hover{background-color:#ffffff40;transform:translateY(-1px)}.quiz-header{padding:1rem 0 1.5rem;text-align:center}.quiz-title{color:#1e293b;font-size:2rem;margin:0 0 .5rem}.quiz-subtitle{color:#64748b;font-size:1.1rem;font-weight:400;margin:0}.quiz-card{animation:cardAppear .8s cubic-bezier(.16,1,.3,1) both;background-image:linear-gradient(180deg,#fff,#fafbff);border:1px solid #e2e8f0cc;border-radius:1.25rem;box-shadow:0 20px 40px #0000000d,0 5px 20px #3b82f612;flex-grow:1;margin:0 0 1rem;transform:translateY(0);transition:all .4s cubic-bezier(.16,1,.3,1)}@keyframes cardAppear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.quiz-card:before{background:radial-gradient(circle at top right,#3b82f608,#0000 70%),radial-gradient(circle at bottom left,#10b98108,#0000 70%);content:"";inset:0;opacity:.8;position:absolute;transition:opacity .5s ease;z-index:-1}.quiz-card:hover{box-shadow:0 25px 50px #00000012,0 10px 24px #3b82f61a;transform:translateY(-5px)}.quiz-card:hover:before{opacity:1}.progress-section{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:linear-gradient(90deg,#f9fafbe6,#f0f9ffe6);border-bottom:1px solid #e2e8f0b3;overflow:visible;padding:1.5rem 2rem;position:relative;z-index:2}.progress-section:after{background:linear-gradient(90deg,#0000,#3b82f6,#0000);bottom:-1px;content:"";height:1px;left:0;opacity:.3;position:absolute;right:0}.progress-header{color:#4a5568;font-size:1rem;font-size:.9rem;font-weight:500;letter-spacing:.03em;margin-bottom:.75rem;text-transform:uppercase}.progress-count{animation:pulse 2s ease-in-out infinite;background-color:#f0f9ffcc;border:1px solid #3b82f633;border-radius:2rem;box-shadow:0 2px 8px #2563eb1a;color:#2d3748;font-family:SF Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85rem;font-weight:700;padding:.3rem .75rem}.quiz-container .progress-bar{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#e2e8f0e6;border:1px solid #e2e8f0;border-radius:9999px;box-shadow:inset 0 1px 3px #0000001a;height:.6rem;margin:.25rem 0;overflow:hidden;position:relative}.quiz-container .progress-bar:after{background:linear-gradient(180deg,#fff3,#0000);content:"";height:50%;left:0;pointer-events:none;position:absolute;right:0;top:0}.quiz-container .progress-value{background:linear-gradient(90deg,#4f46e5,#3b82f6)!important;border-radius:9999px;box-shadow:0 1px 5px #2563eb80;display:block!important;height:100%;min-width:2px;opacity:1!important;overflow:hidden;position:relative;transition:width .7s cubic-bezier(.16,1,.3,1);z-index:1}.quiz-container .progress-value:before{animation:shimmerProgress 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transform:skewX(-25deg);width:50%}@keyframes shimmerProgress{0%{left:-100%}to{left:200%}}.policy-section{animation:sectionFadeIn .8s ease-out .2s both;background:linear-gradient(180deg,#ffffffe6,#f9fafbf2);padding:2rem 2.5rem 2.5rem;position:relative}@keyframes sectionFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.policy-section h2{animation:titleAppear .8s ease-out .4s both;color:#1e293b;display:inline-block;font-size:1.35rem;font-weight:700;letter-spacing:-.01em;margin:0 0 1.5rem;position:relative}@keyframes titleAppear{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.policy-section h2:after{animation:lineExpand 1s cubic-bezier(.16,1,.3,1) .6s both;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:3px;bottom:-6px;content:"";height:3px;left:0;position:absolute;transform-origin:left;width:40%}@keyframes lineExpand{0%{opacity:0;transform:scaleX(0)}to{opacity:1;transform:scaleX(1)}}.policy-statement{animation:statementAppear .8s cubic-bezier(.16,1,.3,1) .6s both;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:linear-gradient(135deg,#ffffffe6,#f0f9fff2);border:1px solid #e2e8f0cc;border-radius:1rem;box-shadow:0 10px 30px #00000008,0 5px 15px #3b82f60d;margin-bottom:2.5rem;overflow:hidden;padding:2rem 2.5rem;position:relative;transform:translateY(0);transition:all .3s ease}@keyframes statementAppear{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.policy-statement:before{color:#3b82f60f;content:'"';font-family:Georgia,serif;font-size:8rem;font-weight:700;left:1rem;line-height:.5;position:absolute;top:-1.5rem;z-index:0}.policy-statement:hover{box-shadow:0 15px 35px #0000000d,0 7px 20px #3b82f614;transform:translateY(-3px)}.policy-statement p{color:#1e293b;font-size:1.2rem;font-weight:500;line-height:1.7;margin:0;position:relative;z-index:1}.question-prompt{animation:promptFadeIn .8s cubic-bezier(.16,1,.3,1) .8s both;color:#334155;font-size:1.3rem;font-weight:600;margin:2.5rem 0;padding:.5rem 0;position:relative;text-align:center;transition:transform .3s ease}@keyframes promptFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.question-prompt:after,.question-prompt:before{background:linear-gradient(90deg,#0000,#3b82f64d,#0000);content:"";height:2px;position:absolute;top:50%;transform:translateY(-50%);width:5rem}.question-prompt:before{left:15%}.question-prompt:after{right:15%}.action-buttons{animation:buttonsAppear .8s cubic-bezier(.16,1,.3,1) 1s both;gap:1rem;margin-bottom:2rem;padding:0 2rem}@keyframes buttonsAppear{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.agree-button,.disagree-button{align-items:center;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:none;border-radius:1rem;box-shadow:0 8px 16px #0000000d;cursor:pointer;display:flex;font-size:1.15rem;font-weight:600;justify-content:center;letter-spacing:.01em;outline:none;overflow:hidden;padding:1.2rem;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1);width:100%;z-index:1}.agree-button:before,.disagree-button:before{content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s ease;z-index:-1}.agree-button:after,.disagree-button:after{background:linear-gradient(to bottom right,#fff0,#ffffff1a 50%,#fff0);content:"";height:200%;left:-50%;opacity:0;position:absolute;top:-50%;transform:rotate(45deg);transition:all .6s cubic-bezier(.16,1,.3,1);width:200%;z-index:-1}.agree-button{background:linear-gradient(135deg,#10b981e6,#059669f2);border:1px solid #10b98133;box-shadow:0 8px 20px #10b98126,0 4px 10px #10b9811a;color:#fff}.agree-button:before{background:linear-gradient(135deg,#06b67af2,#047857)}.agree-button:hover{box-shadow:0 12px 24px #10b98133,0 6px 12px #10b98126;transform:translateY(-3px)}.agree-button:hover:before{opacity:1}.agree-button:hover:after{opacity:1;transform:rotate(45deg) translate(100%,100%)}.agree-button:active{box-shadow:0 6px 12px #10b98126;transform:translateY(-1px)}.disagree-button{background:linear-gradient(135deg,#ef4444e6,#dc2626f2);border:1px solid #ef444433;box-shadow:0 8px 20px #ef444426,0 4px 10px #ef44441a;color:#fff}.disagree-button:before{background:linear-gradient(135deg,#dc2626f2,#b91c1c)}.disagree-button:hover{box-shadow:0 12px 24px #ef444433,0 6px 12px #ef444426;transform:translateY(-3px)}.disagree-button:hover:before{opacity:1}.disagree-button:hover:after{opacity:1;transform:rotate(45deg) translate(100%,100%)}.disagree-button:active{box-shadow:0 6px 12px #ef444426;transform:translateY(-1px)}.agree-button.selected,.disagree-button.selected{animation:pulseSelection .5s cubic-bezier(.16,1,.3,1);font-weight:700}@keyframes pulseSelection{0%{transform:scale(1)}50%{transform:scale(1.03)}to{transform:scale(1)}}.agree-button.selected{background:linear-gradient(135deg,#10b981,#047857);box-shadow:0 10px 25px #10b98140,0 6px 12px #10b98133;color:#fff}.agree-button.selected:before{content:"✓";font-size:1.25rem;opacity:.8;position:absolute;right:1.5rem}.disagree-button.selected{background:linear-gradient(135deg,#ef4444,#b91c1c);box-shadow:0 10px 25px #ef444440,0 6px 12px #ef444433;color:#fff}.disagree-button.selected:before{content:"✕";font-size:1.25rem;opacity:.8;position:absolute;right:1.5rem}.agree-button:disabled,.disagree-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.agree-button:disabled:before,.disagree-button:disabled:before{opacity:0}.agree-button:disabled:after,.disagree-button:disabled:after{display:none}.quiz-footer{animation:footerAppear .8s ease-out 1.2s both;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#f8fafcb3;border-radius:0 0 1.25rem 1.25rem;border-top:1px solid #e2e8f0b3;color:#64748b;font-size:.9rem;font-style:italic;margin:0;padding:1.5rem 2rem;position:relative;text-align:center}@keyframes footerAppear{0%{opacity:0}to{opacity:1}}.quiz-footer:before{background:linear-gradient(90deg,#0000,#3b82f64d,#0000);content:"";height:1px;left:0;position:absolute;right:0;top:-1px}.loading-container{animation:fadeIn .8s ease-out;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #e2e8f0cc;border-radius:1.25rem;box-shadow:0 20px 50px #0000000d,0 10px 24px #00000008;height:50vh;overflow:hidden;padding:3rem;position:relative}.loading-container:before{background:radial-gradient(circle at top right,#3b82f608,#0000 70%),radial-gradient(circle at bottom left,#10b98108,#0000 70%);content:"";inset:0;position:absolute}.loading-spinner{animation:spin 1.2s cubic-bezier(.5,.1,.5,.9) infinite;border:3px solid #3b82f626;box-shadow:0 4px 16px #3b82f626;height:3.5rem;margin-bottom:2rem;position:relative;width:3.5rem}.loading-spinner:before{animation:pulseRing 2s cubic-bezier(.4,0,.6,1) infinite;border:2px solid #3b82f60f;border-radius:50%;content:"";inset:-10px;opacity:0;position:absolute}.loading-text{color:#334155;font-size:1.2rem;text-align:center}.loading-subtext{font-size:.95rem;line-height:1.5;max-width:24rem;text-align:center}.completion-message,.error-message{animation:fadeIn .8s cubic-bezier(.16,1,.3,1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:linear-gradient(135deg,#fffffff2,#f8fafcf2);border:1px solid #e2e8f0cc;border-radius:1.25rem;box-shadow:0 20px 50px #0000000d,0 10px 24px #00000008;margin:0 0 1.5rem;overflow:hidden;padding:2.5rem;position:relative;text-align:center}.completion-message:before,.error-message:before{background:radial-gradient(circle at top right,#ef444408,#0000 70%),radial-gradient(circle at bottom left,#ef444405,#0000 70%);content:"";inset:0;opacity:.8;position:absolute;transition:opacity .5s ease;z-index:-1}.completion-message:before{background:radial-gradient(circle at top right,#3b82f608,#0000 70%),radial-gradient(circle at bottom left,#10b98108,#0000 70%)}.error-message h3{color:#dc2626;display:inline-block;font-size:1.5rem;font-weight:700;margin-bottom:1rem;position:relative}.error-message h3:after{background:linear-gradient(90deg,#0000,#ef444480,#0000);bottom:-6px;content:"";height:2px;left:25%;position:absolute;right:25%}.error-message p{color:#4b5563;font-size:1.1rem;line-height:1.6;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:36rem}.completion-message h2{animation:titleAppear .8s cubic-bezier(.16,1,.3,1) .2s both;color:#1d4ed8;display:inline-block;font-size:2rem;font-weight:700;margin-bottom:1rem;position:relative}.completion-message h2:after{animation:lineExpand 1s cubic-bezier(.16,1,.3,1) .4s both;background:linear-gradient(90deg,#0000,#3b82f680,#0000);bottom:-8px;content:"";height:3px;left:25%;position:absolute;right:25%;transform:scaleX(0);transform-origin:center}.completion-message p{animation:fadeIn .8s cubic-bezier(.16,1,.3,1) .4s both;color:#4b5563;font-size:1.15rem;line-height:1.6;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:36rem}.completion-stats{animation:fadeIn .8s cubic-bezier(.16,1,.3,1) .7s both;display:flex;gap:2.5rem;justify-content:center;margin-bottom:2.5rem}.stat-item{align-items:center;background:#f3f4f699;border:1px solid #e2e8f0cc;border-radius:1rem;box-shadow:0 5px 15px #00000008;display:flex;flex-direction:column;min-width:8rem;overflow:hidden;padding:1.25rem;position:relative;transition:all .3s ease}.stat-item:before{background:linear-gradient(135deg,#3b82f60d,#10b9810d);content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s ease}.stat-item:hover{box-shadow:0 8px 20px #0000000d;transform:translateY(-3px)}.stat-item:hover:before{opacity:1}.stat-value{text-fill-color:#0000;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#1d4ed8;font-size:2.5rem;margin-bottom:.5rem}.stat-label{font-size:.9rem;font-weight:500;text-align:center}.action-button{animation:buttonAppear .8s cubic-bezier(.16,1,.3,1) .6s both;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:.875rem;box-shadow:0 8px 20px #2563eb40;color:#fff;display:inline-block;font-size:1.1rem;font-weight:600;margin-top:1rem;padding:1rem 2rem;transition:all .3s cubic-bezier(.16,1,.3,1)}@keyframes buttonAppear{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.action-button:before{background:linear-gradient(to bottom right,#fff0,#ffffff1a 50%,#fff0);height:200%;left:-50%;top:-50%;transform:rotate(45deg);transition:all .6s cubic-bezier(.16,1,.3,1);width:200%;z-index:0}.action-button:hover{background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 12px 24px #2563eb59;transform:translateY(-3px)}.action-button:hover:before{transform:rotate(45deg) translate(100%,100%)}.action-button:active{box-shadow:0 6px 12px #2563eb33;transform:translateY(-1px)}.icon-button svg{margin-right:.75rem;transition:transform .3s ease}.icon-button:hover svg{transform:scale(1.15)}.intro-card{animation:slideUp .7s ease-out .5s both;background-image:linear-gradient(180deg,#ffffffe6,#f9fafbf2);border:1px solid #e2e8f0cc;border-radius:1.25rem;box-shadow:0 20px 50px #00000014,0 10px 20px #0000000a;opacity:0;position:relative;transform:translateY(20px);transition:all .5s cubic-bezier(.16,1,.3,1);z-index:1}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.intro-card:before{background:radial-gradient(circle at top right,#3b82f60d,#0000 70%),radial-gradient(circle at bottom left,#10b9810d,#0000 70%);content:"";inset:0;opacity:.7;position:absolute;transition:opacity .5s ease;z-index:-1}.intro-card:hover{box-shadow:0 25px 60px #0000001a,0 12px 24px #0000000d;transform:translateY(-5px)}.intro-card:hover:before{opacity:1}.intro-content{padding:2.5rem 3rem;position:relative}.intro-subtitle{animation:fadeIn .8s ease-out .7s both;display:inline-block;font-size:1.75rem;font-weight:700;margin-bottom:2rem;position:relative;text-align:center}.intro-subtitle:after{background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:3px;bottom:-10px;content:"";height:3px;left:0;opacity:.8;position:absolute;right:0;transform:scaleX(.7);transition:all .3s ease}.intro-subtitle:hover:after{opacity:1;transform:scaleX(1)}.intro-list{counter-reset:step-counter;margin-bottom:2.5rem}.intro-list-item{animation:fadeInLeft .5s ease-out;animation-fill-mode:both;border-left:2px solid #3b82f633;color:#334155;font-size:1.05rem;line-height:1.6;margin-bottom:1.25rem;opacity:0;padding-left:2rem;position:relative}.intro-list-item:first-child{animation-delay:.9s}.intro-list-item:nth-child(2){animation-delay:1.1s}.intro-list-item:nth-child(3){animation-delay:1.3s}@keyframes fadeInLeft{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.intro-list-item:hover{border-left-color:#3b82f6;transform:translateX(2px)}.intro-list-item:before{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:50%;box-shadow:0 4px 8px #3b82f64d;color:#fff;content:counter(step-counter);counter-increment:step-counter;display:flex;font-size:.85rem;font-weight:700;height:28px;justify-content:center;left:-15px;position:absolute;top:0;width:28px}.bullet{display:none}.intro-note{animation:fadeIn .8s ease-out 1.5s both;background-color:#f1f5f980;border-left:3px solid #64748b4d;border-radius:.75rem;box-shadow:0 2px 6px #00000008;font-size:.95rem;margin-left:auto;margin-right:auto;max-width:90%;padding:1rem 1.5rem;transition:all .3s ease}.intro-note:hover{background-color:#f1f5f9b3;border-left-color:#64748b;transform:translateX(2px)}.validation-info{animation:fadeIn .8s ease-out 1.7s both;background-color:#ecfdf580;border:1px solid #10b98133;border-radius:.75rem;box-shadow:0 4px 12px #10b98114;margin-bottom:2rem;overflow:hidden;padding:1.25rem 1.5rem;position:relative}.validation-info:before{color:#10b9810d;content:"✓";font-size:6rem;font-weight:700;position:absolute;right:-15px;top:-15px;transform:rotate(-10deg);z-index:0}.validation-message{color:#059669;font-weight:600;margin-bottom:.75rem;position:relative;z-index:1}.policy-count{background-color:#fff9;border-radius:2rem;color:#64748b;display:inline-block;font-size:.95rem;padding:.3rem .75rem;position:relative;z-index:1}.error-info{animation:fadeIn .8s ease-out 1.7s both;background-color:#fef2f2b3;border:1px solid #ef444433;border-radius:.75rem;box-shadow:0 4px 12px #ef444414;margin-bottom:2rem;overflow:hidden;padding:1.25rem 1.5rem;position:relative}.error-info:before{color:#ef44440d;content:"!";font-size:8rem;font-weight:700;position:absolute;right:-15px;top:-25px;z-index:0}.error-message{color:#dc2626;margin-bottom:1.25rem}.error-message,.reset-button{font-weight:600;position:relative;z-index:1}.reset-button{background:linear-gradient(135deg,#ef4444,#b91c1c);border:none;border-radius:.6rem;box-shadow:0 4px 12px #ef444440;cursor:pointer;font-size:.95rem;overflow:hidden;padding:.75rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.reset-button:before{background:linear-gradient(to bottom right,#fff0,#ffffff0d 50%,#fff0);content:"";height:200%;left:-50%;opacity:0;position:absolute;top:-50%;transform:rotate(45deg);transition:all .6s cubic-bezier(.4,0,.2,1);width:200%;z-index:-1}.reset-button:hover{background:linear-gradient(135deg,#dc2626,#991b1b);box-shadow:0 6px 15px #ef44444d;transform:translateY(-2px)}.reset-button:hover:before{opacity:1;transform:rotate(45deg) translate(100%,100%)}.reset-button:active{box-shadow:0 2px 6px #ef444433;transform:translateY(0)}.intro-buttons{animation:fadeIn .8s ease-out 1.9s both;display:flex;flex-direction:row;gap:1.5rem;justify-content:center;margin-top:2.5rem}.start-button{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:.75rem;box-shadow:0 8px 20px #2563eb40;font-size:1.2rem;font-weight:600;letter-spacing:.01em;overflow:hidden;padding:1rem 2.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1}.start-button:before{background:linear-gradient(to bottom right,#fff0,#ffffff1a 50%,#fff0);content:"";height:200%;left:-50%;opacity:0;position:absolute;top:-50%;transform:rotate(45deg);transition:all .6s cubic-bezier(.4,0,.2,1);width:200%;z-index:-1}.start-button:hover{background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 12px 24px #2563eb59;transform:translateY(-3px)}.start-button:hover:before{opacity:1;transform:rotate(45deg) translate(100%,100%)}.start-button:active{box-shadow:0 4px 12px #2563eb33;transform:translateY(-1px)}.start-button:disabled{background:linear-gradient(135deg,#93c5fd,#60a5fa);box-shadow:none;cursor:not-allowed;transform:none}.start-button:disabled:before{display:none}.browse-button{background-color:initial;border:2px solid #3b82f680;border-radius:.75rem;box-shadow:0 4px 12px #2563eb1a;color:#3b82f6;cursor:pointer;font-size:1.2rem;font-weight:600;overflow:hidden;padding:1rem 2rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.browse-button:after{background:#3b82f60d;content:"";height:100%;left:0;position:absolute;top:0;transform:scaleX(0);transform-origin:right;transition:transform .5s cubic-bezier(.16,1,.3,1);width:100%;z-index:-1}.browse-button:hover{background-color:#eff6ffb3;border-color:#3b82f6;box-shadow:0 8px 16px #2563eb26;color:#1d4ed8;transform:translateY(-3px)}.browse-button:hover:after{transform:scaleX(1);transform-origin:left}.browse-button:active{box-shadow:0 2px 8px #2563eb1a;transform:translateY(-1px)}@media (max-width:768px){.quiz-container{padding:1.5rem 1rem}.quiz-title{font-size:1.75rem}.quiz-subtitle{font-size:1rem}.election-banner{border-radius:.875rem;margin-bottom:1.5rem;padding:1.25rem 1.5rem}.election-banner h2{font-size:1.4rem;margin-bottom:.5rem}.election-meta{align-items:center;flex-direction:column;gap:.75rem}.election-jurisdiction{font-size:.7rem;padding:.35rem .75rem}.quiz-card{border-radius:.875rem;box-shadow:0 15px 35px #0000000d,0 5px 15px #00000008;margin:0}.progress-section{padding:1.25rem 1.5rem}.progress-count{font-size:.8rem;padding:.25rem .7rem}.policy-section{padding:1.5rem 1.5rem 2rem}.policy-section h2{font-size:1.25rem;margin-bottom:1.25rem}.policy-statement{margin-bottom:1.75rem;padding:1.5rem 1.25rem}.policy-statement p{font-size:1.1rem;line-height:1.6}.question-prompt{font-size:1.2rem;margin:1.75rem 0}.question-prompt:after,.question-prompt:before{width:2rem}.action-buttons{gap:.75rem;padding:0 1.5rem}.agree-button,.disagree-button{border-radius:.75rem;font-size:1.05rem;padding:1rem}.agree-button.selected:before,.disagree-button.selected:before{font-size:1.1rem;right:1rem}.quiz-footer{font-size:.85rem;padding:1.25rem 1.5rem}.intro-buttons{flex-direction:column;gap:1rem}.browse-button,.start-button{font-size:1.1rem;padding:.85rem 1.5rem;width:100%}.intro-list-item{font-size:1rem;padding-left:1.5rem}.intro-subtitle{font-size:1.5rem}.intro-content,.loading-container{padding:2rem 1.5rem}.loading-spinner{height:3rem;width:3rem}.completion-message,.error-message{padding:2rem 1.5rem}.error-message h3{font-size:1.35rem}.completion-message h2{font-size:1.75rem}.completion-message p,.error-message p{font-size:1.05rem;margin-bottom:1.75rem}.completion-stats{gap:1.5rem;margin-bottom:2rem}.stat-item{min-width:7rem;padding:1rem}.stat-value{font-size:2rem}.stat-label{font-size:.85rem}.action-button{font-size:1rem;padding:.85rem 1.75rem}}@media (max-width:480px){.quiz-container{padding:1rem .75rem}.election-banner{margin-bottom:1.25rem;padding:1rem 1.25rem}.election-banner h2{font-size:1.25rem}.progress-section{padding:1rem 1.25rem}.policy-section{padding:1.25rem 1.25rem 1.75rem}.policy-section h2{font-size:1.2rem;margin-bottom:1rem}.policy-statement{margin-bottom:1.5rem;padding:1.25rem 1rem}.policy-statement p{font-size:1rem}.policy-statement:before{font-size:6rem;top:-1rem}.question-prompt{font-size:1.1rem;margin:1.5rem 0}.question-prompt:after,.question-prompt:before{display:none}.action-buttons{padding:0 1.25rem}.agree-button,.disagree-button{font-size:1rem;padding:.85rem}.quiz-footer{font-size:.8rem;padding:1rem 1.25rem}.intro-content{padding:1.75rem 1.25rem}.intro-subtitle{font-size:1.35rem;margin-bottom:1.5rem}.intro-list-item:before{height:24px;left:-12px;width:24px}.intro-list{margin-bottom:2rem}.intro-note{font-size:.85rem;padding:.85rem 1rem}.error-info,.validation-info{padding:1rem 1.25rem}.completion-stats{flex-direction:column;gap:1rem}.stat-item{align-items:center;flex-direction:row;justify-content:space-between;margin:0 auto;max-width:16rem;padding:.75rem 1rem;width:85%}.stat-value{font-size:1.75rem;margin-bottom:0;margin-right:.5rem}.stat-label{font-size:.8rem;text-align:right}}.candidate-image-placeholder{background-color:#e2e8f0;border-radius:50%}.candidate-initials{color:#64748b;font-size:1.5rem}.alignment-progress{position:relative}.progress-percentage{color:#fff;font-size:.75rem;font-weight:700;left:50%;position:absolute;text-shadow:0 1px 2px #0003;top:50%;transform:translate(-50%,-50%);white-space:nowrap}.quiz-progress-container{background-color:#f8fafc;background-color:var(--bg-secondary,#f8fafc);border-radius:8px;box-shadow:0 1px 3px #0000000d;margin:15px 0;padding:15px;width:100%}.progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.progress-title{align-items:center;color:#334155;color:var(--text-primary,#334155);display:flex;font-weight:600;gap:10px}.progress-count{color:#64748b;color:var(--text-secondary,#64748b);font-size:.9rem;margin-left:8px}.progress-bar-container{background-color:#e2e8f0;background-color:var(--bg-tertiary,#e2e8f0);margin-bottom:10px}.progress-bar,.quiz-progress-container .progress-bar{border-radius:5px;display:block!important;height:100%;transition:width .5s ease-in-out,background .5s ease}.progress-details{display:flex;flex-direction:column;font-size:.85rem;gap:8px;margin-top:12px}.progress-detail-item{display:flex;justify-content:space-between}.detail-label{color:#64748b;color:var(--text-secondary,#64748b)}.detail-value{color:#334155;color:var(--text-primary,#334155)}.status-badge{padding:4px 10px}.status-completed{background-color:#dcfce7;color:#166534}.status-in-progress{background-color:#dbeafe;color:#1e40af}.status-not-started{background-color:#f3f4f6;color:#6b7280}.progress-text{color:var(--text-secondary,#64748b);display:block;font-size:.75rem;margin-top:4px;text-align:right}.mobile-header{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 10px #2563eb33;display:flex;justify-content:space-between;min-height:56px;padding:12px 16px;position:sticky;top:0;z-index:100}.mobile-nav-button:active{transform:scale(.95)}.mobile-header-title{color:#fff;flex:1 1;font-size:20px;font-weight:700;letter-spacing:-.5px;margin:0;text-align:center}.has-mobile-header .navbar,.has-mobile-header nav.navbar{display:none!important}@media (min-width:768px){.mobile-header{padding:16px 24px}.mobile-header-title{font-size:24px}}@media (max-width:480px){.mobile-header{padding:10px 12px}.mobile-nav-button{height:40px;width:40px}.mobile-nav-button svg{height:20px;width:20px}.mobile-header-title{font-size:18px}}.mobile-header-actions{align-items:center;display:flex;gap:8px}.mobile-settings-wrapper{position:relative}.mobile-dropdown{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;min-width:200px;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}.mobile-dropdown-content{padding:8px}.mobile-dropdown-header{border-bottom:1px solid #e5e7eb;padding:12px}.user-email{color:#4b5563;font-size:14px}.mobile-dropdown-item{background:none;border:none;color:#374151;cursor:pointer;font-size:14px;padding:12px;text-align:left;transition:background-color .2s;width:100%}.mobile-dropdown-item:hover{background-color:#f3f4f6;border-radius:4px}.questionnaire-container{margin:0 auto;max-width:800px;padding:1.5rem}.page-title{color:#1e293b;margin-bottom:2rem;text-align:center}.loading-spinner-container{align-items:center;display:flex;height:16rem;justify-content:center}.spinner{border:.25rem solid #3b82f64d}.error-message,.warning-message{background-color:#fff;border-radius:.75rem;box-shadow:0 4px 20px #0000000d;margin-bottom:1.5rem;padding:1.5rem}.error-message{border-left:4px solid #ef4444}.warning-message{border-left:4px solid #f59e0b}.retry-button,.setup-button{background-color:#3b82f6;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-weight:500;margin-top:1rem;padding:.5rem 1rem;transition:all .2s}.retry-button:hover,.setup-button:hover{background-color:#2563eb;transform:translateY(-1px)}.intro-card{background-color:#fff;border-radius:.75rem;box-shadow:0 4px 20px #0000000d;overflow:hidden}.intro-content{padding:2rem;text-align:center}.intro-subtitle{color:#1e293b;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;text-align:left}.intro-list{list-style:none;margin-bottom:2rem;padding:0;text-align:left}.intro-list-item{color:#475569;display:flex;line-height:1.5;margin-bottom:1rem}.bullet{color:#3b82f6;font-size:1.25rem;line-height:1.25;margin-right:.75rem}.intro-note{color:#64748b;font-style:italic;margin-bottom:2rem}.start-button{background-color:#3b82f6;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:1.125rem;font-weight:500;padding:.75rem 2rem;transition:all .2s}.start-button:hover{background-color:#2563eb;transform:translateY(-1px)}.mobile-quiz-container{align-items:center;background:linear-gradient(180deg,#f0f9ff,#e0f2fe);display:flex;flex-direction:column;min-height:100vh;padding:80px 20px 20px}.error-card,.notice-card{background:#fff;border-radius:20px;box-shadow:0 10px 40px #00000014;margin-top:20px;max-width:400px;padding:32px 24px;text-align:center;width:100%}.error-icon-container,.notice-icon-container{align-items:center;border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 24px;width:80px}.notice-icon-container{background:#fef3c7}.error-icon-container{background:#fee2e2}.error-icon,.notice-icon{font-size:40px}.error-title,.notice-title{color:#1e293b;font-size:24px;font-weight:700;margin-bottom:12px}.error-message,.notice-message{color:#64748b;font-size:16px;line-height:1.6;margin-bottom:24px}.quiz-info{background:#f8fafc;border-radius:12px;margin-bottom:24px;padding:16px}.quiz-name{font-size:18px;margin:0 0 4px}.quiz-election{color:#64748b;font-size:14px;margin:0}.action-buttons{gap:12px}.primary-button,.secondary-button{padding:16px 24px}.primary-button{background:#3b82f6}.primary-button:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f64d}.secondary-button{border:2px solid #e2e8f0;color:#64748b}.secondary-button:hover{background:#f8fafc}@media (max-width:480px){.mobile-quiz-container{padding:70px 16px 16px}.error-card,.notice-card{padding:24px 20px}.error-icon-container,.notice-icon-container{height:64px;margin-bottom:20px;width:64px}.error-icon,.notice-icon{font-size:32px}.error-title,.notice-title{font-size:20px}.error-message,.notice-message{font-size:15px}}.results-container{min-height:100vh;overflow-x:hidden;padding-bottom:2rem;z-index:1}.results-header{margin:0 auto;max-width:600px;padding:.5rem 1.5rem 0;text-align:center;width:100%}.results-title{color:#1e293b;font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.results-subtitle{color:#64748b;font-size:.875rem}.results-tabs{background-color:#fff;border:1px solid #e2e8f0;border-bottom:none;border-radius:.75rem .75rem 0 0;display:flex;margin:0 auto;max-width:600px;overflow:hidden;width:calc(100% - 3rem)}.tab-button{background-color:#f1f5f999;border:none;color:#64748b;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;overflow:hidden;padding:1.1rem 1rem;position:relative;transition:all .25s cubic-bezier(.16,1,.3,1)}.tab-button.active{background-color:#3b82f6;box-shadow:0 2px 8px #3b82f64d;color:#fff;font-weight:700}.tab-button:hover:not(.active){background-color:#f1f5f9e6;transform:translateY(-1px)}.results-card{animation:fadeIn .4s cubic-bezier(.16,1,.3,1);background-color:#fff;border:1px solid #e2e8f0;border-radius:0 0 1rem 1rem;box-shadow:0 10px 25px #0000000f;margin:0 auto 1.5rem;max-width:600px;overflow:visible;padding:1.5rem 1.5rem 2rem;position:relative;width:calc(100% - 3rem)}.loading-card{align-items:center;border-radius:1rem;display:flex;flex-direction:column;justify-content:center;margin:1.5rem;min-height:300px;text-align:center}.loading-spinner{border:3px solid #3b82f633;height:50px;margin-bottom:1.5rem;width:50px}.loading-text{color:#3b82f6;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.loading-subtext{color:#64748b;font-size:.9rem;margin-bottom:1rem}.retry-text{color:#f59e0b;font-size:.85rem;font-weight:500;margin-top:.5rem}.error-card{align-items:center;border-radius:1rem;display:flex;flex-direction:column;margin:1.5rem;min-height:250px;text-align:center}.error-icon-container{align-items:center;background-color:#fee2e2;border-radius:50%;color:#ef4444;display:flex;height:56px;justify-content:center;margin-bottom:1rem;width:56px}.error-title{color:#1e293b;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.error-message{color:#64748b;margin-bottom:1.5rem}.empty-card{align-items:center;border-radius:1rem;display:flex;flex-direction:column;margin:1.5rem;min-height:250px;text-align:center}.empty-icon-container{align-items:center;background-color:#fff7ed;border-radius:50%;color:#f59e0b;display:flex;height:56px;justify-content:center;margin-bottom:1rem;width:56px}.empty-title{color:#1e293b;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.empty-message{color:#64748b;margin-bottom:1.5rem}.summary-card{flex-direction:column}.summary-header{margin-bottom:1rem;text-align:center}.summary-title-container{align-items:center;display:flex;justify-content:center;margin-bottom:.1rem}.summary-title{color:#64748b;font-size:1.25rem;font-weight:600;margin-right:.5rem}.summary-title-container .icon{position:relative;top:-5px}.disclaimer-text{color:#64748b;font-size:.875rem;text-align:center}.top-candidate{background-color:#fff;background-image:linear-gradient(135deg,#3b82f608,#6366f108);border:2px solid #3b82f6;border-radius:1rem;box-shadow:0 4px 16px #3b82f61a;margin-bottom:1.5rem;padding:1.25rem;position:relative;transition:all .3s ease}.top-candidate:hover{box-shadow:0 6px 16px #0000000f;transform:translateY(-2px)}.details-card{display:flex;flex-direction:column}.details-title{color:#1e293b;font-size:1.375rem;font-weight:700;margin-bottom:.75rem;text-align:center}.candidates-list{display:flex;flex-direction:column;gap:.75rem;padding:0}.candidate-item{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;padding:1rem;transition:transform .2s}.candidate-item:hover{box-shadow:0 4px 12px #0000000d;transform:translateY(-2px)}.candidate-header{align-items:center;display:flex;gap:1rem;margin-bottom:1rem}.candidate-image-container{align-items:center!important;background-color:#f8fafc!important;border:3px solid #fff!important;border-radius:50%!important;box-shadow:0 4px 12px #0000001a!important;display:flex!important;flex-shrink:0!important;height:80px!important;justify-content:center!important;overflow:hidden!important;position:relative!important;width:80px!important}.candidate-image,.candidate-logo{display:block!important;height:100%!important;left:0!important;object-fit:cover!important;object-position:center 20%!important;position:absolute!important;top:0!important;width:100%!important}.candidate-info{flex-direction:column;gap:.5rem}.candidate-name{color:#1e293b;font-size:1.375rem;font-weight:700;line-height:1.2;margin:0}.alignment-badge{align-items:center;background-color:#eff6ff;border-radius:8px;color:#2563eb;display:inline-flex;font-size:.8125rem;font-weight:600;letter-spacing:.025em;padding:.375rem .75rem;text-transform:uppercase;width:fit-content}.alignment-badge.strong{background-color:#ecfdf5;box-shadow:0 2px 5px #0596691a;color:#059669}.alignment-badge.moderate{background-color:#fff7ed;box-shadow:0 2px 5px #d977061a;color:#d97706}.alignment-badge.slight,.alignment-badge.weak{background-color:#fef2f2;box-shadow:0 2px 5px #dc26261a;color:#dc2626}.alignment-container{background-color:#f8fafccc;border:1px solid #e2e8f0;border-radius:.75rem;margin-top:1rem;padding:1rem}.alignment-label-container{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.alignment-label{color:#475569;font-size:.875rem;font-weight:600}.alignment-percentage{align-items:center;color:#1e293b;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:flex-end;position:relative}.alignment-value{background:#0000;color:#1e293b;display:inline;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1.5rem;font-weight:700;padding:0;transition:all .3s ease}.alignment-emoji{animation:bounce 1s ease infinite;font-size:1.5rem;height:28px;margin-left:.7rem;width:28px}.alignment-emoji,.alignment-icon{align-items:center;display:inline-flex;justify-content:center;position:relative}.alignment-icon{animation:bounce 1.5s ease infinite;color:currentColor;flex-shrink:0;height:24px;width:24px}.alignment-pulse-ring{animation:pulse 2s ease-out infinite;background:radial-gradient(circle,#3b82f61a 0,#3b82f600 70%);border-radius:50%;height:60px;opacity:.8;pointer-events:none;position:absolute;right:-20px;top:50%;transform:translateY(-50%);width:60px;z-index:-1}@keyframes pulse{0%{opacity:.8;transform:translateY(-50%) scale(.8)}70%{opacity:0}to{opacity:0;transform:translateY(-50%) scale(1.5)}}.progress-bar-container{background-color:#e5e7eb;border-radius:5px;box-shadow:inset 0 1px 3px #00000014;height:10px;width:100%}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.progress-bar{border-radius:5px;height:10px;left:0;min-width:3%;position:absolute;top:0;transition:width 1.2s cubic-bezier(.16,1,.3,1) .3s,background .5s ease}.progress-bar:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes animate-stripes{0%{background-position:0 0}to{background-position:60px 0}}.action-buttons{align-items:center;flex-direction:column;gap:.75rem;margin:1.5rem auto 0;max-width:400px;width:100%}.primary-button{align-items:center;border-radius:12px;box-shadow:0 4px 12px #3b82f633;display:flex;font-size:1rem;gap:.5rem;justify-content:center;padding:.875rem 1.5rem;transition:all .2s ease;width:100%}.primary-button:hover{box-shadow:0 12px 32px #3b82f659;transform:translateY(-2px) scale(1.02)}.secondary-button{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000a;color:#475569;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem 1.5rem;transition:all .2s ease;width:100%}.secondary-button:hover{background-color:#f8fafc;border-color:#cbd5e1;box-shadow:0 8px 24px #0000001a;transform:translateY(-2px)}.icon{display:inline-flex;margin-right:.5rem;position:relative;top:-1px}.button-text,.icon{vertical-align:middle}.button-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:640px){.results-title{font-size:1.75rem}.results-container{padding:0}.action-buttons{flex-direction:column}.alignment-label-container{align-items:flex-start;flex-direction:column;gap:.5rem}.alignment-percentage{font-size:1.125rem;margin-top:.25rem}.alignment-emoji{font-size:1.5rem;height:24px}.progress-bar-container{height:10px;margin-top:.75rem}.candidate-item{padding:1rem}.candidate-header{align-items:flex-start;flex-direction:column}.candidate-image-container{height:60px!important;margin-bottom:1rem;width:60px!important}}.candidate-image-placeholder{background-color:#e2e8f0!important;border-radius:50%!important}.candidate-image-placeholder,.candidate-initials{align-items:center!important;display:flex!important;height:100%!important;justify-content:center!important;width:100%!important}.candidate-initials{color:#475569!important;font-size:1.75rem!important;font-weight:700!important;text-transform:uppercase!important}@media (max-width:480px){.results-container{padding:env(safe-area-inset-top) 0 0;scroll-behavior:smooth}.results-tabs{margin:0 1rem;width:calc(100% - 2rem)}.results-card{box-shadow:0 2px 10px #00000014;margin:0 1rem 1.5rem;padding:1.25rem 1rem;width:calc(100% - 2rem)}.tab-button{font-size:.9rem;font-weight:600;padding:.75rem .5rem}.candidate-name,.details-title,.summary-title{font-size:1.25rem}.candidate-name{margin-bottom:.5rem}.alignment-badge{align-items:center;border-radius:1rem;display:inline-flex;font-size:.8rem;justify-content:center;margin-top:.25rem;padding:.3rem .8rem}.top-candidate{background-color:#f8fafc;border-radius:1rem;padding:1rem}.candidate-item{background-color:#f8fafc;border-radius:.75rem;padding:.875rem}.candidate-header{align-items:center;display:flex;flex-direction:row;margin-bottom:.75rem}.candidate-image-container{border:2px solid #fff!important;box-shadow:0 3px 8px #00000014!important;height:70px!important;margin-bottom:0!important;margin-right:0!important;width:70px!important}.candidate-info{display:flex;flex-direction:column;gap:.4rem}.alignment-container{background-color:#ffffff80;border-radius:.5rem;margin-top:.2rem;padding:.5rem}.alignment-label-container{align-items:center;flex-direction:row;justify-content:space-between;margin-bottom:.5rem}.alignment-label{color:#64748b;font-size:.8rem;font-weight:600}.alignment-percentage{align-items:center;background-color:initial;color:#0f172a;display:flex;font-size:.95rem;font-weight:700;margin-bottom:0;padding:0}.alignment-emoji{align-items:center;display:flex;font-size:1.3rem;justify-content:center;margin-left:.5rem}.progress-bar-container{background-color:#e2e8f0;border-radius:.3rem;height:.6rem;margin-top:.5rem;overflow:hidden}.progress-bar{border-radius:.3rem;height:.6rem;transition:width .8s cubic-bezier(.16,1,.3,1)}.progress-strong{background:linear-gradient(90deg,#84e1bc,#10b981)!important}.progress-moderate{background:linear-gradient(90deg,#fcd34d,#f59e0b)!important}.progress-slight,.progress-weak{background:linear-gradient(90deg,#fca5a5,#ef4444)!important}.summary-header{margin-bottom:1.25rem}.action-buttons{flex-direction:column;gap:.75rem;margin-top:1.75rem}.primary-button,.secondary-button{border-radius:12px;box-shadow:0 2px 4px #0000000d;font-size:1rem;font-weight:600;justify-content:center;min-height:48px;overflow:hidden;padding:1rem 1.5rem;text-overflow:ellipsis;white-space:nowrap}.primary-button{background:linear-gradient(135deg,#3b82f6,#2563eb)}.primary-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px)}.secondary-button{background-color:#f8fafc;border:1px solid #e2e8f0;color:#334155}.secondary-button:hover{background-color:#f1f5f9}.icon{align-items:center;display:inline-flex;font-size:1.1rem;margin-right:.5rem;position:relative;top:0;transform:translateY(2px)}.candidate-item:after{display:none}}.text-center{text-align:center}.mb-4{margin-bottom:1rem}.quiz-name{color:#334155;font-size:1.5rem;margin-bottom:.5rem;margin-top:.5rem;text-align:center}.quiz-stats-compact{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;display:flex;gap:2rem;justify-content:center;margin:.75rem 0 1.5rem;padding:.75rem}.stat-item-small{align-items:center;display:flex;flex-direction:column;text-align:center}.stat-value-small{color:#334155;font-size:.9rem;font-weight:600}@media (max-width:640px){.quiz-stats-compact{flex-direction:column;gap:.5rem}.stat-item-small{flex-direction:row;justify-content:space-between;padding:0 1rem;width:100%}}body.has-mobile-header{height:100vh;margin:0;overflow:hidden;padding:0;position:fixed;width:100%}body.has-mobile-header main{display:flex;flex-direction:column;height:100vh;overflow:hidden;padding:0!important;position:relative}.results-container{-webkit-overflow-scrolling:touch;flex:1 1;height:100%;overscroll-behavior:contain;position:relative}.bottom-info{border-top:1px solid #e2e8f0;margin-top:1.5rem;padding-top:1.5rem}.details-button{align-items:center;background:#0000;border:none;border-radius:6px;color:#3b82f6;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.375rem;margin-top:.75rem;padding:.5rem .75rem;transition:all .2s ease}.details-button:hover{background-color:#eff6ff;color:#2563eb}.details-button svg{height:16px;transition:transform .2s ease;width:16px}.details-button:hover svg{transform:translateX(2px)}.bottom-info .disclaimer-text{color:#64748b;font-size:.875rem;margin-bottom:1rem;text-align:center}@media (max-width:480px){.results-header{margin-bottom:.5rem;padding:.25rem 1rem 0}.results-title{display:none;font-size:1.25rem;margin-bottom:.125rem}.results-subtitle{display:none;font-size:.8rem}.summary-card{padding:1rem}.summary-header{margin-bottom:.75rem}.summary-title{font-size:1.125rem}.quiz-name{font-size:1.25rem;margin-bottom:1rem}.top-candidate{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #3b82f6;margin:0 0 1rem;padding:1rem}.candidate-header{align-items:center;flex-direction:row;text-align:left}.candidate-image-container{border:3px solid #fff!important;box-shadow:0 4px 12px #3b82f633!important;height:75px!important;margin-bottom:0!important;margin-right:1rem!important;width:75px!important}.candidate-info{flex:1 1}.candidate-name{color:#1e293b;font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.alignment-badge{font-size:.75rem}.action-buttons{margin-top:1.25rem;max-width:none;width:100%}.bottom-info{margin-top:1rem;padding-top:1rem}.bottom-info .disclaimer-text{font-size:.8rem;margin-bottom:.75rem}.quiz-stats-compact{font-size:.8rem;gap:1rem;padding:.5rem}}.admin-container{background:linear-gradient(150deg,#f9fafbe6,#f3f4f6e6);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;isolation:isolate;min-height:calc(100vh - 64px);position:relative}.admin-container:before{background:radial-gradient(circle at 80% 20%,#3b82f60d,#0000 60%),radial-gradient(circle at 20% 80%,#10b9810a,#0000 60%);content:"";inset:0;opacity:.8;pointer-events:none;position:absolute;z-index:-1}.admin-sidebar{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fffffff2;border-right:1px solid #e5e7eb99;box-shadow:0 4px 20px #00000008,0 2px 8px #00000005;height:100vh;overflow-y:auto;position:sticky;top:0;transition:all .4s cubic-bezier(.16,1,.3,1);width:220px;z-index:10}.admin-brand{align-items:center;animation:fadeIn 1s cubic-bezier(.16,1,.3,1) both;border-bottom:1px solid #e5e7eb99;display:flex;flex-direction:column;gap:.85rem;padding:1.25rem 1rem;position:relative;text-align:center}.admin-brand h1{-webkit-text-fill-color:#0000;text-fill-color:#0000;background:linear-gradient(135deg,#1e293b,#334155);-webkit-background-clip:text;background-clip:text;color:#1e293b;font-size:1.25rem;font-weight:800;letter-spacing:-.01em;margin:0;position:relative}.admin-brand h1:after{animation:expandLine 1.2s cubic-bezier(.16,1,.3,1) forwards;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:3px;bottom:-6px;content:"";height:3px;left:50%;opacity:0;position:absolute;transform:translateX(-50%);transform-origin:center;width:40px}@keyframes expandLine{0%{opacity:0;width:0}to{opacity:1;width:40px}}.admin-home-button{backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:#ffffffb3;border:1px solid #e2e8f0cc;border-radius:1rem;box-shadow:0 4px 12px #0f172a0a,0 2px 4px #0f172a05,inset 0 1px 0 #ffffff80;color:#334155;cursor:pointer;font-size:.95rem;font-weight:600;justify-content:flex-start;letter-spacing:.01em;overflow:hidden;padding:.75rem 1.5rem;width:100%;z-index:1}.admin-home-button,.admin-home-button .button-icon{align-items:center;display:flex;position:relative;transition:all .4s cubic-bezier(.16,1,.3,1)}.admin-home-button .button-icon{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:10px;box-shadow:0 4px 10px #2563eb33;color:#fff;flex-shrink:0;font-size:.875rem;height:32px;justify-content:center;margin-right:1rem;width:32px;z-index:2}.admin-home-button .button-text{color:#334155;font-weight:600;position:relative;transition:color .4s ease;z-index:2}.admin-home-button:before{background:linear-gradient(to bottom right,#fff0,#fff3 50%,#fff0);content:"";height:200%;left:-50%;opacity:0;position:absolute;top:-50%;transform:rotate(45deg);transition:all .6s cubic-bezier(.16,1,.3,1);width:200%;z-index:1}.admin-home-button:after{background:linear-gradient(120deg,#3b82f61a,#2563eb26);border-radius:1rem;content:"";inset:0;opacity:0;position:absolute;transition:opacity .4s ease;z-index:0}.admin-home-button:hover{border-color:#3b82f666;box-shadow:0 8px 20px #2563eb1a,0 4px 8px #2563eb0d,inset 0 1px 0 #fff9;transform:translateY(-3px)}.admin-home-button:hover:after{opacity:1}.admin-home-button:hover:before{opacity:1;transform:rotate(45deg) translate(100%,100%)}.admin-home-button:hover .button-icon{background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 6px 15px #2563eb4d;transform:scale(1.1)}.admin-home-button:hover .button-text{color:#1e293b}.admin-home-button:active{box-shadow:0 4px 8px #2563eb1a;transform:translateY(-1px)}.admin-nav{padding:1.5rem 1rem}.admin-nav-title{color:#64748b;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin:0 0 1rem;padding:0 1rem;text-transform:uppercase}.admin-nav-item{align-items:center;background:none;border:none;border-radius:.75rem;color:#475569;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;margin-bottom:.35rem;padding:.675rem 1rem;position:relative;text-align:left;transition:all .3s cubic-bezier(.16,1,.3,1);width:100%}.admin-nav-item svg{flex-shrink:0;font-size:1rem;margin-right:.75rem;opacity:.85;transition:all .3s ease}.admin-nav-item:before{background:linear-gradient(120deg,#3b82f614,#2563eb1f);border-radius:.75rem;content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s ease;z-index:-1}.admin-nav-item:after{background:linear-gradient(180deg,#3b82f6,#2563eb);border-radius:0 3px 3px 0;content:"";height:1.75rem;left:0;position:absolute;top:50%;transform:translateY(-50%);transition:width .3s cubic-bezier(.16,1,.3,1);width:0}.admin-nav-item:hover{color:#1e293b;transform:translateX(3px)}.admin-nav-item:hover:before{opacity:1}.admin-nav-item:hover svg{color:#3b82f6;opacity:1;transform:scale(1.1)}.admin-nav-item.active{background:linear-gradient(90deg,#eff6ffd9,#dbeafe4d);color:#1d4ed8;font-weight:600;transform:translateX(3px)}.admin-nav-item.active:after{width:4px}.admin-nav-item.active svg{color:#2563eb;opacity:1}.admin-nav-item admin-nav-sub-item{font-size:.825rem;padding-left:2.5rem}.admin-nav-item admin-nav-sub-item svg{font-size:.9rem}.admin-content{animation:fadeSlideUp .8s cubic-bezier(.16,1,.3,1) both;flex:1 1;max-width:calc(100% - 220px);overflow-x:auto;overflow-y:auto;padding:1.75rem}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.admin-dashboard{margin:0 auto;max-width:1400px}.dashboard-title{color:#1e293b;display:inline-block;font-size:1.35rem;font-weight:700;letter-spacing:-.01em;margin-bottom:1.5rem;position:relative}.dashboard-title:after{animation:expandLine 1.2s cubic-bezier(.16,1,.3,1) forwards;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:2px;bottom:-6px;content:"";height:2px;left:0;opacity:0;position:absolute;transform-origin:left;width:40px}.stats-grid{grid-gap:1rem;animation:fadeSlideUp .8s cubic-bezier(.16,1,.3,1) .2s both;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin-bottom:1.75rem}.stat-card{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #e2e8f0cc;border-radius:.85rem;box-shadow:0 8px 20px #00000008,0 4px 10px #00000005;display:flex;overflow:hidden;padding:1.25rem;position:relative;transition:all .4s cubic-bezier(.16,1,.3,1)}.stat-card:hover{border-color:#cbd5e1e6;box-shadow:0 15px 35px #0000000d,0 8px 20px #00000008;transform:translateY(-5px)}.stat-card:before{background:radial-gradient(circle at bottom right,#3b82f608,#0000 70%),radial-gradient(circle at top left,#10b98105,#0000 70%);content:"";inset:0;opacity:.8;position:absolute;transition:opacity .3s ease;z-index:-1}.stat-card:hover:before{opacity:1}.stat-icon{align-items:center;border-radius:.675rem;display:flex;flex-shrink:0;font-size:1.15rem;height:2.5rem;justify-content:center;margin-right:.875rem;position:relative;transition:all .4s cubic-bezier(.16,1,.3,1);width:2.5rem}.stat-card:hover .stat-icon{transform:scale(1.1) rotate(-5deg)}.stat-icon:before{background:inherit;border-radius:inherit;content:"";filter:blur(6px);inset:0;opacity:.4;position:absolute;transition:opacity .4s ease;z-index:-1}.stat-card:hover .stat-icon:before{opacity:.7}.stat-icon.users{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1d4ed8}.stat-icon.elections{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4f46e5}.stat-icon.candidates{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a}.stat-icon.quizzes{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.stat-content{flex:1 1;position:relative}.stat-title{color:#64748b;font-size:.9rem;font-weight:600;letter-spacing:.03em;margin:0 0 .5rem;text-transform:uppercase}.stat-value{color:#1e293b;font-size:1.5rem;letter-spacing:-.02em;margin:0 0 .325rem;transition:all .3s ease}.stat-card:hover .stat-value{transform:scale(1.05);transform-origin:left}.stat-subtitle{color:#6b7280;font-size:.85rem;line-height:1.5;margin:0}.stat-trend{align-items:center;border-radius:1rem;display:inline-flex;font-size:.8rem;font-weight:600;gap:.3rem;margin-top:.5rem;padding:.3rem .6rem}.stat-trend.up{background-color:#10b9811a;color:#059669}.stat-trend.down{background-color:#ef44441a;color:#dc2626}.section-title{display:inline-block;font-size:1.15rem;letter-spacing:-.01em;margin-bottom:1.125rem;position:relative}.section-title:after{animation:expandLine 1.2s cubic-bezier(.16,1,.3,1) forwards;background:linear-gradient(90deg,#3b82f6,#2563eb);border-radius:3px;bottom:-6px;content:"";height:3px;left:0;opacity:0;position:absolute;transform-origin:left;width:40px}.quick-actions{animation:fadeSlideUp .8s cubic-bezier(.16,1,.3,1) .4s both;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #e2e8f0cc;border-radius:1rem;box-shadow:0 10px 25px #00000008,0 5px 15px #00000005;margin-bottom:2.5rem;overflow:hidden;padding:2rem;position:relative}.quick-actions:before{background:radial-gradient(circle at top right,#3b82f608,#0000 70%),radial-gradient(circle at bottom left,#10b98105,#0000 70%);content:"";inset:0;opacity:.8;position:absolute;z-index:-1}.action-buttons{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}.admin-header{align-items:center;animation:fadeSlideUp .8s cubic-bezier(.16,1,.3,1) both;display:flex;justify-content:space-between;margin-bottom:1.75rem;position:relative}.admin-title{-webkit-text-fill-color:#0000;text-fill-color:#0000;background:linear-gradient(135deg,#1e293b,#334155);-webkit-background-clip:text;background-clip:text;color:#1e293b;display:inline-block;font-size:1.5rem;font-weight:800;letter-spacing:-.01em;margin:0;position:relative}.admin-title:after{animation:expandLine 1.2s cubic-bezier(.16,1,.3,1) forwards;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:2px;bottom:-6px;content:"";height:2px;left:0;opacity:0;position:absolute;transform-origin:left;width:40px}.admin-button{background:#ffffffe6;border:1px solid #e2e8f0cc;border-radius:.675rem;box-shadow:0 3px 8px #00000008,0 1px 4px #00000005;color:#475569;display:flex;font-size:.85rem;font-weight:600;gap:.4rem;justify-content:center;overflow:hidden;padding:.65rem 1.125rem;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1);z-index:1}.admin-button:before{background:linear-gradient(90deg,#f9fafbcc,#f3f4f6cc);content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s ease;z-index:-1}.admin-button:hover{border-color:#cbd5e1e6;box-shadow:0 8px 20px #0000000a,0 4px 10px #00000008;transform:translateY(-3px)}.admin-button:hover:before{opacity:1}.admin-button:active{box-shadow:0 4px 8px #00000008;transform:translateY(-1px)}.admin-button svg{transition:transform .3s ease}.admin-button:hover svg{transform:scale(1.1)}.admin-button-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#0000;box-shadow:0 8px 20px #2563eb33,0 4px 10px #2563eb1a;color:#fff}.admin-button-primary:before{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.admin-button-primary:hover{border-color:#0000;box-shadow:0 12px 30px #2563eb40,0 6px 15px #2563eb26}.admin-button-primary svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.admin-button-small{border-radius:.75rem;font-size:.875rem;padding:.625rem 1rem}.admin-table-container{animation:fadeSlideUp .8s cubic-bezier(.16,1,.3,1) .6s both;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #e2e8f0cc;border-radius:.85rem;box-shadow:0 8px 20px #00000008,0 4px 10px #00000005;margin-top:1.5rem;overflow:hidden;position:relative}.candidate-table-info{align-items:center;display:flex;gap:.875rem}.candidate-table-info .candidate-avatar{box-shadow:0 4px 8px #0000000f;height:3rem;width:3rem}.candidate-name-display{color:#334155;font-size:.95rem;font-weight:600;letter-spacing:-.01em}.admin-table-container:before{background:radial-gradient(circle at top right,#3b82f605,#0000 70%),radial-gradient(circle at bottom left,#10b98103,#0000 70%);content:"";inset:0;opacity:.8;position:absolute;z-index:-1}.admin-table{border-collapse:initial;border-spacing:0;width:100%}.admin-table th{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#f8fafccc;border-bottom:1px solid #e2e8f080;color:#64748b;font-size:.7rem;font-weight:600;height:2.5rem;letter-spacing:.05em;padding:.5rem .75rem;position:sticky;text-align:left;text-transform:uppercase;top:0;z-index:10}.admin-table td{border-bottom:1px solid #e2e8f04d;color:#334155;font-size:.8rem;overflow:hidden;padding:.5rem .75rem;text-overflow:ellipsis;transition:all .2s ease;white-space:nowrap}.admin-table tr{animation:fadeSlideUp .5s cubic-bezier(.16,1,.3,1) both;animation-delay:0s;animation-delay:var(--animation-delay,0s);height:3rem;position:relative;transition:all .2s cubic-bezier(.16,1,.3,1)}.candidate-management .admin-table tr,.compare-quiz-management .admin-table tr,.election-management .admin-table tr{height:4.5rem}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background-color:#f3f4f666}.admin-table tr:hover{box-shadow:0 2px 6px #00000005;transform:translateY(-1px);z-index:5}.empty-table{color:#6b7280;font-size:1rem;padding:4rem 2rem;text-align:center}.empty-table:before{content:"📋";opacity:.7}.status-badge{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#ffffffe6;border:1px solid #0000;border-radius:2rem;box-shadow:0 2px 6px #00000008;font-size:.8rem;gap:.4rem;padding:.4rem .8rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.status-badge.active{background:linear-gradient(135deg,#dcfce7e6,#bbf7d0e6);border-color:#a7f3d0e6}.status-badge.active:hover{background:linear-gradient(135deg,#bbf7d0f2,#a7f3d0f2);box-shadow:0 4px 12px #10b9811a;transform:translateY(-1px)}.status-badge.inactive{background:linear-gradient(135deg,#fee2e2e6,#fecacae6);border-color:#fecacae6}.status-badge.inactive:hover{background:linear-gradient(135deg,#fecacaf2,#fecacaf2);box-shadow:0 4px 12px #ef44441a;transform:translateY(-1px)}.action-buttons{display:flex;flex-direction:row;gap:.25rem;justify-content:flex-end;white-space:nowrap}.candidate-actions,.compare-quiz-management .action-buttons,.election-management .action-buttons{gap:.5rem}.action-button{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#fffc;border:1px solid #0000;border-radius:.5rem;box-shadow:0 1px 3px #00000008;color:#64748b;display:flex;font-size:.75rem;height:1.75rem;overflow:hidden;position:relative;transition:all .2s cubic-bezier(.16,1,.3,1);width:1.75rem}.candidate-actions .action-button,.compare-quiz-management .action-button,.election-management .action-button{border-radius:.675rem;font-size:.875rem;height:2.25rem;width:2.25rem}.action-button:before{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s ease;z-index:-1}.action-button:hover{box-shadow:0 2px 6px #0000000d}.action-button:hover:before{opacity:1}.action-button.edit{background:#e0f2fe99;border-color:#bae6fd66;color:#0284c7}.action-button.edit:hover{background:#bae6fdcc;box-shadow:0 2px 6px #0284c71a}.action-button.delete{background:#fee2e299;border-color:#fecaca66}.action-button.delete:hover{background:#fecacacc;box-shadow:0 2px 6px #dc26261a}.action-button.assign-candidates{background:#eef2ff99;border-color:#e0e7ff66;color:#4f46e5}.action-button.assign-candidates:hover{background:#e0e7ffcc;box-shadow:0 2px 6px #4f46e51a}.admin-modal-overlay{animation:fadeIn .5s cubic-bezier(.16,1,.3,1);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#0f172a80;padding:1.5rem;z-index:50}.admin-modal,.election-modal{animation:modalSlideUp .6s cubic-bezier(.16,1,.3,1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #e2e8f0cc;border-radius:1.25rem;box-shadow:0 20px 40px #0000001a,0 15px 30px #0000000d,0 0 0 1px #e2e8f0cc,inset 0 2px 0 #ffffffb3;max-width:700px;overflow:hidden;position:relative;width:90%}.admin-modal-large{max-width:900px}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}70%{opacity:1}to{opacity:1;transform:translateY(0) scale(1)}}.admin-modal:before,.election-modal:before{background:radial-gradient(circle at top right,#3b82f608,#0000 70%),radial-gradient(circle at bottom left,#10b98108,#0000 70%);content:"";inset:0;opacity:.8;position:absolute;z-index:-1}.admin-modal-header,.election-modal-header{align-items:center;animation:fadeSlideDown .5s cubic-bezier(.16,1,.3,1) both;background:linear-gradient(180deg,#ffffffe6,#f9fafbcc);border-bottom:1px solid #e2e8f0cc;display:flex;justify-content:space-between;padding:1.25rem 1.5rem;position:relative}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.admin-modal-header:after,.election-modal-header:after{background:linear-gradient(90deg,#0000,#3b82f64d,#0000);bottom:-1px;content:"";height:1px;left:0;opacity:.8;position:absolute;right:0}.admin-modal-header h3,.election-modal-header h3{-webkit-text-fill-color:#0000;text-fill-color:#0000;background:linear-gradient(135deg,#1e293b,#334155);-webkit-background-clip:text;background-clip:text;color:#1e293b;font-size:1.15rem;font-weight:700;letter-spacing:-.01em;margin:0;position:relative}.admin-modal-header h3:after,.election-modal-header h3:after{animation:expandLine 1.2s cubic-bezier(.16,1,.3,1) forwards;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:3px;bottom:-6px;content:"";height:3px;left:0;opacity:0;position:absolute;transform-origin:left;width:40px}.admin-modal-close,.election-modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;font-size:1.5rem;height:2.5rem;justify-content:center;overflow:hidden;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1);width:2.5rem}.admin-modal-close:before,.election-modal-close:before{background:radial-gradient(circle at center,#e2e8f000,#e2e8f080);content:"";inset:0;opacity:0;position:absolute;transform:scale(.5);transition:opacity .3s ease}.admin-modal-close:hover,.election-modal-close:hover{color:#334155;transform:rotate(90deg)}.admin-modal-close:hover:before,.election-modal-close:hover:before{opacity:1;transform:scale(1.2)}.admin-modal-body,.election-modal-body{max-height:calc(100vh - 180px);overflow-y:auto;padding:1.5rem;scroll-behavior:smooth}.admin-modal-footer,.election-modal-footer{animation:fadeSlideUp .5s cubic-bezier(.16,1,.3,1) .2s both;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:linear-gradient(0deg,#f9fafbe6,#f8fafcb3);border-top:1px solid #e2e8f0cc;box-shadow:0 -8px 20px #00000005;display:flex;gap:.75rem;justify-content:flex-end;padding:1.25rem 1.5rem;position:relative}.admin-modal-footer:before,.election-modal-footer:before{background:linear-gradient(90deg,#0000,#3b82f64d,#0000);content:"";height:1px;left:0;opacity:.8;position:absolute;right:0;top:-1px}.admin-modal-footer .admin-button,.election-modal-footer .admin-button{min-width:120px;transition:all .4s cubic-bezier(.16,1,.3,1)}.admin-modal-footer .admin-button-primary,.election-modal-footer .admin-button-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);overflow:hidden;position:relative}.admin-modal-footer .admin-button-primary:after,.election-modal-footer .admin-button-primary:after{background:linear-gradient(to bottom right,#fff0,#fff3 50%,#fff0);content:"";height:200%;left:-50%;opacity:0;position:absolute;top:-50%;transform:rotate(45deg) translate(-100%,-100%);transition:all .6s cubic-bezier(.16,1,.3,1);width:200%;z-index:1}.admin-modal-footer .admin-button-primary:hover:after,.election-modal-footer .admin-button-primary:hover:after{opacity:1;transform:rotate(45deg) translate(100%,100%)}.form-tabs{border-bottom:1px solid #e2e8f0cc;margin-bottom:2rem;position:relative}.form-tabs:after{background:linear-gradient(90deg,#0000,#e2e8f080,#0000);bottom:-1px;content:"";height:1px;left:0;position:absolute;right:0}.form-tab{color:#64748b;font-size:1rem;padding:1rem 1.5rem;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1);z-index:1}.form-tab:hover{color:#334155}.form-tab.active{border-bottom-color:#2563eb;color:#2563eb;font-weight:600}.form-tab.active:before{animation:expandTabLine .4s cubic-bezier(.16,1,.3,1) forwards;background:linear-gradient(90deg,#3b82f6,#2563eb);border-radius:1px;bottom:-2px;content:"";height:2px;left:0;position:absolute;right:0;transform-origin:center;z-index:2}@keyframes expandTabLine{0%{opacity:.5;transform:scaleX(.3)}to{opacity:1;transform:scaleX(1)}}.election-form-grid{grid-gap:1.75rem;animation:fadeSlideUp .4s cubic-bezier(.16,1,.3,1) both;display:grid;gap:1.75rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}.election-form-group{margin-bottom:1.5rem;position:relative}.election-form-group label{color:#475569;display:block;font-size:.95rem;font-weight:600;margin-bottom:.6rem;transition:all .2s ease}.election-form-group:focus-within label{color:#2563eb}.required-field:after{color:#ef4444;content:" *"}.election-form-group input[type=date],.election-form-group input[type=text],.election-form-group input[type=url],.election-form-group select{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#ffffffe6;border:1px solid #cbd5e1cc;border-radius:.875rem;box-shadow:0 2px 6px #00000005;color:#334155;font-size:.95rem;padding:.875rem 1rem;transition:all .3s cubic-bezier(.16,1,.3,1);width:100%}.election-form-group input[type=date]:hover,.election-form-group input[type=text]:hover,.election-form-group input[type=url]:hover,.election-form-group select:hover{background:#fffffff2;border-color:#94a3b8b3}.election-form-group input[type=date]:focus,.election-form-group input[type=text]:focus,.election-form-group input[type=url]:focus,.election-form-group select:focus{background:#fffffffa;border-color:#60a5fa;box-shadow:0 0 0 3px #3b82f626,0 2px 8px #00000008;outline:none;transform:translateY(-2px)}.switch-container{animation:fadeSlideUp .4s cubic-bezier(.16,1,.3,1) .2s both;margin-top:.75rem}.switch{margin-right:.875rem}.slider{background-color:#e2e8f0cc;box-shadow:inset 0 1px 3px #0000000d}.slider,.slider:before{transition:.4s cubic-bezier(.16,1,.3,1)}.slider:before{box-shadow:0 1px 3px #0000001a}input:checked+.slider{background:linear-gradient(135deg,#10b981,#059669)}input:focus+.slider{box-shadow:0 0 0 3px #10b98126}input:checked+.slider:before{box-shadow:0 2px 5px #10b98133}.switch-label{color:#475569;font-size:.95rem;font-weight:500;transition:all .2s ease}input:checked~.switch-label{color:#334155}.conditional-fields{animation:fadeSlideUp .4s cubic-bezier(.16,1,.3,1) .3s both;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#f9fafbcc;border:1px solid #e2e8f0cc;border-radius:1rem;box-shadow:0 4px 12px #00000005;grid-column:span 2;margin-top:1rem;overflow:hidden;padding:1.5rem;position:relative}.conditional-fields:before{background:radial-gradient(circle at top right,#3b82f605,#0000 70%),radial-gradient(circle at bottom left,#10b98105,#0000 70%);content:"";inset:0;opacity:.8;position:absolute;z-index:-1}.conditional-fields .conditional-title{align-items:center;color:#475569;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin-bottom:1.5rem}.conditional-fields .conditional-title span{color:#3b82f6;opacity:.9}.location-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.candidates-panel{grid-gap:2rem;animation:fadeSlideUp .4s cubic-bezier(.16,1,.3,1) both;display:grid;gap:2rem;grid-template-columns:1fr 1fr;max-height:65vh}.candidates-column{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#ffffffe6;border:1px solid #e2e8f0cc;border-radius:1rem;box-shadow:0 4px 12px #00000005;display:flex;flex-direction:column;height:100%;overflow:hidden;transition:all .3s cubic-bezier(.16,1,.3,1)}.candidates-column:hover{box-shadow:0 8px 20px #0000000a,0 4px 8px #00000005;transform:translateY(-3px)}.candidates-header{background:linear-gradient(90deg,#f9fafbf2,#f8fafcf2);border-bottom:1px solid #e2e8f0b3;padding:1.25rem 1.5rem;position:relative}.candidates-header:after{background:linear-gradient(90deg,#0000,#3b82f633,#0000);bottom:-1px;content:"";height:1px;left:0;opacity:.8;position:absolute;right:0}.candidates-header h4{align-items:center;color:#334155;display:flex;font-size:1.1rem;font-weight:600;gap:.6rem;margin:0}.candidates-header h4 span{color:#3b82f6;opacity:.9}.candidates-list{padding:1rem;scrollbar-color:#cbd5e180 #0000;scrollbar-width:thin}.candidates-list::-webkit-scrollbar{width:6px}.candidates-list::-webkit-scrollbar-track{background:#0000}.candidates-list::-webkit-scrollbar-thumb{background-color:#cbd5e180;border-radius:3px}.empty-candidates{align-items:center;color:#64748b;display:flex;font-size:.95rem;height:100%;justify-content:center;line-height:1.6;padding:2.5rem}.empty-candidates:before{content:"👤";display:block;font-size:2rem;margin-bottom:1rem;opacity:.7}.candidate-card{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#ffffffe6;border:1px solid #e2e8f0cc;border-radius:.875rem;box-shadow:0 2px 6px #00000005;justify-content:space-between;margin-bottom:1rem;padding:1.25rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.candidate-card:hover{border-color:#cbd5e1e6;box-shadow:0 6px 15px #0000000a;transform:translateY(-3px)}.candidate-card:before{background:radial-gradient(circle at top right,#3b82f605,#0000 70%),radial-gradient(circle at bottom left,#10b98105,#0000 70%);content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s ease;z-index:-1}.candidate-card:hover:before{opacity:1}.candidate-info{align-items:center;display:flex;gap:1rem}.candidate-avatar{background:#f8fafce6;border:1px solid #e2e8f0cc;box-shadow:0 2px 6px #00000005;height:3.5rem;position:relative;transition:all .3s ease;width:3.5rem}.candidate-card:hover .candidate-avatar{border-color:#bfdbfecc;box-shadow:0 4px 12px #3b82f61a}.candidate-avatar img{object-position:center center;transition:all .3s ease}.candidate-avatar-placeholder{align-items:center;background:linear-gradient(135deg,#e0f2fe,#bfdbfe);color:#2563eb;display:flex;font-size:1.25rem;font-weight:700;height:100%;justify-content:center;text-transform:uppercase;width:100%}.candidate-details{overflow:hidden}.candidate-name{color:#334155;display:inline-block;font-size:1rem;margin-bottom:.4rem;position:relative}.candidate-name,.candidate-name:after{transition:all .3s cubic-bezier(.16,1,.3,1)}.candidate-name:after{background:linear-gradient(90deg,#3b82f6,#2563eb);border-radius:1px;bottom:-5px;content:"";height:2px;left:0;opacity:0;position:absolute;width:0}.admin-table tr:hover .candidate-name{color:#1e293b;transform:translateY(-1px)}.admin-table tr:hover .candidate-name:after{opacity:1;width:100%}.candidate-card:hover .candidate-name{color:#1e293b}.candidate-website{display:block;font-size:.9rem;max-width:200px;overflow:hidden;position:relative;text-overflow:ellipsis;transition:all .3s cubic-bezier(.16,1,.3,1);white-space:nowrap}.candidate-website:after{background:linear-gradient(90deg,#3b82f6,#2563eb);bottom:-3px;content:"";height:1px;left:0;opacity:0;position:absolute;transition:all .3s cubic-bezier(.16,1,.3,1);width:0}.candidate-website:hover{color:#2563eb;transform:translateY(-1px)}.candidate-website:hover:after{opacity:1;width:100%}.new-candidate-section{animation:fadeSlideUp .4s cubic-bezier(.16,1,.3,1) both;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#f9fafbb3;border:1px solid #e2e8f0cc;border-radius:.875rem;box-shadow:0 4px 12px #00000005;padding:1.5rem}.new-candidate-header{align-items:center;display:flex;margin-bottom:1.5rem}.new-candidate-header h4{align-items:center;color:#334155;display:flex;font-size:1.1rem;font-weight:600;gap:.6rem;margin:0}.new-candidate-header h4 span{color:#3b82f6;opacity:.9}@media (max-width:1024px){.admin-content{padding:2rem}.admin-header{margin-bottom:2rem}.admin-title{font-size:1.65rem}.election-form-grid{grid-template-columns:1fr}}@media (max-width:768px){.admin-container{flex-direction:column}.admin-sidebar{box-shadow:0 4px 12px #0000000d;height:auto;max-height:none;position:static;width:100%}.admin-brand{align-items:center;flex-direction:row;gap:1rem;justify-content:space-between;padding:1.25rem}.admin-home-button{margin-top:0;padding:.75rem 1rem;width:auto}.admin-content{max-width:100%;padding:1.5rem}.candidates-panel{gap:1.5rem;grid-template-columns:1fr;grid-template-rows:1fr 1fr;max-height:none}.admin-header{align-items:flex-start;flex-direction:column;gap:1rem}.stats-grid{grid-template-columns:1fr}.admin-modal,.election-modal{width:95%}.admin-modal-body,.election-modal-body{padding:1.5rem}}@media (max-width:640px){.admin-title{font-size:1.5rem}.admin-content{padding:1.25rem}.action-buttons{grid-template-columns:1fr}.admin-table td,.admin-table th{padding:1rem}.admin-button{width:100%}.admin-modal-header,.election-modal-header{padding:1.25rem 1.5rem}.admin-modal-header h3,.election-modal-header h3{font-size:1.25rem}.admin-modal-footer,.election-modal-footer{flex-direction:column;gap:.75rem;padding:1.25rem 1.5rem}.admin-modal-footer button,.election-modal-footer button{width:100%}.candidate-card{align-items:flex-start;flex-direction:column;padding:1rem}.candidate-info{margin-bottom:1rem;width:100%}.action-button{width:100%}}.election-button{align-items:center;background:#ffffffe6;border:1px solid #e2e8f0cc;border-radius:.875rem;box-shadow:0 4px 12px #00000008,0 2px 6px #00000005;color:#475569;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.6rem;justify-content:center;overflow:hidden;padding:.875rem 1.5rem;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1);z-index:1}.election-button:before{background:linear-gradient(90deg,#f9fafbcc,#f3f4f6cc);content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s ease;z-index:-1}.election-button:hover{border-color:#cbd5e1e6;box-shadow:0 8px 20px #0000000a,0 4px 10px #00000008;transform:translateY(-3px)}.election-button:hover:before{opacity:1}.election-button:active{box-shadow:0 4px 8px #00000008;transform:translateY(-1px)}.election-button-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#0000;box-shadow:0 8px 20px #2563eb33,0 4px 10px #2563eb1a;color:#fff}.election-button-primary:before{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.election-button-primary:hover{border-color:#0000;box-shadow:0 12px 30px #2563eb40,0 6px 15px #2563eb26}.election-button-cancel{background:#ffffffb3;border-color:#e2e8f0cc;color:#64748b}.election-button-cancel:hover{background:#f8fafce6;color:#475569}.election-button-small{border-radius:.75rem;font-size:.875rem;padding:.625rem 1rem}.admin-loading{animation:fadeIn .8s cubic-bezier(.16,1,.3,1) both;color:#64748b;padding:4rem 2rem}.spinner{animation:spin 1.2s cubic-bezier(.5,.1,.5,.9) infinite;border:3px solid #3b82f626;box-shadow:0 4px 16px #3b82f626;height:3.5rem;margin-bottom:2rem;position:relative;width:3.5rem}.spinner:before{animation:pulseRing 2s cubic-bezier(.4,0,.6,1) infinite;border:2px solid #3b82f60f;border-radius:50%;content:"";inset:-10px;opacity:0;position:absolute}@keyframes pulseRing{0%{opacity:0;transform:scale(.8)}50%{opacity:.5}to{opacity:0;transform:scale(1.5)}}.admin-loading p{-webkit-text-fill-color:#0000;text-fill-color:#0000;background:linear-gradient(135deg,#1e293b,#3b82f6);-webkit-background-clip:text;background-clip:text;color:#334155;font-size:1.25rem;font-weight:600;margin:0 0 .5rem;text-align:center}.admin-loading span{color:#64748b;font-size:.95rem;text-align:center}.candidate-management{animation:fadeSlideUp .8s cubic-bezier(.16,1,.3,1) both;margin:0 auto;max-width:1400px}.admin-filters{flex-wrap:wrap;gap:1rem}.admin-filters,.filter-group{align-items:center;display:flex}.filter-group{gap:.75rem;position:relative}.filter-group label{color:#475569;font-size:.95rem;font-weight:600}.filter-group select{-webkit-appearance:none;appearance:none;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#ffffffe6;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m19 9-7 7-7-7'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;background-size:1rem;border:1px solid #e2e8f0cc;border-radius:.875rem;box-shadow:0 2px 6px #00000005;color:#334155;font-size:.95rem;min-width:200px;padding:.75rem 2.5rem .75rem 1rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.filter-group select:hover{background-color:#fffffff2;border-color:#94a3b8b3;box-shadow:0 4px 12px #00000008}.filter-group select:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #3b82f626;outline:none;transform:translateY(-2px)}.admin-alert{align-items:center;animation:fadeSlideUp .5s cubic-bezier(.16,1,.3,1) both;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:linear-gradient(135deg,#fef9c3e6,#fef08ae6);border:1px solid #fde047cc;border-radius:.875rem;box-shadow:0 4px 15px #fde0471a;color:#854d0e;display:flex;flex-direction:column;margin:1rem 0;overflow:hidden;padding:1.5rem;position:relative;text-align:center}.admin-alert:after{background:radial-gradient(circle at top right,#facc151a,#0000 70%),radial-gradient(circle at bottom left,#fbbf241a,#0000 70%);content:"";inset:0;opacity:.8;position:absolute;z-index:-1}.admin-alert.error{background:linear-gradient(135deg,#fee2e2e6,#fecacae6);border-color:#fca5a5cc;box-shadow:0 4px 15px #ef44441a;color:#b91c1c}.admin-alert.error:before{content:"❌"}.admin-alert.error:after{background:radial-gradient(circle at top right,#ef44441a,#0000 70%),radial-gradient(circle at bottom left,#dc26261a,#0000 70%)}.admin-alert.info{background:linear-gradient(135deg,#f0f9ffe6,#e0f2fee6);border:1px solid #bae6fdcc;box-shadow:0 4px 15px #0284c71a;color:#0284c7}.admin-alert.info:before{content:"ℹ️"}.admin-alert.info:after{background:radial-gradient(circle at top right,#38bdf81a,#0000 70%),radial-gradient(circle at bottom left,#0284c71a,#0000 70%)}.admin-alert h3{font-size:1.25rem;font-weight:700;margin:0}.admin-alert p{font-size:.95rem;line-height:1.5;margin:0}.candidate-logo{background-color:#fff;border:2px solid #fff;border-radius:50%;box-shadow:0 4px 12px #00000014;clip-path:circle(50%);display:block;height:3.5rem;overflow:hidden;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1);width:3.5rem}.candidate-logo:hover{border-color:#bfdbfecc;box-shadow:0 4px 12px #3b82f61a;transform:scale(1.05)}.candidate-logo img{display:block!important;height:100%!important;object-fit:cover!important;object-position:center center!important;width:100%!important}.candidate-image-placeholder{align-items:center;background:linear-gradient(135deg,#e0f2fe,#bfdbfe);display:flex;height:100%;justify-content:center;width:100%}.candidate-initials{color:#2563eb;font-size:1.25rem;font-weight:700;text-transform:uppercase}.election-badges-container{display:flex;flex-wrap:wrap;gap:.5rem}.election-badge{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#f0f9ffe6;border:1px solid #bae6fdb3;border-radius:.75rem;box-shadow:0 1px 3px #0284c70d;color:#0284c7;display:inline-flex;font-size:.65rem;font-weight:600;padding:.2rem .5rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.election-badge.neutral{background:#f1f5f9e6;border-color:#cbd5e1b3;box-shadow:0 1px 3px #64748b0d;color:#64748b}.election-badge:hover{background:#e0f2fee6;box-shadow:0 4px 8px #0284c71a;transform:translateY(-2px)}.election-badge.primary{background:linear-gradient(135deg,#ecfeffe6,#cffafee6);border-color:#a5f3fcb3;box-shadow:0 2px 4px #0891b20d;color:#0891b2}.election-badge.primary:hover{background:linear-gradient(135deg,#cffafee6,#a5f3fce6);box-shadow:0 4px 8px #0891b21a}.action-button.import{background:#eef2ff99;border-color:#e0e7ff66;color:#4f46e5}.action-button.import:hover{background:#e0e7ffcc;box-shadow:0 2px 6px #4f46e51a}.logo-preview{background-color:#fff;border:2px solid #fff;border-radius:50%;box-shadow:0 4px 12px #00000014;clip-path:circle(50%);height:90px;margin-left:auto;margin-right:auto;margin-top:1rem;overflow:hidden;position:relative;width:90px}.logo-preview img{display:block!important;height:160%!important;left:50%!important;object-fit:cover!important;object-position:center top!important;position:absolute!important;top:50%!important;transform:translate(-50%,-50%)!important;width:160%!important}.logo-preview:before{background:radial-gradient(circle at top right,#3b82f605,#0000 70%),radial-gradient(circle at bottom left,#10b98105,#0000 70%);content:"";inset:0;opacity:.8;position:absolute;z-index:-1}.form-group{animation:fadeSlideUp .5s cubic-bezier(.16,1,.3,1) both;margin-bottom:1.75rem;position:relative}.form-group label{color:#475569;font-size:.95rem;margin-bottom:.75rem;opacity:.9;transition:all .3s cubic-bezier(.16,1,.3,1)}.form-group .required-field{color:#ef4444;font-weight:700}.form-group:focus-within label{color:#2563eb;opacity:1;transform:translateY(-1px)}.form-group input[type=text],.form-group input[type=url],.form-group select{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background:#ffffffe6;border:1px solid #cbd5e1cc;border-radius:.875rem;box-shadow:0 2px 6px #00000005,inset 0 2px 2px #fffc;color:#334155;font-size:.95rem;padding:.95rem 1.25rem;position:relative;transition:all .3s cubic-bezier(.16,1,.3,1);width:100%}.form-group input[type=text]::placeholder,.form-group input[type=url]::placeholder{color:#94a3b8;opacity:.7;transition:all .3s ease}.form-group input[type=text]:hover,.form-group input[type=url]:hover,.form-group select:hover{background:#fffffff2;border-color:#94a3b8b3;box-shadow:0 4px 12px #00000008,inset 0 2px 2px #ffffffe6}.form-group input[type=text]:focus,.form-group input[type=url]:focus,.form-group select:focus{background:#fffffffa;border-color:#60a5fa;box-shadow:0 0 0 3px #3b82f626,0 2px 8px #00000008,inset 0 2px 2px #ffffffe6;outline:none;transform:translateY(-2px)}.form-group input[type=text]:focus::placeholder,.form-group input[type=url]:focus::placeholder{opacity:.5;transform:translateX(5px)}.form-group:after{background:linear-gradient(90deg,#3b82f64d,#2563eb1a);border-radius:1px;bottom:-10px;content:"";height:2px;left:0;opacity:0;position:absolute;transition:all .4s cubic-bezier(.16,1,.3,1);width:0}.form-group:focus-within:after{opacity:1;width:100%}.empty-table{position:relative}.empty-table:before{animation:bounce 3s infinite;content:"👥";display:block;font-size:2.5rem;margin-bottom:1rem}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}@media (max-width:1024px){.admin-filters{align-items:flex-start;flex-direction:column}.filter-group,.filter-group select{width:100%}.admin-table td:nth-child(3),.admin-table th:nth-child(3){display:none}}@media (max-width:768px){.admin-table td:nth-child(4),.admin-table th:nth-child(4){display:none}.action-buttons{flex-wrap:wrap}.action-button{height:2.5rem;width:2.5rem}.filter-group select{background-image:none;padding-right:1rem}}@media (max-width:640px){.admin-table tr{display:flex;flex-wrap:wrap;padding:.75rem .5rem;position:relative}.admin-table td{border-bottom:none;flex:1 1 auto;padding:.5rem;text-align:left}.admin-table td:last-child{flex:0 0 auto;width:auto}.action-buttons{display:flex;flex-direction:row;gap:.25rem}.admin-table th{display:none}.filter-group{margin-bottom:.75rem}.filter-group select{background-image:none;min-width:100%;padding:.75rem}.filter-group select:focus,.filter-group select:hover{box-shadow:0 0 0 1px #3b82f680;transform:none}.candidate-management label span,.election-form-group .required-field span,.election-form-group label span,.new-candidate-section label span,label[for=logo] span,label[for=website] span,label[for=zipCode] span{display:none!important}.admin-modal input[type=url],input#zipCode,input[type=url]{background-image:none!important;padding-right:.75rem!important}}.mobile-activity-container{background-color:#f5f5f5;display:flex;flex-direction:column;min-height:100vh}.activity-content{background-color:#f5f5f5;flex:1 1;overflow-y:auto;padding-bottom:20px}.status-filter-section{background-color:#fff;box-shadow:0 1px 3px #0000001a;padding:16px;position:sticky;top:0;z-index:10}.filter-pills{-webkit-overflow-scrolling:touch;display:flex;gap:12px;overflow-x:auto;scrollbar-width:none}.filter-pills::-webkit-scrollbar{display:none}.filter-pill{background-color:#f0f0f0;border:none;border-radius:20px;color:#666;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:500;padding:8px 20px;transition:all .2s ease;white-space:nowrap}.filter-pill.active{background-color:#3b82f6;color:#fff}.filter-pill:not(.active):hover{background-color:#e0e0e0}.activity-list{display:flex;flex-direction:column;gap:16px;padding:16px}.activity-card{background-color:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;overflow:hidden;transition:all .2s ease}.activity-card:hover{box-shadow:0 4px 6px #0000001a}.activity-card:active{transform:scale(.99)}.card-content{display:flex;flex-direction:column;gap:20px;min-height:200px;padding:24px;position:relative}.quiz-header{justify-content:space-between}.quiz-title-section{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:12px;text-align:center}.quiz-title{color:#1a1a1a;font-size:20px;font-weight:700;line-height:1.2;margin:0}.quiz-subtitle{align-items:center;display:flex;flex-direction:column;gap:8px;width:100%}.quiz-type-badge{background-color:#3b82f6!important;border-radius:16px;color:#fff!important;font-size:12px;font-weight:600;letter-spacing:.5px;padding:4px 12px}.election-info{align-items:center;display:flex}.separator{color:#cbd5e0;margin:0 4px}.activity-card .election-name{color:#475569!important;font-size:16px;font-weight:500;line-height:1.4}.status-indicator{align-items:center;background-color:#ffffffe6;border-radius:50%;box-shadow:0 2px 4px #0000001a;display:flex;height:32px;justify-content:center;position:absolute;right:20px;top:20px;width:32px}.status-icon{font-size:20px}.status-icon.completed{color:#48bb78}.status-icon.in-progress{color:#ed8936}.status-icon.pending{color:#a0aec0}.progress-section{margin-bottom:12px}.progress-bar-container{margin-bottom:8px}.progress-bar{background-color:#e2e8f0;box-shadow:inset 0 1px 2px #0000001a}.progress-fill{background:linear-gradient(90deg,#3b82f6,#2563eb);box-shadow:0 1px 2px #3b82f680}.progress-text{color:#64748b;font-size:13px;margin:0}.completion-info{margin-bottom:12px}.completion-text{color:#64748b;font-size:13px;margin:0}.quiz-meta{align-items:center;display:flex;font-size:12px;gap:6px;margin-top:8px}.meta-icon,.meta-text{color:#94a3b8;font-size:12px}.card-action{margin-top:auto}.primary-button,.secondary-button{background-color:#3b82f6;border:none;border-radius:12px;box-shadow:0 2px 4px #3b82f633;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 24px;text-align:center;transition:all .2s ease;width:100%}.primary-button:hover,.secondary-button:hover{background-color:#2563eb;box-shadow:0 4px 8px #3b82f64d;transform:translateY(-1px)}.primary-button:active,.secondary-button:active{transform:translateY(0)}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:40px 20px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f0f0f0;margin-bottom:16px}.loading-container p{color:#666;font-size:16px;margin:0}.error-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:40px 20px;text-align:center}.error-container p{color:#666;font-size:16px;margin-bottom:20px}.retry-button{background-color:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px 32px;transition:all .2s ease}.retry-button:hover{background-color:#2563eb}.retry-button:active{transform:scale(.98)}.empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:40px 20px}.empty-icon{font-size:64px;margin-bottom:20px}.empty-state h3{color:#1a1a1a;font-size:20px;font-weight:600;margin:0 0 8px}.empty-state p{color:#666;font-size:16px;margin:0 0 24px}body.mobile-app-mode{height:100vh}body.mobile-app-mode .mobile-activity-container{height:100vh;overflow:hidden}.activity-content::-webkit-scrollbar{width:6px}.activity-content::-webkit-scrollbar-track{background:#0000}.activity-content::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.activity-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (min-width:768px){.activity-content{padding-top:0}.activity-list,.status-filter-section{padding:20px 24px}.activity-list{margin:0 auto;max-width:800px}.activity-card{border-radius:16px}.card-content{padding:24px}.quiz-title{font-size:20px}.filter-pill{font-size:15px;padding:10px 24px}}@media (min-width:1024px){.activity-list{max-width:900px}}.simple-search-container{margin-bottom:20px;width:100%}.simple-search-wrapper{margin:0 auto;max-width:500px;position:relative;width:100%}.simple-search-input{background:#fff;border:2px solid #e2e8f0;border-radius:16px;box-shadow:0 2px 8px #0000000a;color:#1e293b;font-size:16px;padding:14px 48px;transition:all .2s ease,padding-left .2s ease;width:100%}.simple-search-input:focus{border-color:#3b82f6;box-shadow:0 4px 20px #3b82f626;outline:none}.simple-search-input::placeholder{color:#94a3b8;opacity:1}.search-icon-container{align-items:center;color:#94a3b8;display:flex;justify-content:center;left:16px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:opacity .2s ease;z-index:2}.search-icon{height:18px;width:18px}.clear-search-button{align-items:center;background:#0000;border:none;border-radius:8px;color:#94a3b8;cursor:pointer;display:flex;justify-content:center;padding:8px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:all .2s ease}.clear-search-button:hover{background:#f1f5f9;color:#475569}.clear-icon{height:18px;width:18px}@media (max-width:480px){.simple-search-input{font-size:16px}}.election-selection-container{background-color:#f8fafc;margin:0 auto;max-width:1200px;min-height:100vh;padding:2rem}.mobile-election-container{background:linear-gradient(180deg,#dbeafe,#bfdbfe);bottom:0;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;left:0;position:fixed;right:0;top:0;z-index:9999}.mobile-app-header{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 10px #2563eb33;display:flex;justify-content:space-between;padding:12px 16px;position:relative}.mobile-nav-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:50%;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s ease;width:44px}.mobile-nav-button:hover{background:#ffffff4d;transform:scale(1.05)}.mobile-nav-button svg{color:#fff;height:24px;width:24px}.mobile-app-title{color:#fff;font-size:24px;font-weight:700;letter-spacing:-1px;margin:0}.mobile-nav-spacer{width:50px}.mobile-content{flex:1 1;overflow-y:auto;padding:0 20px 20px}.election-intro{margin-bottom:30px;padding-top:20px;text-align:center}.election-question{color:#1e293b;font-size:24px;font-weight:700;margin:0 0 20px}.election-search-wrapper{margin:0 auto;max-width:500px;padding:0 20px}.search-results-count{color:#64748b;font-size:14px;font-weight:500;margin:8px 0 0;text-align:center}.election-subtitle{color:#64748b;font-size:16px;margin:0;opacity:.8}body.mobile-app-mode .navbar,body.mobile-app-mode header,body.mobile-app-mode nav{display:none!important}body.mobile-app-mode{overflow:hidden}body.mobile-app-mode #root>div{margin:0!important;padding:0!important}.mobile-election-container .elections-grid{display:flex;flex-direction:column;gap:16px;padding:0}.mobile-election-container .election-card{background:#fff;border:3px solid #0000;border-radius:16px;box-shadow:0 4px 12px #0000001a;cursor:pointer;overflow:hidden;padding:20px;position:relative;text-align:center;transition:all .3s ease}.mobile-election-container .election-card:hover{border-color:#3b82f6;box-shadow:0 6px 16px #00000026;transform:translateY(-2px)}.mobile-election-container .election-card.selected{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#3b82f6}.mobile-election-container .election-icon{font-size:2.5rem;margin-bottom:12px}.mobile-election-container .election-card h3{color:#1e293b;font-size:18px;font-weight:700;margin:0 0 8px}.mobile-election-container .election-date{color:#3b82f6;font-size:14px;font-weight:600;margin:0 0 4px}.mobile-election-container .election-location{color:#64748b;font-size:13px;margin:0 0 8px}.mobile-election-container .election-type{background:#f1f5f9;border-radius:20px;color:#475569;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.mobile-election-container .no-elections{color:#64748b;padding:40px 20px;text-align:center}.mobile-election-container .no-elections p{font-size:16px;margin:0 0 8px}.mobile-election-container .error-message,.mobile-election-container .loading-spinner{align-items:center;color:#64748b;display:flex;flex:1 1;flex-direction:column;justify-content:center;text-align:center}.mobile-election-container .error-message button{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin-top:16px;padding:12px 24px;transition:all .2s ease}.mobile-election-container .error-message button:hover{background:#2563eb;transform:translateY(-1px)}.election-header{margin-bottom:3rem;text-align:center}.election-header h1{color:#1a365d;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.election-header p{color:#64748b;font-size:1.125rem}.elections-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:2rem}.election-card{background:#fff;border:2px solid #0000;border-radius:12px;box-shadow:0 2px 8px #0000001a;cursor:pointer;overflow:hidden;padding:2rem;position:relative;text-align:center}.election-card:before{background:linear-gradient(135deg,#3b82f6,#2563eb);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.election-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.election-card:hover:before{transform:scaleX(1)}.election-card.selected{background-color:#3b82f60d;border-color:#3b82f6}.election-card:focus{outline:2px solid #3b82f6;outline-offset:2px}.election-icon{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;box-shadow:0 4px 12px #3b82f64d;display:flex;font-size:2rem;height:64px;justify-content:center;margin:0 auto 1rem;width:64px}.election-card h3{color:#1e293b;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.election-date{color:#64748b;font-size:.875rem;margin-bottom:.5rem}.election-location{color:#475569;font-size:.875rem;margin-bottom:1rem}.election-type{background:#e0e7ff;border-radius:9999px;color:#4338ca;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.election-type.federal{background:#dbeafe;color:#1d4ed8}.election-type.state{background:#d1fae5;color:#065f46}.election-type.local{background:#fef3c7;color:#92400e}.no-elections{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:4rem 2rem;text-align:center}.no-elections p{color:#64748b;font-size:1.125rem;margin-bottom:.5rem}.loading-spinner{padding:4rem}.loading-spinner:after{animation:spin 1s linear infinite;border:4px solid #3b82f61a;border-radius:50%;border-top-color:#3b82f6;content:"";display:block;height:40px;width:40px}.error-message{background:#fee2e2;border-radius:12px;padding:4rem 2rem;text-align:center}.error-message p{color:#dc2626;font-size:1.125rem;margin-bottom:1rem}.error-message button{background:#dc2626;border-radius:6px;color:#fff;font-size:1rem;font-weight:500;padding:.5rem 1.5rem;transition:background .2s}.error-message button:hover{background:#b91c1c}.election-card{animation:fadeInUp .4s ease-out backwards;transition:all .3s ease}.elections-grid:not(.filtering) .election-card:first-child{animation-delay:.1s}.elections-grid:not(.filtering) .election-card:nth-child(2){animation-delay:.2s}.elections-grid:not(.filtering) .election-card:nth-child(3){animation-delay:.3s}.elections-grid:not(.filtering) .election-card:nth-child(4){animation-delay:.4s}.elections-grid:not(.filtering) .election-card:nth-child(5){animation-delay:.5s}.elections-grid:not(.filtering) .election-card:nth-child(n+6){animation-delay:.6s}.elections-grid.filtering .election-card{animation:fadeIn .2s ease-out}@media (max-width:768px){.election-selection-container{padding:1rem}.election-header h1{font-size:2rem}.elections-grid{gap:1rem;grid-template-columns:1fr}.election-card{padding:1.5rem}.election-icon{font-size:1.75rem;height:56px;width:56px}}.compare-quiz-selection-container{background:linear-gradient(180deg,#f0f9ff,#e0f2fe 50%,#bae6fd);min-height:100vh;overflow-x:hidden;padding:76px 0 0}.page-content{margin:0 auto;max-width:600px;padding:20px}.election-banner{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:20px;box-shadow:0 8px 24px #3b82f640;color:#fff;margin-bottom:24px;padding:24px 20px;text-align:center}.election-name{color:#fff;font-size:24px;font-weight:700;letter-spacing:-.5px;margin:0}.election-details{display:none}.election-meta{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.meta-item{align-items:center;color:#475569;display:inline-flex;font-size:.875rem}.meta-item svg{margin-right:.375rem}.quizzes-grid{display:flex;flex-direction:row;flex-wrap:wrap;gap:12px;justify-content:center;margin:0 auto;max-width:600px;padding:20px}.quiz-card{align-items:center;background-color:#fff;border:2px solid #e2e8f0;border-radius:50px;box-shadow:0 4px 15px #00000014;cursor:pointer;display:inline-flex;min-width:160px;overflow:hidden;padding:16px 24px;position:relative;transition:all .3s ease}.quiz-card:hover{background:linear-gradient(135deg,#f8fafc,#eff6ff);border-color:#3b82f6;box-shadow:0 8px 25px #0000001f;transform:translateY(-2px) scale(1.02)}.quiz-header{align-items:center;display:flex;gap:12px;width:100%}.quiz-name{color:#1e293b;flex:1 1;font-size:16px;font-weight:600;letter-spacing:-.2px;margin:0}.status-badge{padding:.25rem .5rem}.status-badge.active{background-color:#dcfce7;color:#16a34a}.status-badge svg{height:10px;margin-right:3px;width:10px}.status-badge.inactive{background-color:#fee2e2;color:#dc2626}.status-badge svg{margin-right:.25rem}.quiz-details{display:none}.candidate-count,.date-range{font-size:.875rem;margin-bottom:.5rem}.label{font-weight:500;margin-right:.5rem}.label svg{margin-right:.25rem}.count,.dates{color:#64748b}.quiz-actions{display:none}.quiz-pill{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:50px;box-shadow:0 2px 10px #0000000f;cursor:pointer;display:flex;gap:12px;min-width:200px;overflow:hidden;padding:16px 28px;position:relative;transition:all .3s ease}.quiz-pill:hover{background:linear-gradient(135deg,#f8fafc,#eff6ff);border-color:#3b82f6;box-shadow:0 6px 20px #3b82f626;transform:translateY(-2px) scale(1.02)}.quiz-pill-content{flex:1 1;text-align:left}.quiz-pill-title{color:#1e293b;font-size:16px;font-weight:600;letter-spacing:-.2px;margin:0 0 4px}.quiz-pill-subtitle{color:#64748b;font-size:12px;margin:0}.quiz-pill-arrow{color:#3b82f6;font-size:20px;transition:transform .3s ease}.quiz-pill:hover .quiz-pill-arrow{transform:translateX(4px)}.quiz-pills-container{display:flex;flex-direction:column;gap:12px;margin:0 auto;max-width:400px;padding:20px}.no-quizzes{border-radius:.75rem;box-shadow:0 1px 3px #0000001a;padding:3rem 2rem}.no-quizzes h2{font-size:1.5rem;font-weight:600;margin-bottom:1rem}.no-quizzes p{margin-bottom:1.5rem}.primary-button{background-color:#3b82f6;border-radius:.5rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.primary-button:hover{background-color:#2563eb;transform:translateY(-1px)}.has-mobile-header .compare-quiz-selection-container{padding-top:0}.error-message,.loading-spinner-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:calc(100vh - 120px);padding:20px}.spinner{border:4px solid #3b82f61a;margin-bottom:16px}.error-message h3{color:#1e293b;font-size:24px;margin-bottom:12px}.error-message p{color:#64748b;margin-bottom:24px;text-align:center}.no-quizzes{background-color:#fff;border-radius:24px;box-shadow:0 10px 30px #00000014;margin:0 20px;padding:40px 20px;text-align:center}.no-quizzes h2{color:#1e293b;font-size:20px;font-weight:700;margin-bottom:12px}.no-quizzes p{color:#64748b;font-size:16px;margin-bottom:24px}.primary-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:14px;box-shadow:0 4px 15px #3b82f64d;color:#fff;cursor:pointer;display:inline-block;font-size:16px;font-weight:600;padding:14px 28px;transition:all .3s ease}.primary-button:hover{box-shadow:0 6px 20px #3b82f666;transform:translateY(-2px)}.status-badge{border-radius:12px;font-size:10px;letter-spacing:.3px;white-space:nowrap}.candidate-count,.date-range{align-items:center;display:flex;font-size:14px;gap:4px;margin-bottom:8px}.label{align-items:center;color:#475569;display:inline-flex;font-weight:600;gap:6px}.count,.dates{color:#64748b;font-weight:400}.quiz-card{animation:fadeInUp .5s ease-out backwards}.quiz-card:first-child{animation-delay:.1s}.quiz-card:nth-child(2){animation-delay:.2s}.quiz-card:nth-child(3){animation-delay:.3s}@media (min-width:768px){.page-header{padding:30px}.page-title{font-size:32px}.subtitle{font-size:16px}.quizzes-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));max-width:1000px;padding:30px}}@media (max-width:480px){.page-header{padding:16px}.page-title{font-size:20px}.election-info{font-size:12px;padding:10px 14px}.quiz-card{border-radius:16px}.quiz-header{padding:16px}.quiz-name{font-size:18px}.take-quiz-button{font-size:15px;padding:14px 20px}}.palumba-quiz-container{background:linear-gradient(180deg,#f0f9ff,#e0f2fe 50%,#bae6fd);bottom:0;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;left:0;overflow:hidden;position:fixed;right:0;top:0;z-index:10000}.palumba-header{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 10px #2563eb33;display:flex;justify-content:space-between;padding:12px 16px;position:relative}.palumba-nav-button{align-items:center;background:#fff3;border:1px solid #ffffff4d;border-radius:50%;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s ease;width:44px}.palumba-nav-button:hover{background:#ffffff4d;transform:scale(1.05)}.palumba-nav-button svg{color:#fff;height:24px;width:24px}.palumba-title{color:#fff;font-size:20px;font-weight:700;margin:0}.palumba-instruction{margin-bottom:0;margin-top:20px;padding:20px 16px 16px;text-align:center}.instruction-text{color:#1e293b;font-size:20px;font-weight:700;letter-spacing:-.02em;margin:0}.swipe-instruction{color:#64748b;display:inline-block;font-size:14px;font-weight:500;letter-spacing:.02em;margin:8px 0 0;opacity:.9;position:relative;text-align:center}.swipe-instruction:after{animation:swipeLineHint 3s ease-in-out infinite;background:linear-gradient(90deg,#0000,#3b82f6,#0000);bottom:-4px;content:"";height:2px;left:50%;opacity:.6;position:absolute;top:25px;transform:translateX(-50%);width:100px}@keyframes swipeLineHint{0%,to{opacity:.6;width:40px}50%{opacity:1;width:60px}}.candidates-section{animation:fadeInUp .5s ease-out;margin-bottom:35px;padding:0 16px}.candidates-container{align-items:center;display:flex;gap:20px;justify-content:center;margin:0 auto;max-width:420px}.candidate-card{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #3b82f61a;border-radius:16px;box-shadow:0 2px 8px #0000000f;flex-direction:column;justify-content:center;min-height:160px;min-width:140px;padding:16px;transition:all .3s ease}.candidate-card:hover{background:#fff;border-color:#3b82f633;box-shadow:0 8px 20px #0000001a;transform:translateY(-2px)}.candidate-card.active{background:#3b82f614;border-color:#3b82f6;box-shadow:0 8px 24px #3b82f633;transform:scale(1.02)}.candidate-card.clicked{animation:cardClick .3s ease}.candidate-card.pulse{animation:candidatePulse .6s ease}@keyframes cardClick{0%{transform:scale(1)}50%{transform:scale(.95)}to{transform:scale(1)}}@keyframes candidatePulse{0%{box-shadow:0 0 0 0 #3b82f680;transform:scale(1)}50%{box-shadow:0 0 0 10px #3b82f600;transform:scale(1.05)}to{box-shadow:0 0 0 0 #3b82f600;transform:scale(1)}}.swipe-indicator{align-items:center;background:#3b82f626;border:1px solid #3b82f633;border-radius:50%;display:flex;height:28px;justify-content:center;opacity:.7;position:absolute;transition:all .3s ease;width:28px}.swipe-indicator.left{left:-12px;top:50%;transform:translateY(-50%)}.swipe-indicator.right{right:-12px;top:50%;transform:translateY(-50%)}.candidate-card:hover .swipe-indicator{background:#3b82f640;border-color:#3b82f6;opacity:1}.candidate-card.active .swipe-indicator{animation:arrowPulse 1s ease infinite;background:#3b82f6;border-color:#3b82f6;opacity:1;transform:scale(1.1)}.swipe-indicator svg{stroke-width:2.5;color:#3b82f6;height:18px;width:18px}.candidate-card.active .swipe-indicator svg{color:#fff}@keyframes arrowPulse{0%,to{transform:translateY(-50%) scale(1.1)}50%{transform:translateY(-50%) scale(1.3)}}.candidates-section .candidate-avatar{align-items:center;background:#fff;border-radius:50%;box-shadow:0 4px 12px #0000001a;display:flex;height:100px;justify-content:center;margin:0 auto 10px;overflow:hidden;position:relative;transition:all .3s ease;width:100px}.candidate-card:hover .candidate-avatar{box-shadow:0 6px 16px #00000026;transform:scale(1.05)}.avatar-image{height:130%;left:50%;object-fit:cover;object-position:center;position:absolute;top:50%;transform:translate(-50%,-50%);width:130%}.avatar-placeholder{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:36px;text-transform:uppercase}.candidate-card .candidate-name{color:#1e293b;font-size:15px;font-weight:600;letter-spacing:-.01em;line-height:1.2;margin:0;text-align:center}.candidate-card:hover .candidate-name{color:#3b82f6}.candidate-card.active .candidate-name{color:#3b82f6;font-weight:700}.vs-divider{align-items:center;align-self:center;display:flex;justify-content:center;margin:0 -8px;position:relative}.vs-divider:before{background:linear-gradient(90deg,#0000,#e2e8f0 30%,#e2e8f0 70%,#0000);content:"";height:1px;left:-20px;position:absolute;right:-20px;top:50%;transform:translateY(-50%)}.vs-divider span{background:linear-gradient(180deg,#f0f9ff,#e0f2fe 50%,#bae6fd);color:#94a3b8;font-size:16px;font-weight:500;opacity:.7;padding:2px 8px;position:relative;z-index:1}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.candidate-card:first-child{animation:slideInLeft .5s ease-out .3s backwards}.candidate-card:last-child{animation:slideInRight .5s ease-out .3s backwards}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}.palumba-policy-section{flex:1 1;flex-direction:column;justify-content:flex-start;margin-top:10px;overflow:visible;padding:16px}.palumba-policy-box,.palumba-policy-section{align-items:center;display:flex;position:relative}.palumba-policy-box{background:#fff;border:1px solid #3b82f61a;border-radius:20px;box-shadow:0 10px 30px #00000014;justify-content:center;margin:0;max-width:420px;min-height:220px;padding:48px 36px;width:calc(100% - 32px)}.palumba-policy-box:before{background:#00000005;border-radius:20px;content:"";inset:4px;position:absolute;z-index:-1}.palumba-policy-box:after{background:#00000003;border-radius:16px;content:"";inset:8px;position:absolute;z-index:-2}.palumba-policy-statement{color:#1e293b;font-size:18px;font-weight:500;line-height:1.5;margin:0;text-align:center}.swipe-arrows{display:flex;justify-content:space-between;left:0;padding:0 10px;pointer-events:none;position:absolute;right:0;top:35%;transform:translateY(-50%);transition:opacity .3s ease;z-index:5}.palumba-policy-box:first-child .swipe-arrows{animation:fadeInOut 3s ease-in-out 1s}@keyframes fadeInOut{0%,to{opacity:.4}50%{opacity:.8}}.swipe-arrows.hidden{opacity:0}.swipe-arrow{align-items:center;display:flex;justify-content:center;opacity:.4;position:absolute;top:50%;transform:translateY(-50%)}.swipe-arrow.left{animation:slideHintLeft 2s ease-in-out infinite;left:5px}.swipe-arrow.right{animation:slideHintRight 2s ease-in-out infinite;animation-delay:1s;right:5px}.swipe-arrow svg{color:#64748b;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));height:32px;width:32px}.swipe-arrow.left{animation-name:slideHintLeft}.swipe-arrow.right{animation-name:slideHintRight}@keyframes slideHintLeft{0%,to{opacity:.5;transform:translateY(-50%) translateX(0)}50%{opacity:.8;transform:translateY(-50%) translateX(-10px)}}@keyframes slideHintRight{0%,to{opacity:.5;transform:translateY(-50%) translateX(0)}50%{opacity:.8;transform:translateY(-50%) translateX(10px)}}.candidate-info,.candidate-party,.swipe-background-sections,.swipe-direction,.swipe-hint,.swipe-indicator{display:none!important}.palumba-policy-box.swipeable-card{cursor:grab;touch-action:none;transform-origin:center bottom;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),opacity .3s ease,box-shadow .3s ease;-webkit-user-select:none;user-select:none;will-change:transform}.palumba-policy-box.card-hidden{opacity:0;visibility:hidden}.palumba-policy-box.card-fade-in{animation:cardFadeIn .6s ease-out}.palumba-policy-box.swipeable-card.dragging{cursor:grabbing;transform-origin:center bottom;transition:none}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.palumba-policy-box.swiping-left{animation:swipeOutLeft .5s cubic-bezier(.175,.885,.32,1) forwards}.palumba-policy-box.swiping-right{animation:swipeOutRight .5s cubic-bezier(.175,.885,.32,1) forwards}@keyframes swipeHintLeft{0%{transform:translateX(0) rotate(0)}50%{transform:translateX(-20px) rotate(-2deg)}to{transform:translateX(0) rotate(0)}}@keyframes swipeHintRight{0%{transform:translateX(0) rotate(0)}50%{transform:translateX(20px) rotate(2deg)}to{transform:translateX(0) rotate(0)}}.palumba-policy-box.hint-left{animation:swipeHintLeft .5s ease}.palumba-policy-box.hint-right{animation:swipeHintRight .5s ease}.tutorial-overlay{align-items:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#000c;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.tutorial-content{animation:tutorialSlideUp .4s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 40px #00000026;margin:20px;max-width:90%;padding:24px;text-align:center}@keyframes tutorialSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tutorial-hand{height:60px;margin:0 auto 16px;width:60px}.tutorial-title{color:#1e293b;font-size:20px;font-weight:700;margin:0 0 12px}.tutorial-text{color:#64748b;font-size:14px;line-height:1.5;margin:0 0 20px}.tutorial-button{background:#3b82f6;border:none;border-radius:8px;box-shadow:0 4px 12px #3b82f64d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .2s ease}.tutorial-button:hover{background:#2563eb;box-shadow:0 6px 16px #3b82f666;transform:translateY(-1px)}.tutorial-button:active{box-shadow:0 2px 8px #3b82f64d;transform:translateY(0)}.quiz-progress-bar{margin:12px 0;padding:0 16px;position:relative}.progress-bar-container{background:#ffffff4d;border-radius:2px;height:4px;overflow:hidden;position:relative}.progress-bar-fill{background:#fff;height:100%;position:relative;transition:width .3s ease}.progress-bar-container:after{background:#fff;border-radius:50%;box-shadow:0 0 0 2px #ffffff4d;content:"";height:8px;position:absolute;right:0;top:50%;transform:translate(50%,-50%);width:8px}@media (max-width:480px){.see-results-button{font-size:16px;min-width:180px;padding:14px 28px}.palumba-header{padding:16px}.palumba-nav-button{height:40px;width:40px}.palumba-title{font-size:20px}.candidates-container{gap:12px;max-width:100%;padding:0 8px}.candidate-card{max-width:150px;min-width:0;min-width:auto;padding:10px 12px;width:100%}.candidates-section .candidate-avatar{height:85px;margin:0 auto 8px;width:85px}.avatar-placeholder{font-size:32px}.candidate-card .candidate-name{font-size:14px}.vs-divider span{font-size:16px;padding:3px 8px}.swipe-indicator{height:24px;width:24px}.swipe-indicator.left{left:-10px}.swipe-indicator.right{right:-10px}.swipe-indicator svg{height:16px;width:16px}.candidates-section{margin-bottom:25px;padding:0 12px}.palumba-policy-box{min-height:200px;padding:36px 28px}.palumba-policy-section{margin-top:5px}.swipe-arrow svg{height:28px;width:28px}}@media (min-width:768px){.palumba-title{font-size:24px}.palumba-policy-box{border-radius:24px;min-height:220px;padding:48px 40px}.palumba-policy-statement{font-size:22px;line-height:1.6}.candidates-container{gap:28px;max-width:480px}.candidate-card{min-width:160px;padding:16px 20px}.candidate-avatar{height:110px;margin:0 auto 12px;width:110px}.avatar-placeholder{font-size:40px}.candidate-card .candidate-name{font-size:16px}.vs-divider span{font-size:16px;padding:4px 10px}.candidates-section{margin-bottom:40px}.palumba-policy-section{margin-top:20px}.swipe-arrow svg{height:34px;width:34px}}@keyframes swipeOutLeft{0%{opacity:1;transform:translateX(0) translateY(0) rotate(0) scale(1)}10%{transform:translateX(-10px) translateY(-10px) rotate(-2deg) scale(1.02)}to{opacity:0;transform:translateX(-150%) translateY(-50px) rotate(-30deg) scale(.8)}}@keyframes swipeOutRight{0%{opacity:1;transform:translateX(0) translateY(0) rotate(0) scale(1)}10%{transform:translateX(10px) translateY(-10px) rotate(2deg) scale(1.02)}to{opacity:0;transform:translateX(150%) translateY(-50px) rotate(30deg) scale(.8)}}@keyframes swipeIn{0%{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.swipe-hint-overlay{animation:fadeIn .3s ease-out;bottom:0;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:10}.swipe-hint-card-wrapper{align-items:center;display:flex;justify-content:center;left:50%;max-width:420px;position:absolute;top:10px;transform:translateX(-50%);width:calc(100% - 32px)}.swipe-hint-overlay .palumba-policy-box.swipe-hint-card{animation:swipeHintCardAnimation 2.5s ease-in-out;animation-delay:.25s;animation-fill-mode:both;cursor:default!important;opacity:.9;overflow:visible!important;pointer-events:none!important;position:relative;-webkit-user-select:none!important;user-select:none!important}.swipe-hint-hand{bottom:-25px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.15));left:50%;transform:translateX(-50%);z-index:10}.swipe-hint-direction,.swipe-hint-hand{pointer-events:none!important;position:absolute}.swipe-hint-direction{animation:swipeDirectionPulse 1.5s ease-in-out infinite;animation-delay:1s;right:-80px;top:50%;transform:translateY(-50%)}.swipe-hint-overlay *{pointer-events:none!important}@keyframes swipeHintCardAnimation{0%{opacity:0;transform:translateX(0) rotate(0) scale(1)}5%{opacity:1;transform:translateX(0) rotate(0) scale(1)}25%{opacity:1;transform:translateX(100px) rotate(10deg) scale(1.03)}35%{opacity:1;transform:translateX(0) rotate(0) scale(1)}45%{opacity:1;transform:translateX(0) rotate(0) scale(1)}65%{opacity:1;transform:translateX(-100px) rotate(-10deg) scale(1.03)}75%{opacity:1;transform:translateX(0) rotate(0) scale(1)}90%{opacity:1;transform:translateX(0) rotate(0) scale(1)}to{opacity:0;transform:translateX(0) rotate(0) scale(1)}}@keyframes swipeHintHandAnimation{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}5%{opacity:1;transform:translate(-50%,-50%) scale(1)}25%{opacity:1;transform:translate(-50%,-50%) translateX(100px) scale(1)}35%{opacity:1;transform:translate(-50%,-50%) translateX(0) scale(1)}45%{opacity:1;transform:translate(-50%,-50%) scale(1)}65%{opacity:1;transform:translate(-50%,-50%) translateX(-100px) scale(1)}75%{opacity:1;transform:translate(-50%,-50%) translateX(0) scale(1)}90%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(0)}}@keyframes swipeDirectionPulse{0%,to{opacity:.3;transform:translateY(-50%) translateX(0)}50%{opacity:.7;transform:translateY(-50%) translateX(10px)}}.swipe-hint-overlay{animation:fadeOutDelayed 3.25s ease-out forwards}@keyframes fadeOutDelayed{0%,85%{opacity:1}to{opacity:0}}.see-results-container{bottom:20px;display:flex;justify-content:center;left:0;padding:0 16px;position:fixed;right:0;z-index:100}.see-results-button{background:#3b82f6;border:none;border-radius:12px;box-shadow:0 4px 12px #3b82f64d;color:#fff;cursor:pointer;font-size:18px;font-weight:600;min-width:200px;padding:16px 32px;transition:all .2s ease}.see-results-button:hover{background:#2563eb;box-shadow:0 6px 20px #3b82f666;transform:translateY(-2px)}.see-results-button:active{box-shadow:0 2px 8px #3b82f64d;transform:translateY(0)}@media (max-width:480px){.swipe-hint-container{padding:0 12px}.swipe-hint-direction{right:-60px}.swipe-hint-direction svg{height:40px;width:40px}@keyframes swipeHintCardAnimation{0%{opacity:0;transform:translateX(0) rotate(0) scale(1)}5%{opacity:1;transform:translateX(0) rotate(0) scale(1)}25%{opacity:1;transform:translateX(80px) rotate(8deg) scale(1.02)}35%{opacity:1;transform:translateX(0) rotate(0) scale(1)}45%{opacity:1;transform:translateX(0) rotate(0) scale(1)}65%{opacity:1;transform:translateX(-80px) rotate(-8deg) scale(1.02)}75%{opacity:1;transform:translateX(0) rotate(0) scale(1)}90%{opacity:1;transform:translateX(0) rotate(0) scale(1)}to{opacity:0;transform:translateX(0) rotate(0) scale(1)}}@keyframes swipeHintHandAnimation{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}5%{opacity:1;transform:translate(-50%,-50%) scale(1)}25%{opacity:1;transform:translate(-50%,-50%) translateX(80px) scale(1)}35%{opacity:1;transform:translate(-50%,-50%) translateX(0) scale(1)}45%{opacity:1;transform:translate(-50%,-50%) scale(1)}65%{opacity:1;transform:translate(-50%,-50%) translateX(-80px) scale(1)}75%{opacity:1;transform:translate(-50%,-50%) translateX(0) scale(1)}90%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(0)}}}.feedback-modal-backdrop{align-items:flex-end;animation:fadeIn .2s ease-out;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding-bottom:env(safe-area-inset-bottom);position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.feedback-modal{background:#fff;border-radius:24px 24px 0 0;box-shadow:0 -10px 40px #00000026;max-height:85vh;max-width:600px;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom);position:relative;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);width:100%}.feedback-modal.open{transform:translateY(0)}.feedback-modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px 24px 16px}.feedback-modal-header h3{color:#1e293b;font-size:20px;font-weight:600;margin:0}.feedback-modal-close{align-items:center;background:none;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s}.feedback-modal-close:hover:not(:disabled){background:#f1f5f9;color:#334155}.feedback-modal-close:disabled{cursor:not-allowed;opacity:.5}.feedback-modal-body{-webkit-overflow-scrolling:touch;overflow-y:auto;padding:24px}.feedback-modal-description{color:#64748b;font-size:14px;line-height:1.5;margin:0 0 20px}.feedback-form-group{margin-bottom:16px;position:relative}.feedback-textarea{-webkit-text-size-adjust:100%;-webkit-appearance:none;border:2px solid #e5e7eb;border-radius:12px;font-family:inherit;font-size:16px;line-height:1.5;padding:12px 16px;resize:none;transition:border-color .2s;width:100%}.feedback-textarea:focus{border-color:#3b82f6;outline:none}.feedback-textarea:disabled{background:#f9fafb;opacity:.7}.feedback-char-count{bottom:8px;color:#9ca3af;font-size:12px;pointer-events:none;position:absolute;right:12px}.feedback-error{background:#fee2e2;border-radius:8px;color:#dc2626;font-size:14px;margin-bottom:16px;padding:8px 12px}.feedback-modal-actions{display:flex;gap:12px;justify-content:flex-end}.feedback-btn-cancel,.feedback-btn-submit{border:none;border-radius:12px;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:all .2s}.feedback-btn-cancel{background:#f1f5f9;color:#475569}.feedback-btn-cancel:hover:not(:disabled){background:#e2e8f0}.feedback-btn-submit{background:#3b82f6;color:#fff}.feedback-btn-submit:hover:not(:disabled){background:#2563eb}.feedback-btn-cancel:disabled,.feedback-btn-submit:disabled{cursor:not-allowed;opacity:.5}@media (max-width:640px){.feedback-modal{border-radius:24px 24px 0 0;max-height:50vh}.feedback-modal-header{padding:20px 20px 16px}.feedback-modal-body{padding:20px 20px 40px}.feedback-textarea{-webkit-appearance:none;font-size:16px}}@supports (-webkit-touch-callout:none){.feedback-modal{bottom:0;max-height:50vh;position:fixed}.feedback-modal.open{transform:translateY(0)!important}.feedback-modal-backdrop{align-items:center}.feedback-modal.keyboard-visible{bottom:auto;max-height:40vh;position:fixed;top:10vh;transform:translateY(0)!important}@media (max-width:640px){.feedback-modal{margin-bottom:0;max-height:calc(100vh - 300px)}.feedback-modal.keyboard-visible{max-height:35vh;top:5vh}}}@media (min-width:641px){.feedback-modal-backdrop{align-items:center;padding:20px}.feedback-modal{border-radius:24px;margin-bottom:0;max-height:600px}}.policy-knowledge-test-page{background:#f8f9fa;min-height:100vh}.test-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:100vh}.loading-spinner{border:4px solid #e9ecef;border-top-color:#007bff}.test-progress{background:#fff;box-shadow:0 2px 4px #0000000d;padding:1rem 1.5rem}.progress-bar{background:#e9ecef;margin-bottom:.5rem}.progress-fill{background:#007bff}.progress-text{color:#6c757d;font-size:.875rem}.demographics-container{background:linear-gradient(180deg,#f0f9ff,#e0f2fe 50%,#bae6fd);bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;overflow-y:auto;padding:24px;position:fixed;right:0;top:0}.demographics-container h2{color:#1e293b;font-size:28px;font-weight:700;margin:0 0 8px;text-align:center}.demographics-container>p{color:#64748b;font-size:16px;margin:0 0 32px;text-align:center}.demographics-form{background:#fff;border-radius:24px;box-shadow:0 10px 40px #00000014;margin:0 auto;max-width:420px;padding:32px 24px;width:100%}.form-group{margin-bottom:24px}.form-group label{color:#64748b;font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.form-group select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:#f8fafc;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 20px center;background-repeat:no-repeat;background-size:20px;border:2px solid #e2e8f0;border-radius:16px;color:#1e293b;cursor:pointer;font-size:16px;font-weight:500;min-height:56px;padding:18px 56px 18px 20px;transition:all .2s;width:100%}.form-group select:focus,.form-group select:hover{background-color:#fff;border-color:#3b82f6}.form-group select:focus{box-shadow:0 0 0 4px #3b82f61a;outline:none}.form-group select option{background-color:#fff;color:#1e293b;font-size:16px;padding:12px}@-moz-document url-prefix(){.form-group select{background-color:#f8fafc!important}.form-group select:focus{background-color:#fff!important}}.submit-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:16px;box-shadow:0 4px 16px #3b82f64d;color:#fff;cursor:pointer;font-size:18px;font-weight:600;margin-top:32px;min-height:56px;padding:18px 32px;transition:all .2s;width:100%}.submit-btn:hover{box-shadow:0 8px 24px #3b82f666;transform:translateY(-2px)}.submit-btn:active{transform:translateY(0)}.results-container{background:linear-gradient(180deg,#f0f9ff,#e0f2fe 50%,#bae6fd);bottom:0;display:flex;flex-direction:column;gap:24px;justify-content:center;left:0;overflow-y:auto;padding:24px;position:fixed;right:0;text-align:center;top:0}.results-container h2{color:#1e293b;font-size:32px;font-weight:700;margin:0}.results-summary{gap:16px;margin:0 auto;max-width:420px;width:100%}.result-stat,.results-summary{display:flex;flex-direction:column}.result-stat{align-items:center;background:#fff;border-radius:20px;box-shadow:0 4px 16px #00000014;gap:8px;padding:24px}.stat-label{color:#64748b;font-size:14px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.stat-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#2563eb);-webkit-background-clip:text;background-clip:text;line-height:1}.results-message{background:#fff;border-radius:20px;box-shadow:0 4px 16px #00000014;margin:0 auto;max-width:420px;padding:24px;width:100%}.results-message p{color:#1e293b;font-size:16px;font-weight:600;line-height:1.6;margin:0}.results-actions{display:flex;flex-direction:column;gap:12px;margin:0 auto;max-width:420px;padding-bottom:24px;width:100%}.feedback-btn,.home-btn,.retry-btn,.review-answers-btn{border:none;border-radius:16px;cursor:pointer;font-size:18px;font-weight:600;min-height:56px;padding:18px 32px;transition:all .2s;width:100%}.home-btn{background:#fff;box-shadow:0 2px 8px #00000014;color:#64748b}.review-answers-btn{background:#0000;border:2px solid #3b82f6;box-shadow:none;color:#3b82f6}.home-btn:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.review-answers-btn:hover{background:#3b82f6;box-shadow:0 4px 12px #3b82f64d;color:#fff;transform:translateY(-2px)}.retry-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 4px 16px #3b82f64d;color:#fff}.retry-btn:hover{box-shadow:0 8px 24px #3b82f666;transform:translateY(-2px)}.feedback-btn{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 16px #10b9814d;color:#fff}.feedback-btn:hover{box-shadow:0 8px 24px #10b98166;transform:translateY(-2px)}.feedback-btn:active,.home-btn:active,.retry-btn:active,.review-answers-btn:active{transform:translateY(0)}@media (min-width:768px){.demographics-container,.results-container,.results-summary{justify-content:center}.results-summary{flex-direction:row;gap:24px}.result-stat{min-width:160px}.results-actions{flex-direction:row;justify-content:center}.home-btn,.retry-btn,.review-answers-btn{min-width:180px;width:auto}}.detailed-results-content{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;padding-bottom:24px}.palumba-header{position:sticky;top:0;z-index:10}.results-summary-bar{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #3b82f61a;border-radius:16px;box-shadow:0 2px 8px #0000000f;margin:16px;padding:16px 20px;text-align:center}.results-summary-bar p{color:#1e293b;font-size:18px;font-weight:600;line-height:1.3;margin:0}.results-summary-bar .score-highlight{color:#3b82f6;font-size:19px;font-weight:700}.results-summary-bar .percentage{color:#64748b;font-size:16px;font-weight:500}.policy-results-sections{padding:0 16px 60px}.results-section{margin-bottom:32px}.section-title{color:#1e293b;font-size:20px;font-weight:700;margin:0 0 16px;padding:12px 0}.section-header{margin-bottom:16px}.toggle-button{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 20px;transition:all .2s}.toggle-button:hover{background:#2563eb;transform:translateY(-1px)}.policy-cards-list{display:flex;flex-direction:column;gap:14px;margin-top:14px}.policy-result-card{background:#fff;border:2px solid #0000;border-radius:16px;box-shadow:0 2px 8px #0000000f;margin-bottom:12px;padding:20px;transition:all .2s}.policy-result-card.incorrect{background:#fee2e280;border-color:#ae404096}.policy-result-card.correct{background:#dcfce780;border-color:#10b981}.policy-text-section{margin-bottom:20px}.policy-text{color:#1e293b;font-size:16px;font-weight:500;line-height:1.6;margin:0}.policy-answer-section{border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:12px;padding-top:20px}.answer-row{align-items:center;display:flex;justify-content:space-between}.answer-label{font-size:14px}.policy-result-card .candidate-info{align-items:center;display:flex;gap:8px}.candidate-avatar-small{align-items:center;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;display:flex;flex-shrink:0;height:32px;justify-content:center;overflow:hidden;width:32px}.avatar-image-small{height:100%;object-fit:cover;width:100%}.avatar-placeholder-small{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;display:flex;font-size:14px;font-weight:700;height:100%;justify-content:center;width:100%}.policy-result-card .candidate-name{color:#1e293b;font-size:16px;font-weight:600}.policy-answers{display:flex;flex-direction:column;gap:12px;margin-top:16px;padding-top:16px}.answer-item{align-items:center;display:flex;gap:8px}.answer-label{color:#6b7280;flex-shrink:0;font-size:13px;font-weight:500;letter-spacing:.03em;min-width:130px;text-transform:uppercase}.answer-content{align-items:center;display:flex;flex:1 1;gap:8px;justify-content:space-between}.answer-content .candidate-name{color:#1f2937;flex:1 1;font-size:16px;font-weight:600}.answer-status{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:28px;justify-content:center;width:28px}.answer-status.correct{background-color:#d1fae5;color:#10b981}.answer-status.incorrect{background-color:#fee2e2;color:#ef4444}@media (max-width:480px){.answer-item{align-items:flex-start;flex-direction:column;gap:4px}.answer-label{font-size:12px;min-width:auto}.answer-content{width:100%}}.answer-indicator{align-items:center;border-radius:50%;display:flex;font-size:16px;font-weight:700;height:28px;justify-content:center;width:28px}.answer-indicator.correct{background:#10b981c9;color:#fff}.answer-indicator.incorrect{background:#f59e0b;color:#fff}@media (min-width:768px){.detailed-results-container{padding-bottom:40px}.results-summary-bar{margin:24px auto;max-width:720px}.policy-results-sections{margin:0 auto;max-width:720px;padding:0 24px}.policy-result-card{padding:24px 32px}.policy-text{font-size:18px}}.admin-section{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin:1rem;padding:2rem}.section-header{border-bottom:2px solid #f3f4f6;margin-bottom:2rem;padding-bottom:1rem}.section-title{color:#1f2937;font-size:1.75rem;font-weight:600;margin:0}.admin-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:1.5rem}.admin-item-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;position:relative;transition:all .3s ease}.admin-item-card:hover{box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-2px)}.admin-item-card.active{background:#eff6ff;border-color:#3b82f6}.item-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.item-title{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.item-actions{display:flex;gap:.5rem}.admin-button{background:#f3f4f6;color:#374151}.admin-button:hover{background:#e5e7eb}.admin-button.secondary{background:#6b7280;color:#fff}.admin-button.secondary:hover{background:#4b5563}.admin-button-secondary{background:#6b7280;color:#fff}.admin-button-secondary:hover{background:#4b5563}.admin-button-sm{font-size:.75rem;padding:.375rem .75rem}.action-button{background:#e5e7eb;border:none}.action-button:hover{background:#d1d5db}.action-button.delete{color:#dc2626}.action-button.delete:hover{background:#fee2e2;color:#b91c1c}.action-button.active{color:#10b981}.item-details{gap:.75rem}.detail-label{color:#6b7280}.detail-value.link{color:#3b82f6;text-decoration:none}.detail-value.link:hover{text-decoration:underline}.filters-row{display:flex;gap:1rem}.filter-dropdown{border-radius:.5rem;padding:.5rem 1rem}.admin-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.admin-modal{background:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a;max-height:90vh;max-width:600px;overflow-y:auto;padding:2rem;position:relative;width:90%}.modal-title{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0 0 1.5rem}.admin-modal-close{align-items:center;display:flex;height:2rem;justify-content:center;position:absolute;right:1rem;top:1rem;width:2rem}.modal-actions{gap:1rem;margin-top:2rem}.admin-form{display:flex;flex-direction:column;gap:1.25rem}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.form-input,.form-select,.form-textarea{border:1px solid #d1d5db;border-radius:.375rem;color:#374151;font-size:.875rem;padding:.5rem .75rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.status-badge.active{background:#10b981}.status-badge.inactive{background:#ef4444}.admin-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:4rem}.spinner{height:3rem;width:3rem}.admin-error{background:#fee2e2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;margin:1rem;padding:1rem}.candidates-selection{grid-gap:.75rem;background:#f9fafb;border-radius:.5rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));max-height:300px;padding:1rem}.checkbox-label{border-radius:.375rem;padding:.5rem;transition:background .2s ease}.checkbox-label:hover{background:#e5e7eb}.checkbox-label span{color:#374151;font-size:.875rem}.user-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:1.5rem}.user-card{align-items:flex-start;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.75rem;display:flex;justify-content:space-between;padding:1.5rem}.user-info{flex:1 1}.user-header{gap:1rem;margin-bottom:1rem}.user-avatar,.user-header{align-items:center;display:flex}.user-avatar{background:#e5e7eb;border-radius:50%;color:#6b7280;height:3rem;justify-content:center;width:3rem}.user-basic{flex:1 1}.user-name{color:#1f2937;font-weight:600;margin:0}.user-email{color:#6b7280;font-size:.875rem;margin:0}.user-details{display:flex;flex-direction:column;font-size:.875rem;gap:.5rem}.user-actions{align-items:center;display:flex;gap:.5rem}.role-badge{background:#3b82f6;border-radius:9999px;color:#fff;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.policy-extraction-container{padding:2rem}.extraction-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.page-title{color:#1f2937;font-weight:600}.back-button{background:#f3f4f6;border-radius:.5rem;color:#374151;font-weight:500;padding:.5rem 1rem}.back-button:hover{background:#e5e7eb}.candidate-section,.existing-policies-section,.extraction-section,.review-section{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.candidate-select{border:1px solid #d1d5db;border-radius:.375rem;margin-top:1rem;padding:.5rem;width:100%}.candidate-info{background:#f9fafb;border-radius:.5rem;margin-top:1rem;padding:1rem}.source-type-selection{display:flex;gap:2rem;margin:1rem 0}.radio-label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.extraction-section .form-input,.extraction-section .form-textarea{margin-top:.5rem;width:100%}.extract-button,.save-button{align-items:center;background:#3b82f6;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:inline-flex;font-weight:500;gap:.5rem;margin-top:1rem;padding:.75rem 1.5rem}.extract-button:hover,.save-button:hover{background:#2563eb}.extract-button:disabled{background:#9ca3af;cursor:not-allowed}.policies-list{gap:1rem;margin-top:1rem}.policy-item{align-items:flex-start;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;display:flex;justify-content:space-between;padding:1rem}.policy-item.editing{background:#eff6ff;border-color:#3b82f6}.policy-content{flex:1 1}.policy-title{color:#1f2937;font-weight:600;margin:0 0 .5rem}.policy-description{color:#6b7280;font-size:.875rem;margin:0}.policy-actions{gap:.5rem}.icon-button{background:#e5e7eb;border:none}.icon-button:hover{background:#d1d5db;color:#374151}.icon-button.delete{color:#dc2626}.icon-button.delete:hover{background:#fee2e2;color:#b91c1c}.section-description{color:#6b7280;font-size:.875rem;margin-top:.5rem}.checkbox-label{cursor:pointer;font-size:.875rem}.candidates-selection{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.error{color:#dc2626}.error,.success{font-size:.875rem;margin-top:.25rem}.success{color:#10b981}.button-icon,.detail-icon{height:1.25rem;width:1.25rem}.button-text{font-weight:500}.spinner-text{margin-left:.5rem}.role-modal{max-width:400px}.user-info-summary{background:#f9fafb;border-radius:.5rem;margin-bottom:1rem;padding:1rem}.user-info-summary p{margin:.25rem 0}.candidates-selection{border:1px solid #e5e7eb;border-radius:.375rem;max-height:200px;overflow-y:auto;padding:.5rem}@media (max-width:768px){.admin-grid,.form-row,.user-grid{grid-template-columns:1fr}.section-header{align-items:stretch;flex-direction:column;gap:1rem}.admin-modal{padding:1rem}}.election-modal{animation:modal-fade-in .3s ease-out;background-color:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:900px;overflow:hidden;width:90%}.election-modal-header{align-items:center;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem}.election-modal-header h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.admin-modal-close{background:none;border:none;border-radius:.375rem;color:#6b7280;cursor:pointer;font-size:1.5rem;padding:.5rem;transition:all .2s ease}.admin-modal-close:hover{background:#f3f4f6;color:#374151}.election-modal-body{max-height:calc(100vh - 200px);overflow-y:auto;padding:1.5rem}.election-modal-footer{background-color:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;padding:1.25rem 1.5rem}.form-tabs{border-bottom:1px solid #e5e7eb;display:flex;margin-bottom:1.5rem}.form-tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;font-size:.9375rem;font-weight:500;padding:.75rem 1.25rem;transition:all .2s}.form-tab:hover{color:#4b5563}.form-tab.active{border-bottom-color:#3b82f6;color:#3b82f6}.election-form{gap:1.5rem}.election-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-label{color:#374151;font-size:.875rem;font-weight:500}.form-label .required{color:#ef4444}.form-input{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;color:#1f2937;font-size:.875rem;padding:.75rem;transition:all .2s}.form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.checkbox-label{align-items:center;display:flex;gap:.5rem;margin-top:.5rem}.checkbox-label input[type=checkbox]{cursor:pointer;height:20px;width:20px}.candidates-tab{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;min-height:400px}.candidates-section{display:flex;flex-direction:column}.section-header{border-bottom:2px solid #e5e7eb;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem}.section-header h4{align-items:center;color:#1f2937;display:flex;font-size:1.125rem;font-weight:600;gap:.5rem;margin:0}.section-header h4 svg{color:#3b82f6}.section-header-actions{margin-left:auto}.candidates-list{flex:1 1;max-height:400px;overflow-y:auto}.candidate-card{background:#f9fafb;border-radius:.75rem;margin-bottom:.75rem;padding:1rem;transition:all .2s ease}.candidate-card:hover{background:#f3f4f6;border-color:#d1d5db;transform:translateY(-1px)}.candidate-avatar{background:#e5e7eb;height:48px;margin-right:1rem;width:48px}.candidate-avatar svg{color:#9ca3af;height:24px;width:24px}.candidate-info{min-width:0}.candidate-name{font-weight:600;margin-bottom:.25rem}.candidate-website{align-items:center;color:#3b82f6;display:flex;font-size:.75rem;gap:.25rem;text-decoration:none}.candidate-website:hover{text-decoration:underline}.candidate-actions{display:flex;gap:.5rem;margin-left:1rem}.icon-button{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:.375rem;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .2s ease}.icon-button:hover{background:#f9fafb;border-color:#d1d5db}.icon-button.remove{color:#ef4444}.icon-button.remove:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.icon-button.add{color:#10b981}.icon-button.add:hover{background:#ecfdf5;border-color:#a7f3d0;color:#059669}.new-candidate-button{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;color:#374151;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.new-candidate-button:hover{background:#f9fafb;border-color:#9ca3af}.new-candidate-form{background:#f0f9ff;border:1px solid #bae6fd;border-radius:.75rem;margin-bottom:1rem;padding:1rem}.new-candidate-fields{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.new-candidate-fields input{border:1px solid #d1d5db;border-radius:.375rem;color:#374151;font-size:.875rem;padding:.5rem .75rem}.new-candidate-fields input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.button-group{display:flex;gap:.5rem}.empty-candidates{color:#9ca3af;padding:3rem 1rem;text-align:center}.empty-candidates p{font-size:.875rem;margin:.5rem 0}.admin-button{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.admin-button.primary{background:#3b82f6;color:#fff}.admin-button.primary:hover{background:#2563eb}.admin-button.secondary{background:#e5e7eb;color:#374151}.admin-button.secondary:hover{background:#d1d5db}.election-modal-footer .admin-button{padding:.75rem 1.5rem}@media (max-width:768px){.candidates-tab,.form-row{grid-template-columns:1fr}}.section-title{text-decoration:none!important}.admin-item-card{display:flex;flex-direction:column;min-height:150px}.item-details{display:flex;flex:1 1;flex-direction:column;gap:.5rem;margin-top:.5rem}.detail-item{align-items:center;color:#4b5563;display:flex;font-size:.875rem;gap:.5rem}.detail-item svg{color:#6b7280;height:16px;width:16px}.detail-label{font-weight:500;margin-right:.25rem}.detail-value{color:#374151}.status-badge{border-radius:9999px;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.status-badge.active{background:#3b82f6;color:#fff}.status-badge.inactive{background:#94a3b8;color:#fff}.action-button{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:.375rem;color:#6b7280;cursor:pointer;display:inline-flex;height:36px;justify-content:center;padding:.5rem;transition:all .2s ease;width:36px}.action-button:hover{background:#f9fafb;border-color:#d1d5db;box-shadow:0 2px 4px #0000000d;color:#374151;transform:translateY(-1px)}.action-button:active{box-shadow:none;transform:translateY(0)}.action-button.active{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.action-button.inactive{background:#fef2f2;border-color:#ef4444;color:#ef4444}.action-button.delete:hover{background:#fef2f2;border-color:#ef4444;color:#dc2626}.action-button svg{height:18px;width:18px}.admin-error,.admin-loading{color:#6b7280;padding:3rem;text-align:center}.spinner{border:3px solid #f3f4f6;border-top-color:#3b82f6;display:inline-block;height:40px;margin-bottom:1rem;width:40px}.filters-row{margin-bottom:1.5rem}.filter-dropdown{-webkit-appearance:none;appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;border:1px solid #d1d5db;border-radius:.375rem;color:#374151;cursor:pointer;font-size:.875rem;min-width:200px;padding:.5rem 2.5rem .5rem 1rem;transition:all .2s ease}.filter-dropdown:hover{border-color:#9ca3af}.filter-dropdown:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.button-text{margin-left:.25rem}.search-bar{margin-bottom:1rem}.search-bar .form-input{border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;padding:.5rem .75rem .5rem 2.5rem;transition:all .2s ease;width:100%}.search-bar .form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.search-bar .form-input::placeholder{color:#9ca3af}.form-help-text{color:#6b7280;font-size:.875rem;line-height:1.4;margin-top:.5rem}.quiz-type-badge{border-radius:.375rem;display:inline-block;font-size:.75rem;font-weight:500;letter-spacing:.025em;margin-left:.5rem;padding:.25rem .5rem;text-transform:uppercase}.quiz-type-badge.binary{background:#e0e7ff;color:#4338ca}.quiz-type-badge.scale{background:#d1fae5;color:#065f46}.quiz-type-badge.policy_pick{background:#fef3c7;color:#92400e}.quiz-modal{animation:modal-fade-in .3s ease-out;background-color:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:800px;overflow:hidden;width:90%}@keyframes modal-fade-in{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.quiz-modal-header{align-items:center;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem}.quiz-modal-header h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.quiz-modal-body{max-height:calc(100vh - 200px);overflow-y:auto;padding:1.5rem}.quiz-modal-footer{background-color:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;padding:1.25rem 1.5rem}.quiz-form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}@media (max-width:768px){.quiz-form-grid{grid-template-columns:1fr}}.quiz-form-group{margin-bottom:1.25rem}.quiz-form-group label{color:#4b5563;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.quiz-form-group input[type=date],.quiz-form-group input[type=text],.quiz-form-group select{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;color:#1f2937;font-size:.875rem;padding:.75rem;transition:all .2s;width:100%}.quiz-form-group input[type=date]:focus,.quiz-form-group input[type=text]:focus,.quiz-form-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633;outline:none}.candidates-section{grid-column:span 2;margin-bottom:1.5rem;margin-top:1rem}.candidates-header{align-items:center;display:flex;font-weight:500;justify-content:space-between;margin-bottom:1rem}.candidates-count{background-color:#f3f4f6;border-radius:1rem;color:#6b7280;font-size:.875rem;padding:.25rem .75rem}.candidates-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-top:.75rem}.candidate-card{border:1px solid #e5e7eb;border-radius:.5rem;overflow:hidden}.candidate-card:hover{border-color:#93c5fd;box-shadow:0 1px 3px #0000001a}.candidate-card.selected{background-color:#eff6ff;border-color:#3b82f6}.candidate-card-inner{align-items:center;display:flex;padding:.75rem}.candidate-checkbox{height:0;opacity:0;position:absolute;width:0}.candidate-checkbox+label{align-items:center;cursor:pointer;display:flex;margin:0;width:100%}.candidate-avatar{border:1px solid #e5e7eb;height:2.5rem;margin-right:.75rem;width:2.5rem}.candidate-avatar img{max-height:100%;max-width:100%}.candidate-info{overflow:hidden}.candidate-name{color:#1f2937;font-size:.875rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.candidate-check{align-items:center;background-color:#3b82f6;border-radius:50%;color:#fff;display:flex;flex-shrink:0;height:1.5rem;justify-content:center;margin-left:.5rem;opacity:0;transition:opacity .2s;width:1.5rem}.candidate-card.selected .candidate-check{opacity:1}.switch-container{align-items:center;display:flex;margin-top:.5rem}.switch{height:1.75rem;margin-right:.75rem;width:3.5rem}.slider{background-color:#e5e7eb;border-radius:1.75rem}.slider:before{bottom:.25rem;height:1.25rem;left:.25rem;width:1.25rem}input:checked+.slider{background-color:#10b981}input:focus+.slider{box-shadow:0 0 1px #10b981}input:checked+.slider:before{transform:translateX(1.75rem)}.switch-label{color:#4b5563;font-size:.875rem}.form-error{color:#ef4444;font-size:.75rem;margin-top:.5rem}.quiz-button{align-items:center;border-radius:.5rem;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1.25rem;transition:all .2s}.quiz-button:disabled{cursor:not-allowed;opacity:.5}.quiz-button-cancel{background-color:#f9fafb;border:1px solid #d1d5db;color:#4b5563}.quiz-button-cancel:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.quiz-button-primary{background-color:#3b82f6;border:1px solid #0000;color:#fff}.quiz-button-primary:hover:not(:disabled){background-color:#2563eb}.candidates-select-all{align-items:center;background:none;border:none;color:#3b82f6;cursor:pointer;display:flex;font-size:.8125rem;padding:.25rem .5rem}.candidates-select-all:hover{text-decoration:underline}.simplified-policy-extraction{margin:0 auto;max-width:1200px;padding:20px}.existing-policies-option{background-color:#f8f9fa;border-radius:8px;margin:20px 0;padding:20px;text-align:center}.edit-policies-btn{align-items:center;background-color:#28a745;border:none;border-radius:5px;color:#fff;cursor:pointer;display:inline-flex;font-size:16px;gap:8px;padding:12px 24px;transition:background-color .2s}.edit-policies-btn:hover{background-color:#218838}.edit-policies-btn .btn-icon{font-size:18px}.or-divider{color:#666;font-size:14px;font-style:italic;margin:15px 0 0}.extraction-header{margin-bottom:20px;text-align:center}.extraction-header h2{color:#333;font-size:28px;margin-bottom:8px}.extraction-header p{color:#666;font-size:16px;margin:0}.step-indicator{gap:20px;justify-content:center;margin-bottom:25px}.step,.step-indicator{align-items:center;display:flex}.step{gap:8px}.step-number{align-items:center;background-color:#ddd;border-radius:50%;color:#666;display:flex;font-size:14px;font-weight:700;height:30px;justify-content:center;width:30px}.step.active .step-number{background-color:#007bff;color:#fff}.step.completed .step-number{background-color:#28a745;color:#fff}.step-name{color:#666;font-size:14px;white-space:nowrap}.step.active .step-name{color:#007bff;font-weight:700}.step.completed .step-name{color:#28a745}.wizard-content{background:#fff;border:1px solid #ddd;border-radius:4px;margin-bottom:20px;padding:30px}.step-content h3{color:#333;font-size:24px;margin-bottom:8px}.step-content p{color:#666;font-size:16px}.step-content p,.step-header{margin-bottom:25px}.step-header h3{color:#333;font-size:24px;margin-bottom:8px}.step-header p{color:#666;font-size:16px;margin:0}.candidate-controls{margin-bottom:25px}.search-group{display:flex;gap:10px;margin-bottom:15px}.search-input{border:1px solid #ccc;border-radius:4px;flex:1 1;font-size:16px;padding:12px}.search-input:focus{border-color:#007bff}.btn-sm{font-size:14px;padding:8px 16px}.candidate-stats{color:#666;font-size:14px}.candidate-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:30px}.candidate-card{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;gap:15px;padding:20px;position:relative;transition:all .2s}.candidate-card:hover{border-color:#007bff;box-shadow:0 2px 8px #007bff26}.candidate-card.selected{background-color:#f8f9ff;border-color:#007bff}.candidate-avatar{align-items:center;background-color:#f3f4f6;border-radius:50%;display:flex;flex-shrink:0;height:64px;justify-content:center;overflow:hidden;width:64px}.candidate-avatar img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;background-color:#e5e7eb;color:#6b7280;display:flex;font-size:24px;font-weight:700;height:100%;justify-content:center;width:100%}.candidate-info{flex:1 1}.candidate-info h4{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 4px}.candidate-party{color:#6b7280;font-size:14px;margin:0}.selection-indicator{color:#10b981;font-size:20px;font-weight:700}.error-state,.loading-state{padding:40px;text-align:center}.spinner{border:3px solid #e5e7eb;height:24px;margin:0 auto 16px;width:24px}.error-state h3{color:#dc2626;margin-bottom:8px}.error-state p{color:#6b7280;margin-bottom:20px}.empty-state,.no-results-state{color:#6b7280;padding:40px;text-align:center}.empty-state h4,.no-results-state h4{color:#374151;margin-bottom:8px}.empty-actions{display:flex;gap:12px;justify-content:center;margin-top:20px}.wizard-navigation{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px}.nav-spacer{flex:1 1}.btn{border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background-color:#0056b3}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn-large{font-size:18px;padding:15px 30px}.source-type-selector{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:30px}.source-type-btn{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:24px 16px;text-align:center;transition:all .2s}.source-type-btn:hover{border-color:#007bff;box-shadow:0 2px 8px #007bff26}.source-type-btn.active{background-color:#f8f9ff;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.source-icon{font-size:32px;margin-bottom:4px}.source-type-btn>span:nth-child(2){color:#1f2937;font-size:18px;font-weight:600;margin-bottom:4px}.source-description{color:#6b7280;font-size:14px;line-height:1.4}.source-input-container{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:24px}.text-input-group,.url-input-group{margin-bottom:0}.text-input-group label,.url-input-group label{color:#374151;display:block;font-size:16px;font-weight:600;margin-bottom:8px}.text-input-group textarea,.url-input-group input{border:2px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-family:inherit;font-size:16px;padding:12px 16px;transition:border-color .2s;width:100%}.text-input-group textarea:focus,.url-input-group input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.text-input-group textarea.invalid,.url-input-group input.invalid{border-color:#dc2626}.text-input-group textarea{line-height:1.5;min-height:200px;resize:vertical}.text-guidelines,.url-examples{background:#fff;border-left:4px solid #3b82f6;border-radius:6px;margin-top:16px;padding:16px}.text-guidelines p,.url-examples p{color:#374151;font-size:14px;font-weight:600;margin:0 0 8px}.text-guidelines ul,.url-examples ul{color:#6b7280;font-size:14px;margin:0;padding-left:16px}.text-guidelines li,.url-examples li{margin-bottom:4px}.validation-message{border-radius:6px;font-size:14px;font-weight:500;margin-top:12px;padding:8px 12px}.validation-message.valid{background-color:#ecfdf5;border:1px solid #a7f3d0;color:#059669}.validation-message.invalid{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.extraction-progress{padding:40px 20px;text-align:center}.progress-container{margin:0 auto;max-width:500px}.progress-icon{margin-bottom:24px}.spinner.large{border-width:4px;height:48px;width:48px}.progress-container h3{color:#1f2937;font-size:24px;margin:0 0 8px}.progress-description{color:#6b7280;font-size:16px;line-height:1.5;margin:0 0 32px}.progress-bar{background-color:#e5e7eb;border-radius:4px;height:8px;margin:24px 0;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#007bff,#0056b3);border-radius:4px;height:100%;transition:width .3s ease}.current-action{color:#374151;font-size:16px;font-weight:500;margin:16px 0}.progress-stats{color:#6b7280;font-size:14px;margin-top:16px}.extraction-complete{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin:0 auto;max-width:500px;padding:32px}.success-icon{font-size:48px;margin-bottom:16px}.extraction-complete h3{color:#15803d;font-size:24px;margin:0 0 8px}.extraction-complete p{color:#166534;font-size:16px;margin:0 0 24px}.extraction-summary{background:#fff;border:1px solid #d1fae5;border-radius:6px;margin:20px 0;padding:20px}.summary-item{align-items:center;border-bottom:1px solid #f3f4f6;justify-content:space-between;padding:8px 0}.summary-item:last-child{border-bottom:none}.summary-label{color:#6b7280}.summary-value{color:#1f2937;font-weight:600}.next-step-hint{color:#059669;font-size:14px;font-style:italic;margin:20px 0 0}.extraction-actions{display:flex;justify-content:center;margin-top:24px}.extraction-error{margin:0 auto;max-width:500px;padding:40px;text-align:center}.error-icon{font-size:48px;margin-bottom:16px}.extraction-error h3{color:#dc2626;font-size:20px;margin:0 0 8px}.extraction-error p{color:#7f1d1d;font-size:16px;margin:0 0 24px}.error-actions{display:flex;gap:12px;justify-content:center}.policies-summary{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:24px;padding:20px}.summary-stats{display:flex;gap:24px}.stat{align-items:center;color:#64748b;display:flex;flex-direction:column;font-size:14px;gap:4px}.stat strong{color:#1e293b;font-size:24px;font-weight:600}.empty-policies{background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;color:#6b7280;padding:60px 20px;text-align:center}.empty-policies p{font-size:16px;margin:0 0 20px}.policies-table{border:1px solid #e5e7eb;border-radius:8px;margin-bottom:24px;overflow:hidden}.table-header{grid-gap:16px;background:#f8fafc;border-bottom:1px solid #e5e7eb;color:#374151;display:grid;font-size:14px;font-weight:600;gap:16px;grid-template-columns:2fr 1fr 1fr 1fr 1.5fr auto;padding:16px}.table-body{max-height:600px;overflow-y:auto}.policy-row{grid-gap:16px;align-items:start;border-bottom:1px solid #f3f4f6;display:grid;gap:16px;grid-template-columns:2fr 1fr 1fr 1fr 1.5fr auto;padding:20px 16px}.policy-row:last-child{border-bottom:none}.policy-row.invalid{background-color:#fef2f2;border-left:4px solid #dc2626}.col-text textarea{border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-family:inherit;font-size:14px;min-height:80px;padding:12px;resize:vertical;width:100%}.col-text textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.col-text textarea.empty{background-color:#fef2f2;border-color:#dc2626}.text-stats{align-items:center;display:flex;font-size:12px;gap:8px;margin-top:8px}.word-count{border-radius:4px;font-weight:500;padding:2px 6px}.word-count.good{background-color:#dcfce7;color:#166534}.word-count.too-short{background-color:#fef3c7;color:#92400e}.word-count.too-long{background-color:#fecaca;color:#991b1b}.warning{color:#dc2626;font-size:11px;font-weight:500}.col-category select{background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px;width:100%}.col-category select:focus{border-color:#3b82f6;outline:none}.col-importance input{border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-size:14px;padding:8px 12px;width:100%}.col-importance input:focus{border-color:#3b82f6;outline:none}.importance-label{color:#6b7280;font-size:11px;font-weight:500;margin-top:4px;text-align:center}.col-priority input{border:1px solid #d1d5db;border-radius:6px;box-sizing:border-box;font-size:14px;padding:8px 12px;width:100%}.col-priority input:focus{border-color:#3b82f6;outline:none}.priority-label{color:#6b7280;font-size:11px;font-weight:500;margin-top:4px;text-align:center}.col-actions{display:flex;justify-content:center}.btn-remove{background:none;border:none;border-radius:4px;cursor:pointer;font-size:18px;padding:8px;transition:background-color .2s}.btn-remove:hover{background-color:#fef2f2}.review-footer{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:24px;padding:24px}.validation-summary{margin-bottom:20px}.warning-message{background-color:#fef3c7;border:1px solid #fbbf24;border-radius:6px;color:#92400e}.success-message,.warning-message{align-items:center;display:flex;font-size:14px;gap:8px;padding:12px 16px}.success-message{background-color:#dcfce7;border:1px solid #bbf7d0;border-radius:6px;color:#166534}.confirmation-modal{align-items:center;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-backdrop{background-color:#00000080;bottom:0;left:0;position:absolute;right:0;top:0}.modal-content{border-radius:4px;box-shadow:0 4px 6px #0000001a;padding:30px;position:relative}.modal-content h3{color:#333;font-size:20px;margin:0 0 20px}.save-preview{background-color:#f8f9fa;border-left:4px solid #007bff;border-radius:4px;margin:20px 0;padding:15px}.save-preview h4{color:#333;font-size:16px;margin:0 0 10px}.policy-preview-list{list-style:none;margin:0;padding:0}.policy-preview-list li{border-bottom:1px solid #eee;color:#666;font-size:14px;padding:8px 0}.policy-preview-list li:last-child{border-bottom:none}.modal-actions{gap:15px;margin-top:25px}.save-actions{display:flex;justify-content:center;margin-top:25px}.col-quality{min-width:150px}.quality-scores{display:flex;flex-direction:column;font-size:12px;gap:4px}.score-item{align-items:center;display:flex;gap:4px;justify-content:space-between}.score-label{color:#6b7280;font-weight:500;white-space:nowrap}.score-value{border-radius:3px;font-size:11px}.score-excellent{background-color:#dcfce7;color:#166534}.score-good{background-color:#dbeafe;color:#1e40af}.score-fair{background-color:#fef3c7;color:#92400e}.score-poor{background-color:#fecaca;color:#991b1b}.validation-status{border-radius:3px;font-size:10px;font-weight:600;padding:2px 6px;text-transform:uppercase}.validation-status.pending{background-color:#fef3c7;color:#92400e}.validation-status.validated{background-color:#dcfce7;color:#166534}.validation-status.needs_review{background-color:#fecaca;color:#991b1b}.keywords{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px}.keyword-tag{background-color:#f3f4f6;color:#374151}.keyword-more,.keyword-tag{border-radius:2px;font-size:10px;padding:1px 4px}.keyword-more{background-color:#e5e7eb;color:#6b7280;font-style:italic}.spinner{animation:spin 1s linear infinite;border:2px solid #ddd;border-radius:50%;border-top-color:#007bff;height:20px;width:20px}.loading-spinner{align-items:center;display:flex;justify-content:center;padding:40px}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24}@media (max-width:768px){.simplified-policy-extraction{padding:15px}.candidates-grid{grid-template-columns:1fr}.wizard-navigation{flex-direction:column;gap:15px}.nav-spacer{display:none}.step-indicator{flex-wrap:wrap;gap:10px}}.policy-editor{box-sizing:border-box;margin:0;padding:20px;width:100%}.editor-header{margin-bottom:30px}.back-btn{background:none;border:none;color:#007bff;cursor:pointer;font-size:14px;margin-bottom:10px;padding:5px 10px}.back-btn:hover{text-decoration:underline}.header-main{align-items:flex-start;display:flex;justify-content:space-between}.header-content{flex:1 1}.editor-header h2{color:#333;font-size:28px;margin:0 0 8px}.editor-header p{color:#666;margin:0}.add-policy-btn{align-items:center;background-color:#28a745;border:none;border-radius:5px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:5px;padding:10px 20px;transition:background-color .2s}.add-policy-btn:hover:not(:disabled){background-color:#218838}.add-policy-btn:disabled{cursor:not-allowed;opacity:.6}.policies-summary{margin-bottom:25px}.summary-card{align-items:center;background-color:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;flex-direction:row;gap:40px;justify-content:center;padding:20px 40px}.summary-item{display:flex;flex-direction:column;gap:8px;min-width:100px;text-align:center}.summary-divider{background-color:#e9ecef;height:50px;width:1px}.summary-value{color:#495057;font-size:32px;font-weight:700}.summary-value.validated{color:#28a745}.summary-value.pending{color:#ffc107}.summary-value.needs-review{color:#dc3545}.summary-label{color:#6c757d;font-size:14px;font-weight:500}.policies-controls{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:20px;padding:15px}.controls-left{gap:20px}.controls-left,.controls-right{align-items:center;display:flex}.filter-controls,.sort-controls{align-items:center;display:flex;gap:8px}.filter-controls label,.sort-controls label{color:#495057;font-size:14px;font-weight:500;margin:0}.filter-select,.sort-select{background-color:#fff;border:1px solid #ced4da;border-radius:4px;font-size:14px;min-width:120px;padding:6px 12px}.policy-count{color:#6c757d;font-size:14px;font-weight:500}.clear-filter-btn{background-color:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px}.clear-filter-btn:hover{background-color:#5a6268}.no-filtered-policies{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:40px 20px;text-align:center}.no-filtered-policies p{color:#666;margin-bottom:15px}.add-policy-form{margin-bottom:30px}.form-card{background-color:#fff;border:2px solid #28a745;border-radius:8px;box-shadow:0 4px 12px #28a74526;padding:30px}.form-card h3{color:#333;font-size:20px;margin:0 0 20px}.required{color:#dc3545}.policies-list{display:flex;flex-direction:column;gap:16px;width:100%}.no-policies{background-color:#f8f9fa;border-radius:8px;padding:60px 20px;text-align:center}.no-policies p{color:#666;margin-bottom:20px}.primary-btn{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;padding:10px 20px}.primary-btn:hover{background-color:#0056b3}.policy-item{background-color:#fff;border:1px solid #dee2e6;border-radius:8px;box-sizing:border-box;margin-bottom:16px;overflow:visible;transition:all .2s ease;width:100%}.policy-item:hover{border-color:#adb5bd;box-shadow:0 2px 8px #00000014}.policy-item.editing{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.policy-item.adding{border-color:#28a745;box-shadow:0 0 0 2px #28a7451a}.policy-container{box-sizing:border-box;padding:20px 24px;width:100%}.policy-header-row{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.policy-badges{align-items:center;display:flex;gap:10px}.policy-actions-top{display:flex;gap:8px}.policy-actions-top .delete-btn,.policy-actions-top .edit-btn{font-size:12px;padding:6px 14px}.policy-display{padding:0}.policy-content-row{align-items:flex-start;display:flex;gap:24px;width:100%}.policy-item .policy-main-content{display:flex;flex:1 1;flex-direction:column;gap:16px;min-width:0;padding-right:10px}.policy-item .policy-sidebar{flex-shrink:0;min-width:280px;width:280px}.policy-text-section{display:flex;flex-direction:column;gap:12px}.policy-text-wrapper{position:relative}.policy-text-label{color:#495057;display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.policy-text-content{word-wrap:break-word;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;color:#2c3e50;min-height:60px;overflow-wrap:break-word}.policy-text-content,.policy-text-edit{font-size:14px;line-height:1.6;padding:12px 16px}.policy-text-edit{background-color:#fff;border:1px solid #ced4da;border-radius:6px;box-sizing:border-box;font-family:inherit;min-height:100px;resize:vertical;width:100%}.policy-text-edit:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a;outline:none}.policy-keywords-section{margin-top:8px}.policy-keywords-content{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.keyword-tag{background-color:#e9ecef;border-radius:20px;color:#495057;font-size:12px;font-weight:500;padding:3px 10px}.status-badge{align-items:center;border-radius:20px;display:inline-flex;padding:4px 12px}.status-badge.status-pending{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.status-badge.status-validated{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.status-badge.status-needs_review{background-color:#f8d7da;border:1px solid #f1b0b7;color:#721c24}.status-badge.status-rejected{background-color:#f5c6cb;border:1px solid #f1b0b7;color:#721c24}.category-badge{align-items:center;background-color:#f0f4f8;border-radius:4px;color:#495057;display:inline-flex;font-size:11px;font-weight:600;letter-spacing:.3px;padding:4px 12px;text-transform:uppercase}.policy-sidebar{display:flex;flex-direction:column;gap:16px}.sidebar-section{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:16px}.sidebar-section-title{border-bottom:1px solid #e9ecef;color:#495057;font-size:13px;font-weight:600;margin-bottom:12px;padding-bottom:8px}.policy-metrics{display:flex;flex-direction:column;gap:8px}.metric-group{align-items:center;display:flex;justify-content:space-between;padding:6px 0}.metric-group:not(:last-child){border-bottom:1px solid #f0f4f8}.metric-label{color:#6c757d;font-size:12px;font-weight:500}.metric-value{color:#495057}.metric-input,.metric-value{font-size:13px;font-weight:600}.metric-input{border:1px solid #ced4da;border-radius:4px;padding:4px 8px;text-align:right;width:70px}.metric-input:focus{border-color:#007bff;outline:none}.policy-scores{display:flex;flex-direction:column;gap:8px}.score-group{align-items:center;display:flex;justify-content:space-between;padding:6px 0}.score-group:not(:last-child){border-bottom:1px solid #f0f4f8}.score-label{color:#6c757d;font-size:12px}.score-value{background-color:#fff;border:1px solid #dee2e6;border-radius:12px;color:#495057;font-size:12px;font-weight:600;padding:2px 6px}.policy-actions{border-top:1px solid #e9ecef;display:flex;gap:8px;margin-top:16px;padding-top:16px}.cancel-btn,.delete-btn,.edit-btn,.save-btn{border:none;border-radius:4px;cursor:pointer;flex:1 1;font-size:13px;font-weight:500;padding:8px 12px;text-align:center;transition:all .2s}.edit-btn{background-color:#007bff;color:#fff}.edit-btn:hover:not(:disabled){background-color:#0056b3}.delete-btn{background-color:#fff;border:1px solid #dc3545;color:#dc3545}.delete-btn:hover:not(:disabled){background-color:#dc3545;color:#fff}.save-btn{background-color:#28a745;color:#fff}.save-btn:hover:not(:disabled){background-color:#218838}.cancel-btn{background-color:#6c757d;color:#fff}.cancel-btn:hover:not(:disabled){background-color:#5a6268}.cancel-btn:disabled,.delete-btn:disabled,.edit-btn:disabled,.save-btn:disabled{cursor:not-allowed;opacity:.6}.form-group{margin-bottom:12px}.form-group label{color:#495057;display:block;font-size:12px;font-weight:500;margin-bottom:6px}.form-group input,.form-group select{border:1px solid #ced4da;border-radius:4px;box-sizing:border-box;font-family:inherit;font-size:13px;padding:6px 10px;width:100%}.form-group input:focus,.form-group select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a;outline:none}.form-text{color:#6c757d;display:block;font-size:11px;margin-top:4px}.form-row-2{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.form-row-3{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr}.error,.loading{font-size:16px;padding:40px;text-align:center}.error{color:#dc3545}@media (max-width:1400px){.policy-item .policy-sidebar{min-width:260px;width:260px}}@media (max-width:1200px){.policy-item .policy-sidebar{min-width:240px;width:240px}}@media (max-width:1024px){.form-horizontal,.policy-content-row{flex-direction:column}.form-right-column,.policy-item .policy-sidebar{width:100%}.form-row-3{grid-template-columns:1fr 1fr}.controls-left,.policies-controls{align-items:stretch;flex-direction:column;gap:15px}.filter-controls,.sort-controls{justify-content:space-between}.policy-sidebar{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr 1fr}.policy-actions{flex-direction:row;grid-column:1/-1;justify-content:center}}@media (max-width:768px){.form-row-2,.form-row-3{grid-template-columns:1fr}.header-main{flex-direction:column;gap:15px}.add-policy-btn{justify-content:center;width:100%}.summary-card{flex-wrap:wrap;gap:20px;padding:20px}.summary-divider{display:none}.policy-sidebar{grid-template-columns:1fr}.controls-left{gap:10px}.filter-controls,.sort-controls{align-items:stretch;flex-direction:column;gap:5px}}.category-management-container{margin:0 auto;max-width:1200px;padding:2rem}.page-header{border-bottom:2px solid #e0e0e0;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.page-header,.page-title{align-items:center;display:flex}.page-title{color:#333;font-size:2rem;font-weight:700;gap:.75rem;margin:0}.header-actions{display:flex;gap:1rem}.refresh-button,.reset-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.refresh-button{background-color:#2196f3}.refresh-button:hover{background-color:#1976d2}.reset-button{background-color:#ff9800;color:#fff}.reset-button:hover{background-color:#f57c00}.refresh-button:disabled,.reset-button:disabled{background-color:#ccc;cursor:not-allowed}.error-banner{align-items:center;background-color:#ffebee;border:1px solid #f44336;border-radius:8px;color:#d32f2f;display:flex;gap:1rem;margin-bottom:1rem;padding:1rem}.error-close{background:none;border:none;color:#d32f2f;cursor:pointer;margin-left:auto;padding:.25rem}.intro-section{margin-bottom:2rem}.info-card{align-items:flex-start;background-color:#e3f2fd;border:1px solid #2196f3;border-radius:8px;display:flex;gap:1rem;padding:1.5rem}.info-card svg{color:#2196f3;font-size:1.5rem;margin-top:.25rem}.info-card h3{color:#1976d2;margin:0 0 .5rem}.info-card p{color:#333;line-height:1.5;margin:0}.categories-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(450px,1fr))}.category-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:1.5rem;transition:all .3s}.category-card:hover{box-shadow:0 4px 12px #00000026}.category-card.editing{border-color:#2196f3;box-shadow:0 4px 12px #2196f333}.category-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.category-name{color:#333;font-size:1.25rem;font-weight:600;margin:0}.category-actions{display:flex;gap:.5rem}.edit-button{background-color:#2196f3;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:.5rem;transition:background-color .2s}.edit-button:hover{background-color:#1976d2}.edit-button:disabled{background-color:#ccc;cursor:not-allowed}.edit-actions{display:flex;gap:.5rem}.save-button{background-color:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:.5rem;transition:background-color .2s}.save-button:hover{background-color:#45a049}.save-button:disabled{background-color:#ccc;cursor:not-allowed}.cancel-button{background-color:#f44336;border-radius:6px;color:#fff;padding:.5rem;transition:background-color .2s}.cancel-button:hover{background-color:#d32f2f}.weight-display,.weight-info{margin-bottom:1rem}.weight-info{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.current-weight,.default-weight{display:flex;flex-direction:column;gap:.25rem}.current-weight label,.default-weight label{color:#666;font-size:.875rem;font-weight:600}.weight-value{font-size:1.5rem;font-weight:700}.weight-description{color:#666;font-size:.875rem}.weight-editor{background-color:#f5f5f5;border-radius:8px;margin-top:1rem;padding:1rem}.weight-slider-container{margin-bottom:1rem}.weight-slider-container label{color:#333;display:block;font-weight:600;margin-bottom:.5rem}.weight-slider{margin-bottom:.5rem;width:100%}.slider-labels{color:#666;display:flex;font-size:.75rem;justify-content:space-between}.reason-input{margin-bottom:1rem}.reason-input label{color:#333;display:block;font-weight:600;margin-bottom:.5rem}.reason-textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;padding:.75rem;resize:vertical;width:100%}.reason-textarea:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f333;outline:none}.change-preview{background-color:#e8f5e8;border:1px solid #4caf50;border-radius:6px;margin-top:1rem;padding:.75rem}.change-preview strong{color:#2e7d32}.weight-source{background-color:#fafafa;border-radius:6px;margin-bottom:1rem;padding:1rem}.weight-source label{color:#333;display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.source-text{color:#666;font-size:.875rem;font-style:italic;line-height:1.4;margin:0}.weight-metadata{color:#666;display:flex;font-size:.875rem;gap:2rem}.metadata-item{display:flex;flex-direction:column;gap:.25rem}.metadata-item label{font-weight:600}.empty-state{color:#666;font-size:1.125rem;padding:3rem}@media (max-width:768px){.category-management-container{padding:1rem}.page-header{align-items:stretch;flex-direction:column;gap:1rem}.header-actions{justify-content:center}.categories-grid,.weight-info{grid-template-columns:1fr}.weight-metadata{flex-direction:column;gap:1rem}}.policy-stats-dashboard{margin:0 auto;max-width:1200px;padding:20px}.stats-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.stats-header h2{color:#333;font-size:24px;margin:0}.refresh-button{align-items:center;background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:background-color .2s}.refresh-button:hover:not(:disabled){background-color:#0056b3}.refresh-button:disabled{background-color:#6c757d;cursor:not-allowed}.refresh-button svg.spinning{animation:spin 1s linear infinite}.stats-loading{flex-direction:column;justify-content:center;padding:60px}.error-message,.stats-loading{align-items:center;display:flex}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:6px;justify-content:space-between;margin-bottom:20px;padding:15px}.error-message p{color:#c00;margin:0}.error-message button{background:none;border:none;color:#c00;cursor:pointer;text-decoration:underline}.stats-content{display:flex;flex-direction:column;gap:30px}.stats-overview{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:25px;text-align:center}.stat-card h3{color:#666;font-size:16px;font-weight:500;margin:0 0 15px}.stat-value{color:#333;font-size:36px;font-weight:700}.stat-unit{color:#666;font-size:18px;font-weight:400}.validation-distribution{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:25px}.validation-distribution h3{color:#333;font-size:18px;margin:0 0 20px}.distribution-chart{display:flex;flex-direction:column;gap:15px}.distribution-item{display:flex;flex-direction:column;gap:8px}.distribution-header{align-items:center;display:flex;gap:8px}.distribution-header svg{font-size:18px}.validated-icon{color:#28a745}.review-icon{color:#ffc107}.rejected-icon{color:#dc3545}.status-name{flex:1 1;font-weight:500;text-transform:capitalize}.status-count{color:#333;font-weight:700}.distribution-bar-container{align-items:center;background-color:#f0f0f0;border-radius:4px;display:flex;gap:10px;height:24px;position:relative}.distribution-bar{border-radius:4px;height:100%;transition:width .3s ease}.percentage-label{color:#666;font-size:12px;font-weight:500;position:absolute;right:8px}.stats-insights{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:25px}.stats-insights h3{color:#333;font-size:18px;margin:0 0 20px}.insights-content{display:flex;flex-direction:column;gap:12px}.insight{align-items:center;border-radius:6px;display:flex;font-size:14px;gap:10px;margin:0;padding:12px 16px}.insight svg{flex-shrink:0;font-size:18px}.insight.warning{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.insight.warning svg{color:#ffc107}.insight.success{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.insight.success svg{color:#28a745}@media (max-width:768px){.stats-header{align-items:flex-start;flex-direction:column;gap:15px}.refresh-button{justify-content:center;width:100%}.stats-overview{grid-template-columns:1fr}}.roles-checkboxes{display:flex;flex-direction:column;gap:10px;margin:15px 0}.role-checkbox{align-items:center;display:flex;gap:8px}.role-checkbox input[type=checkbox]{height:16px;width:16px}.role-help-text{color:#666;font-size:.8rem;font-style:italic;margin-top:8px}.user-roles{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:15px}.role-badge{margin-bottom:5px;margin-right:5px}.current-roles{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;margin:12px 0;padding:10px}.current-roles p{color:#4b5563;font-size:.9rem;font-weight:500;margin:0 0 8px}@media (max-width:768px){.user-management .admin-table-container{border-radius:.5rem;max-width:100%;overflow-x:auto}.user-management .admin-table{min-width:650px;width:100%}.user-management .admin-table td,.user-management .admin-table th{font-size:.8rem;padding:.5rem}.user-management .user-roles{display:flex;flex-direction:column;gap:.25rem}.user-management .role-badge{align-items:center;display:inline-flex;font-size:.8rem;margin-bottom:.25rem;padding:.25rem .5rem}.user-management .role-badge svg{margin-right:.375rem}.user-management .action-buttons{display:flex;gap:.5rem;justify-content:flex-end}.user-management .action-button{height:2.25rem;width:2.25rem}}@media (max-width:480px){.user-management .admin-header{align-items:flex-start;flex-direction:column;gap:1rem;margin-bottom:1rem}.user-management .admin-table td:first-child,.user-management .admin-table td:nth-child(5),.user-management .admin-table th:first-child,.user-management .admin-table th:nth-child(5){display:none}.user-management .admin-modal{left:50%;max-height:90vh;max-width:95%;overflow-y:auto;position:fixed;top:50%;transform:translate(-50%,-50%);width:95%;z-index:1000}.user-management .admin-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:999}.user-management .admin-modal-body{max-height:60vh;overflow-y:auto;padding:1rem}.user-management .admin-modal-footer{background-color:#fff;bottom:0;box-shadow:0 -2px 10px #0000001a;flex-direction:column;gap:.5rem;padding:1rem;position:sticky}.user-management .admin-modal-footer button{font-size:1rem;height:42px;width:100%}.user-management .roles-checkboxes{background-color:#f9fafb;border:1px solid #e2e8f0cc;border-radius:.5rem;margin-top:.5rem;padding:.75rem}.user-management .role-checkbox{align-items:center;display:flex;margin-bottom:1.25rem;padding:.25rem}.user-management .role-checkbox:last-child{margin-bottom:.5rem}.user-management .role-checkbox input[type=checkbox]{accent-color:#3b82f6;height:24px;margin-right:10px;width:24px}.user-management .role-checkbox label{font-size:1rem;font-weight:500}.user-management .admin-modal-close{align-items:center;background-color:#e2e8f080;border-radius:50%;display:flex;font-size:1.5rem;height:44px;justify-content:center;width:44px}.user-management .role-help-text{background-color:#e2e8f04d;border-radius:.25rem;font-size:.9rem;margin-top:1rem;padding:.5rem;text-align:center}.user-management .current-roles{border-radius:.5rem;margin-bottom:1.25rem;padding:.75rem}.user-management .current-roles p{font-size:.9rem;margin-bottom:.75rem}.user-management .user-edit-info{background-color:#f1f5f9;border-radius:.5rem;font-size:1rem;margin-bottom:1rem;padding:.5rem;text-align:center}.user-management .roles-label{display:block;font-size:1rem;font-weight:600;margin-bottom:.5rem}}.test-management-page{background-color:#f8fafc;min-height:100vh}.test-management-loading{align-items:center;color:#64748b;display:flex;font-size:18px;justify-content:center;min-height:100vh}.test-management-header{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;gap:20px;padding:20px 40px}.back-button{background:none;border:none;border-radius:8px;color:#64748b;cursor:pointer;font-size:16px;padding:8px 16px;transition:all .2s}.back-button:hover{background:#f1f5f9;color:#475569}.test-management-header h1{color:#1e293b;font-size:28px;margin:0}.test-management-content{margin:0 auto;max-width:1200px;padding:40px}.feature-toggle-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:32px;padding:24px}.feature-toggle-section h2{color:#1e293b;font-size:20px;margin:0 0 20px}.feature-toggle{align-items:center;display:flex;gap:16px;margin-bottom:16px}.toggle-label{color:#475569;font-size:16px}.switch{display:inline-block;height:24px;position:relative;width:50px}.switch input{height:0;opacity:0;width:0}.slider{background-color:#cbd5e1;border-radius:24px;bottom:0;cursor:pointer;left:0;right:0;top:0}.slider,.slider:before{position:absolute;transition:.4s}.slider:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:18px;left:3px;width:18px}input:checked+.slider{background-color:#3b82f6}input:checked+.slider:before{transform:translateX(26px)}.status-label{border-radius:20px;font-size:14px;font-weight:600;padding:4px 12px}.status-label.enabled{background:#dcfce7;color:#16a34a}.status-label.disabled{background:#fee2e2;color:#dc2626}.feature-description{color:#64748b;font-size:14px;margin:0}.configurations-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.section-header h2{color:#1e293b;font-size:20px;margin:0}.create-button{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.create-button:hover{background:#2563eb}.create-button:disabled{background:#94a3b8;cursor:not-allowed}.empty-state{color:#64748b;padding:48px;text-align:center}.configurations-list{display:flex;flex-direction:column;gap:16px}.configuration-card{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;padding:20px;transition:all .2s}.configuration-card.active{background:#eff6ff;border-color:#3b82f6}.config-info h3{color:#1e293b;font-size:18px;margin:0 0 8px}.config-date{color:#64748b;font-size:14px;margin:0}.active-badge{background:#3b82f6;border-radius:20px;color:#fff;display:inline-block;font-size:12px;font-weight:600;margin-top:8px;padding:4px 12px}.activate-button{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;color:#475569;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.activate-button:hover{background:#e2e8f0;color:#334155}.config-actions{align-items:center;display:flex;gap:12px}.analytics-button{background:#8b5cf6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.analytics-button:hover{background:#7c3aed}.active-toggle-wrapper{align-items:center;display:flex;gap:8px}.toggle-label-small{color:#475569;font-size:14px}.switch-small{display:inline-block;height:22px;position:relative;width:42px}.switch-small input{height:0;opacity:0;width:0}.slider-small{background-color:#cbd5e1;border-radius:22px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.4s}.slider-small:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:16px;left:3px;position:absolute;transition:.4s;width:16px}input:checked+.slider-small{background-color:#3b82f6}input:checked+.slider-small:before{transform:translateX(20px)}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;max-height:90vh;max-width:600px;overflow-y:auto;padding:32px;width:90%}.modal-content h2{color:#1e293b;font-size:24px;margin:0 0 24px}.candidate-selection{align-items:center;display:flex;gap:24px;margin-bottom:32px}.candidate-select{flex:1 1}.candidate-select label{color:#475569;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.candidate-select select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#1e293b;cursor:pointer;font-size:16px;padding:10px 12px;width:100%}.candidate-select select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.vs-divider{color:#94a3b8;font-size:18px;font-weight:700;margin-top:24px;padding:0 16px}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.cancel-button{background:#f1f5f9;border:none;border-radius:8px;color:#475569;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.cancel-button:hover{background:#e2e8f0}@media (max-width:768px){.test-management-header{padding:16px 20px}.test-management-content{padding:20px}.section-header{align-items:flex-start;gap:16px}.candidate-selection,.section-header{flex-direction:column}.vs-divider{margin:16px 0}.configuration-card{align-items:flex-start;flex-direction:column;gap:16px}.config-actions{justify-content:flex-start;width:100%}}.feedback-management-container{background:#f8f9fa;min-height:100vh;padding:24px}.feedback-management-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.header-title{align-items:center;display:flex;gap:12px}.header-icon{color:#3b82f6;font-size:28px}.feedback-management-header h2{color:#1e293b;font-size:28px;font-weight:700;margin:0}.header-stats{display:flex;gap:16px}.stat-badge{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;color:#475569;font-weight:600;padding:8px 16px}.feedback-controls{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:24px}.search-box{flex:1 1;max-width:400px}.search-input{border:2px solid #e5e7eb;border-radius:8px;font-size:14px;padding:10px 16px;transition:all .2s;width:100%}.search-input:focus{border-color:#3b82f6;outline:none}.control-buttons{display:flex;gap:12px}.export-btn{align-items:center;background:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s}.export-btn:hover:not(:disabled){background:#059669;transform:translateY(-2px)}.export-btn:disabled{cursor:not-allowed;opacity:.5}.feedback-table-container{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;overflow:hidden}.feedback-table{border-collapse:collapse;width:100%}.feedback-table thead{background:#f1f5f9}.feedback-table th{color:#475569;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase;-webkit-user-select:none;user-select:none}.feedback-table th:hover{background:#e2e8f0}.feedback-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.feedback-table tbody tr:hover{background:#f8fafc}.feedback-table td{padding:16px;vertical-align:top}.date-cell{width:150px}.date-info{display:flex;flex-direction:column;gap:4px}.date-full{color:#1e293b;font-weight:600}.date-relative{color:#64748b;font-size:12px}.feedback-cell{max-width:400px}.feedback-text{color:#334155;line-height:1.5;max-height:60px;overflow:hidden;transition:max-height .3s}.feedback-text.expanded{max-height:none}.expand-btn{align-items:center;background:#f1f5f9;border:none;border-radius:4px;color:#3b82f6;cursor:pointer;display:flex;font-size:12px;gap:4px;margin-top:8px;padding:4px 8px;transition:all .2s}.expand-btn:hover{background:#e2e8f0}.test-details-cell{width:250px}.test-details{display:flex;flex-direction:column;gap:6px}.candidates{color:#1e293b;font-size:14px;font-weight:600}.test-stats{color:#64748b;font-size:13px}.status-badge{border-radius:4px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.status-badge.completed{background:#dcfce7;color:#16a34a}.status-badge.incomplete{background:#fef3c7;color:#d97706}.no-test{color:#9ca3af;font-style:italic}.accuracy-cell{width:120px}.accuracy-display{display:flex;flex-direction:column;gap:6px}.accuracy-value{color:#3b82f6;font-size:18px;font-weight:700}.accuracy-bar{background:#e5e7eb;border-radius:3px;height:6px;overflow:hidden;width:80px}.accuracy-fill{background:linear-gradient(90deg,#3b82f6,#2563eb);height:100%;transition:width .3s}.no-data{color:#9ca3af;font-style:italic;padding:48px!important;text-align:center}.pagination{align-items:center;background:#fff;border-radius:8px;display:flex;gap:16px;justify-content:center;margin-top:24px;padding:16px}.pagination button{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;transition:all .2s}.pagination button:hover:not(:disabled){background:#2563eb}.pagination button:disabled{cursor:not-allowed;opacity:.5}.page-info{color:#475569;font-weight:600}.page-size-select{border:2px solid #e5e7eb;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 12px}.feedback-management-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px}.loading-spinner{animation:spin .8s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.feedback-management-error{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px}.feedback-management-error p{color:#dc2626;font-weight:600}.feedback-management-error button{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px}@media (max-width:768px){.feedback-controls{flex-direction:column}.search-box{max-width:100%}.feedback-table{font-size:14px}.feedback-table td,.feedback-table th{padding:12px 8px}.feedback-cell{max-width:200px}}.navbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(90deg,#2563eb,#3b82f6);box-shadow:0 4px 12px #00000014;color:#fff;padding:.75rem 1.5rem;position:sticky;top:0;z-index:1000}.navbar-container{gap:2.5rem;justify-content:flex-start;margin:0 auto;max-width:1200px}.navbar-brand,.navbar-container{align-items:center;display:flex;position:relative}.navbar-brand{color:#fff;font-size:1.75rem;font-weight:800;letter-spacing:-.02em;padding:.5rem 0;text-decoration:none}.navbar-brand:hover{opacity:.9;text-decoration:none}.nav-links{align-items:center;display:flex;gap:.75rem}.nav-link{border-radius:.5rem;color:#fff;font-size:1rem;font-weight:500;margin:0;opacity:.85;padding:.6rem 1.2rem;position:relative;text-decoration:none;transition:all .2s ease}.nav-link:hover{background-color:#ffffff1f;opacity:1;text-decoration:none}.nav-link.active{background-color:#ffffff29;font-weight:600;opacity:1;position:relative;text-decoration:none}.nav-link.active:after{background-color:#ffffffd9;border-radius:1px;bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);width:30px}.desktop-menu{flex-grow:1;justify-content:space-between}.desktop-menu,.user-section{align-items:center;display:flex}.user-section{background-color:#ffffff1f;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;gap:1rem;margin-left:auto;padding:.5rem .75rem}.username{border-radius:.5rem;color:#fffffff2;font-size:.95rem;padding:.3rem .5rem}.logout-button,.username{align-items:center;display:flex;font-weight:500;gap:.5rem}.logout-button{background-color:#ffffff1f;border:none;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s;white-space:nowrap}.logout-button:hover{background-color:#fff3;transform:translateY(-1px)}.mobile-menu-toggle{display:none}.menu-icon{color:#fff;font-size:1.5rem}.mobile-menu{display:none}.navbar-search-btn{margin:0 1rem}.search-nav-button{align-items:center;background-color:#ffffff1a;border:none;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.6rem 1.2rem;transition:all .2s}.search-nav-button:hover{background-color:#fff3;transform:translateY(-1px)}@media (max-width:768px){.navbar{padding:.75rem 1rem;position:sticky;top:0;z-index:1000}.navbar-container{gap:1rem;justify-content:space-between}.desktop-menu,.navbar-search-btn{display:none}.mobile-menu-toggle{display:block}.mobile-menu-toggle button{align-items:center;background:#ffffff1a;border:none;border-radius:.5rem;cursor:pointer;display:flex;height:40px;justify-content:center;padding:.5rem;transition:all .2s;width:40px}.mobile-menu-toggle button:hover{background:#fff3}.mobile-menu{animation:slideDown .2s ease-out forwards;background-color:#3b82f6;background-image:linear-gradient(90deg,#2563eb,#3b82f6);border-radius:0 0 1rem 1rem;box-shadow:0 8px 20px #00000026;display:flex;flex-direction:column;gap:.5rem;left:0;padding:1rem;position:absolute;right:0;top:100%;z-index:100}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mobile-nav-link{align-items:center;background-color:#ffffff14;border-radius:.75rem;color:#fff;display:flex;font-size:1.1rem;font-weight:500;gap:.75rem;margin-bottom:.5rem;padding:1.2rem 1.5rem;text-decoration:none;transition:all .15s}.mobile-nav-icon{align-items:center;display:flex;font-size:1.2rem;justify-content:center}.mobile-nav-link.active,.mobile-nav-link:hover{background-color:#ffffff26;transform:translateX(5px)}.mobile-nav-link.active{background-color:#ffffff29;font-weight:600}.mobile-user-section{align-items:center;background-color:#ffffff14;border-radius:.75rem;border-top:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-top:1rem;padding:1.2rem 1.5rem}.mobile-user-section .username{font-size:1.1rem;font-weight:600}.mobile-user-section .logout-button{background-color:#ffffff26;border-radius:.5rem;font-size:1rem;padding:.6rem 1rem}}@media (max-width:480px){.navbar-brand{font-size:1.5rem}}
/*# sourceMappingURL=main.9b93659c.css.map*/