.form-control-custom { /* O il nome classe che hai usato */
    background: #ffffff;
    width: 100%;
    padding: 0.875rem;
    border: 2px solid #e5e7eb;
    border-radius: 0.75rem;
    font-size: 1rem;
    transition: all 0.2s ease;
    font-family: inherit;
    line-height: 1.5;
    resize: vertical;
}

.form-control-custom:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 4px var(--input-focus);
    outline: none;
}

/* Colori Primari Lions (da definire anche in variables.css se non già presenti) */
:root {
    --lions-blue: #00338D;
    --lions-gold: #FDB714;
    --lions-blue-light-gradient: #0053a0;
    --lions-gold-light-gradient: #ffe082;
    --lions-blue-darker: #00225e;
    --lions-gold-darker: #e0a010;

    --text-color-on-blue: #FFFFFF;
    --text-color-on-gold: var(--lions-blue);
    --page-bg: #f4f6f9;
    --card-bg: #FFFFFF;
    --text-color-dark: #2c3e50;
    --text-color-medium: #566573;
    --text-color-muted: #7f8c8d;

    /* RGB per ombre colorate, se usate */
    --rgb-lions-blue: 0, 51, 141;
    --rgb-lions-gold: 253, 183, 20;
}

/* Hero Section (più contenuta) */
.hero-section-enrollment {
    background: linear-gradient(135deg, var(--lions-blue-light-gradient) 0%, var(--lions-blue) 100%);
    color: var(--text-color-on-blue);
    padding: 2rem 1rem; /* Padding ridotto */
    text-align: center;
}
.hero-section-enrollment .lions-logo-hero {
    max-height: 50px; /* Logo leggermente più piccolo */
    margin-bottom: 0.75rem;
}
.hero-section-enrollment h1 {
    font-size: 2rem; /* Titolo ridotto */
    font-weight: 700;
    margin-bottom: 0.3rem;
}
.hero-section-enrollment p {
    font-size: 1rem; /* Sottotitolo ridotto */
    max-width: 650px;
    margin-left: auto;
    margin-right: auto;
    opacity: 0.9;
}

/* Login Section (Prominente) */
.login-section-wrapper {
    padding: 2rem 1rem;
    background-color: var(--page-bg); /* Sfondo pagina per staccare dalla hero */
    display: flex;
    justify-content: center;
    align-items: center;
}
.login-box-enrollment { /* Classe specifica per non confliggere con login.css se importato globalmente */
    background: var(--card-bg);
    padding: 2rem;
    border-radius: 0.75rem;
    box-shadow: none; /* RIMOSSA Ombra marcata */
    width: 100%;
    max-width: 450px; /* Larghezza tipica per un box di login */
    text-align: left; /* Allineamento testo a sinistra dentro il box */
}
.login-box-enrollment .login-header-text { /* Per il titolo "Accedi al tuo Account" */
    text-align: center;
    font-size: 1.6rem;
    font-weight: 600;
    color: var(--lions-blue);
    margin-bottom: 1.25rem;
}
.login-box-enrollment .form-group {
    margin-bottom: 1rem;
}
.login-box-enrollment .form-group label {
    display: block;
    font-weight: 500;
    margin-bottom: 0.25rem;
    color: var(--text-color-dark);
    font-size: 0.8rem;
}
.login-box-enrollment .form-group input[type="text"],
.login-box-enrollment .form-group input[type="password"] {
    display: block;
    width: 100%;
    padding: 0.6rem 0.9rem;
    font-size: 0.9rem;
    border: 1px solid #ced4da;
    border-radius: 0.4rem;
    transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}
.login-box-enrollment .form-group input:focus {
    border-color: var(--lions-gold);
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(var(--rgb-lions-gold, 253,183,20), 0.25);
}
.login-box-enrollment .btn-login-main {
    width: 100%;
    padding: 0.75rem;
    font-size: 1rem;
    font-weight: 600;
    background-color: var(--lions-gold) !important;
    border-color: var(--lions-gold) !important;
    color: var(--text-color-on-gold) !important;
    border-radius: 0.4rem;
    text-transform: uppercase;
}
.login-box-enrollment .login-footer-links {
    text-align: center;
    margin-top: 1.25rem;
    font-size: 0.8rem;
}
.login-box-enrollment .login-footer-links a {
    color: var(--lions-blue);
    text-decoration: none;
}
.login-box-enrollment .login-footer-links a:hover {
    text-decoration: underline;
}
/* Stile per gli errori del form di login, se necessario qui */
.login-box-enrollment .alert-danger { /* Assumendo che il form di Django usi queste classi */
    background-color: #f8d7da;
    border-color: #f5c6cb;
    color: #721c24;
    padding: 0.6rem 1rem;
    margin-bottom: 0.8rem;
    border: 1px solid transparent;
    border-radius: 0.2rem;
    font-size: 0.8rem;
}


/* Sezione Scelta Iscrizione (Più Leggera) */
.enrollment-choice-section {
    padding: 2rem 1rem; /* Padding ridotto */
    background-color: var(--page-bg); /* Sfondo pagina */
    border-top: 1px solid #e0e0e0; /* Separatore */
}
.enrollment-choice-section .section-title {
    text-align: center;
    font-size: 1.6rem; /* Titolo ridotto */
    font-weight: 600;
    color: var(--text-color-dark);
    margin-bottom: 1.5rem;
}
.enrollment-card-secondary { /* Classe per le card di iscrizione, ora secondarie */
    background-color: var(--card-bg);
    border: 1px solid #e0e0e0;
    border-radius: 0.6rem;
    padding: 1.2rem; /* Padding ridotto */
    text-align: center;
    box-shadow: none; /* RIMOSSA Ombra più leggera */
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.enrollment-card-secondary:hover {
    transform: translateY(-2px); /* Meno spostamento all'hover */
    /* box-shadow: 0 6px 20px -7px rgba(0, 51, 141, 0.15);  RIMOSSA */
}
.enrollment-card-secondary .card-icon {
    font-size: 2rem; /* Icone ridotte */
    margin-bottom: 0.8rem;
}
/* Colori icone come prima */
.enrollment-card-secondary.club-card .card-icon { color: var(--lions-blue); }
.enrollment-card-secondary.member-card .card-icon { color: var(--lions-gold); }

.enrollment-card-secondary .card-title {
    font-size: 1.1rem; /* Titolo card ridotto */
    font-weight: 600;
    color: var(--text-color-dark);
    margin-bottom: 0.6rem;
}
.enrollment-card-secondary .card-text {
    color: var(--text-color-medium);
    font-size: 0.8rem; /* Testo ridotto */
    margin-bottom: 1rem;
    flex-grow: 1;
}
.enrollment-card-secondary .btn-enroll-secondary {
    padding: 0.55rem 1.1rem; /* Bottone ridotto */
    font-weight: 500;
    border-radius: 0.4rem;
    width: 100%;
    max-width: 200px;
    margin-left: auto;
    margin-right: auto;
    font-size: 0.8rem;
}
/* Colori bottoni come prima, ma applichiamo alla nuova classe */
.enrollment-card-secondary.club-card .btn-enroll-secondary {
    background: linear-gradient(90deg, var(--lions-blue) 0%, var(--lions-blue-light-gradient) 100%) !important;
    border: none !important;
    color: var(--text-color-on-blue) !important;
}
.enrollment-card-secondary.member-card .btn-enroll-secondary {
    background: linear-gradient(90deg, var(--lions-gold) 0%, var(--lions-gold-light-gradient) 100%) !important;
    border: none !important;
    color: var(--text-color-on-gold) !important;
}

.assistants-preview-section {
    padding-top: 2rem;
    padding-bottom: 2rem;
    background-color: var(--card-bg);
    font-weight: 600;
    color: var(--text-color-dark);
}

.assistants-preview-section .section-title {
    font-size: 1.6rem;
    margin-bottom: 1.5rem;
    text-align: center;
}

.assistant-preview-card {
    text-align: center;
    padding: 1rem;
}

.assistant-preview-card .card-icon {
    font-size: 1.6rem;
    margin-bottom: 0.5rem;
}

.assistant-preview-card .card-title {
    font-size: 1rem;
    margin-bottom: 0.3rem;
    font-weight: 600; /* Assicurati che il grassetto sia applicato */
}

.assistant-preview-card .card-text {
    font-size: 0.75rem;
    color: var(--text-color-medium);
}

.enrollment-footer {
    background-color: var(--lions-blue);
    padding: 0.5rem 1rem; /* Ridotto padding */
    color: var(--text-color-on-blue);
    text-align: center;
    font-size: 0.7rem; /* Ridotto font */
    height: auto; /* Rimosso height fisso */
    min-height: 60px; /* Imposta un'altezza minima */
    display: flex;
    flex-direction: column;
    justify-content: center; /* Allinea verticalmente */
}
.enrollment-footer .container {
    max-width: 1200px;
    margin: 0 auto;
}
.enrollment-footer p {
    margin: 0.2rem 0; /* Ridotto margine */
}
.enrollment-footer a {
    color: var(--text-color-on-blue);
    text-decoration: none;
}
.enrollment-footer a:hover {
    text-decoration: underline;
}
.enrollment-footer .footer-logo {
    margin-top: 0.3rem; /* Aggiunto margine superiore */
}
.enrollment-footer .footer-logo img {
    max-height: 30px; /* Ridotto logo */
    vertical-align: middle; /* Allinea verticalmente */
}

.form-check {
    display: flex;
    align-items: flex-start; /* Allinea verticalmente all'inizio (top) */
    margin-bottom: 0.5rem;
    padding-left: 0;
}

.form-check input[type="checkbox"] {
    margin-right: 0.5rem;
    margin-top: 0.25rem; /* Un piccolo margine superiore per allineare al testo */
}

.form-check-label {
    margin-bottom: 0;
    word-break: break-word; /* Forza l'interruzione delle parole se la label è troppo lunga */
    font-size: 0.9rem;
}

.alert-error {
    color: #842029;       /* Rosso scuro per il testo (Bootstrap 5) */
    background-color: #f8d7da; /* Rosso chiaro per lo sfondo (Bootstrap 5) */
    border-color: #f5c6cb;  /* Rosso tenue per il bordo (Bootstrap 5) */
}

.alert-error a {
    color: #842029;      /* Rosso scuro per i link (Bootstrap 5) */
}

/* MEDIA QUERIES (RESPONSIVE DESIGN) */
@media (max-width: 768px) {
    /* Hero Section */
    .hero-section-enrollment {
        padding: 1.5rem 0.5rem;
    }
    .hero-section-enrollment .lions-logo-hero {
        max-height: 40px;
    }
    .hero-section-enrollment h1 {
        font-size: 1.7rem;
    }
    .hero-section-enrollment p {
        font-size: 0.9rem;
    }

    /* Login Section */
    .login-box-enrollment {
        padding: 1.5rem;
    }
    .login-box-enrollment .login-header-text {
        font-size: 1.4rem;
    }
    .login-box-enrollment .form-group label {
        font-size: 0.75rem;
    }
    .login-box-enrollment .form-group input[type="text"],
    .login-box-enrollment .form-group input[type="password"] {
        padding: 0.5rem 0.8rem;
        font-size: 0.8rem;
    }
    .login-box-enrollment .btn-login-main {
        font-size: 0.9rem;
    }

    /* Enrollment Choice Section */
    .enrollment-choice-section {
        padding: 1.5rem 0.5rem;
    }
    .enrollment-choice-section .section-title {
        font-size: 1.4rem;
    }
    .enrollment-card-secondary {
        padding: 1rem;
    }
    .enrollment-card-secondary .card-icon {
        font-size: 1.8rem;
    }
    .enrollment-card-secondary .card-title {
        font-size: 1rem;
    }
    .enrollment-card-secondary .card-text {
        font-size: 0.75rem;
    }
    .enrollment-card-secondary .btn-enroll-secondary {
        font-size: 0.75rem;
    }

    /* Assistant Preview Section */
    .assistants-preview-section {
        padding-top: 1.5rem;
        padding-bottom: 1.5rem;
    }
    .assistants-preview-section .section-title {
        font-size: 1.4rem;
    }

    /* Impila le card di iscrizione e assistenti su schermi piccoli */
    .row.gy-4 {
        flex-direction: column;
    }
    .col-lg-5, .col-md-6, .col-lg-3, .col-md-6 {
        width: 100%;
        max-width: 100%;
    }

    /* Footer */
    .enrollment-footer {
        font-size: 0.6rem;
        min-height: 50px;
    }
    .enrollment-footer .footer-logo img {
        max-height: 25px;
    }
}

/* Schermi ancora più piccoli (telefoni) */
@media (max-width: 480px) {
    .hero-section-enrollment h1 {
        font-size: 1.5rem;
    }
    .login-box-enrollment {
        padding: 1rem;
    }
    .enrollment-choice-section .section-title {
        font-size: 1.3rem;
    }
}