﻿/* Importazione dei font locali */
@font-face {
    font-family: 'Roboto';
    src: url('/fonts/roboto/Roboto-Regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: 'Roboto';
    src: url('/fonts/roboto/Roboto-Bold.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
}

@font-face {
    font-family: 'BebasNeue';
    src: url('/fonts/BebasNeue-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'IBMPlexSansCondensed';
    src: url('/fonts/IBMPlexSansCondensed/IBMPlexSansCondensed-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Oswald';
    src: url('/fonts/Oswald/Oswald-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

/* Definizione delle variabili globali */
:root {
    /* Palette principale */
    --color-primary: #0E2547; /* Blu Navy (cornici, header, navbar) */
    --color-accent: #ffc107; /* Arancio bruciato (pulsanti standard, highlight) */
    --color-bg: #F4F5F7; /* Grigio chiaro (sfondo della pagina) */
    --color-text: #212529; /* Nero profondo (testo principale) */
    --color-text-light: #FFFFFF; /* Bianco puro (testo su sfondi scuri) */
    --color-border: #D1D1D1; /* Grigio medio (bordi sottili) */
    --color-secondary: #E1E5EA;
    --color-light: #f2f2f2;
    /* Pulsanti speciali */
    --color-action: #F39C12; /* Ambra (azioni importanti) */
    --color-danger: #C0392B; /* Rosso scuro (cancellazione, reset) */
    /* Font */
    --font-primary: 'Roboto', sans-serif;
    --off-white: #e6e6e6; /* Un bianco leggermente sporco */
    --font-title: 'Oswald', serif;
    --font-card-compilative: 'Oswald', serif;
    --font-button: 'Oswald', serif;
    --color-highlight: #2ECC71;
}

.hidden-section {
    display: none;
}

.font-title {
    font-family: var(--font-title);
}

.font-body {
    font-family: var(--font-card-compilative);
}

.navbar {
    z-index: 1030 !important;
}

.modal {
    z-index: 1055 !important;
}

.modal-backdrop {
    z-index: 1045 !important;
}



/* 🌟 Stile globale per SweetAlert2 con la tua palette */
.swal2-popup {
    border-radius: 12px !important;
    box-shadow: 0px 4px 20px rgba(14, 37, 71, 0.3) !important;
    background-color: var(--color-primary) !important;
    color: var(--color-text-light) !important;
    font-family: var(--font-primary) !important;
}

/* Titolo del modale */
.swal2-title {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--color-text-light) !important;
    text-transform: uppercase;
}

/* Testo del modale */
.swal2-content, .swal2-html-container {
    font-size: 16px !important;
    color: var(--off-white) !important;
}

/* Overlay sfondo (sfondo scuro dietro il modale) */
.swal2-backdrop {
    background: rgba(14, 37, 71, 0.75) !important;
}

/* 🔹 Pulsanti principali */
.swal2-confirm, .swal2-cancel {
    font-size: 14px !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
    padding: 10px 20px !important;
    transition: all 0.3s ease-in-out !important;
    border: 2px solid transparent !important;
}

/* ✅ Pulsante di conferma (OK, Successo) */
.swal2-confirm {
    background-color: var(--color-action) !important;
    color: var(--color-text-light) !important;
    border-color: #b36b00 !important;
}

    .swal2-confirm:hover {
        background-color: #cc8500 !important;
        border-color: #995f00 !important;
        transform: scale(1.05);
    }

    .swal2-confirm:active {
        background-color: #a56500 !important;
        border-color: #7a4a00 !important;
        transform: scale(0.98);
    }

/* ❌ Pulsante di annullamento (Cancel, Errore) */
.swal2-cancel {
    background-color: var(--color-danger) !important;
    color: var(--color-text-light) !important;
    border-color: #a1271e !important;
}

    .swal2-cancel:hover {
        background-color: #d14339 !important;
        border-color: #8a1f17 !important;
        transform: scale(1.05);
    }

    .swal2-cancel:active {
        background-color: #b83228 !important;
        border-color: #6d1a13 !important;
        transform: scale(0.98);
    }

    /* 🖱️ Effetto Focus (quando il pulsante viene selezionato) */
    .swal2-confirm:focus, .swal2-cancel:focus {
        box-shadow: 0 0 10px rgba(255, 255, 255, 0.5) !important;
        outline: none !important;
    }

/* 🔹 Stili delle icone */
.swal2-icon.swal2-success {
    border-color: var(--color-action) !important;
}

.swal2-icon.swal2-error {
    border-color: var(--color-danger) !important;
}

.swal2-icon.swal2-warning {
    border-color: var(--color-action) !important;
}

.swal2-icon.swal2-info {
    border-color: var(--color-accent) !important;
}

/* 🏆 Ombreggiatura per un effetto elegante */
.swal2-popup {
    box-shadow: 0px 8px 30px rgba(0, 0, 0, 0.5) !important;
}

/* ✅ Stato disabilitato */
.swal2-confirm:disabled, .swal2-cancel:disabled {
    background-color: #5C718D !important;
    border-color: #3D5169 !important;
    color: #CCD3DB !important;
    cursor: not-allowed;
    transform: none;
}



/* Stili generali */
body {
    font-family: var(--font-primary);
    font-size: 16px;
    line-height: 1.6;
    background-color: var(--color-bg);
    color: var(--color-text);
}

.font-modal-type {
    font-weight: 700;
    color: var(--color-primary);
}

/* Cornice principale (header, navbar, sidebar) */
.header, .navbar, .sidebar {
    background-color: var(--color-primary) !important;
    color: var(--color-text-light) !important;
    padding: 15px;
}

.navbar-brand img {
    height: 90px; /* Altezza massima */
    max-width: 100%; /* Mantiene la proporzione */
    width: auto;
}

/* Stile base del pulsante */
.btn-elegant {
    background-color: #0E2547; /* Colore principale */
    color: #FFFFFF; /* Testo bianco */
    border: 2px solid #13305E; /* Bordo leggermente più chiaro */
    padding: 10px 20px; /* Spaziatura equilibrata */
    font-size: 1rem; /* Dimensione standard */
    font-weight: 600; /* Testo leggermente più marcato */
    text-transform: uppercase; /* Maiuscolo per un look più deciso */
    border-radius: 8px; /* Bordo arrotondato */
    transition: all 0.3s ease-in-out; /* Animazione fluida */
    display: inline-block;
    text-decoration: none;
}

    /* Hover (quando il mouse è sopra) */
    .btn-elegant:hover {
        background-color: #091A33; /* Tonalità più scura */
        border-color: #0E2547; /* Bordo più scuro */
        color: #FFFFFF; /* Mantiene il testo bianco */
        transform: scale(1.05); /* Leggero ingrandimento */
    }

    /* Stato attivo (quando viene cliccato) */
    .btn-elegant:active {
        background-color: #112B51; /* Ancora più scuro */
        border-color: #0E2547;
        color: #FFFFFF;
        transform: scale(0.98); /* Leggera compressione per effetto click */
    }

    /* Focus (quando si usa con la tastiera) */
    .btn-elegant:focus {
        box-shadow: 0 0 8px rgba(14, 37, 71, 0.5); /* Ombra elegante */
        outline: none;
    }

    /* Variante disabilitata */
    .btn-elegant:disabled,
    .btn-elegant.disabled {
        background-color: #5C718D; /* Colore spento */
        border-color: #3D5169;
        color: #CCD3DB; /* Testo più chiaro */
        cursor: not-allowed;
        transform: none;
    }

.public-img {
    height: 250px;
    width: auto;
}

/* Stile base del pulsante outline */
.btn-outline-elegant {
    background-color: transparent;
    color: #0E2547;
    border: 2px solid #0E2547;
    padding: 9px 19px; /* RIDOTTO per allinearsi al btn-gold */
    font-size: 1rem;
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 8px;
    transition: all 0.3s ease-in-out;
    display: inline-block;
    text-decoration: none;
}

    /* Hover (quando il mouse è sopra) */
    .btn-outline-elegant:hover {
        background-color: rgba(14, 37, 71, 0.1);
        color: #0E2547;
        border-color: #0E2547;
        transform: scale(1.05);
    }

    /* Stato attivo (quando viene cliccato) */
    .btn-outline-elegant:active {
        background-color: rgba(14, 37, 71, 0.2);
        color: #0E2547;
        transform: scale(0.98);
    }

    /* Focus */
    .btn-outline-elegant:focus {
        box-shadow: 0 0 8px rgba(14, 37, 71, 0.5);
        outline: none;
    }


/* Stile base del pulsante */
.btn-gold {
    background-color: #E8A317; /* Oro ambrato */
    color: #FFFFFF; /* Testo bianco */
    border: none; /* Niente bordo per un aspetto più pulito */
    padding: 10px 20px;
    font-size: 1rem;
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 8px;
    transition: all 0.3s ease-in-out;
    display: inline-block;
    text-decoration: none;
}

    /* Hover (quando il mouse è sopra) */
    .btn-gold:hover {
        background-color: #D89214; /* Leggermente più scuro per effetto elegante */
        color: #FFFFFF;
        transform: scale(1.05);
    }

    /* Stato attivo (quando viene cliccato) */
    .btn-gold:active {
        background-color: #C57F12; /* Ancora più scuro */
        color: #FFFFFF;
        transform: scale(0.98);
    }

    /* Focus (quando si usa con la tastiera) */
    .btn-gold:focus {
        box-shadow: 0 0 8px rgba(232, 163, 23, 0.5); /* Glow leggero */
        outline: none;
    }

    /* Variante disabilitata */
    .btn-gold:disabled,
    .btn-gold.disabled {
        background-color: #F0C37E; /* Oro più spento */
        color: #FFFFFF;
        cursor: not-allowed;
        transform: none;
    }

.font-size-2 {
    font-size: 2rem !important;
}

    .font-size-2 svg {
        height: 40px !important;
        width: 40px !important;
    }

.same-width-btn {
    min-width: 160px; /* Larghezza minima uguale per tutti */
    max-width: 180px; /* Evita allargamenti eccessivi */
    text-align: center; /* Centra il testo */
}


/* Stile pulsanti generici */
button, a {
    font-family: var(--font-button) !important;
    border: none;
    padding: 12px 20px;
    font-size: 16px;
    border-radius: 4px;
    transition: 0.3s ease;
    cursor: pointer;
}


    /* Pulsanti per azioni importanti (ambra) */
    button.action {
        background-color: var(--color-action);
        color: var(--color-text-light);
    }

        button.action:hover {
            background-color: #E67E00; /* Ambra più scura */
        }

    /* Pulsanti per eliminazione/pericolo (rosso scuro) */
    button.danger {
        background-color: var(--color-danger);
        color: var(--color-text-light);
    }

        button.danger:hover {
            background-color: #A93226; /* Rosso più scuro */
        }

/* Card professionali */
.card {
    background: #FFFFFF;
    border: 1px solid var(--color-border);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    padding: 20px;
    border-radius: 8px;
}

.card-header {
    background-color: white !important;
    color: var(--color-primary) !important; /* Blu professionale */
    text-transform: uppercase;
    font-weight: bold;
    text-align: center;
    padding: 1rem;
    border-bottom: 2px solid #0A2A5A; /* Sottolineatura sottile per effetto professionale */
}


/* Alert */
.alert-success {
    background-color: #4CAF50;
    color: var(--color-text-light);
}

.alert-error {
    background-color: #C62828;
    color: var(--color-text-light);
}

/* Link */
a {
    color: var(--color-primary);
    text-decoration: none;
}

    a:hover {
        color: var(--color-accent);
    }

/* Miglioriamo la separazione visiva delle sezioni */
.section-title {
    font-size: 18px;
    font-weight: bold;
    color: grey;
    margin-top: 20px;
    padding-bottom: 8px;
    /*border-bottom: 2px solid var(--color-primary);*/
}

/* Card della registrazione */
.card {
    background: #FFFFFF;
    border: 1px solid var(--color-border);
    box-shadow: 0 3px 15px rgba(0, 0, 0, 0.15);
    padding: 25px;
    border-radius: 10px;
}

.card-login {
    min-width: 400px;
}
/* Miglioriamo i campi di input */
.form-control {
    border: 1px solid var(--color-border);
    padding: 10px;
    border-radius: 6px;
    font-size: 16px;
}


/* Stile per la navbar */
.custom-navbar {
    background-color: transparent !important; /* Navbar trasparente */
    border-bottom: 1px solid rgba(255, 255, 255, 0.3); /* Bordo sottile */
}

/* Stile per il toggle sempre bianco */
.white-toggle {
    border: none;
}

    .white-toggle .navbar-toggler-icon {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='rgba(255, 255, 255, 1)' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
    }

    /* Assicuriamoci che resti bianco in tutte le interazioni */
    .white-toggle:focus,
    .white-toggle:active,
    .white-toggle:hover {
        outline: none !important;
        box-shadow: none !important;
        background-color: transparent !important;
    }


/* Pulsante con sfondo bianco */
.btn-white {
    background-color: #FFFFFF; /* Bianco puro */
    color: #0E2547; /* Testo blu elegante */
    border: 2px solid #FFFFFF; /* Bordo bianco */
    padding: 8px 16px;
    font-size: 1rem;
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 8px;
    transition: all 0.3s ease-in-out;
    display: inline-block;
    text-decoration: none;
}

    /* Hover */
    .btn-white:hover {
        background-color: #F8F9FA; /* Bianco leggermente più scuro */
        color: #0E2547;
        transform: scale(1.05);
    }

    /* Stato attivo */
    .btn-white:active {
        background-color: #EAEAEA; /* Più scuro per feedback */
        transform: scale(0.98);
    }

    /* Focus */
    .btn-white:focus {
        box-shadow: 0 0 8px rgba(255, 255, 255, 0.5);
        outline: none;
    }

/* Pulsante outline con bordo bianco */
.btn-outline-white {
    background-color: transparent;
    color: #FFFFFF; /* Testo bianco */
    border: 2px solid #FFFFFF; /* Bordo bianco */
    padding: 8px 16px;
    font-size: 1rem;
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 8px;
    transition: all 0.3s ease-in-out;
    display: inline-block;
    text-decoration: none;
}

    /* Hover */
    .btn-outline-white:hover {
        background-color: rgba(255, 255, 255, 0.1); /* Leggera trasparenza */
        color: #FFFFFF;
        transform: scale(1.05);
    }

    /* Stato attivo */
    .btn-outline-white:active {
        background-color: rgba(255, 255, 255, 0.2);
        transform: scale(0.98);
    }

    /* Focus */
    .btn-outline-white:focus {
        box-shadow: 0 0 8px rgba(255, 255, 255, 0.5);
        outline: none;
    }

/* Stile base */
.btn-elegant-green {
    background-color: #2A7A40; /* Verde scuro elegante */
    color: #ffffff; /* Testo bianco per contrasto */
    font-family: var(--font-button);
    font-size: 0.9rem;
    padding: 10px 20px;
    border: 0px; /* Bordo leggermente più scuro */
    border-radius: 6px;
    text-transform: uppercase;
    font-weight: bold;
    transition: all 0.3s ease-in-out;
}

    /* Effetto hover */
    .btn-elegant-green:hover {
        background-color: #1F5A30; /* Verde ancora più profondo */
        border-color: #144020;
        color: #ffffff;
    }

    /* Effetto focus */
    .btn-elegant-green:focus {
        outline: none;
        box-shadow: 0 0 5px rgba(42, 122, 64, 0.7);
    }

    /* Effetto active */
    .btn-elegant-green:active {
        background-color: #18502D;
        border-color: #0F331D;
    }

    /* Variante disabilitata */
    .btn-elegant-green:disabled {
        background-color: #A5C5A0;
        border-color: #7F9B7B;
        color: #E3EDE2;
        cursor: not-allowed;
    }


.btn {
    display: flex;
    align-items: center; /* Centra verticalmente testo e icona */
    justify-content: center; /* Centra il contenuto orizzontalmente */
    padding: 10px 16px; /* Bilancia il padding verticale */
    font-size: 1rem;
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 8px;
    transition: all 0.3s ease-in-out;
    text-decoration: none;
    line-height: 1.2; /* Evita che il testo si "sposti" in alto */
}

    .btn svg {
        width: 22px; /* Mantieni la dimensione 20x20 */
        height: 22px;
        vertical-align: middle; /* Centra l'icona rispetto al testo */
        margin-right: 5px; /* Distanza tra icona e testo */
    }


.btn-offcanvas svg {
    width: 40px; /* Mantieni la dimensione 20x20 */
    height: 40px;
}

.is-invalid {
    border-color: #D32F2F !important;
    background-color: #FAE3E3; /* Un rosato chiaro per non essere troppo aggressivo */
}

.invalid-feedback {
    display: none;
    color: #D32F2F;
    font-size: 0.875rem;
}

.success-icon {
    color: blue;
    font-size: 1.2em;
    margin-left: 10px;
}

.error-icon {
    color: indianred;
    font-size: 1.2em;
    margin-left: 10px;
}

.position-relative {
    position: relative;
}

/* Assicura che l'input non si restringa */
.password-field {
    width: 100%;
    padding-right: 75px; /* Aggiungiamo spazio sufficiente per entrambe le icone */
}

/* Miglioriamo la gestione dell'icona di errore di Bootstrap */
.is-invalid {
    padding-right: 75px !important; /* Assicura spazio sufficiente */
}

    /* Spostiamo il punto esclamativo più a sinistra per evitare la sovrapposizione */
    .is-invalid::after {
        right: 45px !important; /* Prima era 38px, ora spostato per più spazio */
    }

/* Posizioniamo correttamente l'icona dell'occhio */
.toggle-password {
    position: absolute;
    right: 10px; /* Resta sempre a destra */
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    z-index: 3; /* Assicura che sia sopra l'input */
    padding: 5px;
}

    /* Stile dell'icona */
    .toggle-password svg {
        width: 20px;
        height: 20px;
        fill: gray;
    }

    .toggle-password:hover svg {
        fill: black;
    }

.is-valid {
    border-color: #4cd253 !important; /* Verde scuro più professionale */
    background-color: #E8F5E9; /* Verde molto chiaro per dare feedback visivo */
}

.menu-svg {
    fill: var(--color-primary) !important; /* Colore desiderato */
    color: var(--color-primary) !important; /* Colore desiderato */
    margin-right: 3px;
    font-size: 1rem; /* Dimensione standard */
    font-weight: 600; /* Testo leggermente più marcato */
    text-transform: uppercase; /* Maiuscolo per un look più deciso */
    transition: all 0.3s ease-in-out; /* Animazione fluida */
}

.nav-link {
    color: var(--color-primary) !important; /* Colore desiderato */
    font-size: 1rem !important; /* Dimensione standard */
    font-weight: 600 !important; /* Testo leggermente più marcato */
    transition: all 0.3s ease-in-out; /* Animazione fluida */
}

.logo-svg {
    fill: var(--off-white) !important; /* Colore desiderato */
    color: var(--off-white) !important; /* Colore desiderato */
}

.logo-svg-exit {
    fill: var(--color-primary) !important; /* Colore desiderato */
    color: var(--color-primary) !important; /* Colore desiderato */
}

.offcanvas-img-content {
    justify-content: center;
    align-content: center !important;
    display: flex;
}

.offcanvas-img {
    margin-bottom: 1rem;
    width: 150px;
}

#sidebar-toggle {
    width: 40px;
    height: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%; /* Rotondo */
    cursor: pointer;
    transition: background-color 0.3s;
    border: none; /* Rimozione del bordo */
    padding: 0; /* Rimozione del padding */
}


.user-menu {
    display: flex;
    align-items: center;
    gap: 4px;
    color: white;
    font-weight: 500;
    text-decoration: none;
}


.user-name {
    max-width: 120px; /* Evita problemi con nomi lunghi */
    white-space: nowrap;
    overflow: hidden;
    color: white;
    text-overflow: ellipsis;
}

.custom-dropdown {
    min-width: 250px;
    background-color: var(--color-primary); /* Stesso colore della navbar */
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    border: 1px solid #ffffff40;
    padding: 10px 0;
}

.custom-dropdown-item {
    display: flex;
    align-items: center;
    padding: 12px 18px;
    color: #ffffff;
    font-size: 16px;
    transition: background 0.3s ease-in-out, color 0.3s ease-in-out;
    text-decoration: none;
}

    .custom-dropdown-item svg {
        margin-right: 8px;
        fill: #ffffff;
        transition: fill 0.3s ease-in-out;
    }

    .custom-dropdown-item:hover {
        background-color: rgba(255, 255, 255, 0.15);
        color: #ffffff;
    }

        .custom-dropdown-item:hover svg {
            fill: #f0f0f0;
        }

.custom-dropdown-divider {
    height: 1px;
    background-color: rgba(255, 255, 255, 0.2);
    margin: 6px 0;
}

/* Hero Section */
.hero-section {
    position: relative;
    background: url('/images/hero.jpg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 80vh; /* Regola l'altezza secondo necessità */
    display: flex;
    align-items: center;
    justify-content: left;
    /*text-align: center;*/
    color: var(--color-text-light);
}

.hero-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /*background: rgba(14, 37, 71, 0.7);*/ /* Overlay con trasparenza */
    display: flex;
    align-items: center;
    justify-content: center;
}

@media (max-width: 768px) {
    .hero-title {
        font-size: 2rem;
        font-weight: bold;
        font-family: var(--font-title);
        color: var(--color-text-light); /* Oppure usa var(--color-text-light) per trasparenza */
    }

    .hero-subtitle {
        font-family: var(--font-title);
        font-size: 1rem;
        margin-top: 10px;
        color: var(--color-text-light);
    }
}

@media (min-width: 768px) {
    .hero-title {
        font-size: 4rem;
        font-weight: bold;
        font-family: var(--font-title);
        color: var(--color-text-light); /* Oppure usa var(--color-text-light) per trasparenza */
    }

    .hero-subtitle {
        font-family: var(--font-title);
        font-size: 1.2rem;
        margin-top: 10px;
        color: var(--color-text-light);
    }
}


.hero-btn {
    display: inline-block;
    padding: 15px 40px;
    font-size: 1.4rem;
    font-weight: 600;
    text-transform: uppercase;
    background-color: var(--color-accent);
    color: var(--color-primary);
    border-radius: 6px;
    transition: all 0.3s ease-in-out;
}

    .hero-btn:hover {
        background-color: #e6a800; /* Versione più scura dell'accent color */
        transform: scale(1.05);
    }

.container-no-border {
    margin: 0 !important;
    padding: 0 !important;
}

.required-marker {
    color: red;
    font-weight: bold;
    margin-left: 5px;
    cursor: help; /* Mostra il cursore di aiuto */
    position: relative;
}

    /* Tooltip automatico */
    .required-marker::after {
        content: " *";
    }

    .required-marker:hover::before {
        content: "Campo obbligatorio"; /* Testo del tooltip */
        position: relative;
        bottom: 100%; /* Mostra sopra l'asterisco */
        left: 10%;
        transform: translateX(-50%);
        background-color: #333;
        color: #fff;
        padding: 5px 8px;
        font-size: 12px;
        font-weight: 300;
        border-radius: 4px;
        white-space: nowrap;
        opacity: 0;
        transition: opacity 0.2s ease-in-out;
        pointer-events: none;
        z-index: 10000;
    }

    /* Quando il mouse passa sopra, mostra il tooltip */
    .required-marker:hover::before {
        opacity: 1;
    }
/* Sezione con padding dinamico */
.welcome-section {
    background-color: var(--color-bg);
    padding: 5vw 5vw; /* Adatta lo spazio ai diversi schermi */
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Card che si adatta alla larghezza dello schermo */
.welcome-container {
    background-color: white;
    padding: 4vw;
    border-radius: 12px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
    text-align: center;
    width: 80%;
    max-width: 900px; /* Non cresce troppo */
    min-width: 320px; /* Si adatta anche su mobile */
}

/* Titolo dinamico che scala con la larghezza */
.welcome-title {
    font-size: clamp(2rem, 5vw, 4rem); /* Min 2rem, max 4rem, scala con lo schermo */
    font-weight: bold;
    font-family: var(--font-title);
    color: var(--color-primary);
    margin-bottom: 20px;
}

/* Testo descrittivo che si ridimensiona */
.welcome-subtitle,
.welcome-description {
    font-size: clamp(1.5rem, 3vw, 2rem) !important;
    font-family: var(--font-primary);
    color: var(--color-text);
    line-height: 1.6;
    margin-bottom: 25px;
}

.welcome-description {
    font-size: clamp(1rem, 3vw, 1.5rem) !important;
    color: #6e6e6e !important;
}
/* Link con colore evidenziato */
.highlight-link {
    color: var(--color-highlight);
    font-weight: bold;
    text-decoration: none;
    transition: color 0.3s ease;
    font-size: clamp(1rem, 3vw, 1.5rem) !important;
}

    .highlight-link:hover {
        color: #1c7d44;
    }

.company-documents {
    background-color: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 20px;
    margin-bottom: 20px;
}

.documents-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

/* Centra i pulsanti nella cella */
tbody td.status-cell {
    display: flex;
    justify-content: center; /* Centra orizzontalmente */
    align-items: center; /* Centra verticalmente */
}

/* Stile uniforme per i pulsanti */
span[class^="status-"] {
    display: flex;
    align-items: center;
    justify-content: center;
    /*width: 100px;*/ /* Imposta una larghezza fissa */
    border-radius: 15px;
    border: none;
    font-family: var(--font-button) !important;
    font-size: 0.85rem;
    font-weight: 400;
    color: white;
    text-transform: uppercase;
    cursor: default;
}

/* Colori specifici */
.status-pending {
    background-color: #ead721;
    color: white;
}

.status-confirmed {
    background-color: #339966;
    color: white;
}

.status-expired {
    background-color: red;
    color: white;
}

.status-rejected {
    background-color: #cc2900;
    color: white;
}

.status-in-processing {
    background-color: #ead721;
    color: white;
}

.status-processed {
    background-color: forestgreen;
    color: white;
}

.status-risk-completed {
    background-color: #2851e5;
    color: white;
}

.status-risk-confirmed {
    background-color: forestgreen;
    color: white;
}

.status-default {
    background-color: var(--color-secondary);
    color: var(--color-primary);
}

/* ============================= */
/* 📌 STILE GENERALE DELLA TABELLA */
/* ============================= */
.table-container {
    width: 100%;
    overflow-x: auto;
    border-radius: 10px; /* Arrotonda gli angoli */
    border: 1px solid var(--color-border); /* Bordo sottile */
    overflow: hidden; /* Impedisce che i bordi interni rompano l'effetto */
}


table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0; /* Evita spazi tra le celle */
    table-layout: fixed; /* Distribuzione equa delle colonne */
    font-family: var(--font-title);
}

/* Intestazione della tabella */
thead th {
    background-color: var(--color-light);
    color: black;
    text-align: center;
    padding: 12px;
    font-weight: bold;
}

    /* Arrotonda l'intestazione e il footer della tabella */
    thead th:first-child {
        border-top-left-radius: 10px;
    }

    thead th:last-child {
        border-top-right-radius: 10px;
    }

tfoot td:first-child {
    border-bottom-left-radius: 10px;
}

tfoot td:last-child {
    border-bottom-right-radius: 10px;
}


/* Celle della tabella */
tbody td {
    padding: 12px;
    border-bottom: 1px solid var(--color-border);
    text-align: center;
    vertical-align: middle; /* Centra tutto verticalmente */
    height: 60px; /* Altezza fissa per uniformare le righe */
}

/* Alternanza colore righe */
tbody tr {
    background-color: var(--color-bg);
}

    tbody tr:nth-child(even) {
        background-color: var(--color-bg);
    }

/* Distribuzione delle colonne */
thead th, tbody td {
    width: 20%; /* 5 colonne con la stessa larghezza */
}

/* ============================= */
/* 📌 STILE DELLE ICONE */
/* ============================= */

/* Contenitore del numero pratica + icone */
.document-actions {
    align-items: center;
    justify-content: space-between; /* Numero pratica a sinistra, icone a destra */
    width: 100%;
    padding-right: 10px;
}

/* Numero pratica ben allineato */
.document-number {
    flex-grow: 1; /* Occupa tutto lo spazio disponibile senza andare a capo */
}

/* Contenitore delle icone (Ora affiancate!) */
.actions-group {
    display: flex;
    gap: 10px; /* Spazio tra le icone */
    align-items: center;
}

/* Pulsanti icona rotondi e discreti */
.action-icon {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: transparent;
    border: 1px solid transparent;
    cursor: pointer;
    transition: all 0.2s ease-in-out;
    padding: 0; /* Rimuove padding extra */
    margin: 0; /* Evita margini indesiderati */
    overflow: visible;
}

    /* SVG delle icone */
    .action-icon svg {
        width: 18px;
        height: 18px;
        fill: var(--color-text);
    }

        /* SVG delle icone */
        .action-icon svg .white-icon {
            width: 18px;
            height: 18px;
            fill: white !important;
        }

    /* Effetto hover */
    .action-icon:hover {
        background-color: rgba(0, 0, 0, 0.1);
        border: 1px solid var(--color-border);
    }

/* Differenziazione colori */
.icon-view:hover svg {
    fill: var(--color-highlight); /* Verde */
}

.icon-edit:hover svg {
    fill: var(--color-action); /* Ambra */
}

/* Stile del tooltip */
.tooltip-container {
    position: relative;
    display: inline-block;
}

    .tooltip-container:hover::after {
        content: attr(data-tooltip); /* Usa l'attributo data-tooltip */
        position: absolute;
        bottom: 125%; /* Posiziona sopra l'elemento */
        left: 50%;
        transform: translateX(-50%);
        background-color: rgba(0, 0, 0, 0.85);
        color: #fff;
        padding: 6px 10px;
        border-radius: 5px;
        font-size: 14px;
        white-space: nowrap;
        box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.2);
        opacity: 0;
        visibility: hidden;
        transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
    }

    /* Mostra il tooltip quando passi sopra */
    .tooltip-container:hover::after {
        opacity: 1;
        visibility: visible;
    }


/* ============================= */
/* 📌 RESPONSIVE (Mobile) */
/* ============================= */
@media (max-width: 768px) {
    thead {
        display: none;
    }

    tbody td {
        display: block;
        width: 100%;
        text-align: left;
        padding: 10px;
        height: auto;
    }

    tbody tr {
        margin-bottom: 15px;
        display: block;
        border: 1px solid var(--color-border);
        border-radius: 8px;
        padding: 10px;
        background-color: var(--color-bg);
    }

    /* Icone più piccole su mobile */
    .action-icon {
        width: 24px;
        height: 24px;
    }

        .action-icon svg {
            width: 16px;
            height: 16px;
        }
}

#documentDropZone {
    border: 3px dashed #999999;
    padding: 20px;
    text-align: center;
    cursor: pointer;
    transition: background-color 0.3s ease, border-color 0.3s ease;
    border-radius: 8px;
}

    #documentDropZone.drag-over {
        background-color: #f0f8ff;
        border-color: #007bff;
    }

.remove-document {
    background: none;
    border: none;
    color: #bb271a; /* Rosso scuro */
    font-size: 18px;
    cursor: pointer;
    padding: 5px;
    transition: color 0.2s ease-in-out;
}

    .remove-document:hover {
        color: #ff0000; /* Rosso acceso */
    }

    .remove-document svg {
        width: 18px;
        height: 18px;
        fill: currentColor;
        vertical-align: middle;
    }

/* Stili generali per tutti gli help */
.help-content {
    display: flex;
    flex-direction: column; /* Disposizione verticale */
    align-items: flex-start; /* Centra i contenuti */
    text-align: left; /* Allinea il testo */
    padding: 10px;
    max-width: 100%; /* Evita che il contenuto esca dalla modale */
}

    /* Ottimizzazione per immagini */
    .help-content img {
        max-width: 100%; /* Evita che l'immagine esca dalla modale */
        height: auto; /* Mantiene le proporzioni */
        border-radius: 5px; /* Smussa gli angoli */
        margin-bottom: 10px; /* Distanza tra immagine e testo */
    }

    /* Testo e paragrafi */
    .help-content p {
        font-size: 14px; /* Dimensione del testo ottimizzata */
        color: #333;
        line-height: 1.4; /* Maggiore leggibilità */
        margin-bottom: 8px;
        max-width: 90%;
    }

    /* Liste (se presenti) */
    .help-content ul {
        padding: 0;
        margin: 10px 0;
        list-style-type: none; /* Rimuove il default */
    }

        .help-content ul li {
            /*background: #f8f8f8;*/
            padding: 5px;
            border-radius: 3px;
            margin-bottom: 5px;
            font-size: 14px;
            width: 90%;
            text-align: left;
        }

    /* Se si vuole dare uno stile differente ai titoli */
    .help-content strong {
        font-size: 16px;
        color: #222;
    }

.map-container {
    height: 500px;
    width: 100%;
}

.map-preview img {
    max-height: 200px;
    object-fit: cover;
    transition: transform 0.2s ease;
}

    .map-preview img:hover {
        transform: scale(1.02);
    }


.map-preview-clickable {
    border: 2px dashed #999;
    padding: 20px;
    text-align: center;
    cursor: pointer;
    transition: background-color 0.3s, border-color 0.3s;
    border-radius: 8px;
}

    .map-preview-clickable:hover {
        background-color: #f8f9fa;
        border-color: #666;
    }

.pac-container {
    z-index: 1065 !important; /* più della modale (1050) e del backdrop (1040) */
}

.icon-circle-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background-color: transparent;
    border: none;
    padding: 0;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

    .icon-circle-btn:hover {
        background-color: #f2f2f2; /* grigio chiarissimo */
    }

    .icon-circle-btn svg {
        width: 20px;
        height: 20px;
    }


.register-company-modal {
    height: 90vh; /* altezza limitata */
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
}

.register-company-body {
    flex: 1 1 auto; /* permette al body di crescere e scrollare */
    overflow-y: auto;
    padding: 1.5rem; /* spazio interno laterale */
}

.form-label {
    margin-bottom: .1rem;
    margin-top: .5rem;
}

.logo-img {
    max-height: 150px;
}

/* Stile base del pulsante */
.btn-elegant-grid {
    background-color: #3f7dd9; /* Colore principale */
    color: #FFFFFF !important; /* Testo bianco */
    border: 2px solid #3f7dd9; /* Bordo leggermente più chiaro */
    padding-bottom:5px !important;
    margin: 5px !important; /* Spaziatura equilibrata */
    font-size: 0.8rem !important; /* Dimensione standard */
    font-weight: 400 !important; /* Testo leggermente più marcato */
    text-transform: uppercase; /* Maiuscolo per un look più deciso */
    border-radius: 4px; /* Bordo arrotondato */
    transition: all 0.3s ease-in-out; /* Animazione fluida */
    display: inline-block;
    text-decoration: none;
}

    /* Hover (quando il mouse è sopra) */
    .btn-elegant-grid:hover {
        background-color: #2663c0; /* Tonalità più scura */
        border-color: #2663c0; /* Bordo più scuro */
        color: #FFFFFF; /* Mantiene il testo bianco */
        transform: scale(1.05); /* Leggero ingrandimento */
    }

    /* Stato attivo (quando viene cliccato) */
    .btn-elegant-grid:active {
        background-color: #2258aa; /* Ancora più scuro */
        border-color: #2258aa;
        color: #FFFFFF;
        transform: scale(0.98); /* Leggera compressione per effetto click */
    }

    /* Focus (quando si usa con la tastiera) */
    .btn-elegant-grid:focus {
        box-shadow: 0 0 8px rgba(14, 37, 71, 0.5); /* Ombra elegante */
        outline: none;
    }

    /* Variante disabilitata */
    .btn-elegant-grid:disabled,
    .btn-elegant-grid.disabled {
        background-color: #5C718D; /* Colore spento */
        border-color: #3D5169;
        color: #CCD3DB; /* Testo più chiaro */
        cursor: not-allowed;
        transform: none;
    }

.img-help {
    height: auto;
    width: 450px;
}
/* Adattamento proposto dal cliente: img-help-sm */
.img-help-sm {
    width: 70%;
    margin: 30px;
    min-width: 350px;
    border-radius: 10px;
}

/* Wrapper per evitare modifica globale a .col-6 */
.image-help-container .col-md-6 {
    display: flex;
    justify-content: center;
    align-items: center;
}


.modal-backdrop {
    z-index: 1040 !important;
}

.modal[data-help="true"] {
    z-index: 1065 !important; /* più alto della modale normale */
}


.custom-help-backdrop {
    z-index: 1060 !important; /* tra la modale principale e l'help */
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0,0,0,0.5);
}
