/* ==========================================================================
   AREA RISERVATA (SUB-NAVIGAZIONE & DASHBOARD)
   ========================================================================== */

/* --- 1. SUB-NAVIGAZIONE --- */
.private-sub-nav {
    background-color: #f8f9fa; /* Grigio chiaro */
    border-bottom: 1px solid #e0e0e0;
    padding: 0;
    margin-bottom: 40px;
}

.private-menu {
    display: flex;
    list-style: none;
    gap: 30px;
}

.private-menu li a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 20px 5px;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.95rem;
    font-weight: 600;
    color: #666;
    text-transform: uppercase;
    border-bottom: 3px solid transparent;
    transition: all 0.3s;
}

/* Hover e Stato Attivo */
.private-menu li a:hover {
    color: var(--rotary-blue);
}

.private-menu li.active a {
    color: var(--rotary-blue);
    border-bottom-color: var(--rotary-gold);
}

/* Logout Item (Stile diverso, magari rosso o separato) */
.private-menu li.logout-item {
    margin-left: auto; /* Spinge a destra */
}

.private-menu li.logout-item a {
    color: #d9534f; /* Rosso spento */
}
.private-menu li.logout-item a:hover {
    color: #c9302c;
}


/* --- 2. LAYOUT DASHBOARD --- */
.private-dashboard-section {
    padding-bottom: 80px;
    min-height: 60vh;
}

.dashboard-header {
    margin-bottom: 30px;
}
.dashboard-header h2 { font-size: 2rem; margin-bottom: 5px; }
.dashboard-header p { color: #666; }


/* --- 3. CARD FILTRI (Data Da - A) --- */
.filter-card {
    background: #fff;
    padding: 25px;
    border-radius: 12px;
    box-shadow: 0 5px 20px rgba(0,0,0,0.05);
    margin-bottom: 30px;
    border: 1px solid rgba(0,0,0,0.05);
}

.filter-form {
    display: flex;
    align-items: flex-end; /* Allinea il bottone in basso con gli input */
    gap: 20px;
    flex-wrap: wrap;
}

.filter-group {
    display: flex;
    flex-direction: column;
}

.filter-group label {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--rotary-blue);
    margin-bottom: 8px;
    text-transform: uppercase;
}

/* Input Data Stilizzato */
.date-input-wrapper {
    position: relative;
    width: 200px;
}

.date-input-wrapper i {
    position: absolute;
    left: 15px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--rotary-gold);
    z-index: 1;
}

.form-control-date {
    width: 100%;
    padding: 10px 15px 10px 40px; /* Spazio per icona */
    border: 1px solid #ddd;
    border-radius: 50px;
    font-family: 'Inter', sans-serif;
    color: #333;
    background: #fcfcfc;
    outline: none;
    transition: all 0.3s;
    /* Rimuove stile default datepicker brutto su alcuni browser */
    appearance: none; 
}

.form-control-date:focus {
    border-color: var(--rotary-blue);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(0, 36, 125, 0.1);
}

/* Bottone Cerca */
.btn-filter-search {
    background-color: var(--rotary-blue);
    color: #fff;
    border: none;
    padding: 11px 30px;
    border-radius: 50px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.3s;
    height: 42px; /* Allineamento visivo con input */
    display: flex;
    align-items: center;
    gap: 8px;
}

.btn-filter-search:hover {
    background-color: var(--rotary-gold);
    color: var(--rotary-blue);
}


/* --- 4. STILI SPECIFICI TABELLA MOVIMENTI --- */
/* (Eredita .rotary-table ma aggiunge questi dettagli) */

.date-text {
    font-weight: 600;
    color: #555;
    font-family: 'Inter', sans-serif;
}

.movement-desc strong {
    display: block;
    color: var(--rotary-blue);
    font-size: 0.95rem;
    text-align:left;
}
.movement-sub {
    font-size: 0.8rem;
    color: #888;
}

/* Colori Importi */
.amount-positive {
    color: #28a745; /* Verde */
    font-weight: 700;
}

.amount-negative {
    color: #dc3545; /* Rosso */
    font-weight: 700;
}

.table-footer-info {
    padding: 15px 20px;
    background-color: #f9f9f9;
    border-top: 1px solid #eee;
    font-size: 0.9rem;
    color: #666;
    text-align: right;
}


/* --- RESPONSIVE --- */
@media (max-width: 768px) {
    
    /* Rimuoviamo lo scroll orizzontale e impiliamo le voci */
    .private-menu {
        flex-direction: column; /* Voci una sotto l'altra */
        gap: 0;                 /* Gestiamo lo spazio coi bordi */
        overflow-x: visible;    /* Niente scroll orizzontale */
        white-space: normal;    /* Testo a capo se serve */
        padding-bottom: 0;
    }
    
    .private-menu li {
        width: 100%;
        display: block;
        border-bottom: 1px solid #eee; /* Separatore tra le voci */
    }

    .private-menu li:last-child {
        border-bottom: none;
    }

    .private-menu li a {
        font-size: 0.9rem;
        padding: 15px 10px; /* Più spazio per il dito */
        width: 100%;        /* Cliccabile su tutta la riga */
        border-bottom: none; /* Rimuove la linea dorata desktop */
        border-left: 4px solid transparent; /* Spostiamo l'indicatore a sinistra */
    }

    /* Stato Attivo Mobile: Linea a sinistra invece che sotto */
    .private-menu li.active a {
        background-color: #fff;
        border-bottom: none;
        border-left-color: var(--rotary-gold);
        color: var(--rotary-blue);
    }

    /* FIX LOGOUT SU MOBILE */
    .private-menu li.logout-item {
        margin-left: 0;     /* Rimuove la spinta a destra del desktop */
        margin-top: 10px;   /* Un po' di spazio sopra il logout */
        border-top: 1px solid #eee;
    }

    .private-menu li.logout-item a {
        background-color: #fff5f5; /* Sfondo rossiccio leggero per evidenziare */
        color: #dc3545;
        justify-content: center; /* Centra il testo logout */
    }
    
    /* Correzione input data su mobile per non sforare */
    .date-input-wrapper {
        width: 100%;
    }
}

/* ==========================================================================
   USER WELCOME BAR (Sopra il Submenu)
   ========================================================================== */

.user-welcome-bar {
    background-color: var(--rotary-blue); /* Sfondo Blu scuro */
    color: #fff;
    padding: 12px 0;
    position: relative;
    z-index: 5; /* Sopra al sottomenu se serve */
    border-bottom: 1px solid rgba(255,255,255,0.1);
}

.welcome-inner {
    display: flex;
    align-items: center;
    gap: 15px;
}

/* Icona Utente Cerchiata */
.user-icon-circle {
    width: 35px;
    height: 35px;
    background-color: rgba(255, 255, 255, 0.1);
    border: 1px solid var(--rotary-gold); /* Bordo Oro */
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--rotary-gold);
    font-size: 1rem;
}

/* Testi */
.user-info-text {
    display: flex;
    align-items: baseline; /* Allinea il testo sulla riga */
    gap: 5px;
    font-family: 'Montserrat', sans-serif;
}

.welcome-label {
    font-weight: 400;
    font-size: 0.95rem;
    opacity: 0.8; /* Leggermente trasparente */
}

.user-fullname {
    font-weight: 700; /* Cognome in grassetto */
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Info Extra (Data) - Spinta a destra */
.user-meta-info {
    margin-left: auto; /* Spinge tutto a destra */
    font-family: 'Inter', sans-serif;
    font-size: 0.85rem;
    opacity: 0.7;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* --- Responsive per la barra utente --- */
@media (max-width: 600px) {
    .user-meta-info {
        display: none; /* Nascondi la data su mobile per spazio */
    }
    
    .user-info-text {
        flex-direction: column; /* Nome sotto "Benvenuto" su schermi piccoli */
        align-items: flex-start;
        gap: 0;
        line-height: 1.2;
    }
    
    .welcome-label { font-size: 0.8rem; }
    .user-fullname { font-size: 0.9rem; }
}

/* ==========================================================================
   PAGINA SICUREZZA - LAYOUT LIBERO
   ========================================================================== */

/* Wrapper che limita la larghezza per non far "spanciare" il form su schermi larghi */
.security-layout-wrapper {
    max-width: 900px; /* Più largo del precedente perché non c'è il padding del box */
   
}

/* Sezioni "Libere" */
.security-section-free {
    margin-bottom: 20px;
}

/* Titoli delle Sezioni (Senza bordo sotto, più puliti) */
.security-section-title {
    font-size: 1.3rem;
    color: var(--rotary-blue);
    margin-bottom: 25px;
    display: flex;
    align-items: center;
    gap: 12px;
    font-weight: 700;
}

.security-section-title i {
    color: var(--rotary-gold);
    background: rgba(247, 168, 27, 0.1); /* Sfondo leggero oro dietro l'icona */
    width: 40px; height: 40px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%;
    font-size: 1.1rem;
}

/* Spaziatore tra le sezioni */
.security-spacer {
    height: 40px;
    border-bottom: 1px dashed #ddd; /* Linea tratteggiata leggera per separare visivamente */
    margin-bottom: 40px;
}

/* --- INPUT CON OMBRA (Per risaltare senza box contenitore) --- */
.shadow-input {
    background-color: #fff !important; /* Forza bianco puro */
    border: 1px solid #eee;
    box-shadow: 0 4px 10px rgba(0,0,0,0.03); /* Ombra leggera su ogni input */
    height: 50px; /* Input un po' più alti per eleganza */
}

.shadow-input:focus {
    box-shadow: 0 5px 15px rgba(0, 36, 125, 0.1);
    border-color: var(--rotary-blue);
}

/* Griglia layout (Rimane uguale) */
.row {
    display: flex;
    margin: 0 -15px;
}

.col-md-6 {
    flex: 0 0 50%;
    max-width: 50%;
    padding: 0 15px;
}

/* Label più evidenti visto che non c'è il box */
.form-group label {
    font-size: 0.9rem;
    color: #444;
    margin-bottom: 10px;
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: 0.5px;
}

/* Bottoni */
.btn-save-security {
    background-color: var(--rotary-blue);
    color: #fff;
    border: none;
    padding: 16px 45px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 0.95rem;
    border-radius: 50px;
    cursor: pointer;
    transition: all 0.3s;
    box-shadow: 0 5px 15px rgba(0, 36, 125, 0.2);
}

.btn-save-security:hover {
    background-color: var(--rotary-gold);
    color: var(--rotary-blue);
    transform: translateY(-2px);
}

.btn-cancel {
    margin-left: 20px;
    color: #666;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.9rem;
}

/* Responsive */
@media (max-width: 768px) {
    .row { flex-direction: column; }
    .col-md-6 { max-width: 100%; margin-bottom: 20px; }
    .form-group[style*="max-width: 50%"] { max-width: 100% !important; } /* Su mobile full width */
}

/* ==========================================================================
   BANNER NOTIFICHE (ERRORE)
   ========================================================================== */

.error-alert-bar {
    background-color: #dc3545; /* Rosso Errore */
    color: #fff;
    padding: 15px 0;
    margin-bottom: 20px;
    position: relative;
    box-shadow: 0 4px 10px rgba(220, 53, 69, 0.2);
    
    /* Usa la stessa animazione del banner successo */
    animation: slideDownFade 0.5s ease-out forwards;
}

/* Nota: .alert-content, .alert-icon, .alert-text, .alert-close 
   sono già definiti nel CSS precedente del banner verde, 
   quindi vengono ereditati automaticamente! 
   Non serve riscriverli. */

/* ==========================================================================
   BANNER NOTIFICHE (SUCCESSO)
   ========================================================================== */

.success-alert-bar {
    background-color: #28a745; /* Verde Successo Standard */
    color: #fff;
    padding: 15px 0;
    margin-bottom: 20px; /* Attaccato visivamente, o dai margine se preferisci */
    position: relative;
    box-shadow: 0 4px 10px rgba(40, 167, 69, 0.2);
    
    /* Animazione Ingresso */
    animation: slideDownFade 0.5s ease-out forwards;
}

.alert-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.alert-icon {
    font-size: 1.5rem;
    margin-right: 15px;
    background: rgba(255, 255, 255, 0.2);
    width: 40px; height: 40px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%;
}

.alert-text {
    flex-grow: 1;
    font-family: 'Inter', sans-serif;
    font-size: 1rem;
}

.alert-text strong {
    font-weight: 700;
    text-transform: uppercase;
    font-size: 0.9rem;
    margin-right: 5px;
}

.alert-close {
    background: none;
    border: none;
    color: #fff;
    font-size: 1.2rem;
    cursor: pointer;
    opacity: 0.7;
    transition: opacity 0.3s, transform 0.3s;
    padding: 0 10px;
}

.alert-close:hover {
    opacity: 1;
    transform: scale(1.1);
}

/* Animazione Keyframes */
@keyframes slideDownFade {
    0% {
        opacity: 0;
        transform: translateY(-20px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Responsive */
@media (max-width: 600px) {
    .alert-text { font-size: 0.9rem; }
    .alert-icon { width: 30px; height: 30px; font-size: 1.2rem; }
}