/*
 * _login.css — 登录页（dark 皮 DOM）
 * ===================================
 *
 * 配合 app/admin/view/login/index.html 的 dark 分支 DOM：
 *
 *   .skin-login                            整页 wrapper（整页深色背景）
 *   .skin-login-main                       居中容器（垂直水平居中）
 *     .skin-login-card                     登录卡（唯一视觉焦点）
 *       .skin-login-card-header            卡片头
 *         .skin-login-brand                品牌徽标行（logo + 名 + slogan）
 *         .skin-login-card-titlebar        当前态标题 + 副标题
 *           .skin-login-card-title         标题（多个，按 data-target 切换）
 *           .skin-login-card-hint          副标题（多个，按 data-target 切换）
 *       .skin-login-panel                  #login / #register / #forget 三面板
 *         .skin-login-field                单字段（label 含图标 + input）
 *         .skin-login-field-row            验证码行
 *         .skin-login-options              checkbox + 链接行
 *         .skin-login-submit               提交大按钮
 *     .skin-login-footer                   版权脚注
 *
 * 设计取向：居中单卡，极简金融风
 *   - 整页深色，仅卡片承载内容；
 *   - 卡片顶部 1px 渐变高光作为唯一装饰；
 *   - 没有左右分栏、没有装饰图层、没有浮动光晕；
 *   - 仅保留必要的 hover / focus 过渡。
 *
 * JS 选择器（#login / #register / #forget / #captchaImg / sa-event-type / lay-filter）保持不变。
 */

/* ========== 整页 wrapper ==========
 * 不在 body 上设 overflow: hidden（全局会影响所有 iframe 子页面）；
 * 登录页的滚动隔离改为只设在 .skin-login 容器上。
 */
html[data-skin="dark"] body {
    margin: 0;
    background: var(--bg-1);
}

html[data-skin="dark"] .skin-login {
    position: relative;
    width: 100vw;
    min-height: 100vh;
    background:
        radial-gradient(ellipse 800px 600px at 50% -10%, rgba(0, 229, 255, 0.06), transparent 60%),
        radial-gradient(ellipse 600px 500px at 50% 110%, rgba(124, 92, 255, 0.05), transparent 60%),
        var(--bg-1);
    color: var(--text-1);
    font-family: var(--font-family);
}

/* ========== 居中容器 ========== */
html[data-skin="dark"] .skin-login-main {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
    gap: 32px;
}

/* ========== 登录卡 ========== */
html[data-skin="dark"] .skin-login-card {
    width: 100%;
    max-width: 420px;
    background: var(--bg-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 44px 40px 40px;
    box-shadow: var(--shadow-card);
    position: relative;
}

/* 卡片顶部 1px 渐变高光 — 唯一的装饰 */
html[data-skin="dark"] .skin-login-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 20%;
    right: 20%;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--primary) 50%, transparent);
    opacity: 0.6;
}

/* ========== 卡片头 ==========
 * 视觉层级重设：
 * - 品牌区（logo + 系统名 + slogan）做成"hero 居中"，是这一屏的视觉主角
 * - 表单态标题（账号登录 / 注册 / 找回密码）作为辅助文字，明显小于品牌
 */
html[data-skin="dark"] .skin-login-card-header {
    margin-bottom: 28px;
}

/* 品牌区：横向 + 整组居中（logo 在左，名字 + slogan 在右） */
html[data-skin="dark"] .skin-login-brand {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 18px;
    padding-bottom: 24px;
    margin-bottom: 20px;
    border-bottom: 1px solid var(--divider);
}

/* Logo 容器：80×80（原 44×44），加香槟金光晕和微立体内高光 */
html[data-skin="dark"] .skin-login-brand-logo {
    width: 80px;
    height: 80px;
    border-radius: 20px;
    background: linear-gradient(135deg, var(--bg-3) 0%, var(--bg-2) 100%);
    border: 1px solid var(--border-strong);
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    box-shadow:
        0 8px 24px rgba(0, 0, 0, 0.4),
        0 0 0 6px rgba(212, 184, 112, 0.05),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

/* Logo 图：60×60（原 30×30），翻倍 */
html[data-skin="dark"] .skin-login-brand-logo img {
    width: 60px;
    height: 60px;
    object-fit: contain;
}

html[data-skin="dark"] .skin-login-brand-text {
    text-align: left;
    min-width: 0;
    flex: 0 1 auto;
}

/* 系统名：28px / 700 / 香槟金渐变文字 —— 真正的视觉主角 */
html[data-skin="dark"] .skin-login-brand-name {
    margin: 0;
    font-size: 28px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 1.5px;
    background: linear-gradient(135deg, #F4E4B5 0%, #D4B870 50%, #A8893E 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* slogan：辅助层级，深灰 + 大字间距，跟主名拉开层级 */
html[data-skin="dark"] .skin-login-brand-slogan {
    margin: 8px 0 0;
    color: var(--text-3);
    font-size: 12px;
    letter-spacing: 2px;
    line-height: 1.4;
}

/* 表单态标题区：居中，整体压小，让品牌区独占 hero 位 */
html[data-skin="dark"] .skin-login-card-titlebar {
    display: block;
    text-align: center;
}

/* "账号登录 / 注册 / 找回密码"：15px / 500 / text-2 —— 明显小于品牌名 */
html[data-skin="dark"] .skin-login-card-title {
    margin: 0 0 4px;
    color: var(--text-2);
    font-size: 15px;
    font-weight: 500;
    line-height: 1.4;
    letter-spacing: 1px;
}

html[data-skin="dark"] .skin-login-card-hint {
    margin: 0;
    color: var(--text-3);
    font-size: 12px;
    line-height: 1.5;
}

/* ========== 面板 ========== */
html[data-skin="dark"] .skin-login-panel form {
    display: block;
}

html[data-skin="dark"] .skin-login-field,
html[data-skin="dark"] .skin-login-field-row,
html[data-skin="dark"] .skin-login-panel .valicode,
html[data-skin="dark"] .skin-login-panel .settingPwd {
    margin-bottom: 16px;
    display: block;
}

html[data-skin="dark"] .skin-login-panel .settingPwd .skin-login-field {
    margin-bottom: 12px;
}

html[data-skin="dark"] .skin-login-panel .settingPwd .skin-login-field:last-child {
    margin-bottom: 0;
}

html[data-skin="dark"] .skin-login-options {
    margin-top: 2px;
    margin-bottom: 22px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
}

html[data-skin="dark"] .skin-login-submit,
html[data-skin="dark"] .skin-login-card .layui-btn-fluid.skin-login-submit {
    margin-top: 0;
}

/* ========== 字段 ========== */
html[data-skin="dark"] .skin-login-field {
    position: relative;
    display: block;
}

html[data-skin="dark"] .skin-login-field .layui-input {
    width: 100%;
    height: 44px;
    line-height: 42px;
    padding: 0 14px 0 42px;
    background: var(--bg-input) !important;
    border: 1px solid var(--border-strong);
    border-radius: var(--radius-sm);
    color: var(--text-1);
    font-size: var(--font-size-md);
    transition: border-color var(--transition-base), background-color var(--transition-base);
    -webkit-text-fill-color: var(--text-1);
    caret-color: var(--primary);
}

html[data-skin="dark"] .skin-login-field .layui-input::placeholder {
    color: var(--text-3);
}

html[data-skin="dark"] .skin-login-field .layui-input:hover {
    border-color: rgba(255, 255, 255, 0.28);
}

html[data-skin="dark"] .skin-login-field .layui-input:focus {
    border-color: var(--primary);
    background: var(--bg-input) !important;
    outline: none;
    box-shadow: 0 0 0 3px var(--primary-glow);
}

/* Autofill 配色覆盖（webkit hack） */
html[data-skin="dark"] .skin-login-field .layui-input:-webkit-autofill,
html[data-skin="dark"] .skin-login-field .layui-input:-webkit-autofill:hover,
html[data-skin="dark"] .skin-login-field .layui-input:-webkit-autofill:focus,
html[data-skin="dark"] .skin-login-field .layui-input:-webkit-autofill:active {
    -webkit-text-fill-color: var(--text-1) !important;
    -webkit-box-shadow: 0 0 0 1000px var(--bg-input) inset !important;
    box-shadow: 0 0 0 1000px var(--bg-input) inset !important;
    caret-color: var(--primary);
    transition: background-color 5000s ease-in-out 0s, color 5000s ease-in-out 0s;
}

html[data-skin="dark"] .skin-login-field-icon {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 14px;
    display: flex;
    align-items: center;
    pointer-events: none;
    color: var(--text-3);
    transition: color var(--transition-base);
}

html[data-skin="dark"] .skin-login-field-icon i {
    font-size: 16px;
}

html[data-skin="dark"] .skin-login-field:focus-within .skin-login-field-icon {
    color: var(--primary);
}

/* ========== 验证码行 ========== */
html[data-skin="dark"] .skin-login-field-row {
    display: flex;
    gap: 10px;
    align-items: center;
}

html[data-skin="dark"] .skin-login-field-row .skin-login-field-captcha {
    flex: 1;
    margin: 0;
}

html[data-skin="dark"] .skin-login-captcha-img {
    flex: 0 0 auto;
    display: block;
    height: 44px;
    border-radius: var(--radius-sm);
    overflow: hidden;
    border: 1px solid var(--border-strong);
    background: var(--bg-input);
    transition: border-color var(--transition-base);
    cursor: pointer;
}

html[data-skin="dark"] .skin-login-captcha-img:hover {
    border-color: var(--primary);
}

html[data-skin="dark"] .skin-login-captcha-img img {
    display: block;
    height: 100%;
    width: auto;
}

/* ========== 选项行 ========== */
html[data-skin="dark"] .skin-login-checkbox {
    display: inline-flex;
    align-items: center;
    color: var(--text-2);
    font-size: var(--font-size-sm);
    cursor: pointer;
}

html[data-skin="dark"] .skin-login-link {
    color: var(--text-2);
    font-size: var(--font-size-sm);
    text-decoration: none;
    transition: color var(--transition-base);
}

html[data-skin="dark"] .skin-login-link:hover {
    color: var(--primary);
}

/* ========== 提交按钮 ========== */
html[data-skin="dark"] .skin-login-submit,
html[data-skin="dark"] .skin-login-card .layui-btn-fluid.skin-login-submit {
    width: 100%;
    height: 44px;
    line-height: 44px;
    margin-top: 6px;
    background: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
    border: 0;
    border-radius: var(--radius-sm);
    color: var(--text-on-primary);
    font-size: var(--font-size-md);
    font-weight: 600;
    letter-spacing: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 229, 255, 0.2);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}

html[data-skin="dark"] .skin-login-submit:hover {
    box-shadow: 0 4px 16px rgba(0, 229, 255, 0.35);
    color: var(--text-on-primary);
}

html[data-skin="dark"] .skin-login-submit:active {
    transform: translateY(1px);
    box-shadow: 0 1px 4px rgba(0, 229, 255, 0.25);
}

html[data-skin="dark"] .skin-login-submit i {
    font-size: 14px;
}

/* 错误态 */
html[data-skin="dark"] .skin-login-field .layui-input.layui-form-danger {
    border-color: var(--danger);
    box-shadow: 0 0 0 3px var(--danger-soft);
}

/* ========== 版权脚注 ========== */
html[data-skin="dark"] .skin-login-footer {
    color: var(--text-3);
    font-size: var(--font-size-xs);
    letter-spacing: 0.5px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
    text-align: center;
}

html[data-skin="dark"] .skin-login-footer-sep {
    opacity: 0.5;
}

/* ========== 响应式 ========== */
@media (max-width: 480px) {
    html[data-skin="dark"] .skin-login-main {
        padding: 32px 16px;
        gap: 24px;
    }

    html[data-skin="dark"] .skin-login-card {
        padding: 32px 24px 28px;
    }

    html[data-skin="dark"] .skin-login-card-header {
        margin-bottom: 24px;
    }

    html[data-skin="dark"] .skin-login-brand {
        padding-bottom: 18px;
        margin-bottom: 18px;
        gap: 14px;
    }

    /* 手机版 logo 缩到 64×64，保留明显的"品牌主角"分量 */
    html[data-skin="dark"] .skin-login-brand-logo {
        width: 64px;
        height: 64px;
        border-radius: 16px;
    }

    html[data-skin="dark"] .skin-login-brand-logo img {
        width: 48px;
        height: 48px;
    }

    /* 小屏系统名也跟着缩，但仍明显大于表单态标题 */
    html[data-skin="dark"] .skin-login-brand-name {
        font-size: 22px;
        letter-spacing: 1px;
    }

    html[data-skin="dark"] .skin-login-card-title {
        font-size: 14px;
    }
}
