:root{--navy:#1a2744;--navy-dark:#0f1a2e;--green:#1a7a5c;--green-dark:#145e47;--green-light:#22a87a;--cream:#faf8f2;--cream-dark:#f0ece2;--text-primary:#1a2744;--text-secondary:#64748b;--text-muted:#94a3b8;--border:#e2e8f0;--bg-card:#ffffffd9;--bg-glass:#ffffffa6;--status-green:#16a34a;--status-yellow:#ca8a04;--status-red:#dc2626;--font-heading:"Playfair Display", serif;--font-body:"DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font-body);background:var(--cream);color:var(--text-primary);max-width:480px;min-height:100dvh;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom);margin:0 auto}.portal-header{background:linear-gradient(135deg, var(--navy) 0%, var(--navy-dark) 100%);color:#fff;text-align:center;padding:2rem 1.25rem 1.5rem;position:relative;overflow:hidden}.portal-header:after{content:"";background:var(--cream);border-radius:50% 50% 0 0;height:40px;position:absolute;bottom:-20px;left:0;right:0}.portal-header .logo{font-family:var(--font-heading);letter-spacing:3px;text-transform:uppercase;opacity:.7;margin-bottom:.5rem;font-size:.75rem}.portal-header h1{font-family:var(--font-heading);margin-bottom:.25rem;font-size:1.75rem;font-weight:700}.portal-header .address{opacity:.8;font-size:.8rem}.portal-content{padding:.75rem 1rem 2rem}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:16px;margin-bottom:1rem;padding:1.25rem;transition:transform .2s,box-shadow .2s;box-shadow:0 1px 3px #0000000a}.card:active{transform:scale(.98)}.card-title{font-family:var(--font-heading);color:var(--navy);align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:1rem;font-weight:600;display:flex}.card-title .icon{font-size:1.1rem}.carousel{aspect-ratio:16/9;background:var(--navy-dark);border-radius:16px;margin-bottom:1rem;position:relative;overflow:hidden}.carousel-slide{opacity:0;background:linear-gradient(#0000 40%,#000000b3 100%);flex-direction:column;justify-content:flex-end;padding:1rem;transition:opacity .6s;display:flex;position:absolute;inset:0}.carousel-slide.active{opacity:1}.carousel-slide .slide-title{color:#fff;font-size:.9rem;font-weight:600}.carousel-slide .slide-meta{color:#ffffffbf;margin-top:.25rem;font-size:.75rem}.carousel-dots{justify-content:center;gap:6px;padding:.75rem 0 0;display:flex}.carousel-dot{background:var(--text-muted);cursor:pointer;border:none;border-radius:50%;width:6px;height:6px;transition:all .3s}.carousel-dot.active{background:var(--green);border-radius:3px;width:18px}.activity-item{border-bottom:1px solid var(--cream-dark);align-items:flex-start;gap:.75rem;padding:.6rem 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;display:flex}.activity-icon.green{color:var(--status-green);background:#16a34a1f}.activity-icon.yellow{color:var(--status-yellow);background:#ca8a041f}.activity-text{flex:1}.activity-text .label{font-size:.85rem;font-weight:500}.activity-text .date{color:var(--text-muted);margin-top:2px;font-size:.7rem}.announcement{border-bottom:1px solid var(--cream-dark);padding:.75rem 0}.announcement:last-child{border-bottom:none}.announcement .title{font-size:.85rem;font-weight:600}.announcement .date{color:var(--text-muted);margin-top:2px;font-size:.7rem}.announcement .content{color:var(--text-secondary);margin-top:.4rem;font-size:.8rem;line-height:1.4}.compliance-row{border-bottom:1px solid var(--cream-dark);justify-content:space-between;align-items:center;padding:.6rem 0;display:flex}.compliance-row:last-child{border-bottom:none}.compliance-label{font-size:.85rem;font-weight:500}.status-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:999px;padding:.25rem .6rem;font-size:.7rem;font-weight:600}.status-badge.vigente{color:var(--status-green);background:#16a34a1f}.status-badge.por_vencer{color:var(--status-yellow);background:#ca8a041f}.status-badge.vencido{color:var(--status-red);background:#dc26261a}.cta-row{gap:.75rem;margin-bottom:1rem;display:flex}.btn{font-family:var(--font-body);cursor:pointer;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.85rem 1rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.btn:active{transform:scale(.96)}.btn-primary{background:var(--green);color:#fff}.btn-outline{color:var(--navy);border:1.5px solid var(--border);background:#fff}.contact-row{gap:.75rem;display:flex}.contact-btn{border:1.5px solid var(--border);color:var(--navy);background:#fff;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:1rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.contact-btn:active{background:var(--cream-dark);transform:scale(.96)}.contact-btn .emoji{font-size:1.2rem}.committee-grid{grid-template-columns:1fr 1fr 1fr;gap:.5rem;display:grid}.committee-member{text-align:center;padding:.5rem 0}.committee-member .role{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:.25rem;font-size:.65rem}.committee-member .name{font-size:.8rem;font-weight:600}.portal-footer{text-align:center;color:var(--text-muted);padding:1.5rem 1rem 2rem;font-size:.7rem}.portal-footer a{color:var(--green);font-weight:600;text-decoration:none}.loading{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100dvh;display:flex}.loading .spinner{border:3px solid var(--border);border-top-color:var(--green);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:2rem;display:flex}.error-state h2{font-family:var(--font-heading);margin-bottom:.5rem}.error-state p{color:var(--text-secondary);font-size:.9rem}.empty-text{color:var(--text-muted);text-align:center;padding:1rem 0;font-size:.85rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.4s forwards fadeInUp}.fade-in-1{opacity:0;animation-delay:50ms}.fade-in-2{opacity:0;animation-delay:.1s}.fade-in-3{opacity:0;animation-delay:.15s}.fade-in-4{opacity:0;animation-delay:.2s}.fade-in-5{opacity:0;animation-delay:.25s}.fade-in-6{opacity:0;animation-delay:.3s}.fade-in-7{opacity:0;animation-delay:.35s}.qr-page{background:var(--cream);min-height:100dvh}.qr-header{background:linear-gradient(135deg, var(--navy) 0%, var(--navy-dark) 100%);color:#fff;text-align:center;padding:2rem 1.25rem 1.5rem}.qr-header .qr-logo{font-family:var(--font-heading);letter-spacing:3px;text-transform:uppercase;opacity:.7;margin-bottom:.4rem;font-size:.7rem}.qr-header h1{font-family:var(--font-heading);font-size:1.4rem;font-weight:700}.qr-header .qr-desc{opacity:.8;margin-top:.25rem;font-size:.8rem}.qr-progress{justify-content:center;gap:.5rem;padding:1rem 1rem 0;display:flex}.qr-progress-step{background:var(--cream-dark);width:32px;height:32px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;transition:all .3s;display:flex}.qr-progress-step.active{background:var(--green);color:#fff}.qr-progress-step.current{box-shadow:0 0 0 3px #1a7a5c4d}.qr-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:16px;margin:1rem;padding:1.5rem;box-shadow:0 2px 8px #0000000f}.qr-form h2,.qr-form h3{font-family:var(--font-heading);color:var(--navy);margin-bottom:1rem;font-size:1rem}.qr-form input,.qr-form select,.qr-form textarea{border:1.5px solid var(--border);width:100%;font-family:var(--font-body);color:var(--text-primary);-webkit-appearance:none;background:#fff;border-radius:10px;margin-bottom:.75rem;padding:.75rem 1rem;font-size:.9rem;transition:border-color .2s}.qr-form input:focus,.qr-form select:focus,.qr-form textarea:focus{border-color:var(--green);outline:none}.qr-btn{width:100%;font-family:var(--font-body);cursor:pointer;background:var(--green);color:#fff;border:none;border-radius:12px;margin-top:.5rem;padding:.85rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s}.qr-btn:disabled{opacity:.5;cursor:not-allowed}.qr-btn:active:not(:disabled){transform:scale(.97)}.qr-btn-outline{color:var(--navy);border:1.5px solid var(--border);background:#fff}.qr-btn-finish{background:var(--navy)}.qr-btn-sm{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:8px;margin-top:.25rem;padding:.4rem .75rem;font-size:.75rem}.qr-timer{color:var(--green);background:#16a34a14;border-radius:12px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:1rem;font-size:.9rem;font-weight:600;display:flex}.qr-timer-dot{background:var(--status-green);border-radius:50%;width:10px;height:10px;animation:1.5s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.qr-notice{color:var(--status-yellow);text-align:center;margin-bottom:1rem;font-size:.8rem}.qr-file-label{border:2px dashed var(--border);text-align:center;cursor:pointer;border-radius:12px;width:100%;margin-bottom:.75rem;padding:.85rem 1rem;font-size:.9rem;font-weight:600;transition:border-color .2s;display:block}.qr-file-label:active{border-color:var(--green)}.qr-photos{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.qr-photo-thumb{object-fit:cover;border:1px solid var(--border);border-radius:8px;width:64px;height:64px}.qr-signature{margin-bottom:.75rem}.qr-signature p{margin-bottom:.5rem;font-size:.85rem;font-weight:600}.qr-sig-canvas{border:1.5px solid var(--border);touch-action:none;background:#fff;border-radius:10px;max-width:300px;width:100%!important}.qr-success{text-align:center;padding:2rem 0}.qr-success h2{font-family:var(--font-heading);color:var(--green);margin-bottom:.75rem;font-size:1.5rem}.qr-folio{color:var(--text-secondary);margin-bottom:.5rem;font-size:.85rem;font-weight:600}.qr-info-row{border-bottom:1px solid var(--cream-dark);align-items:center;gap:.75rem;padding:.75rem 0;font-size:.9rem;display:flex}.qr-info-icon{font-size:1.2rem}.qr-rules{margin:1rem 0}.qr-rules h3{font-family:var(--font-heading);margin-bottom:.5rem;font-size:.9rem}.qr-rules pre{font-family:var(--font-body);color:var(--text-secondary);white-space:pre-wrap;font-size:.8rem;line-height:1.5}.qr-actions{gap:.75rem;margin-top:1rem;display:flex}.qr-actions .qr-btn{flex:1}.qr-loading,.qr-error{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100dvh;padding:2rem;display:flex}.qr-error h2{font-family:var(--font-heading)}.qr-error p{color:var(--text-secondary);font-size:.9rem}.qr-footer{text-align:center;color:var(--text-muted);padding:1.5rem 1rem 2rem;font-size:.7rem}.qr-footer a{color:var(--green);font-weight:600;text-decoration:none}
