/* CSR Wiki 登录页（两栏：左 Logo / 右主色 + 表单） */
:root {
    --csr-primary: #2e8555;
    --csr-primary-dark: #25724d;
    --csr-panel: #ffffff;
    --csr-field-bg: #e8f4ec;
    --csr-field-bg-focus: #dceee3;
    --csr-text: #1a1a2e;
    --csr-muted: #6b7280;
    --csr-radius: 10px;
}

body.login {
    min-height: 100vh;
    margin: 0;
    padding: 0;
    background: var(--csr-primary);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;
}

/* 左侧白底 + Logo */
body.login::before {
    content: '';
    position: fixed;
    inset: 0 auto 0 0;
    width: 50vw;
    background: var(--csr-panel);
    background-image: url('/wp-content/uploads/2024/06/logoCSR-55x55.png');
    background-repeat: no-repeat;
    background-position: 48px 36px;
    background-size: 160px auto;
    z-index: 0;
}

/* 右侧主色面板（用于清晰分栏，不依赖 body 背景） */
body.login::after {
    content: '';
    position: fixed;
    inset: 0 0 0 auto;
    width: 50vw;
    background: var(--csr-primary);
    z-index: 0;
}

/* WordPress 默认会给 #login 固定宽度/居中，这里把它放到右侧并垂直居中 */
#login {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 420px;
    margin: 0;
    margin-left: 50vw;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 48px 48px 64px;
    box-sizing: border-box;
}

/* 隐藏 WP 默认 Logo（左侧已放品牌 Logo） */
#login h1 {
    display: none;
}

.login form {
    background: var(--csr-panel);
    border: 0;
    border-radius: var(--csr-radius);
    padding: 36px;
    margin: 0;
    box-sizing: border-box;
}

.login form::before {
    content: '欢迎回来';
    display: block;
    font-size: 22px;
    font-weight: 700;
    color: var(--csr-text);
    margin-bottom: 18px;
}

.login form::after {
    content: 'CSR Wiki · csrwiki.com';
    display: block;
    margin-top: 18px;
    color: var(--csr-muted);
    font-size: 12px;
}

.login label {
    font-size: 13px;
    color: var(--csr-text);
    font-weight: 600;
}

.login input[type="text"],
.login input[type="password"],
.login input[type="email"] {
    background: var(--csr-field-bg);
    border: 1px solid transparent;
    border-radius: 8px;
    padding: 12px 12px;
    font-size: 14px;
    margin-top: 6px;
    width: 100%;
    box-sizing: border-box;
}

.login input[type="text"]:focus,
.login input[type="password"]:focus,
.login input[type="email"]:focus {
    background: var(--csr-field-bg-focus);
    border-color: rgba(46, 133, 85, 0.35);
    outline: none;
}

/* 记住我 + 忘记密码保持 WP 默认结构，避免浮动导致错位 */
.login .forgetmenot {
    margin-top: 10px;
}

.login .submit {
    margin-top: 14px;
}

.login .button-primary {
    width: 100%;
    height: 46px;
    border: 0;
    border-radius: 10px;
    background: var(--csr-primary);
    font-size: 15px;
    font-weight: 600;
    text-shadow: none;
    box-shadow: none;
}

.login .button-primary:hover,
.login .button-primary:focus {
    background: var(--csr-primary-dark);
}

/* 链接：表单内用主色；表单外（nav/backtoblog）在绿色面板上用白色 */
.login form a {
    color: var(--csr-primary);
    text-decoration: none;
}

.login form a:hover {
    color: var(--csr-primary-dark);
    text-decoration: underline;
}

#login #nav,
#login #backtoblog {
    margin: 14px 0 0;
    text-align: center;
}

#login #nav a,
#login #backtoblog a {
    color: rgba(255, 255, 255, 0.92);
    text-decoration: none;
}

#login #nav a:hover,
#login #backtoblog a:hover {
    color: #ffffff;
    text-decoration: underline;
}

/* 提示信息宽度跟随表单 */
.login .message,
.login .success,
.login #login_error {
    border-radius: var(--csr-radius);
    margin: 0 0 14px;
}

/* 语言切换（兼容常见输出）固定右下角 */
.language-switcher,
#language-switcher,
.pll-switcher-select,
.pll-switcher,
.pll-language-switcher {
    position: fixed;
    right: 24px;
    bottom: 24px;
    z-index: 10;
}

/* 移动端：上 Logo / 下登录 */
@media screen and (max-width: 900px) {
    body.login::before {
        width: 100vw;
        height: 110px;
        background-position: center 24px;
        background-size: 140px auto;
    }

    body.login::after {
        width: 100vw;
        height: calc(100vh - 110px);
        top: 110px;
    }

    #login {
        margin-left: 0;
        max-width: 420px;
        padding: 140px 20px 64px;
        min-height: auto;
    }
}