:root{--color-primary:#ff6b35;--color-primary-dark:#e85a2b;--color-primary-light:#ff8c5a;--color-primary-lighter:#fff4f0;--color-secondary:#4a90e2;--color-secondary-dark:#357abd;--color-secondary-light:#6ba3e8;--color-accent:#ffb84d;--color-accent-dark:#ff9f1c;--color-accent-light:#ffd699;--color-success:#10b981;--color-success-dark:#059669;--color-success-light:#d1fae5;--color-error:#ef4444;--color-error-dark:#dc2626;--color-error-light:#fee2e2;--color-warning:#f59e0b;--color-warning-dark:#d97706;--color-warning-light:#fef3c7;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-300:#d1d5db;--color-gray-400:#9ca3af;--color-gray-500:#6b7280;--color-gray-600:#4b5563;--color-gray-700:#374151;--color-gray-800:#1f2937;--color-gray-900:#111827;--color-text-primary:#111827;--color-text-secondary:#6b7280;--color-text-tertiary:#9ca3af;--color-text-inverse:#fff;--color-bg-primary:#fff;--color-bg-secondary:#f9fafb;--color-bg-tertiary:#f3f4f6;--gradient-primary:linear-gradient(135deg,#ff6b35,#ff8c5a 50%,#ffb84d);--gradient-secondary:linear-gradient(135deg,#4a90e2,#6ba3e8);--gradient-success:linear-gradient(135deg,#10b981,#34d399);--gradient-hero:linear-gradient(135deg,#ff6b35,#ff8c5a 50%,#ffb84d);--gradient-card:linear-gradient(135deg,#ff6b350d,#ffb84d0d);--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--shadow-2xl:0 25px 50px -12px #00000040;--shadow-primary:0 10px 25px -5px #ff6b354d;--shadow-primary-lg:0 20px 40px -10px #ff6b3566;--border-radius-sm:0.375rem;--border-radius-md:0.5rem;--border-radius-lg:0.75rem;--border-radius-xl:1rem;--border-radius-2xl:1.5rem;--border-radius-full:9999px;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--spacing-3xl:4rem;--font-family-base:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--font-family-heading:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-size-5xl:3rem;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.25;--line-height-normal:1.5;--line-height-relaxed:1.75;--transition-fast:150ms ease-in-out;--transition-base:200ms ease-in-out;--transition-slow:300ms ease-in-out;--transition-slower:500ms ease-in-out;--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070;--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--breakpoint-2xl:1536px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px;scroll-behavior:smooth}body{background-color:var(--color-bg-secondary);color:var(--color-text-primary);font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);text-rendering:optimizeLegibility}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{cursor:pointer;font-family:inherit;font-size:inherit;line-height:inherit}button:disabled{cursor:not-allowed;opacity:.6}a{color:inherit;text-decoration:none;transition:color var(--transition-base)}a:focus-visible{border-radius:var(--border-radius-sm);outline:2px solid var(--color-primary);outline-offset:2px}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::-webkit-scrollbar{height:10px;width:10px}::-webkit-scrollbar-track{background:var(--color-gray-100)}::-webkit-scrollbar-thumb{background:var(--color-gray-400);border-radius:var(--border-radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-500)}::selection{background-color:var(--color-primary-light);color:var(--color-text-inverse)}.encuesta-card{background:var(--color-bg-primary);border:2px solid #0000;border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative;transition:all var(--transition-base)}.encuesta-card:before{background:var(--gradient-primary);content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity var(--transition-base)}.encuesta-card:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-primary-lg);transform:translateY(-8px)}.encuesta-card:hover:before{opacity:1}.encuesta-card:focus-within{outline:2px solid var(--color-primary);outline-offset:2px}.encuesta-card--participada{background:linear-gradient(to bottom,var(--color-success-light) 0,var(--color-bg-primary) 10%);border-color:var(--color-success);opacity:.9}.encuesta-card--participada:before{background:var(--gradient-success);opacity:1}.encuesta-card-image{background:var(--gradient-card);height:200px;overflow:hidden;position:relative;width:100%}.encuesta-card-image:after{background:linear-gradient(180deg,#0000 0,#ffffff1a);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.encuesta-card-image img{height:100%;object-fit:cover;transition:transform var(--transition-slow);width:100%}.encuesta-card:hover .encuesta-card-image img{transform:scale(1.05)}.encuesta-card-content{display:flex;flex:1 1;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg)}.encuesta-card-title{-webkit-line-clamp:2;color:var(--color-text-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}.encuesta-card-description,.encuesta-card-title{-webkit-box-orient:vertical;display:-webkit-box;margin:0;overflow:hidden}.encuesta-card-description{-webkit-line-clamp:3;color:var(--color-text-secondary);flex:1 1;font-size:var(--font-size-base);line-height:var(--line-height-relaxed)}.encuesta-card-meta{border-top:1px solid var(--color-gray-200);display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:auto;padding-top:var(--spacing-md)}.encuesta-card-date,.encuesta-card-time{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm)}.encuesta-card-date svg,.encuesta-card-time svg{flex-shrink:0;height:16px;opacity:.7;width:16px}.encuesta-card-badge{align-items:center;background:var(--gradient-success);border-radius:var(--border-radius-full);box-shadow:var(--shadow-sm);color:var(--color-text-inverse);display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);gap:var(--spacing-xs);justify-content:center;margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.encuesta-card-actions{background:var(--color-gray-50);border-top:1px solid var(--color-gray-200);padding:var(--spacing-md) var(--spacing-lg)}.encuesta-card-button{background:var(--gradient-primary);border:none;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-primary);color:var(--color-text-inverse);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);overflow:hidden;padding:var(--spacing-md) var(--spacing-lg);position:relative;transition:all var(--transition-base);width:100%}.encuesta-card-button:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left var(--transition-slow);width:100%}.encuesta-card-button:hover:not(:disabled):before{left:100%}.encuesta-card-button:hover:not(:disabled){box-shadow:var(--shadow-primary-lg);transform:translateY(-2px)}.encuesta-card-button:active:not(:disabled){transform:translateY(0)}.encuesta-card-button:focus-visible{outline:2px solid var(--color-primary-dark);outline-offset:2px}.encuesta-card-button--disabled{background:var(--color-gray-400);box-shadow:none;cursor:not-allowed;opacity:.6}.encuesta-card-button--disabled:before{display:none}@media (max-width:640px){.encuesta-card-image{height:160px}.encuesta-card-content{padding:var(--spacing-md)}.encuesta-card-title{font-size:var(--font-size-lg)}.encuesta-card-actions{padding:var(--spacing-md)}}@media (min-width:641px){.encuesta-card-image{height:200px}}.loading-container{min-height:200px;padding:var(--spacing-2xl)}.loading-container,.loading-container--fullscreen{align-items:center;display:flex;justify-content:center}.loading-container--fullscreen{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#fffffff2;bottom:0;left:0;position:fixed;right:0;top:0;z-index:var(--z-modal)}.loading-content{align-items:center;display:flex;flex-direction:column;gap:var(--spacing-lg)}.loading-spinner{display:inline-block;position:relative}.loading-spinner--small{height:30px;width:30px}.loading-spinner--medium{height:50px;width:50px}.loading-spinner--large{height:80px;width:80px}.spinner-ring{animation:spin 1s linear infinite;border:3px solid #0000;border-radius:50%;border-top:3px solid var(--color-primary);height:100%;left:0;position:absolute;top:0;width:100%}.spinner-ring:nth-child(2){animation-delay:-.33s;border-top-color:var(--color-accent)}.spinner-ring:nth-child(3){animation-delay:-.66s;border-top-color:var(--color-secondary)}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-message{animation:pulse 2s ease-in-out infinite;color:var(--color-text-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);margin:0;text-align:center}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.error-message{align-items:center;background-color:#fff;border-left:4px solid;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin:1rem 0;padding:1rem}.error-message--error{background-color:#f8d7da;border-left-color:#dc3545;color:#721c24}.error-message--warning{background-color:#fff3cd;border-left-color:#ffc107;color:#856404}.error-message--info{background-color:#d1ecf1;border-left-color:#17a2b8;color:#0c5460}.error-message-content{align-items:center;display:flex;flex:1 1;gap:.75rem}.error-message-icon{flex-shrink:0;font-size:1.25rem}.error-message-text{flex:1 1;line-height:1.5}.error-message-dismiss{align-items:center;background:none;border:none;color:inherit;cursor:pointer;display:flex;flex-shrink:0;font-size:1.5rem;height:24px;justify-content:center;margin-left:1rem;opacity:.7;padding:0;transition:opacity .2s;width:24px}.error-message-dismiss:hover{opacity:1}.error-message-dismiss:focus{border-radius:4px;outline:2px solid currentColor;outline-offset:2px}.home-page{background:var(--gradient-hero);min-height:100vh;overflow-x:hidden;padding:var(--spacing-xl) var(--spacing-md);position:relative}.home-page-nav-buttons{display:flex;flex-direction:column;gap:.75rem;left:1rem;position:fixed;top:1rem;z-index:100}.nav-button{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border:1px solid #0000001a;border-radius:9999px;box-shadow:0 4px 12px #00000026;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-family-primary,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif);font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;text-decoration:none;transition:all .2s ease}.nav-button:hover{background:#fff;box-shadow:0 6px 16px #0003;transform:translateY(-1px)}.nav-button-primary{color:#2563eb;color:var(--color-primary,#2563eb)}.nav-button-secondary{color:#7c3aed;color:var(--color-secondary,#7c3aed)}.nav-button-icon{flex-shrink:0;height:1.125rem;width:1.125rem}.nav-button-text{white-space:nowrap}@media (max-width:640px){.home-page-nav-buttons{gap:.5rem;left:.75rem;top:.75rem}.nav-button{justify-content:center;min-width:2.5rem;padding:.625rem}.nav-button-text{display:none}.nav-button-icon{height:1.25rem;width:1.25rem}}@media (min-width:641px){.nav-button-text{display:inline}}.home-page:before{background:radial-gradient(circle at 20% 50%,#ffffff1a 0,#0000 50%),radial-gradient(circle at 80% 80%,#ffffff1a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.container{max-width:1280px;position:relative;z-index:1}.home-page-header{animation:fadeInUp .6s ease-out;color:var(--color-text-inverse);margin-bottom:var(--spacing-3xl);text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.home-page-header h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:var(--font-weight-bold);letter-spacing:-.02em;line-height:var(--line-height-tight);margin:0 0 var(--spacing-md) 0;text-shadow:0 4px 12px #0003}.home-page-subtitle{font-size:clamp(1rem,2.5vw,1.25rem);font-weight:var(--font-weight-medium);margin:0 auto;max-width:600px;opacity:.95;text-shadow:0 2px 8px #00000026}.encuestas-grid{grid-gap:var(--spacing-xl);animation:fadeInUp .8s ease-out .2s both;display:grid;gap:var(--spacing-xl);grid-template-columns:repeat(auto-fill,minmax(min(100%,320px),1fr));margin-top:var(--spacing-2xl)}.home-page-empty{animation:fadeInUp .6s ease-out;background:var(--color-bg-primary);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-xl);padding:var(--spacing-3xl) var(--spacing-xl);text-align:center}.home-page-empty-icon{font-size:4rem;margin-bottom:var(--spacing-lg);opacity:.5}.home-page-empty p{color:var(--color-text-secondary);font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);margin:var(--spacing-sm) 0}.home-page-empty-subtitle{color:var(--color-text-tertiary);font-size:var(--font-size-base);margin-top:var(--spacing-md)}@media (max-width:640px){.home-page{padding:var(--spacing-lg) var(--spacing-md)}.home-page-header{margin-bottom:var(--spacing-2xl)}.encuestas-grid{gap:var(--spacing-lg);grid-template-columns:1fr;margin-top:var(--spacing-xl)}.home-page-empty{padding:var(--spacing-2xl) var(--spacing-lg)}}@media (min-width:641px) and (max-width:1024px){.encuestas-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (min-width:1025px){.encuestas-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}.formulario-encuesta{width:100%}.progreso-container{background:var(--color-gray-50);border:2px solid var(--color-gray-200);border-radius:var(--border-radius-xl);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-2xl);padding:var(--spacing-lg)}.progreso-info{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:space-between;margin-bottom:var(--spacing-md)}.progreso-texto{color:var(--color-text-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.progreso-porcentaje{color:var(--color-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.progreso-bar{background:var(--color-gray-200);box-shadow:inset 0 2px 4px #0000001a;height:16px;overflow:hidden;width:100%}.progreso-bar,.progreso-fill{border-radius:var(--border-radius-full);position:relative}.progreso-fill{background:var(--gradient-primary);box-shadow:0 2px 4px #ff6b354d;height:100%;transition:width var(--transition-slow)}.progreso-fill:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.preguntas-container{display:flex;flex-direction:column;gap:var(--spacing-xl)}.pregunta-item{background:var(--color-bg-primary);border:2px solid var(--color-gray-200);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);position:relative;transition:all var(--transition-base)}.pregunta-item:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.pregunta-item:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #ff6b351a}.pregunta-item.pregunta-respondida{background:var(--color-success-light);border-color:var(--color-success)}.pregunta-item.pregunta-respondida:before{background:var(--gradient-success);border-radius:var(--border-radius-xl) 0 0 var(--border-radius-xl);content:"";height:100%;left:0;position:absolute;top:0;width:4px}.pregunta-item.pregunta-error{animation:shake .5s;background:var(--color-error-light);border-color:var(--color-error)}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.pregunta-header{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:space-between;margin-bottom:var(--spacing-md)}.pregunta-numero{background:var(--color-gray-100);border-radius:var(--border-radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:.05em;padding:var(--spacing-xs) var(--spacing-sm);text-transform:uppercase}.pregunta-check{animation:scaleIn .3s ease-out;color:var(--color-success);font-size:1.5rem;font-weight:700}.pregunta-texto{color:var(--color-text-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);line-height:var(--line-height-relaxed);margin:0 0 var(--spacing-lg) 0}.pregunta-opciones{display:flex;flex-direction:column;gap:var(--spacing-md)}.opcion-radio{align-items:center;background:var(--color-gray-50);border:2px solid var(--color-gray-200);border-radius:var(--border-radius-lg);cursor:pointer;display:flex;padding:var(--spacing-lg);position:relative;transition:all var(--transition-base)}.opcion-radio:hover{background:var(--color-gray-100);border-color:var(--color-primary-light);transform:translateX(4px)}.opcion-radio:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #ff6b351a}.opcion-radio input[type=radio]{accent-color:var(--color-primary);cursor:pointer;flex-shrink:0;height:22px;margin-right:var(--spacing-md);width:22px}.opcion-radio input[type=radio]:checked+.opcion-texto{color:var(--color-primary);font-weight:var(--font-weight-semibold)}.opcion-radio:has(input[type=radio]:checked){background:var(--color-primary-lighter);border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.opcion-texto{color:var(--color-text-primary);flex:1 1;font-size:var(--font-size-base);line-height:var(--line-height-relaxed)}.pregunta-texto-container{margin-top:var(--spacing-md)}.texto-libre-input{background:var(--color-bg-primary);border:2px solid var(--color-gray-200);border-radius:var(--border-radius-lg);color:var(--color-text-primary);font-family:inherit;font-size:var(--font-size-base);min-height:140px;padding:var(--spacing-lg);resize:vertical;transition:all var(--transition-base);width:100%}.texto-libre-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #ff6b351a;outline:none}.texto-libre-input::placeholder{color:var(--color-text-tertiary)}.texto-libre-input:disabled{background:var(--color-gray-100);cursor:not-allowed;opacity:.6}.pregunta-error-mensaje{align-items:center;background:var(--color-error-light);border-left:4px solid var(--color-error);border-radius:var(--border-radius-md);color:var(--color-error-dark);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--spacing-sm);margin-top:var(--spacing-md);padding:var(--spacing-md)}.pregunta-error-mensaje:before{content:"⚠️";font-size:var(--font-size-lg)}@media (max-width:640px){.progreso-container{padding:var(--spacing-md)}.progreso-info{align-items:flex-start;flex-direction:column}.pregunta-item{padding:var(--spacing-md)}.pregunta-texto{font-size:var(--font-size-base)}.opcion-radio,.texto-libre-input{padding:var(--spacing-md)}.texto-libre-input{min-height:120px}}.formulario-demografico-overlay{align-items:center;animation:fadeIn var(--transition-base);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:var(--spacing-md);position:fixed;right:0;top:0;z-index:var(--z-modal)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.formulario-demografico-modal{animation:slideUp var(--transition-slow);background:var(--color-bg-primary);border:1px solid var(--color-gray-200);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-2xl);max-height:90vh;max-width:550px;overflow-y:auto;width:100%}.formulario-demografico-header{border-bottom:2px solid #e9ecef;padding:2rem 2rem 1rem}.formulario-demografico-header h2{color:#212529;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.formulario-demografico-subtitle{color:#6c757d;font-size:.95rem;margin:0}.formulario-demografico-disclaimer{background:#e7f3ff;border-left:4px solid #007bff;border-radius:8px;display:flex;gap:.75rem;margin:1.5rem 2rem;padding:1rem}.disclaimer-icon{flex-shrink:0;font-size:1.5rem}.disclaimer-text{color:#004085;flex:1 1;font-size:.875rem;line-height:1.6}.disclaimer-text strong{font-weight:600}.formulario-demografico-form{padding:0 2rem 2rem}.form-group{margin-bottom:1.5rem}.form-label{color:#212529;display:block;font-size:.95rem;font-weight:500;margin-bottom:.5rem}.form-input,.form-select{border:2px solid #e9ecef;border-radius:8px;font-family:inherit;font-size:1rem;padding:.75rem;transition:border-color .2s;width:100%}.form-input:focus,.form-select:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-input:disabled,.form-select:disabled{background:#f8f9fa;cursor:not-allowed;opacity:.6}.form-error{color:#dc3545;display:block;font-size:.875rem;margin-top:.5rem}.form-group-checkbox{background:#f8f9fa;border-radius:8px;margin:2rem 0 1.5rem;padding:1rem}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:.75rem}.checkbox-label input[type=checkbox]{accent-color:#007bff;cursor:pointer;height:20px;width:20px}.checkbox-text{color:#212529;font-size:.95rem;font-weight:500}.formulario-demografico-actions{display:flex;gap:1rem;margin-top:2rem}.btn-cancel,.btn-submit{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.btn-cancel{background:#6c757d;color:#fff}.btn-cancel:hover{background:#5a6268}.btn-submit{background:#007bff;color:#fff}.btn-submit:hover{background:#0056b3}.btn-submit:active{transform:scale(.98)}@media (max-width:768px){.formulario-demografico-modal{border-radius:0;max-height:100vh;max-width:100%}.formulario-demografico-form,.formulario-demografico-header{padding-left:1.5rem;padding-right:1.5rem}.formulario-demografico-disclaimer{margin-left:1.5rem;margin-right:1.5rem}.formulario-demografico-actions{flex-direction:column}}.encuesta-page{background:var(--color-bg-secondary);min-height:100vh;padding:var(--spacing-xl) var(--spacing-md)}.container{margin:0 auto;max-width:900px}.encuesta-content{animation:fadeInUp .5s ease-out;background:var(--color-bg-primary);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-xl);padding:var(--spacing-2xl)}.encuesta-header{border-bottom:2px solid var(--color-gray-200);margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-lg)}.encuesta-header h1{color:var(--color-text-primary);font-size:clamp(1.75rem,4vw,2.25rem);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);margin:0 0 var(--spacing-md) 0}.encuesta-description{color:var(--color-text-secondary);font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);margin:0}.encuesta-info{background:var(--color-gray-50);border-left:4px solid var(--color-primary);border-radius:var(--border-radius-lg);color:var(--color-text-secondary);display:flex;flex-wrap:wrap;font-size:var(--font-size-base);gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl);padding:var(--spacing-lg)}.encuesta-info span{align-items:center;display:flex;font-weight:var(--font-weight-medium);gap:var(--spacing-sm)}.encuesta-actions,.encuesta-form-wrapper{margin-top:var(--spacing-2xl)}.encuesta-actions{border-top:2px solid var(--color-gray-200);display:flex;justify-content:center;padding-top:var(--spacing-2xl)}.btn-continuar{background:var(--gradient-primary);border:none;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-primary);color:var(--color-text-inverse);cursor:pointer;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);min-width:200px;overflow:hidden;padding:var(--spacing-md) var(--spacing-2xl);position:relative;transition:all var(--transition-base)}.btn-continuar:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left var(--transition-slow);width:100%}.btn-continuar:hover:not(:disabled):before{left:100%}.btn-continuar:hover:not(:disabled){box-shadow:var(--shadow-primary-lg);transform:translateY(-2px)}.btn-continuar:active:not(:disabled){transform:translateY(0)}.btn-continuar:focus-visible{outline:2px solid var(--color-primary-dark);outline-offset:2px}.btn-continuar:disabled{background:var(--color-gray-400);box-shadow:none;cursor:not-allowed;opacity:.6}.btn-continuar:disabled:before{display:none}.encuesta-already-voted{align-items:center;display:flex;justify-content:center;min-height:400px}.already-voted-content{animation:fadeInUp .5s ease-out;background:var(--color-bg-primary);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-xl);max-width:500px;padding:var(--spacing-3xl) var(--spacing-2xl);text-align:center}.already-voted-content .icon{animation:scaleIn .5s ease-out;color:var(--color-success);font-size:4rem;margin-bottom:var(--spacing-lg)}.already-voted-content h2{color:var(--color-success);font-size:clamp(1.5rem,3vw,1.875rem);font-weight:var(--font-weight-bold);margin:0 0 var(--spacing-md) 0}.already-voted-content p{color:var(--color-text-secondary);font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);margin:0 0 var(--spacing-2xl) 0}.btn-back{background:var(--gradient-primary);border:none;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-primary);color:var(--color-text-inverse);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);padding:var(--spacing-md) var(--spacing-2xl);transition:all var(--transition-base)}.btn-back:hover{box-shadow:var(--shadow-primary-lg);transform:translateY(-2px)}.btn-back:focus-visible{outline:2px solid var(--color-primary-dark);outline-offset:2px}@media (max-width:640px){.encuesta-page{padding:var(--spacing-lg) var(--spacing-md)}.encuesta-content{border-radius:var(--border-radius-xl);padding:var(--spacing-lg)}.encuesta-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md)}.encuesta-info{flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.encuesta-actions{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg)}.btn-continuar{min-width:auto;width:100%}.already-voted-content{padding:var(--spacing-2xl) var(--spacing-lg)}}@media (min-width:641px) and (max-width:1024px){.encuesta-content{padding:var(--spacing-xl)}}.gracias-page{align-items:center;background:var(--gradient-hero);display:flex;justify-content:center;min-height:100vh;overflow-x:hidden;padding:var(--spacing-xl) var(--spacing-md);position:relative}.gracias-page:before{background:radial-gradient(circle at 20% 50%,#ffffff1a 0,#0000 50%),radial-gradient(circle at 80% 80%,#ffffff1a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.gracias-container{max-width:600px;position:relative;width:100%;z-index:1}.gracias-content{animation:slideUp var(--transition-slower);background:var(--color-bg-primary);border:1px solid #fff3;border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-2xl);padding:var(--spacing-3xl) var(--spacing-2xl);text-align:center}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.gracias-icon{align-items:center;animation:scaleIn var(--transition-slower) .2s both;background:var(--gradient-success);border-radius:50%;box-shadow:var(--shadow-lg);color:var(--color-text-inverse);display:flex;font-size:3.5rem;height:100px;justify-content:center;margin:0 auto var(--spacing-lg);width:100px}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.gracias-titulo{color:var(--color-text-primary);font-size:clamp(1.75rem,4vw,2.25rem);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);margin:0 0 var(--spacing-md) 0}.gracias-mensaje{color:var(--color-text-secondary);font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);margin:0 0 var(--spacing-2xl) 0}.gracias-info{background:#f8f9fa;border-radius:12px;display:flex;flex-direction:column;gap:1rem;margin:2rem 0;padding:1.5rem}.info-item{align-items:center;display:flex;gap:.75rem;justify-content:center;text-align:left}.info-icon{flex-shrink:0;font-size:1.5rem}.info-text{color:#495057;font-size:.95rem;line-height:1.5}.gracias-actions{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.btn-compartir,.btn-inicio{border:none;border-radius:var(--border-radius-lg);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);overflow:hidden;padding:var(--spacing-md) var(--spacing-2xl);position:relative;transition:all var(--transition-base)}.btn-compartir{background:var(--gradient-secondary);box-shadow:var(--shadow-md);color:var(--color-text-inverse)}.btn-compartir:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-inicio{background:var(--gradient-primary);box-shadow:var(--shadow-primary);color:var(--color-text-inverse)}.btn-inicio:hover{box-shadow:var(--shadow-primary-lg);transform:translateY(-2px)}.btn-compartir:active,.btn-inicio:active{transform:translateY(0)}.btn-compartir:focus-visible,.btn-inicio:focus-visible{outline:2px solid var(--color-primary-dark);outline-offset:2px}@media (max-width:640px){.gracias-page{padding:var(--spacing-lg) var(--spacing-md)}.gracias-content{padding:var(--spacing-2xl) var(--spacing-lg)}.gracias-icon{font-size:2.5rem;height:80px;width:80px}.gracias-actions{flex-direction:column}.btn-compartir,.btn-inicio{width:100%}}.not-found-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.not-found-content{background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000026;max-width:500px;padding:3rem 2rem;text-align:center}.not-found-content h1{color:#667eea;font-size:6rem;font-weight:700;line-height:1;margin:0}.not-found-content h2{color:#212529;font-size:1.75rem;font-weight:600;margin:1rem 0}.not-found-content p{color:#6c757d;font-size:1.05rem;margin:0 0 2rem}.btn-home{background-color:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 2rem;transition:background-color .2s}.btn-home:hover{background-color:#0056b3}.App{min-height:100vh;width:100%}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;padding:0}
/*# sourceMappingURL=main.f74330f1.css.map*/