*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;line-height:1.5;color:#1a1a1a;background:#f5f5f5}main{max-width:800px;margin:4rem auto;padding:0 1rem}.signup-form section{background:#fff;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #00000014}.signup-form h2{font-size:1rem;font-weight:600;margin-bottom:1rem;color:#111}.field-row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.75rem}.field{position:relative;flex:1;min-width:150px}.field--wide{flex:1 1 100%}.field>label{position:absolute;left:.6875rem;top:50%;transform:translateY(-50%);font-size:.875rem;font-weight:400;color:#9ca3af;pointer-events:none;transition:top .15s ease,transform .15s ease,font-size .15s ease,color .15s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 1.25rem);line-height:1}.field input:not([type=file]),.field select{width:100%;height:3.25rem;padding:1.25rem .6875rem .375rem;border:1px solid #d1d5db;border-radius:4px;font-size:.9rem;background:#fff;color:#111}.field select:not(:focus):not(.field--has-value select){color:transparent}.field:not(.field--has-value) select{color:transparent}.field--has-value select,.field select:focus{color:#111}.field input:focus+label,.field input:not(:placeholder-shown)+label,.field--has-value input+label{top:.5rem;transform:none;font-size:.6875rem;color:#6b7280}.field input:focus+label{color:#2563eb}.field select:focus+label,.field--has-value select+label{top:.5rem;transform:none;font-size:.6875rem;color:#6b7280}.field select:focus+label{color:#2563eb}.field input:not([type=file]):focus,.field select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.field--file{display:flex;flex-direction:column;gap:.375rem}.field--file>label{position:static;transform:none;font-size:.8125rem;font-weight:500;color:#555;pointer-events:auto;white-space:normal}.field--file input[type=file]{height:auto;padding:.25rem 0;border:none;font-size:.85rem;color:#374151}.field-check{display:flex;gap:.5rem;align-items:flex-start;margin-bottom:.625rem}.field-check input[type=checkbox]{margin-top:.2rem;flex-shrink:0;accent-color:#2563eb}.field-check label{font-size:.9rem;color:#374151}.section--guardian{border:2px solid #f59e0b!important}.section-note{font-size:.8125rem;color:#92400e;background:#fef3c7;padding:.5rem .75rem;border-radius:4px;margin-bottom:1rem}.signup-form>button[type=submit]{display:block;width:100%;padding:.75rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:4rem}.signup-form>button[type=submit]:hover:not(:disabled){background:#1d4ed8}.signup-form>button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.members-filter-wrap{position:relative;display:inline-block;width:100%;max-width:24rem;margin:1rem 0 0}.members-filter{display:block;width:100%;padding:.5rem 2rem .5rem .75rem;font-size:.875rem;border:1px solid #d1d5db;border-radius:6px;outline:none;box-sizing:border-box}.members-filter:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.members-filter-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#9ca3af;font-size:.75rem;line-height:1;padding:.25rem}.members-filter-clear:hover{color:#374151}.members-empty{color:#6b7280;font-size:.9rem;margin-top:1.5rem}.tabs{display:flex;gap:0;border-bottom:2px solid #e5e7eb;margin-bottom:1.5rem}.tab{background:none;border:none;padding:.625rem 1.25rem;font-size:.9rem;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;display:flex;align-items:center;gap:.5rem}.tab:hover{color:#111}.tab--active{color:#2563eb;border-bottom-color:#2563eb}.tab-badge{background:#e5e7eb;color:#374151;font-size:.75rem;font-weight:600;padding:.125rem .5rem;border-radius:999px}.tab--active .tab-badge{background:#dbeafe;color:#1d4ed8}.tab-badge--warning{background:#fef3c7;color:#92400e}.tab--active .tab-badge--warning{background:#fde68a;color:#78350f}.mode-badge{display:inline-block;font-size:.72rem;font-weight:600;padding:.2rem .5rem;border-radius:999px;text-transform:uppercase;letter-spacing:.04em;background:#e5e7eb;color:#374151}.mode-badge--payment_failed{background:#fee2e2;color:#b91c1c}.mode-badge--payment_completed{background:#dcfce7;color:#15803d}.row--expired td{color:#9ca3af}.members-table{width:100%;border-collapse:collapse;font-size:.9rem;margin-top:1.5rem}.members-table th,.members-table td{text-align:left;padding:.625rem .75rem;border-bottom:1px solid #e5e7eb}.members-table th{font-weight:600;color:#6b7280;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;background:#f9fafb}.members-table tbody tr:hover{background:#f3f4f6}.periods-table{width:100%;border-collapse:collapse;font-size:.82rem}.periods-table th,.periods-table td{text-align:left;padding:.4rem .6rem;border-bottom:1px solid #e5e7eb}.periods-table th{font-weight:600;color:#6b7280;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;background:#f9fafb}.detail-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#6b7280;padding:.25rem;border-radius:4px}.detail-btn:hover{color:#2563eb;background:#eff6ff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#fff;border-radius:10px;width:min(640px,calc(100vw - 2rem));max-height:calc(100vh - 4rem);display:flex;flex-direction:column;box-shadow:0 20px 60px #0003}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e5e7eb;flex-shrink:0}.modal-header h2{font-size:1rem;font-weight:600}.modal-close{background:none;border:none;font-size:1rem;cursor:pointer;color:#6b7280;line-height:1;padding:.25rem;border-radius:4px}.modal-close:hover{color:#111;background:#f3f4f6}.modal-loading{padding:2rem 1.5rem;color:#6b7280}.modal-body{overflow-y:auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem}.modal-body section h3{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin-bottom:.5rem}.modal-body dl{display:grid;grid-template-columns:10rem 1fr;gap:.25rem 1rem;font-size:.875rem}.modal-body dt{color:#6b7280;font-weight:500}.modal-body dd{color:#111;word-break:break-all}.resume-link-applicant{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px}.resume-link-applicant-info{display:flex;flex-direction:column;gap:.2rem}.resume-link-applicant-name{font-size:.9rem;font-weight:600;color:#1e3a5f}.resume-link-applicant-email{font-size:.8rem;color:#3b82f6}.resume-link-hint{font-size:.875rem;color:#6b7280;margin-bottom:.75rem;line-height:1.5}.resume-link-box{display:flex;align-items:center;gap:.5rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:.625rem .75rem}.resume-link-url{flex:1;font-family:ui-monospace,monospace;font-size:.8rem;color:#374151;word-break:break-all;line-height:1.4}.resume-link-copy{flex-shrink:0;padding:.375rem .875rem;font-size:.8rem;font-weight:500;border:none;border-radius:6px;cursor:pointer;background:#2563eb;color:#fff;transition:background .15s}.resume-link-copy:hover{background:#1d4ed8}.resume-link-copy:active{background:#1e40af}.resume-link-mailto{flex-shrink:0;display:inline-block;padding:.375rem .875rem;font-size:.8rem;font-weight:500;color:#1d4ed8;background:#dbeafe;border:1px solid #bfdbfe;border-radius:6px;text-decoration:none;transition:background .15s}.resume-link-mailto:hover{background:#bfdbfe}.confirmation-page{display:flex;justify-content:center;align-items:flex-start;padding-top:4rem}.confirmation-card{background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;padding:2.5rem 2rem;text-align:center;width:min(440px,100%);display:flex;flex-direction:column;align-items:center;gap:.75rem}.confirmation-check{width:3rem;height:3rem;border-radius:50%;background:#dcfce7;color:#16a34a;font-size:1.5rem;display:flex;align-items:center;justify-content:center;margin-bottom:.25rem}.confirmation-check--error{background:#fee2e2;color:#dc2626}.confirmation-card h1{font-size:1.375rem;font-weight:700;color:#111}.confirmation-name{font-size:1.125rem;font-weight:600;color:#2563eb}.confirmation-subtitle{font-size:.9rem;color:#6b7280;margin-bottom:.5rem}.confirmation-card .membership-card-wrap{margin:.75rem 0}.confirmation-link{font-size:.875rem;color:#6b7280;text-decoration:none;margin-top:.25rem}.confirmation-link:hover{color:#111}.ko-actions{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:.5rem;width:100%}.ko-btn-primary{display:inline-block;padding:.625rem 2rem;background:#2563eb;color:#fff;border-radius:6px;text-decoration:none;font-weight:600;font-size:.95rem}.ko-btn-primary:hover{background:#1d4ed8}.ko-contact{font-size:.85rem;color:#6b7280}.ko-contact a{color:#2563eb;text-decoration:none}.ko-contact a:hover{text-decoration:underline}.ctx-menu{position:relative;display:inline-block}.ctx-trigger{background:none;border:none;cursor:pointer;font-size:1.1rem;color:#6b7280;padding:.125rem .375rem;border-radius:4px;line-height:1}.ctx-trigger:hover{background:#f3f4f6;color:#111}.ctx-dropdown{position:absolute;right:0;top:calc(100% + 4px);background:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 4px 12px #0000001a;min-width:160px;z-index:50;list-style:none;padding:.25rem 0}.ctx-item{display:block;width:100%;text-align:left;background:none;border:none;padding:.5rem .875rem;font-size:.875rem;color:#111;cursor:pointer}.ctx-item:hover{background:#f3f4f6}.ctx-item--danger{color:#dc2626}.ctx-item--danger:hover{background:#fef2f2}.resume-fields{width:100%;display:flex;flex-direction:column;gap:0;margin-bottom:1.5rem;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.resume-field{display:flex;justify-content:space-between;padding:.625rem .875rem;font-size:.9rem;border-bottom:1px solid #e5e7eb}.resume-field:last-child{border-bottom:none}.resume-field__label{color:#6b7280;font-weight:500}.resume-field__value{color:#111}.resume-pay-btn{width:100%;padding:.75rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer}.resume-pay-btn:hover:not(:disabled){background:#1d4ed8}.resume-pay-btn:disabled{opacity:.6;cursor:not-allowed}.renew-unemployment-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#374151;margin:1.25rem 0 .75rem;cursor:pointer}.renew-amount{font-size:.95rem;color:#374151;margin-bottom:1.25rem}.card-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#e8edf5;padding:2rem}.membership-card-wrap{display:flex;flex-direction:column;gap:12px}.membership-card{position:relative;width:340px;aspect-ratio:86 / 54;border-radius:10px;overflow:hidden;box-shadow:0 8px 32px #00000040;background-image:url(/card-front.png);background-size:cover;background-position:center;color:#fff;font-family:system-ui,-apple-system,sans-serif;text-align:left}.membership-card__name{position:absolute;top:9px;left:27px;right:5%;font-size:1.15rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.membership-card__val{position:absolute;right:23px;font-size:.72rem;font-weight:600}.membership-card__val--number{top:61px}.membership-card__val--nif{top:93px}.membership-card__val--exp{top:128px}.membership-card--back{background-image:url(/card-back.png)}.membership-card__qr{position:absolute;left:10px;top:88px}.card-link-modal-preview{margin-top:1rem;display:flex;justify-content:center}.card-validation{display:flex;flex-direction:column;align-items:center;gap:.5rem}.card-validation__badge{font-size:1.1rem;font-weight:700;padding:.5rem 1.5rem;border-radius:999px}.card-validation__badge--valid{background:#dcfce7;color:#15803d}.card-validation__badge--expired{background:#fee2e2;color:#dc2626}.card-validation__expiry{font-size:.85rem;color:#6b7280;margin-bottom:.5rem}.card-error,.card-loading{color:#6b7280;font-size:.95rem}.app-header{display:flex;justify-content:flex-end;padding:.5rem 1.5rem;border-bottom:1px solid #e5e7eb;background:#fff;position:sticky;top:0;z-index:100}.lang-picker{display:flex;gap:.25rem}.lang-btn{background:none;border:1px solid #d1d5db;border-radius:4px;padding:.2rem .5rem;font-size:.75rem;font-weight:600;color:#6b7280;cursor:pointer;letter-spacing:.05em}.lang-btn:hover{border-color:#9ca3af;color:#374151}.lang-btn--active{background:#1d4ed8;border-color:#1d4ed8;color:#fff}.payment-method-radios{margin-top:.75rem}.payment-method-label{font-size:.875rem;color:#374151;margin-bottom:.5rem}.payment-method-option{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;font-size:.9rem;cursor:pointer}.payment-method-option input[type=radio]{accent-color:#1d4ed8}.payment-section-note{font-size:.875rem;color:#6b7280;margin-top:.75rem}.file-upload-field{margin-top:.75rem}.file-upload-label{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;color:#374151;cursor:pointer}.file-upload-label input[type=file]{font-size:.875rem;color:#374151}.file-upload-status{display:block;font-size:.8rem;margin-top:.25rem;color:#6b7280}.file-upload-status--ok{color:#15803d}.file-upload-status--error{color:#dc2626}.signup-success{background:#fff;border-radius:8px;padding:2rem;margin-top:2rem;box-shadow:0 1px 3px #00000014;font-size:1rem;color:#374151;line-height:1.6}.payment-choose-form{background:#fff;border-radius:8px;padding:1.5rem;margin-top:1.5rem;box-shadow:0 1px 3px #00000014}
