/*
 * HelpCounter — Volunteer Application Stylesheet
 * Used by: /apply  (public-facing volunteer application form)
 *
 * Design principles:
 *   - Mobile-first: base styles for phones, breakpoints add tablet/desktop layout
 *   - 16px minimum input font — prevents iOS from zooming on input focus
 *   - Generous form spacing — reduces errors and intimidation on long forms
 *   - Progress indicator at the top — gives applicants a sense of where they are
 *   - Accessible: every input has an associated <label>, errors are descriptive,
 *     required fields are marked, and color is never the sole error indicator
 *   - No authentication — this form is public-facing
 *
 * Breakpoints:
 *   sm: 36em  (576px)
 *   md: 48em  (768px)
 *   lg: 64em  (1024px)
 *
 * Color contrast ratios:
 *   --color-text    #1f2937 on white  12.6:1  AAA
 *   --color-muted   #4b5563 on white   7.0:1  AAA
 *   --color-primary #1d4ed8 on white   6.1:1  AA
 *   progress text   white on #1d4ed8   6.1:1  AA
 *   error text      #b91c1c on #fef2f2 5.6:1  AA
 *   required mark   #b91c1c on white   5.2:1  AA  (large enough at 1em)
 */

/* ── Custom properties ─────────────────────────────────────────────────── */

:root {
    /* Brand */
    --color-primary:        #1d4ed8;   /* blue-700 */
    --color-primary-dark:   #1e40af;   /* blue-800 */
    --color-primary-light:  #eff6ff;   /* blue-50  */

    /* Semantic */
    --color-success:        #15803d;
    --color-success-bg:     #f0fdf4;
    --color-success-border: #86efac;

    --color-error:          #b91c1c;
    --color-error-bg:       #fef2f2;
    --color-error-border:   #fca5a5;

    --color-info:           #0369a1;   /* sky-700 — 5.9:1 on white */
    --color-info-bg:        #f0f9ff;
    --color-info-border:    #bae6fd;

    /* Neutrals */
    --color-text:           #1f2937;
    --color-muted:          #4b5563;
    --color-subtle:         #6b7280;
    --color-border:         #d1d5db;   /* slightly darker for form usability */
    --color-border-light:   #e5e7eb;
    --color-bg:             #f9fafb;
    --color-white:          #ffffff;

    /* Typography */
    --font-sans:      system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --font-size-base: 1rem;           /* 16px */
    --line-height:    1.65;

    /* Spacing */
    --sp-1:  0.25rem;
    --sp-2:  0.5rem;
    --sp-3:  0.75rem;
    --sp-4:  1rem;
    --sp-5:  1.25rem;
    --sp-6:  1.5rem;
    --sp-8:  2rem;
    --sp-10: 2.5rem;
    --sp-12: 3rem;

    /* Shape */
    --radius:    6px;
    --radius-lg: 10px;

    /* Shadow */
    --shadow-sm: 0 1px 3px rgb(0 0 0 / 0.08);
    --shadow:    0 2px 8px rgb(0 0 0 / 0.10);

    /* Touch */
    --touch-min: 44px;

    /* Progress */
    --progress-height: 6px;

    /* Content */
    --content-width: 40rem;
    --content-width-wide: 52rem;
}


/* ── Reset ─────────────────────────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }

body {
    margin: 0;
    background: var(--color-bg);
    color: var(--color-text);
    font-family: var(--font-sans);
    font-size: var(--font-size-base);
    line-height: var(--line-height);
}

img { display: block; max-width: 100%; }
a { color: var(--color-primary); }
a:hover { color: var(--color-primary-dark); }
h1, h2, h3 { line-height: 1.3; }


/* ── Accessibility ─────────────────────────────────────────────────────── */

.skip-link {
    position: absolute;
    top: -100%;
    left: 0;
    z-index: 9999;
    padding: var(--sp-3) var(--sp-5);
    background: var(--color-primary);
    color: var(--color-white);
    font-size: 0.9375rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: 0 0 var(--radius) 0;
}
.skip-link:focus { top: 0; }

:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}
:focus:not(:focus-visible) { outline: none; }

main:focus { outline: none; }

/* Required field marker — announced by screen readers via aria-required,
   this is a visual supplement only */
.required-mark {
    color: var(--color-error);
    font-weight: 700;
    margin-left: var(--sp-1);
    aria-hidden: true;
}


/* ── Application header ────────────────────────────────────────────────── */

.app-header {
    background: var(--color-white);
    border-bottom: 1px solid var(--color-border-light);
    padding: var(--sp-4) var(--sp-4);
}

.app-header-inner {
    max-width: var(--content-width-wide);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-4);
}

.app-header-brand {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text);
    text-decoration: none;
}
.app-header-brand:hover { color: var(--color-primary); }

.app-header-district {
    font-size: 0.875rem;
    color: var(--color-muted);
    text-align: right;
}

@media (min-width: 36em) {
    .app-header { padding: var(--sp-4) var(--sp-6); }
}


/* ── Progress bar ──────────────────────────────────────────────────────── */
/*
 * The progress bar sits directly below the header.
 * Use role="progressbar", aria-valuenow, aria-valuemin, aria-valuemax,
 * and aria-label on the container for screen reader support.
 */

.progress-bar-wrap {
    background: var(--color-border-light);
    height: var(--progress-height);
}
.progress-bar-fill {
    height: 100%;
    background: var(--color-primary);
    transition: width 0.3s ease;
    border-radius: 0 3px 3px 0;
}

/* Step indicator row — shown below the progress bar */
.step-indicator {
    display: flex;
    justify-content: center;
    gap: var(--sp-2);
    padding: var(--sp-3) var(--sp-4);
    background: var(--color-white);
    border-bottom: 1px solid var(--color-border-light);
    flex-wrap: wrap;
}

.step-indicator-item {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    font-size: 0.8125rem;
    color: var(--color-subtle);
    white-space: nowrap;
}
.step-indicator-item--active {
    color: var(--color-primary);
    font-weight: 600;
}
.step-indicator-item--complete {
    color: var(--color-success);
}

.step-dot {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: currentColor;
    flex-shrink: 0;
}


/* ── Main content ──────────────────────────────────────────────────────── */

.app-main {
    max-width: var(--content-width);
    margin: 0 auto;
    padding: var(--sp-6) var(--sp-4);
}

@media (min-width: 48em) {
    .app-main { padding: var(--sp-8) var(--sp-6); }
}


/* ── Section headings within the form ─────────────────────────────────── */

.form-section {
    margin-bottom: var(--sp-8);
}
.form-section + .form-section {
    padding-top: var(--sp-8);
    border-top: 1px solid var(--color-border-light);
}

.form-section-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 var(--sp-2);
}
.form-section-desc {
    font-size: 0.9375rem;
    color: var(--color-muted);
    margin: 0 0 var(--sp-6);
    line-height: 1.6;
}


/* ── Flash / info messages ─────────────────────────────────────────────── */

.flash {
    padding: var(--sp-4);
    margin-bottom: var(--sp-5);
    border: 1px solid transparent;
    border-radius: var(--radius);
    font-size: 0.9375rem;
    line-height: 1.6;
}
.flash p     { margin: 0; }
.flash p + p { margin-top: var(--sp-2); }
.flash ul    { margin: var(--sp-2) 0 0; padding-left: var(--sp-5); }
.flash li    { margin-bottom: var(--sp-1); }

.flash--info {
    background: var(--color-info-bg);
    border-color: var(--color-info-border);
    color: var(--color-info);
}
.flash--success {
    background: var(--color-success-bg);
    border-color: var(--color-success-border);
    color: var(--color-success);
}
.flash--error {
    background: var(--color-error-bg);
    border-color: var(--color-error-border);
    color: var(--color-error);
}


/* ── Forms ─────────────────────────────────────────────────────────────── */

.form-group { margin-bottom: var(--sp-5); }

/* Two-column grid on tablets+ */
.form-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
}
@media (min-width: 36em) {
    .form-row--2col {
        grid-template-columns: 1fr 1fr;
        gap: 0 var(--sp-4);
    }
    .form-row--3col {
        grid-template-columns: 1fr 1fr 1fr;
        gap: 0 var(--sp-4);
    }
}

/* <label> — always explicitly associated with its input via for/id */
.form-label {
    display: block;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--sp-2);
    line-height: 1.3;
}
.form-label-hint {
    display: block;
    font-weight: 400;
    font-size: 0.875rem;
    color: var(--color-muted);
    margin-top: var(--sp-1);
}

/* 16px font on inputs prevents iOS auto-zoom */
.form-input,
.form-select,
.form-textarea {
    display: block;
    width: 100%;
    min-height: var(--touch-min);
    padding: var(--sp-3) var(--sp-4);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-white);
    color: var(--color-text);
    font: inherit;
    font-size: 1rem;    /* 16px */
    line-height: 1.5;
    appearance: none;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgb(29 78 216 / 0.15);
    outline: none;
}

/* Error state — border color AND descriptive text, never color alone */
.form-input.is-invalid,
.form-select.is-invalid,
.form-textarea.is-invalid {
    border-color: var(--color-error);
}

.form-textarea {
    min-height: 7rem;
    resize: vertical;
}

.form-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%234b5563'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--sp-3) center;
    background-size: 1.125rem;
    padding-right: 2.5rem;
    cursor: pointer;
}

/* Field-level error — linked to input via aria-describedby */
.field-error {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-1);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-error);
    margin-top: var(--sp-2);
    line-height: 1.4;
}
/* Helper text */
.field-hint {
    font-size: 0.875rem;
    color: var(--color-muted);
    margin-top: var(--sp-2);
    line-height: 1.5;
}

/* Checkbox / radio — label wraps both input and text */
.form-check {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-3);
    cursor: pointer;
    line-height: 1.5;
    margin-bottom: var(--sp-3);
}
.form-check input[type="checkbox"],
.form-check input[type="radio"] {
    width: 1.25rem;
    height: 1.25rem;
    flex-shrink: 0;
    margin-top: 0.125rem;
    accent-color: var(--color-primary);
    cursor: pointer;
}
.form-check-label {
    font-size: 0.9375rem;
    color: var(--color-text);
}

/* Group of checkboxes / radios */
.form-check-group {
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
}

/* Error summary at top of page — use role="alert" so screen readers announce it */
.error-summary {
    background: var(--color-error-bg);
    border: 1px solid var(--color-error-border);
    border-radius: var(--radius);
    padding: var(--sp-4);
    margin-bottom: var(--sp-6);
}
.error-summary-title {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--color-error);
    margin: 0 0 var(--sp-2);
}
.error-summary ul {
    margin: 0;
    padding-left: var(--sp-5);
    color: var(--color-error);
    font-size: 0.9375rem;
}
.error-summary li { margin-bottom: var(--sp-1); }

/* Long legal/disclosure text */
.legal-text {
    font-size: 0.875rem;
    color: var(--color-muted);
    line-height: 1.7;
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius);
    padding: var(--sp-4);
    max-height: 12rem;
    overflow-y: auto;
    margin-bottom: var(--sp-4);
}

/* Signature field (for digital signature) */
.signature-field {
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-white);
    padding: var(--sp-4);
    font-size: 1rem;
    color: var(--color-text);
    width: 100%;
    min-height: var(--touch-min);
}


/* ── Buttons ───────────────────────────────────────────────────────────── */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-2);
    min-height: var(--touch-min);
    padding: var(--sp-3) var(--sp-6);
    border: 1px solid transparent;
    border-radius: var(--radius);
    font: inherit;
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: background-color 0.15s, border-color 0.15s;
    white-space: nowrap;
    text-align: center;
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; }

.btn--primary {
    background: var(--color-primary);
    color: var(--color-white);
}
.btn--primary:hover { background: var(--color-primary-dark); color: var(--color-white); }

.btn--secondary {
    background: var(--color-white);
    color: var(--color-text);
    border-color: var(--color-border);
}
.btn--secondary:hover { background: var(--color-bg); }

.btn--full { width: 100%; }

/* Navigation row at the bottom of each form step */
.form-nav {
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    margin-top: var(--sp-8);
    padding-top: var(--sp-6);
    border-top: 1px solid var(--color-border-light);
}
@media (min-width: 36em) {
    .form-nav {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }
}


/* ── Confirmation / thank-you screen ───────────────────────────────────── */

.confirmation-box {
    background: var(--color-white);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: var(--sp-8) var(--sp-6);
    text-align: center;
}
.confirmation-icon {
    font-size: 3.5rem;
    line-height: 1;
    margin-bottom: var(--sp-4);
}
.confirmation-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 var(--sp-3);
}
.confirmation-body {
    font-size: 0.9375rem;
    color: var(--color-muted);
    max-width: 30rem;
    margin: 0 auto;
    line-height: 1.7;
}


/* ── Footer ────────────────────────────────────────────────────────────── */

.app-footer {
    margin-top: var(--sp-12);
    padding: var(--sp-6) var(--sp-4);
    text-align: center;
    font-size: 0.8125rem;
    color: var(--color-subtle);
    border-top: 1px solid var(--color-border-light);
}
.app-footer a { color: var(--color-subtle); }
.app-footer a:hover { color: var(--color-primary); }


/* ── Utility ───────────────────────────────────────────────────────────── */

.sr-only {
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}


/* ── Buttons (additional variants) ────────────────────────────────────── */

.btn--ghost {
    background: transparent;
    color: var(--color-muted);
    border-color: var(--color-border);
}
.btn--ghost:hover {
    background: var(--color-bg);
    color: var(--color-text);
}

.btn--sm {
    min-height: 2rem;
    padding: var(--sp-1) var(--sp-3);
    font-size: 0.875rem;
    font-weight: 500;
}

/* Form action rows — back/continue navigation at the bottom of each step */
.form-actions {
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    margin-top: var(--sp-8);
    padding-top: var(--sp-6);
    border-top: 1px solid var(--color-border-light);
}
@media (min-width: 36em) {
    .form-actions {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }
}

.form-actions-secondary {
    margin-top: var(--sp-3);
}


/* ── Input error state ─────────────────────────────────────────────────── */
/* Applied by the view as .form-input.input--error, etc. */

.form-input.input--error,
.form-select.input--error,
.form-textarea.input--error {
    border-color: var(--color-error);
}

.field-error--block {
    display: block;
    margin-bottom: var(--sp-4);
}


/* ── Fieldset / radio groups ───────────────────────────────────────────── */

.form-fieldset {
    border: none;
    padding: 0;
    margin: 0 0 var(--sp-5) 0;
}

.radio-group {
    display: flex;
    gap: var(--sp-5);
    flex-wrap: wrap;
    margin-top: var(--sp-2);
}

.radio-label {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    font-size: 0.9375rem;
    color: var(--color-text);
    cursor: pointer;
    min-height: var(--touch-min);
}

.radio-label input[type="radio"] {
    width: 1.125rem;
    height: 1.125rem;
    flex-shrink: 0;
    accent-color: var(--color-primary);
    cursor: pointer;
}

/* form-check (checkboxes) input sizing */
.form-check-input {
    width: 1.25rem;
    height: 1.25rem;
    flex-shrink: 0;
    margin-top: 0.125rem;
    accent-color: var(--color-primary);
    cursor: pointer;
}

.form-check-label {
    font-size: 0.9375rem;
    color: var(--color-text);
    line-height: 1.4;
}


/* ── Custom field: yes_no_explain ──────────────────────────────────────── */

.explain-wrap {
    margin-top: var(--sp-3);
}

.form-link {
    word-break: break-all;
}


/* ── Crime disclosure section ──────────────────────────────────────────── */

.crime-disclosure-list {
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
    margin-bottom: var(--sp-5);
}

.crime-disclosure-item {
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius);
    padding: var(--sp-4);
}

.crime-question {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.4;
    margin-bottom: var(--sp-2);
}


/* ── Search page ───────────────────────────────────────────────────────── */

.page-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 var(--sp-4) 0;
    line-height: 1.2;
}

.search-form {
    margin-bottom: var(--sp-6);
}

.search-input-wrap {
    display: flex;
    gap: var(--sp-3);
    align-items: flex-end;
}
.search-input-wrap .form-input {
    flex: 1;
}

.search-no-results {
    color: var(--color-muted);
    font-size: 0.9375rem;
    margin-top: var(--sp-4);
}

.search-prompt {
    margin-top: var(--sp-4);
}

.district-list {
    list-style: none;
    margin: var(--sp-2) 0 0;
    padding: 0;
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius);
    overflow: hidden;
}

.district-list-item + .district-list-item {
    border-top: 1px solid var(--color-border-light);
}

.district-list-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--sp-4) var(--sp-5);
    text-decoration: none;
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--color-text);
    background: var(--color-white);
    transition: background-color 0.1s;
    min-height: var(--touch-min);
}
.district-list-link:hover {
    background: var(--color-primary-light);
    color: var(--color-primary);
}

.district-list-state {
    font-size: 0.875rem;
    font-weight: 400;
    color: var(--color-muted);
}


/* ── School selection (step 3) ─────────────────────────────────────────── */

.school-checklist {
    display: flex;
    flex-direction: column;
    gap: 0;
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius);
    overflow: hidden;
    margin-top: var(--sp-4);
}

.school-check {
    background: var(--color-white);
    padding: var(--sp-4) var(--sp-5);
    margin: 0;
    border-bottom: 1px solid var(--color-border-light);
    min-height: var(--touch-min);
}
.school-check:last-child { border-bottom: none; }
.school-check:hover { background: var(--color-primary-light); }

.school-city {
    font-size: 0.875rem;
    color: var(--color-muted);
    font-weight: 400;
}


/* ── Activity selection (step 4) ───────────────────────────────────────── */

.school-activity-section {
    margin-bottom: var(--sp-6);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius);
    overflow: hidden;
}

.school-activity-heading {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-white);
    background: var(--color-primary);
    margin: 0;
    padding: var(--sp-3) var(--sp-5);
}

.school-activity-section .form-fieldset {
    margin: 0;
    padding: var(--sp-2) 0;
}

.activity-check {
    padding: var(--sp-3) var(--sp-5);
    margin: 0;
    background: var(--color-white);
    border-bottom: 1px solid var(--color-border-light);
    min-height: var(--touch-min);
}
.activity-check:last-child { border-bottom: none; }
.activity-check:hover { background: var(--color-primary-light); }

.no-activities {
    padding: var(--sp-4) var(--sp-5);
    margin: 0;
}

.activity-description {
    display: block;
    font-size: 0.875rem;
    color: var(--color-muted);
    margin-top: var(--sp-1);
    font-weight: 400;
}


/* ── Student rows (step 2) ─────────────────────────────────────────────── */

.student-row {
    padding: var(--sp-4);
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius);
    margin-bottom: var(--sp-4);
}


/* ── Signature field ───────────────────────────────────────────────────── */

.signature-input {
    font-style: italic;
    font-size: 1.125rem;
    letter-spacing: 0.02em;
}


/* ── Intro text (district-specific application intro) ──────────────────── */

.intro-text {
    margin-bottom: var(--sp-6);
    max-height: 16rem;
}


/* ── Confirmation / thank-you screen (additional) ──────────────────────── */

.confirmation-name {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 var(--sp-4);
}

.confirmation-message {
    font-size: 0.9375rem;
    color: var(--color-muted);
    max-width: 30rem;
    margin: 0 auto var(--sp-4);
    line-height: 1.7;
}

/* confirmation icon green tint */
.confirmation-box .confirmation-icon {
    color: var(--color-success);
}


/* ── Language switcher ──────────────────────────────────────────────────── */
/*
 * Sits in the app-header-inner flex row.
 * Two compact EN / ES links. The active locale is highlighted.
 */

.lang-switcher {
    display: flex;
    gap: var(--sp-1);
    margin-left: auto;   /* push to the far right after the district name */
    flex-shrink: 0;
}

.lang-btn {
    display: inline-flex;
    align-items: center;
    padding: var(--sp-1) var(--sp-3);
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--color-muted);
    text-decoration: none;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    letter-spacing: 0.03em;
    transition: background-color 0.1s, color 0.1s;
    min-height: 32px;    /* meets AA touch target when paired with adequate spacing */
}
.lang-btn:hover {
    background: var(--color-primary-light);
    color: var(--color-primary);
    border-color: var(--color-primary);
}
.lang-btn--active {
    background: var(--color-primary);
    color: var(--color-white);
    border-color: var(--color-primary);
    cursor: default;
    pointer-events: none;
}

/* ── Applicant type selection cards ────────────────────────────────────── */

.applicant-type-radio {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

.applicant-type-card {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-3);
    padding: var(--sp-4);
    border: 2px solid var(--color-border);
    border-radius: var(--radius);
    cursor: pointer;
    transition: border-color 0.15s, background-color 0.15s;
}

.applicant-type-card:hover {
    border-color: var(--color-primary);
    background-color: var(--color-primary-light, #eff6ff);
}

.applicant-type-radio:checked + .applicant-type-card__body {
    /* handled via JS — sibling selector not available for hidden radio */
}

.applicant-type-card:has(.applicant-type-radio:checked) {
    border-color: var(--color-primary);
    background-color: var(--color-primary-light, #eff6ff);
}

.applicant-type-card__body {
    display: flex;
    flex-direction: column;
    gap: var(--sp-1);
}

.applicant-type-card__label {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text);
}

.applicant-type-card__desc {
    font-size: 0.875rem;
    color: var(--color-muted);
}
