/*
 File: /wp-content/themes/snapbrainy-website/style.css
 Theme Name:  SnapBrainy Child
 Description: Stile Premium "Apple Library" - Unified System (Product, Dashboard, Login & Header)
 Version:     5.1 (Includes Header & Product Page Fixes)
*/

/* ====================================================================== */
/* 1. DESIGN TOKENS (IL CUORE DEL SISTEMA)                                */
/* ====================================================================== */
:root {
    /* --- COLORI BRAND --- */
    --sb-brand: #01144f;            /* Navy Blue Scuro (Primary Action) */
    --sb-brand-hover: #000f3d;      /* Deep Navy */
    --sb-brand-glow: rgba(1, 20, 79, 0.25); 
    
    --sb-accent: #eff6ff;           /* Celeste chiarissimo (Sfondi Badge/Active) */
    --sb-accent-text: #1e3a8a;      /* Testo Badge */
    
    --sb-success: #16a34a;          /* Verde (Download/Successo) */
    --sb-success-bg: #dcfce7;
    --sb-error: #ef4444;            /* Rosso (Errori) */
    --sb-warning: #f59e0b;          /* Arancio (Processing) */

    /* --- SCALA GRIGI (Apple Slate) --- */
    --sb-dark: #1d1d1f;             /* Testo Titoli (Quasi nero Apple) */
    --sb-text: #334155;             /* Testo Paragrafi */
    --sb-muted: #86868b;            /* Testo secondario */
    --sb-border: #e2e8f0;           /* Bordi sottili */
    --sb-bg: #F5F5F7;               /* Sfondo Generale (Apple Light Gray) */
    --sb-surface: #ffffff;          /* Sfondo Card (Bianco) */

    /* --- GEOMETRIE --- */
    --sb-radius: 12px;              /* Input e Bottoni */
    --sb-radius-lg: 20px;           /* Card e Container grandi */
    --sb-radius-pill: 100px;        /* Navigazione e Badge */
    
    /* --- TIPOGRAFIA --- */
    --sb-font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

/* ====================================================================== */
/* 2. RESET GLOBALE ACCOUNT (VIA IL BLU SCURO!)                           */
/* ====================================================================== */

/* Questo blocco forza lo sfondo Grigio Apple (#F5F5F7) sovrascrivendo Kadence */
body.woocommerce-account,
body.woocommerce-account #inner-wrap,
body.woocommerce-account .site-container,
body.woocommerce-account .content-area,
body.woocommerce-account .site-main,
body.woocommerce-account .entry-content,
body.woocommerce-account #sb-auth-iso,
body.woocommerce-account .sb-auth-container {
    background-color: var(--sb-bg) !important; 
    background-image: none !important;
    color: var(--sb-dark) !important; 
}

/* Rimuove padding inutili che creano spazi vuoti */
body.woocommerce-account .site-content {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* Nasconde titoli del tema e footer residui */
body.woocommerce-account .entry-header,
body.woocommerce-account .page-header,
body.woocommerce-account .site-footer,
body.woocommerce-account #colophon {
    display: none !important;
}

/* ====================================================================== */
/* 3. WRAPPER & HEADER (DASHBOARD)                                        */
/* ====================================================================== */
.sb-dashboard-wrapper {
    max-width: 980px;
    margin: 60px auto 100px;
    padding: 0 24px;
    font-family: var(--sb-font);
}

.sb-dash-header {
    text-align: center;
    margin-bottom: 50px;
}

.sb-dash-header h1 {
    font-size: 3rem !important;
    font-weight: 700 !important;
    letter-spacing: -0.02em !important;
    color: var(--sb-dark) !important;
    margin-bottom: 12px !important;
    line-height: 1.1;
}

.sb-dash-header p {
    font-size: 1.25rem !important;
    color: var(--sb-muted) !important;
    font-weight: 400;
    max-width: 600px;
    margin: 0 auto;
}

/* ====================================================================== */
/* 4. NAVIGAZIONE (SEGMENTED CONTROL STYLE)                               */
/* ====================================================================== */
.sb-nav-pills {
    display: inline-flex;
    background: rgba(118, 118, 128, 0.12); /* Sfondo semitrasparente */
    padding: 3px;
    border-radius: 100px;
    margin: 0 auto 60px;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    backdrop-filter: blur(10px);
}

.sb-nav-link {
    padding: 8px 20px;
    border-radius: 100px;
    color: #48484a;
    font-weight: 500;
    font-size: 0.9rem;
    text-decoration: none !important;
    transition: all 0.2s cubic-bezier(0.25, 1, 0.5, 1);
    white-space: nowrap;
}

.sb-nav-link:hover {
    color: #000;
}

.sb-nav-link.active {
    background: #ffffff;
    color: #000000;
    font-weight: 600;
    box-shadow: 0 3px 8px rgba(0,0,0,0.12), 0 1px 1px rgba(0,0,0,0.04);
}

/* ====================================================================== */
/* 5. LIBRARY GRID (APPLE CARDS)                                          */
/* ====================================================================== */
.sb-library-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 32px;
}

.sb-asset-card {
    background: #ffffff;
    border-radius: var(--sb-radius-lg);
    padding: 24px;
    border: none !important;
    box-shadow: 0 4px 24px rgba(0,0,0,0.04), 0 1px 2px rgba(0,0,0,0.02); 
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
}

.sb-asset-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.08);
}

.sb-asset-cover-wrap {
    height: 240px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 24px;
    background: transparent;
}

.sb-asset-cover {
    height: 100%;
    width: auto;
    object-fit: contain;
    border-radius: 6px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.15), 0 2px 6px rgba(0,0,0,0.1);
    transition: transform 0.3s ease;
}

.sb-asset-card:hover .sb-asset-cover { transform: scale(1.03); }

.sb-asset-info { text-align: center; }

.sb-asset-title {
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
    margin-bottom: 6px !important;
    color: var(--sb-dark) !important;
    min-height: 3em;
}
.sb-asset-title a { color: inherit; text-decoration: none; }

.sb-asset-meta {
    font-size: 0.8rem;
    color: var(--sb-muted);
    margin-bottom: 20px;
    font-weight: 500;
}

.sb-dl-actions {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: auto;
}

.sb-dl-btn {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    background: #F2F2F7;
    color: var(--sb-brand) !important;
    border-radius: 100px;
    font-size: 0.75rem;
    font-weight: 700;
    transition: all 0.2s;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none;
}
.sb-dl-btn:hover { background: #E5E5EA; transform: scale(1.05); }

/* ====================================================================== */
/* 6. ORDERS & FORMS (PANEL STYLES)                                       */
/* ====================================================================== */
.sb-panel-card {
    background: #ffffff;
    border-radius: 20px;
    box-shadow: 0 4px 24px rgba(0,0,0,0.04);
    padding: 40px;
    margin-bottom: 30px;
    border: none !important;
}

/* Fix Input (Leggibilità su sfondo) */
input.sb-input, 
input[type="text"], input[type="email"], input[type="password"] {
    background-color: #F5F5F7 !important;
    border: 1px solid transparent !important;
    border-radius: 12px !important;
    padding: 14px 16px !important;
    font-size: 16px !important; 
    color: var(--sb-dark) !important;
    box-shadow: none !important;
}

input.sb-input:focus,
input[type="text"]:focus {
    background-color: #fff !important;
    border-color: var(--sb-brand) !important;
    box-shadow: 0 0 0 4px var(--sb-brand-glow) !important;
    outline: none !important;
}

label.sb-form-label {
    color: var(--sb-muted);
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    margin-bottom: 8px;
    display: block;
}

/* ====================================================================== */
/* 7. LOGIN PAGE OVERRIDES (FIX GRAFICA GIALLA/BIANCA)                    */
/* ====================================================================== */
#customer_login, 
.u-column1, 
.u-column2,
.woocommerce-form-login {
    background: #ffffff !important;
    border-radius: 24px !important;
    border: none !important;
    box-shadow: 0 20px 40px -10px rgba(0,0,0,0.08) !important;
    padding: 40px !important;
    max-width: 450px !important;
    margin: 0 auto !important;
}

#customer_login h2,
.woocommerce h2 {
    color: var(--sb-brand) !important;
    font-size: 2rem !important;
    font-weight: 800 !important;
    text-align: center !important;
    text-shadow: none !important;
    margin-bottom: 30px !important;
    background: transparent !important;
}

.woocommerce-form-login label,
.woocommerce-form-register label {
    color: var(--sb-muted) !important;
    font-size: 0.85rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    margin-bottom: 8px !important;
}
.required { color: var(--sb-error) !important; text-decoration: none !important; }

/* Link sotto il form */
.woocommerce-LostPassword, .woocommerce-form-login__rememberme {
    text-align: center;
    margin-top: 20px !important;
}
.woocommerce-LostPassword a { color: var(--sb-muted) !important; text-decoration: underline !important; }
.woocommerce-LostPassword a:hover { color: var(--sb-brand) !important; }

/* ====================================================================== */
/* 8. GLOBAL BUTTON FIX (FORZA BRUTA CONTRO IL GIALLO)                    */
/* ====================================================================== */

/* Targettiamo esattamente tutti i bottoni Woo per uniformarli al Navy */
body .woocommerce button.button.woocommerce-form-login__submit,
body .woocommerce button.button[name="register"],
body .woocommerce button.button,
body #customer_login .button {
    
    /* 1. Colore Navy Blue (Via il giallo) */
    background-color: var(--sb-brand) !important;
    color: #ffffff !important;
    
    /* 2. Reset Grafico Completo */
    background-image: none !important;
    border: 1px solid var(--sb-brand) !important;
    text-shadow: none !important;
    box-shadow: 0 4px 14px rgba(1, 20, 79, 0.3) !important;
    
    /* 3. Dimensioni e Font */
    border-radius: 12px !important;
    padding: 15px 24px !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    
    /* 4. Layout */
    width: 100%;
    display: block;
    margin-top: 10px;
    cursor: pointer;
}

/* Hover State */
body .woocommerce button.button:hover,
body .woocommerce button.button.woocommerce-form-login__submit:hover {
    background-color: var(--sb-brand-hover) !important;
    border-color: var(--sb-brand-hover) !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(1, 20, 79, 0.4) !important;
    color: #fff !important;
}

/* Fix Focus Input Login (Da giallo a Blu) */
body .woocommerce form .form-row input.input-text:focus,
#customer_login input:focus {
    border-color: var(--sb-brand) !important;
    box-shadow: 0 0 0 4px var(--sb-brand-glow) !important;
    outline: none !important;
}

/* ====================================================================== */
/* 9. HEADER & NAVIGATION FIXES (DAL TUO CSS AGGIUNTIVO)                  */
/* ====================================================================== */

/* Correzione specifica per bottoni custom nel menu (classe buttuni_login) */
body .kb-buttons-wrap a.buttuni_login {
    color: #ffffff !important;
}

/* --- OTTIMIZZAZIONE HEADER PAGINA PRODOTTO (APPLE CLEAN STYLE) --- */

/* Nasconde la riga centrale (ricerca) solo nella Product Page */
body.single-product .wp-block-kadence-header-row-center {
    display: none !important;
}

/* MOBILE TWEAK: Alza il contenuto riducendo il padding dell'header */
@media (max-width: 767px) {
    body.single-product header.site-header {
        padding-bottom: 0px !important;
        min-height: auto !important;
    }
    body.single-product .site-header-inner-wrap {
        padding-bottom: 0 !important;
    }
}

/* ====================================================================== */
/* 10. RESPONSIVE ADJUSTMENTS                                             */
/* ====================================================================== */
@media (max-width: 768px) {
    .sb-dashboard-wrapper {
        margin-top: 20px;
        margin-bottom: 40px;
        padding: 0 16px;
    }
    .sb-dash-header h1 { font-size: 2.2rem !important; }
    
    .sb-library-grid { grid-template-columns: 1fr; gap: 20px; }
    
    /* Mobile Card Layout */
    .sb-asset-card {
        padding: 20px;
        flex-direction: row;
        align-items: center;
        gap: 16px;
        text-align: left;
    }
    .sb-asset-cover-wrap {
        height: 100px; width: 70px;
        margin-bottom: 0; flex-shrink: 0;
    }
    .sb-asset-info { text-align: left; flex-grow: 1; }
    .sb-asset-title { font-size: 1rem !important; min-height: auto; margin-bottom: 8px !important; }
    .sb-dl-actions { justify-content: flex-start; flex-wrap: wrap; }
    
    /* Navigazione Scrollabile */
    .sb-nav-pills {
        width: 100%;
        justify-content: space-between;
        padding: 4px;
    }
    .sb-nav-link { padding: 8px 0; flex: 1; text-align: center; font-size: 0.8rem; }
}
/* ====================================================================== */
/* 10. LOGIN PAGE FIX (ISOLAMENTO TOTALE)                                 */
/* ====================================================================== */

/* Wrapper che copre l'eventuale sfondo nero del tema */
.sb-login-page-wrapper {
    background-color: #F5F5F7 !important; /* Grigio Apple */
    min-height: 80vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
}

.sb-login-container {
    width: 100%;
    max-width: 440px;
}

.sb-login-header {
    text-align: center;
    margin-bottom: 30px;
}
.sb-login-header h1 {
    color: #1d1d1f !important;
    font-size: 2.2rem !important;
    margin-bottom: 8px !important;
}
.sb-login-header p {
    color: #86868b !important;
    font-size: 1.1rem !important;
}

/* La Card Bianca */
.sb-login-card {
    background: #ffffff !important;
    padding: 40px !important;
    border-radius: 24px !important;
    box-shadow: 0 20px 40px -10px rgba(0,0,0,0.08) !important;
    border: 1px solid rgba(0,0,0,0.05) !important;
}

/* Reset Label */
.sb-input-group label {
    color: #86868b !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    margin-bottom: 8px !important;
    display: block;
}

/* Reset Input */
input.sb-login-input {
    background-color: #F5F5F7 !important;
    border: 1px solid transparent !important;
    border-radius: 12px !important;
    padding: 16px !important;
    font-size: 16px !important;
    color: #1d1d1f !important;
    width: 100% !important;
    box-shadow: none !important;
    margin-bottom: 20px !important;
}

input.sb-login-input:focus {
    background: #fff !important;
    border-color: #01144f !important;
    box-shadow: 0 0 0 4px rgba(1, 20, 79, 0.15) !important;
}

/* IL BOTTONE (BLU DEFINITIVO) */
button.sb-login-btn {
    background-color: #01144f !important; /* Navy Brand */
    color: #ffffff !important;
    border: 1px solid #01144f !important;
    background-image: none !important;
    text-shadow: none !important;
    box-shadow: 0 4px 14px rgba(1, 20, 79, 0.3) !important;
    border-radius: 12px !important;
    padding: 16px !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    width: 100% !important;
    margin-top: 15px !important;
    opacity: 1 !important;
}

button.sb-login-btn:hover {
    background-color: #000f3d !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(1, 20, 79, 0.4) !important;
}

/* Link persi */
.woocommerce-LostPassword { text-align: center; margin-top: 20px !important; }
.woocommerce-LostPassword a { color: #86868b !important; font-size: 0.9rem !important; }
.woocommerce-LostPassword a:hover { color: #01144f !important; }