/* =============================================
   auth-form.css — 登录 / 注册
   宠物商城 · 极简风格 · 全分辨率自适应 (PC / 平板 / H5)
   ============================================= */

.auth-page {
    --a-red:#ff2d2d;
    --a-red-deep:#e01313;
    --a-red-ink:#b50f0f;
    --a-soft:#fff1ef;
    --a-ink:#1d1a21;
    --a-ink-2:#6f6a78;
    --a-ink-3:#a8a2af;
    --a-cream:#fafafa;
    --a-line:#ececf0;
    --a-display:'Baloo 2','PingFang SC','Microsoft YaHei',sans-serif;
    --a-body:'Nunito','PingFang SC','Microsoft YaHei',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;

    position:relative;
    width:100%;
    min-height:calc(100vh - 200px);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:48px 20px;
    box-sizing:border-box;
    font-family:var(--a-body);
    color:var(--a-ink);
    background:#fafafb;
}

/* ===== 卡片：单列居中 ===== */
.auth-card{
    position:relative;
    z-index:1;
    width:100%;
    box-sizing:border-box;
    display:block;
    background:#fff;
    border-radius:20px;
    box-shadow:0 1px 2px rgba(0,0,0,.04), 0 12px 32px -16px rgba(0,0,0,.12);
    border:1px solid var(--a-line);
    overflow:hidden;
    animation:authCardIn .5s cubic-bezier(.16,1,.3,1) both;
}
@keyframes authCardIn{
    from{opacity:0;transform:translateY(14px)}
    to{opacity:1;transform:none}
}

/* 左侧品牌面板已移除（极简风格） */

/* ===== 表单区 ===== */
.auth-main{
    width:100%;
    box-sizing:border-box;
    padding:44px 48px;
    display:flex;
    flex-direction:column;
}
.register-right{width:100%;display:flex;
    flex-direction:column;align-items:stretch;margin:0 !important;}
.register-formWrapper{width:100%;max-width:100;margin: 0 !important}

/* ===== 品牌头（Logo 居中，极简） ===== */
.auth-mini-brand{
    display:flex;align-items:center;justify-content:center;gap:10px;
    margin-bottom:26px;
    text-decoration:none;
}
.auth-mini-brand .auth-logo{
    height:40px;width:auto;max-width:170px;
    object-fit:contain;display:block;flex-shrink:0;
}
.auth-mini-brand .name{font-family:var(--a-display);font-weight:800;font-size:19px;color:var(--a-ink);letter-spacing:.2px}

.register-title{
    font-family:var(--a-display);
    font-size:24px;font-weight:800;color:var(--a-ink);
    margin-bottom:6px;line-height:1.25;
}
.register-subtitle{
    font-size:13px;color:var(--a-ink-3);
    margin:0 0 22px;line-height:1.5;
}

/* ===== 返回首页 ===== */
.back-home-link{
    display:inline-flex;align-items:center;gap:5px;
    margin-bottom:18px;
    font-size:13px;color:var(--a-ink-3);
    text-decoration:none;transition:color .2s,gap .2s;
    align-self:flex-start;
}
.back-home-link:hover{color:var(--a-red);gap:8px}

/* ===== Tab 切换（极简分段控件） ===== */
.login-tabs{
    display:flex;
    gap:3px;
    padding:4px;
    margin-bottom:24px;
    background:#f4f4f6;
    border-radius:12px;
}
.login-tab{
    flex:1;
    display:inline-flex;align-items:center;justify-content:center;
    padding:14px 100px;
    font-family:var(--a-body);
    font-size:13.5px;font-weight:700;
    color:var(--a-ink-2);
    cursor:pointer;
    background:transparent;
    border:none;border-radius:9px;
    white-space:nowrap;
    transition:color .2s,background .2s,box-shadow .2s;
}
.login-tab:hover{color:var(--a-ink)}
.login-tab.active{
    color:var(--a-ink);
    background:#fff;
    box-shadow:0 1px 3px rgba(0,0,0,.10);
}
.login-tab.active svg{stroke:var(--a-red)}

/* ===== 表单 ===== */
.login-form,.reg-form{width:100%;padding:0;box-sizing:border-box}
.login-form .form-group{margin-bottom:16px}
.reg-form .form-group{margin-bottom:15px}

.login-form .form-field label,
.reg-form .form-field label{
    font-size:12.5px;font-weight:700;color:var(--a-ink);
    margin-bottom:7px;display:block;letter-spacing:.2px;
}
.login-form .form-field .field-wrapper,
.reg-form .field-wrapper{position:relative}

.login-form .form-field input,
.reg-form .field-wrapper input{
    width:100%;height:48px;
    padding:8px 16px;
    border:1.5px solid var(--a-line);
    border-radius:10px;
    font-family:var(--a-body);
    font-size:14.5px;font-weight:600;
    color:var(--a-ink);
    background:var(--a-cream);
    transition:border-color .2s,box-shadow .2s,background .2s;
}
.reg-form .field-wrapper input{padding:0 42px 0 16px}

.login-form .form-field input:focus,
.reg-form .field-wrapper input:focus{
    border-color:var(--a-red);
    outline:none;
    background:#fff;
    box-shadow:0 0 0 4px rgba(255,45,45,.10);
}
.login-form .form-field input::placeholder,
.reg-form .field-wrapper input::placeholder{color:var(--a-ink-3);font-weight:500}

.reg-form .field-wrapper input.is-valid{border-color:#22c55e;background:#fff}
.reg-form .field-wrapper input.is-invalid{border-color:#ef4444;background:#fff}

/* 状态图标 */
.field-icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:6px}
.field-icon .icon-status{width:18px;height:18px;display:none}
.field-icon .icon-status.show{display:flex;align-items:center;justify-content:center}

/* 发送验证码 */
.send-code-btn{
    position:absolute;right:8px;top:50%;transform:translateY(-50%);
    font-family:var(--a-body);
    font-size:12.5px;font-weight:800;
    color:var(--a-red);
    cursor:pointer;white-space:nowrap;
    border:none;background:rgba(255,45,45,.08);
    padding:7px 11px;border-radius:9px;
    transition:background .2s,color .2s;
}
.send-code-btn:hover{background:rgba(255,45,45,.16)}
.send-code-btn:disabled{color:var(--a-ink-3);background:var(--a-soft);cursor:not-allowed}

/* 记住 / 链接 */
.remember-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:nowrap}
.remember-label{display:flex;align-items:center;gap:7px;cursor:pointer}
.remember-label input[type="checkbox"]{width:16px;height:16px;cursor:pointer;accent-color:var(--a-red)}
.remember-label span{font-size:13px;color:var(--a-ink-2);user-select:none;font-weight:600}
.forgot-link{font-size:13px;color:var(--a-red);text-decoration:none;font-weight:700;white-space:nowrap}
.forgot-link:hover{text-decoration:underline}

/* 提示 / 错误 */
.reg-form .field-hint{font-size:12px;margin-top:5px;display:none;font-weight:600}
.reg-form .field-hint.error{color:#ef4444;display:block}
.reg-form .field-hint.success{color:#16a34a;display:block}
.error-msg{
    color:#dc2626;font-size:13px;font-weight:600;
    margin-bottom:14px;display:none;
    padding:11px 14px;
    background:#fef2f2;border:1px solid #fee2e2;border-radius:11px;
}

/* 协议 */
.reg-form .terms-row{display:flex;align-items:flex-start;gap:9px;margin-bottom:18px}
.reg-form .terms-row input[type="checkbox"]{width:17px;height:17px;margin-top:1px;accent-color:var(--a-red);cursor:pointer;flex-shrink:0}
.reg-form .terms-row label{font-size:12px;color:var(--a-ink-2);cursor:pointer;line-height:1.55;font-weight:600}
.reg-form .terms-row label a{color:var(--a-red);text-decoration:none;font-weight:800}
.reg-form .terms-row label a:hover{text-decoration:underline}

/* 提交按钮 */
.submit-btn{
    width:100%;height:50px;
    display:flex;align-items:center;justify-content:center;gap:8px;
    font-family:var(--a-body);
    font-size:15px;font-weight:800;letter-spacing:.3px;
    color:#fff;
    background:var(--a-red);
    border:none;border-radius:11px;cursor:pointer;
    transition:background .2s,transform .12s;
}
.submit-btn svg{transition:transform .2s}
.submit-btn:hover{background:var(--a-red-deep)}
.submit-btn:hover svg{transform:translateX(3px)}
.submit-btn:active{transform:translateY(1px)}
.submit-btn:disabled{background:#dcdce0;color:#fff;cursor:not-allowed;transform:none}

/* 三方登录 */
.form-signup{margin-top:24px}
.form-signup__label{
    text-align:center;color:var(--a-ink-3);font-size:12px;font-weight:600;
    margin-bottom:14px;display:flex;align-items:center;gap:12px;
}
.form-signup__label::before,.form-signup__label::after{content:'';flex:1;height:1px;background:var(--a-line)}
.form-signup__wrapper{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.form-signup__wrapper .social-medaia-box-btn::before{content:none!important;display:none!important;width:0!important;height:0!important;background:none!important;position:static!important;opacity:0!important}
.social-medaia-box-btn{
    min-width:0;flex:1;
    padding:11px 10px;
    border:1.5px solid var(--a-line);
    border-radius:10px;
    font-family:var(--a-body);
    font-size:12.5px;font-weight:700;
    color:var(--a-ink-2);
    background:#fff;
    text-decoration:none;
    display:flex;align-items:center;justify-content:center;gap:7px;
    white-space:nowrap;overflow:hidden;
    transition:border-color .2s,color .2s,background .2s;
}
.social-medaia-box-btn:hover{
    border-color:#d6d6db;color:var(--a-ink);
    background:#fafafa;
}
.social-medaia-box-btn svg{flex-shrink:0}

/* 底部链接 */
.register-bottom-link{text-align:center;margin-top:22px;font-size:13px;color:var(--a-ink-2);font-weight:600}
.register-bottom-link a{color:var(--a-red);font-weight:800;text-decoration:none;margin-left:4px}
.register-bottom-link a:hover{text-decoration:underline}

/* =============================================
   响应式适配（单列卡片 · 全分辨率）
   ============================================= */

/* 大屏 PC：仅微调留白 */
@media (min-width:1200px){
    .auth-page{min-height:calc(100vh - 160px);padding:64px 20px}
    .auth-main{padding:48px 52px}
}

/* 平板 */
@media (max-width:991px){

    .auth-main{margin:10px 40px}
}

/* H5 手机 */
@media (max-width:575px){
    .auth-page{
        min-height:calc(100vh - 140px);
        padding:18px 14px;
        align-items:flex-start;
    }
    .auth-card{
        max-width:100%;
        border-radius:16px;
        box-shadow:0 1px 2px rgba(0,0,0,.04), 0 8px 24px -16px rgba(0,0,0,.14);
    }
    .auth-main{padding:28px 22px 30px}
    .auth-mini-brand{margin-bottom:22px}
    .register-title{font-size:21px}
    .register-subtitle{margin-bottom:18px}
    .login-tabs{margin-bottom:20px}
    .login-tab{padding:9px 8px;font-size:13px}
    .login-tab svg{display:none}
    .login-form .form-group,.reg-form .form-group{margin-bottom:13px}
    .login-form .form-field input,.reg-form .field-wrapper input{height:46px}
    .submit-btn{height:48px}
    .form-signup{margin-top:20px}
    .form-signup__wrapper{gap:8px}
    .social-medaia-box-btn{font-size:11.5px;padding:11px 6px}
    .register-bottom-link{margin-top:18px;font-size:12.5px}
    .forgot-link{white-space:nowrap}
    .remember-row{flex-wrap:nowrap;gap:8px}
}

/* 超小屏 */
@media (max-width:359px){
    .auth-main{padding:24px 16px 26px}
    .social-medaia-box-btn{font-size:11px;gap:4px}
}

/* 横屏矮屏 */
@media (max-height:560px) and (min-width:576px){
    .auth-page{min-height:auto;padding:28px 20px}
}

/* 减少动效 */
@media (prefers-reduced-motion:reduce){
    .auth-card{animation:none!important}
    .submit-btn,.social-medaia-box-btn{transition:none}
}

/* =============================================
   图形验证码弹窗
   ============================================= */
#captcha-modal-overlay{
    position:fixed;inset:0;
    background:rgba(44,38,48,.5);
    z-index:99990;
    display:flex;align-items:center;justify-content:center;
    backdrop-filter:blur(3px);
}
#captcha-modal{
    background:#fff;border-radius:16px;padding:28px;
    width:380px;max-width:calc(100% - 32px);
    box-shadow:0 20px 60px -20px rgba(0,0,0,.3);
    position:relative;
    font-family:var(--a-body,'Nunito',sans-serif);
    animation:authCardIn .3s cubic-bezier(.16,1,.3,1) both;
}
#captcha-modal .captcha-modal-title{
    font-family:var(--a-body,'Nunito',sans-serif);
    font-size:17px;font-weight:800;color:#1d1a21;
    margin:0 0 20px;display:flex;align-items:center;justify-content:space-between;
}
#captcha-modal .captcha-modal-close{
    background:none;border:none;cursor:pointer;color:#a8a2af;
    padding:0;line-height:1;font-size:22px;transition:color .2s;
}
#captcha-modal .captcha-modal-close:hover{color:#1d1a21}
#captcha-modal .captcha-img-row{display:flex;gap:10px;align-items:center;margin-bottom:16px}
#captcha-modal .captcha-img-box{
    flex:1;height:46px;border:1.5px solid #ececf0;border-radius:10px;
    background:#fafafa;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;
}
#captcha-modal .captcha-img-box img{
    width:100%;height:100%;object-fit:contain;transition:opacity .2s;
    position:relative;z-index:1;
}
#captcha-modal .captcha-loading{
    position:absolute;display:flex;align-items:center;justify-content:center;
}
#captcha-modal .captcha-loading svg{animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#captcha-modal .captcha-img-row .captcha-refresh{
    width:38px;height:38px;border:1.5px solid #ececf0;border-radius:10px;
    background:#fafafa;cursor:pointer;display:flex;align-items:center;justify-content:center;
    color:#6f6a78;transition:background .2s,border-color .2s,color .2s;flex-shrink:0;
}
#captcha-modal .captcha-img-row .captcha-refresh:hover{background:#f4f4f6;border-color:#d6d6db;color:#1d1a21}
#captcha-modal .captcha-input-row input{
    width:100%;padding:12px 14px;
    border:1.5px solid #ececf0;border-radius:10px;
    font-size:15px;font-weight:600;outline:none;box-sizing:border-box;
    background:#fafafa;transition:border-color .2s,background .2s;
}
#captcha-modal .captcha-input-row input:focus{border-color:#ff2d2d;background:#fff;box-shadow:0 0 0 4px rgba(255,45,45,.10)}
#captcha-modal .captcha-error{color:#ef4444;font-size:13px;font-weight:600;margin-top:6px;min-height:18px}
#captcha-modal .captcha-submit-btn{
    width:100%;margin-top:16px;padding:13px;
    background:#ff2d2d;
    color:#fff;border:none;border-radius:11px;
    font-family:var(--a-body,'Nunito',sans-serif);
    font-size:15px;font-weight:800;letter-spacing:.3px;cursor:pointer;
    transition:background .2s;
}
#captcha-modal .captcha-submit-btn:hover{background:#e01313}
#captcha-modal .captcha-submit-btn:disabled{background:#dcdce0;cursor:not-allowed}

/* =============================================
   Cookie Consent Banner
   ============================================= */
.cookie-consent-banner{
    position:fixed;bottom:0;left:0;right:0;z-index:10001;
    background:#fff;box-shadow:0 -4px 24px rgba(0,0,0,.12);
    border-top:1px solid #efe5df;
    transform:translateY(100%);
    transition:transform .4s cubic-bezier(.4,0,.2,1);
    font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
}
.cookie-consent-banner.show{transform:translateY(0)}
.cookie-consent-inner{max-width:1320px;margin:0 auto;padding:20px 24px;display:flex;align-items:flex-start;gap:16px}
.cookie-consent-icon{flex-shrink:0;margin-top:2px}
.cookie-consent-text{flex:1;min-width:0}
.cookie-consent-title{font-size:15px;font-weight:700;color:#2c2630;margin:0 0 6px}
.cookie-consent-desc{font-size:13px;color:#6f6a78;margin:0;line-height:1.6}
.cookie-consent-desc a{color:#ff2d2d;text-decoration:none}
.cookie-consent-desc a:hover{text-decoration:underline}
.cookie-consent-actions{flex-shrink:0;display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.cookie-btn{
    padding:9px 18px;border-radius:9px;font-size:13px;font-weight:700;cursor:pointer;
    transition:all .2s;white-space:nowrap;
    border:1.5px solid #efe5df;background:#fff7f3;color:#2c2630;
}
.cookie-btn:hover{background:#ff2d2d;border-color:#ff2d2d;color:#fff}
.cookie-btn-accept{background:linear-gradient(135deg,#ff4242,#e21010);border-color:transparent;color:#fff}
.cookie-btn-accept:hover{filter:brightness(1.05);background:linear-gradient(135deg,#ff4242,#e21010)}
.cookie-consent-close{
    position:absolute;top:12px;right:16px;background:none;border:none;
    font-size:16px;color:#a8a2af;cursor:pointer;padding:4px 8px;border-radius:6px;
    transition:color .2s,background .2s;
}
.cookie-consent-close:hover{color:#2c2630;background:#fff1ef}
.cookie-category-list{margin-top:14px;border:1px solid #efe5df;border-radius:11px;overflow:hidden}
.cookie-category-item{display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:13px;color:#2c2630;border-bottom:1px solid #efe5df;cursor:pointer}
.cookie-category-item:last-child{border-bottom:none}
.cookie-category-item input[type="checkbox"]{width:16px;height:16px;accent-color:#ff2d2d;cursor:pointer;flex-shrink:0}
.cookie-category-item input[type="checkbox"]:disabled{opacity:.5;cursor:not-allowed}
.cookie-category-item span{font-weight:600;min-width:180px}
.cookie-category-item em{font-style:normal;color:#a8a2af;font-size:12px}
@media (max-width:768px){
    .cookie-consent-inner{flex-direction:column;padding:16px;gap:12px}
    .cookie-consent-actions{justify-content:flex-start;width:100%}
    .cookie-consent-close{top:8px;right:12px}
    .cookie-category-item span{min-width:140px}
    .cookie-category-item em{display:none}
}
