/* ═══════════════════════════════════════════════════════════════
   TESSITURA BLEVE — Custom Login CSS  v1.0.0
   Layout: split-screen (pannello decorativo + form)
   Palette: CSS variables iniettate da PHP (override di wp-login.css)
═══════════════════════════════════════════════════════════════ */

/* ── Reset globale pagina login ─────────────────────────────── */
html,
body.tb-custom-login {
    height: 100%;
    min-height: 100vh;
    margin: 0;
    padding: 0;
    background-color: var(--color-bg);
    font-family: var(--font-body);
    font-weight: 300;
    color: var(--color-text);
    -webkit-font-smoothing: antialiased;
}

/* Nasconde solo gli elementi nativi WordPress — NON #login (contiene il form) */
body.tb-custom-login .wp-login-logo,
body.tb-custom-login #backtoblog,
body.tb-custom-login .language-switcher {
    display: none !important;
}

/* ── Wrapper split-screen ───────────────────────────────────── */
#tb-login-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 100vh;
}

@media (max-width: 900px) {
    #tb-login-wrap {
        grid-template-columns: 1fr;
    }
}

/* ── PANNELLO SINISTRO ─────────────────────────────────────── */
.tb-login-panel {
    position: relative;
    overflow: hidden;
    background-color: var(--color-accent);
    background-image: var(--panel-bg-image, none);
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: stretch;
    min-height: 100vh;
}

/* Overlay pattern tessile (quando non c'è immagine) */
.tb-login-panel::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 39px,
            rgba(255,255,255,.04) 39px,
            rgba(255,255,255,.04) 40px
        ),
        repeating-linear-gradient(
            90deg,
            transparent,
            transparent 39px,
            rgba(255,255,255,.04) 39px,
            rgba(255,255,255,.04) 40px
        );
    z-index: 1;
    pointer-events: none;
}

/* Overlay scuro sopra l'immagine di sfondo */
.tb-login-panel::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        160deg,
        rgba(46,36,32,.72) 0%,
        rgba(46,36,32,.45) 60%,
        rgba(122,79,45,.35) 100%
    );
    z-index: 2;
    pointer-events: none;
}

.tb-login-panel__inner {
    position: relative;
    z-index: 3;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 60px 52px;
    width: 100%;
    color: rgba(255,255,255,.9);
}

/* Etichetta verticale */
.tb-login-panel__label {
    position: absolute;
    top: 52px;
    left: 52px;
    font-family: var(--font-body);
    font-size: 10px;
    font-weight: 400;
    letter-spacing: .32em;
    text-transform: uppercase;
    color: rgba(255,255,255,.55);
}

.tb-login-panel__label::before {
    content: var(--panel-label, 'TESSITURA BLEVE');
}

/* Ornamento geometrico */
.tb-login-panel__ornament {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 120px;
    height: 120px;
    color: rgba(255,255,255,.12);
    animation: tb-rotate 60s linear infinite;
}

@keyframes tb-rotate {
    from { transform: translate(-50%, -50%) rotate(0deg); }
    to   { transform: translate(-50%, -50%) rotate(360deg); }
}

/* Claim in basso */
.tb-login-panel__claim {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 2.5vw, 2.25rem);
    font-weight: 300;
    font-style: italic;
    line-height: 1.3;
    color: rgba(255,255,255,.88);
    margin: 0;
    letter-spacing: -.01em;
}

/* Linea decorativa sopra il claim */
.tb-login-panel__claim::before {
    content: '';
    display: block;
    width: 40px;
    height: 1px;
    background: rgba(255,255,255,.4);
    margin-bottom: 20px;
}

/* Nasconde il pannello su mobile */
@media (max-width: 900px) {
    .tb-login-panel {
        display: none;
    }
}

/* ── COLONNA DESTRA — Form ─────────────────────────────────── */
.tb-login-main {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 60px 40px;
    background-color: var(--color-bg);
}

.tb-login-main__inner {
    width: 100%;
    max-width: 400px;
    display: flex;
    flex-direction: column;
    gap: 0;
}

/* ── Logo ───────────────────────────────────────────────────── */
.tb-login-logo {
    margin-bottom: 44px;
    display: flex;
    justify-content: center;
}

.tb-login-logo-link {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    transition: opacity .3s ease;
}

.tb-login-logo-link:hover { opacity: .75; }

.tb-login-logo-img {
    display: block !important;
    width: auto !important;
    height: auto !important;
    /* Solo max-width: nessun max-height che con loghi quadrati
       diventa il vincolo dominante e blocca il resize */
    max-width: var(--logo-width, 180px) !important;
    object-fit: contain;
}

@media (max-width: 767px) {
    .tb-login-logo-img {
        max-width: var(--logo-width-mobile, 140px) !important;
    }
}

/* Fallback testo */
.tb-login-logo-text {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    font-weight: 400;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--color-accent);
    text-decoration: none;
    line-height: 1;
    transition: color .3s ease;
}

.tb-login-logo-text:hover { color: var(--color-primary); }

/* ── Titolo sopra form (aggiunto da WP via filtro) ──────────── */
/* Lo nascondo: il logo fa da heading */
body.tb-custom-login h1.screen-reader-text {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0,0,0,0) !important;
}

/* ── Riposiziona il div #login nativo DENTRO .tb-login-main ─── */
/* WordPress inserisce #login FUORI da tutto —
   lo intercettiamo via JS inline per spostarlo, oppure lo
   rigeneriamo completamente via hook login_header / login_footer.
   Il CSS qui sopra con display:none lo nasconde comunque. */

/* ── FORM — override stili nativi WordPress ─────────────────── */
body.tb-custom-login #loginform,
body.tb-custom-login #lostpasswordform,
body.tb-custom-login #registerform {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* Inserisce il form DENTRO la colonna destra */
body.tb-custom-login .tb-login-main .tb-login-main__inner > form,
body.tb-custom-login .tb-login-main__inner #loginform,
body.tb-custom-login .tb-login-main__inner #lostpasswordform {
    width: 100%;
}

/* Intercettazione: WP inserisce #login fuori, ma noi usiamo
   login_header e login_footer per wrappare tutto correttamente. */

/* ── Labels ─────────────────────────────────────────────────── */
body.tb-custom-login label,
body.tb-custom-login .form-table td label {
    font-family: var(--font-body);
    font-size: 11px;
    font-weight: 400;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--color-accent);
    display: block;
    margin-bottom: 6px;
}

/* ── Input fields ───────────────────────────────────────────── */
body.tb-custom-login input[type="text"],
body.tb-custom-login input[type="password"],
body.tb-custom-login input[type="email"] {
    width: 100% !important;
    padding: 13px 16px !important;
    background-color: var(--color-bg) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: 0 !important;
    font-family: var(--font-body) !important;
    font-size: 16px !important;
    font-weight: 400 !important;            /* era 300: troppo sottile */
    color: var(--color-accent) !important;  /* era color-text: più scuro = più leggibile */
    letter-spacing: .01em !important;
    box-shadow: none !important;
    transition: border-color .3s ease, box-shadow .3s ease !important;
    box-sizing: border-box !important;
    appearance: none;
    -webkit-appearance: none;
}

body.tb-custom-login input[type="text"]:focus,
body.tb-custom-login input[type="password"]:focus,
body.tb-custom-login input[type="email"]:focus {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 3px rgba(122,79,45,.1) !important;
    outline: none !important;
    color: var(--color-accent) !important;
}

/* Placeholder leggibile */
body.tb-custom-login input::placeholder {
    color: var(--color-secondary) !important;
    opacity: .7 !important;
    font-weight: 300 !important;
}

/* .wp-pwd: contenitore relativo, il bordo lo porta l'input dentro —
   stesso aspetto del campo username, altezza identica */
body.tb-custom-login .wp-pwd {
    position: relative;
    display: block;
}

/* Il bottone occhio è assoluto dentro l'input, non aggiunge altezza */
body.tb-custom-login .wp-hide-pw {
    position: absolute !important;
    top: 50% !important;
    right: 0 !important;
    transform: translateY(-50%) !important;
    width: 44px !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    color: var(--color-secondary) !important;
    padding: 0 !important;
    margin: 0 !important;
    cursor: pointer !important;
    z-index: 2;
}

body.tb-custom-login .wp-hide-pw:hover {
    color: var(--color-primary) !important;
}

body.tb-custom-login .wp-hide-pw .dashicons {
    width: 18px;
    height: 18px;
    font-size: 18px;
    line-height: 1;
}

/* Input password: padding-right per non sovrapporre il testo al bottone occhio */
body.tb-custom-login .wp-pwd input[type="password"],
body.tb-custom-login .wp-pwd input[type="text"] {
    padding-right: 48px !important;
    /* Bordo e altezza identici all'input username */
}

/* Caps lock warning
   display:none di base; il nostro login.js imposta style.display='flex'
   quando CapsLock è attivo — inline style batte questa regola CSS. */
body.tb-custom-login #caps-warning,
body.tb-custom-login .caps-warning {
    display: none;
    align-items: center;
    gap: 8px;
    margin-top: 8px;
    padding: 7px 10px;
    background: rgba(122,79,45,.08);
    border-left: 2px solid var(--color-secondary);
    font-size: 12px;
    font-family: var(--font-body);
    letter-spacing: .04em;
    color: var(--color-accent);
    line-height: 1.4;
}

body.tb-custom-login #caps-warning .caps-icon svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    fill: var(--color-secondary);
    stroke: var(--color-secondary);
}

/* ── Spaziatura paragrafi form ──────────────────────────────── */
body.tb-custom-login #loginform p,
body.tb-custom-login #lostpasswordform p {
    margin-bottom: 20px !important;
    padding: 0 !important;
}

body.tb-custom-login #loginform p:last-child {
    margin-bottom: 0 !important;
}

/* ── "Ricordami" checkbox ───────────────────────────────────── */
body.tb-custom-login .forgetmenot {
    display: flex !important;
    align-items: center;
    gap: 8px;
    margin-bottom: 24px !important;
}

body.tb-custom-login .forgetmenot input[type="checkbox"] {
    width: 16px !important;
    height: 16px !important;
    margin: 0 !important;
    padding: 0 !important;
    accent-color: var(--color-primary);
    cursor: pointer;
}

body.tb-custom-login .forgetmenot label {
    font-size: 12px;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--color-secondary);
    margin: 0 !important;
    cursor: pointer;
    user-select: none;
}

/* ── Submit button ──────────────────────────────────────────── */
body.tb-custom-login .submit,
body.tb-custom-login p.submit {
    margin: 0 !important;
    padding: 0 !important;
}

body.tb-custom-login input[type="submit"],
body.tb-custom-login #wp-submit {
    display: block !important;
    width: 100% !important;
    padding: 14px 28px !important;
    background-color: var(--color-primary) !important;
    color: #ffffff !important;
    border: 1px solid var(--color-primary) !important;
    border-radius: 0 !important;
    font-family: var(--font-body) !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    letter-spacing: .18em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    box-shadow: none !important;
    text-shadow: none !important;
    transition: background-color .3s ease, border-color .3s ease, transform .15s ease !important;
    height: auto !important;
    line-height: 1 !important;
}

body.tb-custom-login input[type="submit"]:hover,
body.tb-custom-login #wp-submit:hover {
    background-color: var(--color-accent) !important;
    border-color: var(--color-accent) !important;
}

body.tb-custom-login input[type="submit"]:active {
    transform: translateY(1px) !important;
}

body.tb-custom-login input[type="submit"]:focus-visible {
    outline: 2px solid var(--color-primary) !important;
    outline-offset: 3px !important;
}

/* ── User/Pass wrap ─────────────────────────────────────────── */
body.tb-custom-login .user-pass-wrap {
    position: relative;
}

/* ── Divisore tra form e link ───────────────────────────────── */
body.tb-custom-login #loginform::after {
    content: '';
    display: block;
    height: 1px;
    background: var(--color-border);
    margin: 28px 0 20px;
}

/* ── Link "Password dimenticata?" ───────────────────────────── */
body.tb-custom-login #nav,
body.tb-custom-login p#nav {
    display: block !important;
    text-align: center;
    margin: 0 !important;
    padding: 0 !important;
}

body.tb-custom-login #nav a,
body.tb-custom-login p#nav a,
body.tb-custom-login .wp-login-lost-password {
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    letter-spacing: .1em !important;
    text-transform: uppercase !important;
    color: var(--color-secondary) !important;
    text-decoration: none !important;
    border-bottom: 1px solid transparent !important;
    transition: color .3s ease, border-color .3s ease !important;
}

body.tb-custom-login #nav a:hover,
body.tb-custom-login .wp-login-lost-password:hover {
    color: var(--color-primary) !important;
    border-bottom-color: var(--color-primary) !important;
}

/* ── Link "Torna al sito" custom ────────────────────────────── */
.tb-login-back {
    margin-top: 40px !important;
    text-align: center;
    padding-top: 28px;
    border-top: 1px solid var(--color-border);
}

.tb-login-back a {
    font-family: var(--font-body);
    font-size: 11px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--color-secondary);
    text-decoration: none;
    transition: color .3s ease;
}

.tb-login-back a:hover {
    color: var(--color-primary);
}

/* ── Messaggi di errore / successo ──────────────────────────── */
body.tb-custom-login #login_error,
body.tb-custom-login .message,
body.tb-custom-login .success {
    background: transparent !important;
    border-left: 2px solid var(--color-primary) !important;
    border-radius: 0 !important;
    padding: 12px 16px !important;
    margin-bottom: 20px !important;
    font-size: 13px !important;
    font-family: var(--font-body) !important;
    box-shadow: none !important;
}

body.tb-custom-login #login_error {
    border-left-color: #c0392b !important;
    background-color: rgba(192,57,43,.06) !important;
    color: #c0392b !important;
}

body.tb-custom-login .message {
    background-color: rgba(122,79,45,.07) !important;
    color: var(--color-accent) !important;
}

body.tb-custom-login .success {
    background-color: rgba(46,36,32,.06) !important;
    color: var(--color-accent) !important;
}

/* ── Rimuove il bordo/sfondo nativo del blocco #login ──────── */
body.tb-custom-login #login {
    padding: 0 !important;
    background: none !important;
    box-shadow: none !important;
    border: none !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 0 !important;
}

/* ── Animazione di entrata ──────────────────────────────────── */
.tb-login-main__inner {
    animation: tb-fade-up .5s ease both;
    animation-delay: .1s;
    opacity: 0;
}

@keyframes tb-fade-up {
    from {
        opacity: 0;
        transform: translateY(14px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.tb-login-panel {
    animation: tb-fade-in .6s ease both;
}

@keyframes tb-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* ── Responsive mobile ──────────────────────────────────────── */
@media (max-width: 900px) {
    .tb-login-main {
        padding: 48px 28px;
        min-height: 100vh;
        justify-content: center;
    }

    .tb-login-main__inner {
        max-width: 100%;
    }
}

@media (max-width: 480px) {
    .tb-login-main {
        padding: 40px 20px;
    }
}

/* ── Accessibility: riduzione movimento ─────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .tb-login-main__inner,
    .tb-login-panel,
    .tb-login-panel__ornament {
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
    }
}

/* ── Focus visible globale ──────────────────────────────────── */
body.tb-custom-login :focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 3px;
}

/* ── Nasconde elementi residui WP ───────────────────────────── */
body.tb-custom-login .privacy-policy-page-link,
body.tb-custom-login #reg_passmail,
body.tb-custom-login .tb-login-back ~ * {
    display: none;
}
