@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;700&family=Plus+Jakarta+Sans:wght@500;700;800&display=swap');

:root {
    --imm-login-ink: #0c1d3a;
    --imm-login-muted: #60718f;
    --imm-login-surface: rgba(255, 255, 255, 0.88);
    --imm-login-surface-border: rgba(255, 255, 255, 0.45);
    --imm-login-focus: rgba(14, 109, 219, 0.25);
    --imm-login-accent-1: #0e6ddb;
    --imm-login-accent-2: #00b3c4;
}

body.login {
    min-height: 100vh;
    font-family: 'Plus Jakarta Sans', 'Segoe UI', sans-serif;
    color: var(--imm-login-ink);
    background:
        radial-gradient(1200px 700px at 5% 10%, rgba(255, 191, 98, 0.2), transparent 60%),
        radial-gradient(900px 600px at 95% 90%, rgba(45, 224, 255, 0.2), transparent 56%),
        linear-gradient(128deg, #021a3c 0%, #0a2d63 35%, #0f75c5 72%, #14a6af 100%);
    overflow-x: hidden;
}

body.login::before,
body.login::after {
    content: '';
    position: fixed;
    pointer-events: none;
    z-index: 0;
}

body.login::before {
    width: 44vw;
    min-width: 320px;
    height: 44vw;
    min-height: 320px;
    top: -12vh;
    right: -12vw;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.35), rgba(255, 255, 255, 0) 72%);
    transform: rotate(12deg);
}

body.login::after {
    inset: 0;
    background-image: linear-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.08) 1px, transparent 1px);
    background-size: 34px 34px;
    opacity: 0.12;
}

.login #login {
    position: relative;
    z-index: 1;
    width: min(92vw, 460px);
    margin: clamp(26px, 6vh, 70px) auto 0;
    padding: 0;
}

.login h1 {
    margin: 0 0 20px;
}

.login h1 a {
    width: min(84%, 320px);
    height: 78px;
    margin: 0 auto;
    background-size: contain;
    background-position: center;
}

.login form {
    margin-top: 0;
    padding: 30px 28px 24px;
    border-radius: 24px;
    border: 1px solid var(--imm-login-surface-border);
    background: var(--imm-login-surface);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 34px 70px rgba(2, 18, 43, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.7);
    animation: immigway-login-float 650ms cubic-bezier(0.18, 0.84, 0.34, 1);
}

@keyframes immigway-login-float {
    from {
        opacity: 0;
        transform: translateY(12px) scale(0.99);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.login .message,
.login #login_error,
.login .success {
    border-radius: 14px;
    border-left-width: 4px;
    box-shadow: 0 12px 24px rgba(8, 24, 54, 0.14);
}

.login label {
    display: inline-block;
    margin-bottom: 5px;
    font-family: 'Space Grotesk', 'Plus Jakarta Sans', sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--imm-login-muted);
}

.login form .input,
.login input[type="text"],
.login input[type="password"] {
    min-height: 46px;
    border-radius: 14px;
    border: 1px solid #cdd8ea;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: none;
    font-size: 15px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.login form .input:focus,
.login input[type="text"]:focus,
.login input[type="password"]:focus {
    border-color: var(--imm-login-accent-1);
    background: #ffffff;
    box-shadow: 0 0 0 4px var(--imm-login-focus);
}

.login .button.wp-hide-pw {
    color: #536381;
}

.login .forgetmenot label {
    font-family: 'Plus Jakarta Sans', 'Segoe UI', sans-serif;
    text-transform: none;
    letter-spacing: 0;
    font-size: 13px;
    font-weight: 600;
}

.login .button-primary {
    width: 100%;
    min-height: 48px;
    border: 0;
    border-radius: 14px;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-shadow: none;
    background: linear-gradient(135deg, var(--imm-login-accent-1) 0%, var(--imm-login-accent-2) 100%);
    box-shadow: 0 16px 30px rgba(8, 84, 176, 0.34);
    transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}

.login .button-primary:hover,
.login .button-primary:focus {
    transform: translateY(-1px);
    filter: saturate(1.08);
    box-shadow: 0 20px 32px rgba(5, 65, 145, 0.42);
}

.login #nav,
.login #backtoblog {
    margin: 16px 0 0;
    text-align: center;
}

.login #nav a,
.login #backtoblog a {
    font-family: 'Space Grotesk', 'Plus Jakarta Sans', sans-serif;
    font-weight: 700;
    letter-spacing: 0.01em;
    color: #e8f4ff;
    text-decoration: none;
}

.login #nav a:hover,
.login #backtoblog a:hover {
    color: #ffffff;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.login .language-switcher {
    margin-top: 15px;
    text-align: center;
}

.login .language-switcher select,
.login .language-switcher .button {
    border-radius: 10px;
    border-color: rgba(255, 255, 255, 0.45);
    background: rgba(7, 36, 75, 0.28);
    color: #ffffff;
}

@media (max-width: 600px) {
    body.login::before {
        width: 80vw;
        height: 80vw;
        top: -18vh;
        right: -24vw;
    }

    .login #login {
        width: min(94vw, 460px);
        margin-top: 3vh;
    }

    .login h1 a {
        width: min(80%, 250px);
        height: 62px;
    }

    .login form {
        padding: 24px 18px 20px;
        border-radius: 18px;
    }
}
