/**
 * WeChat Login button styles + 登录表单宽度修复.
 *
 * @package    auth_wechat
 * @copyright  2026 CueSpeed Sports (cuespeedsports.com)
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

/* ==========================================================================
   登录表单宽度修复
   根因：boost主题 .login-container 设为 width:500px !important
   方案：让 form 和 input/button 在 500px 容器内撑满宽度
   ========================================================================== */

/* 表单和表单元素在容器内撑满 + 高度对齐 */
.loginform form,
.loginform form .form-group,
.loginform form input.form-control,
.loginform form button.loginbtn {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* 输入框和按钮高度对齐 */
body.path-login .loginform input.form-control,
body.path-login .loginform button.loginbtn,
body.path-login .login-identityproviders button,
body.path-login .login-identityproviders .loginbtn,
body.path-login .login-identityproviders a button,
body.path-login .login-identityproviders a .loginbtn {
    height: 48px !important;
    line-height: 48px !important;
    padding: 0 16px !important;
    font-size: 16px !important;
    border-radius: 8px !important;
}

/* 输入框内部文字垂直居中 */
body.path-login .loginform input.form-control {
    display: flex !important;
    align-items: center !important;
}

/* 微信/短信 identity provider 按钮也在容器内撑满 */
.login-identityproviders a {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
}
.login-identityproviders a button,
.login-identityproviders a .loginbtn,
.login-identityproviders a .login-identityprovider-btn {
    width: 100% !important;
    display: block !important;
    box-sizing: border-box !important;
}

/* ==========================================================================
   登录标题样式 - 隐藏原始标题并显示在新位置
   ========================================================================== */

.login-identityproviders .login-heading {
    display: none !important;
}

.loginform > form::before {
    content: "使用您的账号登录：";
    display: block;
    text-align: center;
    font-size: 1.2rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 20px;
    margin-top: 0;
}

/* ==========================================================================
   WeChat Login Button Styles - 使用极高优先级选择器
   ========================================================================== */

/* 微信登录按钮 - 第一个按钮（微信） - 绿色背景 + 微信图标 */
body.path-login .login-identityproviders > a:first-child > button,
body.path-login .login-identityproviders > a:first-child > .loginbtn,
body.path-login .login-identityproviders > a:first-child > .login-identityprovider-btn,
body.path-login .login-identityproviders > a:first-child > .btn-block,
body.path-login .login-identityproviders > a:first-child > .btn,
body.path-login .login-identityproviders > a:first-child > button.loginbtn,
body.path-login .login-identityproviders > a:first-child > button.login-identityprovider-btn,
body.path-login .login-identityproviders > a:first-child > button.btn-block,
body.path-login .login-identityproviders > a:first-child > button.btn,
body.path-login .login-identityproviders > a:first-child > button,
body.path-login .login-identityproviders > a:first-child > .loginbtn,
body.path-login .login-identityproviders > a:first-child > .login-identityprovider-btn,
body.path-login .login-identityproviders > a:first-child > .btn-block,
body.path-login .login-identityproviders > a:first-child > .btn,
body.path-login .login-identityproviders > a:first-child button.loginbtn,
body.path-login .login-identityproviders > a:first-child button.login-identityprovider-btn,
body.path-login .login-identityproviders > a:first-child button.btn-block,
body.path-login .login-identityproviders > a:first-child button.btn,
body.path-login .login-identityproviders > a:first-child button {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    background: linear-gradient(135deg, #07C160 0%, #05A050 100%) !important;
    background-color: #07C160 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 12px 24px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    cursor: pointer !important;
    transition: all 0.25s ease !important;
    width: 100% !important;
    margin: 8px 0 !important;
    letter-spacing: 0.5px !important;
    box-shadow: 0 4px 12px rgba(7, 193, 96, 0.35) !important;
    text-align: center !important;
}

/* 微信登录按钮 - hover 状态 */
body.path-login .login-identityproviders > a:first-child > button:hover,
body.path-login .login-identityproviders > a:first-child > .loginbtn:hover,
body.path-login .login-identityproviders > a:first-child > .login-identityprovider-btn:hover,
body.path-login .login-identityproviders > a:first-child > .btn-block:hover,
body.path-login .login-identityproviders > a:first-child > .btn:hover,
body.path-login .login-identityproviders > a:first-child button:hover {
    background: linear-gradient(135deg, #05a04f 0%, #038840 100%) !important;
    background-color: #05a04f !important;
    color: #ffffff !important;
    text-decoration: none !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(7, 193, 96, 0.45) !important;
    border-color: transparent !important;
}

/* 微信登录按钮 - active 状态 */
body.path-login .login-identityproviders > a:first-child > button:active,
body.path-login .login-identityproviders > a:first-child > .loginbtn:active,
body.path-login .login-identityproviders > a:first-child > .login-identityprovider-btn:active,
body.path-login .login-identityproviders > a:first-child > .btn-block:active,
body.path-login .login-identityproviders > a:first-child > .btn:active,
body.path-login .login-identityproviders > a:first-child button:active {
    background: linear-gradient(135deg, #059546 0%, #037838 100%) !important;
    background-color: #059546 !important;
    transform: translateY(0) !important;
    box-shadow: 0 2px 8px rgba(7, 193, 96, 0.35) !important;
    color: #ffffff !important;
}

/* 微信登录按钮 - 图标样式 */
/* 微信图标显示 - 最强制方案 */
#page-login-index .login-identityproviders img,
#page-login-index .login-identityproviders a img,
#page-login-index .login-identityproviders button img,
body.path-login #page .login-identityproviders img,
body.pagelayout-login .login-identityproviders img,
.login-identityproviders a img,
.login-identityproviders button img,
.login-identityproviders img {
    width: 24px !important;
    height: 24px !important;
    min-width: 24px !important;
    min-height: 24px !important;
    flex-shrink: 0 !important;
    margin-right: 8px !important;
    margin: 0 8px 0 0 !important;
    padding: 0 !important;
    display: inline-block !important;
    display: inline-flex !important;
    display: -webkit-inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    overflow: visible !important;
    position: relative !important;
    z-index: 1 !important;
}

/* 按钮 flex 布局 */
#page-login-index .login-identityproviders button,
#page-login-index .login-identityproviders .loginbtn,
body.path-login .login-identityproviders button,
body.path-login .login-identityproviders .loginbtn,
.login-identityproviders button,
.login-identityproviders .loginbtn {
    display: flex !important;
    display: -webkit-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    justify-content: center !important;
    gap: 8px !important;
    -webkit-align-items: center !important;
}

/* ==========================================================================
   微信登录按钮 - 绿色背景（最强制方案）
   ========================================================================== */
body.path-login .login-identityproviders a .loginbtn,
body.path-login .login-identityproviders a button,
body.path-login .login-identityproviders a .btn-block,
body.path-login .login-identityproviders a .btn,
body.path-login .login-identityproviders a .login-identityprovider-btn,
body.path-login div.login-identityproviders a button,
body.path-login div.login-identityproviders a .loginbtn,
body.path-login div.login-identityproviders a .btn-block,
a[title="微信扫码"] .loginbtn,
a[title="微信扫码"] button,
a[title="微信扫码"] .btn-block,
a[title="微信扫码"] .btn,
a[title="微信扫码"] .login-identityprovider-btn,
.login-identityproviders a[title="微信扫码"] .loginbtn,
.login-identityproviders a[title="微信扫码"] button,
.login-identityproviders a[title="微信扫码"] .btn-block,
#page-login-index .login-identityproviders a .loginbtn,
#page-login-index .login-identityproviders a button,
#page-login-index .login-identityproviders a .btn-block {
    background: #07C160 !important;
    background-color: #07C160 !important;
    background-image: none !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    box-shadow: none !important;
}

/* 登录容器 - 防止在小屏幕下缩小 */
body.path-login .login-container {
    min-width: 400px !important;
    width: 400px !important;
    max-width: 100% !important;
}

@media (max-width: 480px) {
    body.path-login .login-container {
        min-width: auto !important;
        width: 90% !important;
    }
}

.login-identityproviders a .loginbtn:hover,
.login-identityproviders a button:hover,
.login-identityproviders a .btn-block:hover,
.login-identityproviders a .btn:hover {
    background: linear-gradient(135deg, #05a04f 0%, #038840 100%) !important;
    background-color: #05a04f !important;
    color: #ffffff !important;
}
