/**
 * Branded login page for TDB Forms.
 * Loaded via TDB_Auth::brand_login_screen() on every wp-login.php request.
 */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&family=Open+Sans:wght@400;500;600;700&display=swap');

:root {
    --tdb-plum: #603F5D;
    --tdb-plum-deep: #3E2940;
    --tdb-plum-soft: #8A6685;
    --tdb-green: #1C7012;
    --tdb-gold: #C9A961;
    --tdb-cream: #FBF8F3;
    --tdb-bone: #FDFCF8;
    --tdb-ink: #1A1614;
    --tdb-ink-muted: #7A6E64;
    --tdb-line: #ECE4D6;
}

body.login {
    background: var(--tdb-cream) !important;
    font-family: 'Open Sans', system-ui, sans-serif;
    background-image:
        radial-gradient(ellipse 700px 500px at 20% 10%, rgba(96,63,93,0.08) 0%, transparent 55%),
        radial-gradient(ellipse 600px 400px at 80% 90%, rgba(28,112,18,0.05) 0%, transparent 55%) !important;
}

body.login::before {
    content: '';
    position: fixed; inset: 0;
    background-image: radial-gradient(circle at 1px 1px, rgba(96,63,93,0.05) 1px, transparent 0);
    background-size: 28px 28px;
    pointer-events: none;
    z-index: 0;
}

#login {
    position: relative;
    z-index: 1;
    width: 380px !important;
    padding: 5% 0 0 !important;
}

/* Logo */
.login h1 a {
    background-image: none !important;
    width: auto !important;
    height: auto !important;
    text-indent: 0 !important;
    display: block !important;
    padding: 0 !important;
    margin-bottom: 28px !important;
}
.login h1 a::before {
    content: 'T';
    display: block;
    width: 72px; height: 72px;
    background: var(--tdb-plum);
    color: var(--tdb-gold);
    border-radius: 50%;
    margin: 0 auto 14px;
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    font-size: 32px;
    line-height: 72px;
    box-shadow:
        0 8px 24px -4px rgba(96,63,93,0.35),
        inset 0 -2px 8px rgba(0,0,0,0.15),
        0 0 0 6px rgba(96,63,93,0.06);
}
.login h1 a::after {
    content: 'TDB Forms';
    display: block;
    font-family: 'Poppins', sans-serif;
    font-size: 22px;
    font-weight: 600;
    color: var(--tdb-ink);
    letter-spacing: -0.015em;
    text-align: center;
}

/* Form container */
.login form {
    background: #fff !important;
    border: 1px solid var(--tdb-line) !important;
    border-radius: 20px !important;
    padding: 32px !important;
    box-shadow:
        0 1px 2px rgba(26,22,20,0.04),
        0 16px 40px -16px rgba(96,63,93,0.18) !important;
    margin-top: 0 !important;
}

.login label {
    color: var(--tdb-ink) !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    margin-bottom: 6px !important;
    display: block !important;
}

.login input[type="text"],
.login input[type="password"],
.login input[type="email"] {
    background: var(--tdb-bone) !important;
    border: 1.5px solid var(--tdb-line) !important;
    border-radius: 12px !important;
    padding: 12px 14px !important;
    font-family: 'Open Sans', sans-serif !important;
    font-size: 15px !important;
    color: var(--tdb-ink) !important;
    box-shadow: none !important;
    margin-bottom: 16px !important;
    transition: all 0.15s !important;
}
.login input[type="text"]:focus,
.login input[type="password"]:focus,
.login input[type="email"]:focus {
    background: #fff !important;
    border-color: var(--tdb-plum) !important;
    box-shadow: 0 0 0 4px rgba(96,63,93,0.08) !important;
    outline: none !important;
}

/* Submit button */
.wp-core-ui .button-primary {
    background: var(--tdb-plum) !important;
    border: none !important;
    border-radius: 100px !important;
    padding: 12px 22px !important;
    font-family: 'Open Sans', sans-serif !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #fff !important;
    text-shadow: none !important;
    box-shadow: 0 4px 12px -2px rgba(96,63,93,0.35) !important;
    transition: all 0.15s !important;
    width: 100% !important;
    height: auto !important;
    line-height: 1 !important;
}
.wp-core-ui .button-primary:hover,
.wp-core-ui .button-primary:focus {
    background: var(--tdb-plum-deep) !important;
    transform: translateY(-1px);
}

/* Forgot password / nav links */
#nav, #backtoblog {
    text-align: center !important;
    padding: 16px 0 !important;
    margin: 0 !important;
}
#nav a, #backtoblog a {
    color: var(--tdb-ink-muted) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
}
#nav a:hover, #backtoblog a:hover {
    color: var(--tdb-plum) !important;
}

/* Remember me checkbox */
.forgetmenot {
    color: var(--tdb-ink-muted) !important;
    font-size: 13px !important;
}

/* Hide language switcher (not needed for community client) */
.language-switcher { display: none !important; }

/* Privacy policy link */
.privacy-policy-page-link {
    text-align: center !important;
    margin-top: 16px !important;
}
.privacy-policy-page-link a {
    color: var(--tdb-ink-muted) !important;
    font-size: 12px !important;
}

/* Error messages */
.login .message,
.login #login_error {
    border-radius: 10px !important;
    border-left: 4px solid var(--tdb-plum) !important;
    background: #fff !important;
    box-shadow: 0 4px 12px -2px rgba(96,63,93,0.1) !important;
}
.login #login_error {
    border-left-color: #B85450 !important;
}
