:root{
            --page-bg:linear-gradient(135deg,#0b3b36 0%,#0f766e 42%,#dbf8ef 100%);
            --glass:rgba(255,255,255,.14);
            --card:#ffffff;
            --text:#17322d;
            --muted:#5d766f;
            --border:rgba(18,59,49,.12);
            --accent:#0f766e;
            --accent-strong:#0a5c56;
            --accent-soft:#e6f7f1;
            --shadow:0 30px 80px rgba(6,32,28,.24);
            --danger:#a42828;
            --danger-bg:#fff1f1;
        }

        *{box-sizing:border-box}

        body{
            margin:0;
            min-height:100vh;
            padding:28px 18px;
            display:flex;
            align-items:center;
            justify-content:center;
            font-family:"Noto Sans SC",sans-serif;
            color:var(--text);
            background:#fbfcfc;
        }

        body.public-home-page{
            padding:92px 18px 0;
            flex-direction:column;
            justify-content:flex-start;
        }

        body.public-home-page .auth-shell{
            position:fixed;
            z-index:1;
            margin:0;
            top:50%;
            right:max(112px,calc((100vw - 1400px)/2 + 84px));
            transform:translateY(-50%);
        }

        body.hide-auth-shell .auth-shell{
            display:none;
        }

        body.hide-auth-shell .footer{
            margin-top:auto;
        }

        .login-bg-art{
            position:fixed;
            inset:0;
            z-index:0;
            overflow:hidden;
            pointer-events:none;
            background:linear-gradient(90deg,#fbfbfb 0%,#ffffff 67%,#eefbff 100%);
        }

        .login-bg-art:before{
            content:"";
            position:absolute;
            left:41%;
            top:-304px;
            width:640px;
            height:430px;
            border-radius:50%;
            background:linear-gradient(90deg,#ecfdfb 0%,rgba(236,253,251,0) 100%);
            opacity:.72;
        }

        .login-bg-art:after{
            content:"";
            position:absolute;
            right:-300px;
            bottom:-312px;
            width:680px;
            height:680px;
            border-radius:50%;
            background:linear-gradient(180deg,#c7fbf6 0%,#f1fcfa 50%,#f1fcfa 100%);
            opacity:.58;
        }

        .login-bg-art__ring{
            position:absolute;
            left:0;
            top:33vh;
            width:322px;
            height:322px;
            border-radius:50%;
            background:linear-gradient(135deg,#b7faf0 0%,rgba(183,250,240,0) 76%,rgba(183,250,240,0) 100%);
            -webkit-mask-image:radial-gradient(circle,transparent 0 31%,#000 31.3% 50%,transparent 50.3%);
            mask-image:radial-gradient(circle,transparent 0 31%,#000 31.3% 50%,transparent 50.3%);
            opacity:.7;
        }

        .login-bg-art__grid{
            display:none;
        }

        .navbar-actions{display:flex;align-items:center;gap:17px}
        .navbar-account-frame{position:relative;display:inline-flex;align-items:center;justify-content:center}
        .navbar-guest-avatar{width:40px;height:40px;border-radius:999px;object-fit:cover;background:transparent;box-shadow:0 8px 18px rgba(15,23,42,.16)}
        .navbar-login-link{display:inline-flex;align-items:center;gap:10px}
        .navbar-drawer-toggle{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border:none;border-radius:999px;background:rgba(255,255,255,.12);color:#fff;cursor:pointer;box-shadow:0 8px 18px rgba(15,23,42,.14)}
        .navbar-drawer-toggle svg{width:22px;height:22px;stroke:currentColor}
        .navbar-drawer-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.15);backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1200}
        .navbar-drawer-backdrop.is-open{opacity:1;pointer-events:auto}
        .navbar-drawer-panel{position:fixed;top:0;right:0;bottom:0;width:min(360px,86vw);background:rgba(255,255,255,.7);color:#1f2937;box-shadow:-20px 0 40px rgba(15,23,42,.1);transform:translateX(100%);opacity:0;visibility:hidden;pointer-events:none;transition:transform .22s ease,opacity .18s ease,visibility 0s linear .22s;z-index:1201;display:flex;flex-direction:column;border-left:1px solid rgba(15,23,42,.08);backdrop-filter:blur(10px);overflow:hidden}
        .navbar-drawer-panel.is-open{transform:translateX(0);opacity:1;visibility:visible;pointer-events:auto;transition:transform .22s ease,opacity .18s ease}
        .navbar-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:22px 22px 18px;border-bottom:1px solid rgba(15,23,42,.08)}
        .navbar-drawer-title{font-size:20px;font-weight:700;color:#333333;display:inline-flex;align-items:center;gap:8px}
        .navbar-drawer-title svg{width:20px;height:20px;stroke:currentColor}
    .navbar-drawer-close{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid rgba(15,23,42,.1);border-radius:999px;background:rgba(255,255,255,.55);color:#334155;cursor:pointer;transition:box-shadow .18s ease,transform .18s ease}
    .navbar-drawer-close:hover{box-shadow:0 8px 18px rgba(15,23,42,.14);transform:scale(1.04)}
    .navbar-drawer-close:active{box-shadow:0 5px 12px rgba(15,23,42,.12);transform:scale(.98)}
    .navbar-drawer-close:focus-visible{outline:3px solid rgba(94,137,238,.28);outline-offset:3px}
        .navbar-drawer-close svg{width:20px;height:20px;stroke:currentColor}
        .navbar-drawer-nav{display:grid;gap:18px;padding:18px 24px 22px;align-content:start;flex:1 1 auto;min-height:0;overflow-y:auto;overscroll-behavior:contain}
    .navbar-drawer-link{font-size:17px;display:flex;align-items:center;justify-content:space-between;padding:16px 21px;border-radius:14px;color:#444444;text-decoration:none;font-weight:500;border:none;transition:background .18s ease,box-shadow .18s ease,transform .18s ease}
    .navbar-drawer-link:hover{background:rgba(255,255,255,.86);box-shadow:0 10px 24px rgba(15,23,42,.10);transform:translateY(-2px)}
    .navbar-drawer-link:active{box-shadow:0 6px 16px rgba(15,23,42,.08);transform:translateY(0) scale(.99)}
    .navbar-drawer-link:focus-visible{outline:3px solid rgba(94,137,238,.24);outline-offset:3px}
        .navbar-drawer-link .drawer-link-main{display:inline-flex;align-items:center;gap:12px;min-width:0}
        .navbar-drawer-link .drawer-link-main svg{width:18px;height:18px;flex-shrink:0;stroke:currentColor;opacity:.65}
        .navbar-drawer-link .drawer-link-main span{line-height:1.1}
    .navbar-drawer-link.is-active{background:rgba(255,255,255,.8);box-shadow:1px 1px 3px rgb(0,0,0,0.1)}
    .navbar-drawer-link.is-active:hover{background:rgba(255,255,255,.8);box-shadow:1px 1px 3px rgb(0,0,0,0.1);transform:none}
    .navbar-drawer-link.is-active:active{background:rgba(255,255,255,.8);box-shadow:1px 1px 3px rgb(0,0,0,0.1);transform:none}
        .navbar-drawer-link small{font-size:12px;font-weight:500;color:#64748b}
        @media (max-width: 767px){
            .navbar-drawer-nav{display:grid;gap:14px;padding:18px 24px 22px;align-content:start;flex:1 1 auto;min-height:0;overflow-y:auto;overscroll-behavior:contain}
            .navbar-drawer-link{font-size:15px;display:flex;align-items:center;justify-content:space-between;padding:13px 21px;border-radius:14px;color:#444444;text-decoration:none;font-weight:500;border:none;transition:background .18s ease,box-shadow .18s ease,transform .18s ease}
            .navbar-drawer-close svg{width:18px;height:18px;stroke:currentColor}
            .navbar-drawer-close{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid rgba(15,23,42,.1);border-radius:999px;background:rgba(255,255,255,.55);color:#334155;cursor:pointer;transition:box-shadow .18s ease,transform .18s ease}
            .navbar-drawer-title{font-size:17.5px}
            .navbar-drawer-head{padding:14px 22px 14px}
        }
        .home-top-nav{position:fixed;left:0;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;width:100%;height:62px;margin:0;padding:0 max(32px,calc((100vw - 1920px)/2));border:none;border-bottom:1px solid rgba(15,23,42,.05);border-radius:0;background:rgba(255,255,255,.4);box-shadow:0 8px 24px rgba(15,23,42,.03);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transform:none}
        .home-top-brand{display:flex;align-items:center;gap:12px;color:#222222;text-decoration:none;font-size:19px;font-weight:500;white-space:nowrap}
        .home-top-brand span{display:inline-block;transform:skewX(-6deg)}
        .home-top-brand img{display:block;width:36px;height:48px;object-fit:contain}
        .home-top-links{display:flex;align-items:center;gap:70px;margin-left:auto;margin-right:34px}
        .home-top-nav .navbar-login-link{color:#1f2937;border-radius:10px;padding:9px 12px;font-size:15px;text-decoration:none}
        .home-top-nav .navbar-login-link{display:none}
        .home-top-nav .navbar-guest-avatar{width:38px;height:38px;box-shadow:none;border:none}
        .home-top-nav .navbar-drawer-toggle.home-drawer-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid #cbd5e1;border-radius:8px;background:rgba(255,255,255,.7);color:#475569;box-shadow:none;flex-shrink:0;transition:box-shadow .18s ease,transform .18s ease}
        .home-top-nav .navbar-drawer-toggle.home-drawer-btn:hover{box-shadow:0 8px 18px rgba(15,23,42,.14);transform:scale(1.03)}
        .home-top-nav .navbar-drawer-toggle.home-drawer-btn:active{box-shadow:0 5px 12px rgba(15,23,42,.12);transform:scale(.98)}
        .home-top-nav .navbar-drawer-toggle.home-drawer-btn:focus-visible{outline:3px solid rgba(94,137,238,.28);outline-offset:3px}
        .home-top-nav .home-drawer-btn svg{width:20px;height:20px;stroke:currentColor}
        body.public-home-page .footer{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;width:100%;padding:26px 20px;background:transparent;color:#8a8f93;font-size:12px;line-height:1.4}
        body.public-home-page .footer{position:fixed;left:0;bottom:0;z-index:10}
        body.public-home-page .footer:before{content:"\00a9  2026 百灵果 BilingGo"}
        body.public-home-page .footer p{margin:0}
        body.public-home-page .footer p:first-child{display:none}
        body.public-home-page .footer p:nth-child(2){display:flex!important;align-items:center;justify-content:center;gap:16px!important;flex-wrap:wrap;margin:0!important;font-size:12px!important}
        body.public-home-page .footer a{color:#8a8f93;text-decoration:underline;text-underline-offset:3px}
        body.public-home-page .footer a:hover{color:#4abc99}
        .terms-modal-overlay{position:fixed;inset:0;z-index:99990;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(15,23,42,.18);backdrop-filter:blur(6px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s ease,visibility 0s linear .18s}
        body.terms-modal-lock{overflow:hidden}
        .terms-modal-overlay.is-open{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .18s ease}
        .terms-modal-dialog{position:relative;display:flex;flex-direction:column;width:min(680px,calc(100vw - 40px));height:min(560px,calc(100vh - 72px));background:#fff;border:none;border-radius:6px;box-shadow:0 28px 86px rgba(15,23,42,.18);overflow:hidden}
        .terms-modal-head{position:relative;display:flex;align-items:center;justify-content:center;flex:0 0 58px;border-bottom:1px solid #edf0f3;background:#fff}
        .terms-modal-title{margin:0;padding:0 58px;color:#333333;font-size:18px;font-weight:600;line-height:1.2;text-align:center}
        .terms-modal-body{flex:1 1 auto;min-height:0;padding:18px;background:#fff}
        .terms-modal-content-panel{width:100%;height:100%;overflow:hidden;border:1px solid #e5e7eb;background:#f8fafc}
        .terms-modal-frame{display:block;width:100%;height:100%;border:0;background:#f8fafc}
        .terms-modal-foot{display:flex;align-items:center;justify-content:center;flex:0 0 auto;padding:0 18px 20px;background:#fff}
        .terms-modal-confirm{display:inline-flex;align-items:center;justify-content:center;min-width:170px;height:42px;padding:0 28px;border:none;border-radius:999px;background:#4abc99;color:#fff;font-size:15px;font-weight:600;line-height:1;cursor:pointer;box-shadow:none}
        .terms-modal-confirm:hover{background:#3cae8d}
        .login-left-stack{
            position:fixed;
            left:max(112px,calc((100vw - 1400px)/2 + 84px));
            top:50%;
            transform:translateY(-50%);
            z-index:1;
            width:600px;
        }
        .login-hero-copy{position:relative;z-index:1;width:100%;margin:0}
        .home-hero-title{margin:0;color:#333333;font-size:46px;font-weight:600;line-height:1.05;letter-spacing:0;white-space:nowrap}
        .home-hero-title .is-green{color:transparent;background:linear-gradient(90deg,#48dc7f 0%,#059969 100%);-webkit-background-clip:text;background-clip:text}
        .home-hero-subtitle{position:relative;z-index:0;margin:30px 0 0;color:#111111;font-size:30px;font-weight:300;line-height:1.16;letter-spacing:0;white-space:nowrap}
        .home-hero-subtitle .subtitle-text{position:relative;z-index:1}
        .home-hero-subtitle .marked{position:relative;display:inline-block;padding:0 .12em;z-index:0}
        .home-hero-subtitle .marked-text{position:relative;z-index:1}
        .home-hero-subtitle .marked-arc{position:absolute;left:-.38em;top:-.58em;width:4.85em;height:2.56em;z-index:0;pointer-events:none;overflow:visible}
        .home-hero-subtitle .marked:before{content:none}
        .home-hero-subtitle .marked:after{content:none}
        .login-preview-stage{position:relative;z-index:1;width:100%;margin:50px 0 0}
        .login-preview-shell{position:relative;width:600px}
        .login-preview-outline{position:absolute;left:0;top:0;width:766px;height:500px;z-index:0;overflow:visible;pointer-events:none}
        .login-preview-card{position:relative;z-index:1;width:600px;height:394px;padding:14px;border-radius:24px;background:rgba(255,255,255,.96);box-shadow:0 18px 44px rgba(15,23,42,.10);overflow:hidden}
        .login-preview-inner{width:100%;height:100%;border-radius:20px;overflow:hidden}
        .login-preview-inner img{display:block;width:100%;height:auto}
        .login-preview-image--mobile{display:none!important}

        .auth-shell{
            width:min(460px,100%);
            margin:0 0 0 auto;
            border-radius:24px;
            border:1px solid rgba(216,226,242,.65);
            background:rgba(255,255,255,.95);
            box-shadow:0 14px 38px rgba(15,23,42,.06);
            overflow:hidden;
        }

        .auth-copy{
            position:relative;
            padding:52px 46px;
            color:#f5fffb;
            background:
                linear-gradient(165deg,rgba(8,43,38,.92),rgba(15,118,110,.76)),
                radial-gradient(circle at top left,rgba(255,255,255,.16),transparent 34%);
        }

        .auth-copy::after{
            content:"";
            position:absolute;
            right:-54px;
            bottom:-54px;
            width:220px;
            height:220px;
            border-radius:50%;
            background:radial-gradient(circle,rgba(255,255,255,.18),rgba(255,255,255,0));
        }

        .auth-badge{
            display:inline-flex;
            align-items:center;
            gap:8px;
            padding:9px 14px;
            border-radius:999px;
            background:rgba(255,255,255,.12);
            font-size:12px;
            font-weight:800;
            letter-spacing:.08em;
            text-transform:uppercase;
        }

        .auth-brand-lockup{
            display:flex;
            align-items:center;
            gap:14px;
            margin-bottom:26px;
        }

        .auth-brand-mark{
            width:58px;
            height:58px;
            border-radius:18px;
            object-fit:contain;
            background:rgba(255,255,255,.94);
            padding:7px;
            box-shadow:0 16px 34px rgba(0,0,0,.18);
            flex:0 0 auto;
        }

        .auth-brand-text strong{
            display:block;
            color:#fff;
            font-size:25px;
            line-height:1.08;
            font-weight:900;
        }

        .auth-brand-text span{
            display:block;
            margin-top:6px;
            color:rgba(245,255,251,.78);
            font-size:12px;
            line-height:1.35;
            font-weight:900;
            letter-spacing:.08em;
            text-transform:uppercase;
        }

        .auth-copy h1{
            margin:18px 0 14px;
            font-size:clamp(34px,4vw,50px);
            line-height:1.06;
            letter-spacing:-.02em;
        }

        .auth-copy p{
            margin:0;
            max-width:460px;
            font-size:15px;
            line-height:1.9;
            color:rgba(245,255,251,.88);
        }

        .auth-card{
            padding:44px 40px 40px;
            background:transparent;
        }

        .auth-card-head{
            margin-bottom:24px;
        }

        .auth-card-head h2{
            margin:0;
            color:#333333;
            font-size:25px;
            line-height:1.22;
            letter-spacing:0;
            font-weight:500;
        }

        .login-mode-tabs{
            display:flex;
            margin:28px 0 28px;
            border-bottom:1px solid #d7e3f6;
        }

        .login-mode-tab{
            position:relative;
            padding:0 20px 12px;
            color:#39bb9f;
            font-size:16px;
            line-height:1;
            font-weight:500;
            letter-spacing:0;
        }

        .login-mode-tab:after{
            content:"";
            position:absolute;
            left:20px;
            right:20px;
            bottom:-1px;
            height:2px;
            border-radius:999px;
            background:#39bb9f;
        }

        .error,
        .error-message{
            margin-bottom:16px;
            padding:12px 14px;
            border-radius:14px;
            background:var(--danger-bg);
            color:var(--danger);
            font-size:14px;
            line-height:1.6;
        }

        .login-form{
            display:grid;
            gap:18px;
        }

        .field{margin:0}

        .field > input,
        .field > select,
        .phone-row input{
            width:100%;
            height:52px;
            padding:0 26px;
            border-radius:10px;
            border:2px solid #ccd9ee;
            background:#fff;
            color:#424952;
            font-size:15px;
            font-weight:500;
            outline:none;
            transition:border-color .16s ease;
        }

        .field > input::placeholder,
        .phone-row input::placeholder{color:#bcc8db}
        .field > input:focus,
        .field > select:focus{border-color:#39bb9f}

        .phone-row{
            display:grid;
            grid-template-columns:80px 1fr;
            gap:0;
            border:1px solid #ccd9ee;
            border-radius:10px;
            overflow:hidden;
            background:#fff;
        }

        .phone-row:focus-within{
            border-color:#39bb9f;
        }

        .phone-row select{
            appearance:none;
            -webkit-appearance:none;
            -moz-appearance:none;
            outline:none;
            border:0;
            border-right:1px solid #ccd9ee;
            border-radius:0;
            padding:0 24px 0 12px;
            font-size:15px;
            color:#1f2430;
            background:#fff;
            background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2390A0B8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");
            background-repeat:no-repeat;
            background-position:calc(100% - 10px) 50%;
        }

        .phone-row:focus-within select{
            border-right-color:#39bb9f;
        }

        .phone-row input{
            border:0;
            border-radius:0;
            height:52px;
            outline:none;
        }

        .phone-row select:focus,
        .phone-row input:focus{
            outline:none;
            box-shadow:none;
        }

        #phone-login-password{
            border-width:1px;
        }

        .login-agreement{
            margin:0 0 6px;
            color:#7a8498;
            font-size:13px;
            line-height:1.4;
        }

        .login-agreement a{
            color:#4a83f6;
            text-decoration:none;
        }

        .submit-btn{
            margin-top:28px;
            width:100%;
            height:52px;
            border:none;
            border-radius:10px;
            background:#4abc99;
            color:#fff;
            font-size:16px;
            font-weight:500;
            cursor:pointer;
            box-shadow:none;
            transition:background-color .18s ease,transform .18s ease;
        }
        .submit-btn:hover{background:#3cad8d}
        .submit-btn:active{background:#359f82;transform:translateY(1px)}

        .panel-links{
            margin-top:130px;
            display:flex;
            justify-content:space-between;
            align-items:center;
            gap:12px;
            font-size:14px;
            line-height:1.4;
        }

        .panel-links .muted{
            color:#7a8498;
            font-weight:400;
        }

        .panel-links a{
            color:#7a8498;
            text-decoration:none;
            font-weight:400;
        }

        .panel-links a.register-link{
            color:#3dbc9f;
            font-weight:500;
        }

        @media (max-width:767px){
            html{
                min-height:100%;
                height:auto;
                overflow-x:hidden;
                overflow-y:auto;
            }
            body.public-home-page{
                min-height:100dvh;
                height:auto;
                padding:0 0 28px;
                background:#f7f9fb;
                align-items:stretch;
                overflow-x:hidden;
                overflow-y:auto;
                overscroll-behavior-y:auto;
            }
            .home-top-nav{
                position:fixed;
                left:0;
                top:0;
                z-index:20;
                display:flex;
                align-items:center;
                justify-content:space-between;
                width:100%;
                height:56px;
                margin:0;
                padding:0 max(13px,calc((100vw - 1920px)/2));
                border:none;
                border-bottom:1px solid rgba(15,23,42,.06);
                border-radius:0;
                background:rgba(255,255,255,.72);
                box-shadow:none;
                backdrop-filter:blur(10px);
                transform:none;
            }
            .home-top-brand{
                display:flex;
                align-items:center;
                align-self:center;
                gap:3px;
                height:56px;
                min-width:0;
                max-width:calc(100% - 62px);
                color:#222222;
                text-decoration:none;
                font-size:16px;
                font-weight:500;
                white-space:nowrap;
                overflow:hidden;
                line-height:1;
            }
            .home-top-brand span{
                min-width:0;
                overflow:hidden;
                text-overflow:ellipsis;
                white-space:nowrap;
                line-height:1;
            }
            .home-top-brand img{
                display:block;
                width:30px;
                height:40px;
                flex:0 0 30px;
                align-self:center;
                object-fit:contain;
            }
            .home-top-nav .navbar-menu,
            .home-top-nav .navbar-actions{
                height:56px;
                display:flex;
                align-items:center;
                align-self:center;
                margin-left:auto;
            }
            .home-top-nav .navbar-drawer-toggle.home-drawer-btn{
                display:inline-flex;
                align-items:center;
                justify-content:center;
                width:40px;
                height:56px;
                min-height:44px;
                align-self:center;
                padding:0;
                border:none;
                border-radius:0;
                background:transparent;
                color:#475569;
                box-shadow:none;
                flex-shrink:0;
            }
            body.public-home-page .footer{
                display:none;
            }
            .login-left-stack{
                position:relative;
                left:auto;
                top:auto;
                transform:none;
                width:calc(100% - 48px);
                margin:76px auto 0;
            }
            .login-hero-copy{width:100%;margin:0;padding-right:43%}
            .login-hero-copy:before{
                content:"欢迎使用";
                display:block;
                margin:10px 0 0;
                color:#333333;
                font-size:27px;
                font-weight:700;
                line-height:1.1;
            }
            .home-hero-title{margin-top:13px;font-size:21px;line-height:1.2;white-space:normal;word-spacing:-0.1em}
            .home-hero-subtitle{margin-top:12px;color:#8a8f9c;font-size:14px;line-height:1.45;white-space:nowrap}
            .home-hero-subtitle .marked-arc{left:-.34em;top:-.44em;width:4.45em;height:2.15em}
            .login-preview-stage{
                position:absolute;
                right:-8px;
                top:8px;
                z-index:0;
                width:47%;
                margin:0;
            }
            .login-preview-shell,
            .login-preview-card{width:100%;height:auto;padding:0;border-radius:0;background:transparent;box-shadow:none;overflow:visible}
            .login-preview-outline{display:none}
            .login-preview-inner{border-radius:0;overflow:visible}
            .login-preview-image--desktop{display:none!important}
            .login-preview-image--mobile{display:block!important;width:100%;height:auto}
            body.public-home-page .auth-shell{
                position:static;
                top:auto;
                right:auto;
                transform:none;
                width:calc(100% - 48px);
                margin:18px auto 0;
                border:none;
                border-radius:0;
                background:transparent;
                box-shadow:none;
                overflow:visible;
            }
            .auth-card{padding:0;background:transparent}
            .auth-card-head{display:none}
            .login-mode-tabs{margin:22px 0 24px;border-bottom:none}
            .login-mode-tab{position:relative;padding:0;color:#4abc99;font-size:15px;font-weight:500;line-height:1.1;z-index:1}
            .login-mode-tab:after{
                content:"";
                display:block;
                position:absolute;
                left:50%;
                transform:translateX(-50%);
                bottom:-4px;
                width:34px;
                height:5px;
                border-radius:999px;
                background:#67d4be;
                z-index:-1;
            }
            .login-form{gap:16px}
            .field > input,.field > select,.phone-row input{height:48px;padding:0 16px;border:2px solid #dfe8f8;border-radius:10px;color:#101010;font-size:14px;font-weight:400;background:#fff}
            .field > input::placeholder,
            .phone-row input::placeholder{color:#c7cfdd}
            .field > input:focus,
            .field > select:focus{border-color:#9ec7f4}
            .phone-row{grid-template-columns:82px 1fr;border:2px solid #dfe8f8;border-radius:10px;background:#fff}
            .phone-row:focus-within{border-color:#9ec7f4}
            .phone-row select{
                appearance:none;
                -webkit-appearance:none;
                -moz-appearance:none;
                padding:0 28px 0 18px;
                border-right:2px solid #dfe8f8;
                color:#101010;
                font-size:14px;
                background-color:#fff;
                background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2390A0B8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");
                background-repeat:no-repeat;
                background-position:calc(100% - 14px) 50%;
            }
            .phone-row:focus-within select{border-right-color:#9ec7f4}
            .phone-row input{border:none;border-radius:0}
            #phone-login-password{border-width:2px}
            .login-agreement{margin:0 0 0;color:#7c8292;font-size:10.5px;line-height:1.45}
            .login-agreement a{color:#4387ff}
            .submit-btn{margin-top:22px;height:48px;border-radius:100px;font-size:16px;font-weight:500}
            .panel-links{margin-top:34px;font-size:13px}
            .terms-modal-overlay{padding:18px}
            .terms-modal-dialog{width:calc(100vw - 36px);height:min(520px,calc(100vh - 120px))}
            .terms-modal-head{flex-basis:52px}
            .terms-modal-title{font-size:16px}
            .terms-modal-body{padding:12px}
            .terms-modal-foot{padding:0 12px 16px}
            .terms-modal-confirm{min-width:148px;height:38px;padding:0 22px;font-size:14px}
            .login-bg-art:before{left:-76px;top:70px;width:250px;height:250px;opacity:.42}
            .login-bg-art:after{right:-220px;top:-80px;bottom:auto;width:520px;height:520px;opacity:.22}
            .login-bg-art__ring{display:none}
            .login-bg-art__grid{display:none}
        }

        .register-form .send-row{display:grid;grid-template-columns:1fr 112px;gap:12px}
        .register-form .send-row input{width:100%;height:52px;padding:0 26px;border:1px solid #ccd9ee;border-radius:10px;background:#fff;color:#424952;font-size:15px;font-weight:500;outline:none;transition:border-color .16s ease}
        .register-form .send-row input::placeholder{color:#bcc8db}
        .register-form .send-row input:focus{border-color:#39bb9f}
        .register-form .send-btn{height:52px;border:1px solid #cbd5e1;border-radius:10px;background:#f8fafc;color:#64748b;font-size:14px;font-weight:400;cursor:pointer;box-shadow:none;transition:background-color .18s ease,border-color .18s ease,color .18s ease,transform .18s ease}
        .register-form .send-btn:hover{background:#eef2f7;border-color:#b8c6d9;color:#475569}
        .register-form .send-btn:active{background:#e2e8f0;border-color:#aebdd0;color:#334155;transform:translateY(1px)}
        .register-form .field > input{height:52px;border:1px solid #ccd9ee;border-radius:10px}
        .register-form .field > input:focus{border-color:#39bb9f}
        .register-form .field-label{margin:0 0 7px;color:#5f697b;font-size:13px;font-weight:500;line-height:1.3}
        .register-form .field-hint{min-height:16px;margin-top:5px;color:#7a8498;font-size:11px;line-height:1.35}
        .register-form .field-hint:empty{display:none}
        .register-form .field-hint.error{color:#a42828}
        .status-line{min-height:18px;margin-top:6px;color:#7a8498;font-size:12px;line-height:1.4}
        .status-line.success{color:#0f766e}
        .status-line.error{color:#a42828}
        .referral-notice{
            margin:0 0 16px;
            padding:12px 14px;
            border:1px solid rgba(74,188,153,.2);
            border-radius:12px;
            background:rgba(74,188,153,.08);
            color:#217662;
            font-size:13px;
            line-height:1.6;
        }
        .registration-closed{
            margin:8px 0 18px;
            padding:14px 16px;
            border:1px solid rgba(74,188,153,.22);
            border-radius:14px;
            background:rgba(74,188,153,.08);
            color:#217662;
            font-size:14px;
            line-height:1.7;
        }
        .register-agreement{display:flex;align-items:flex-start;gap:8px;margin:0;color:#7a8498;font-size:13px;line-height:1.45}
        .register-agreement input{
            appearance:none;
            -webkit-appearance:none;
            width:14px;
            height:14px;
            margin:2px 0 0;
            border:1px solid #ccd9ee;
            border-radius:3px;
            background:transparent;
            flex:0 0 auto;
            display:inline-grid;
            place-content:center;
        }
        .register-agreement input:checked{
            border-color:#4abc99;
            background-color:transparent;
            background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='8' viewBox='0 0 10 8' fill='none'%3E%3Cpath d='M1 4l2.5 2.5L9 1' stroke='%234ABC99' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
            background-repeat:no-repeat;
            background-position:center;
            background-size:10px 8px;
        }
        .register-agreement input:focus{outline:none;box-shadow:0 0 0 2px rgba(74,188,153,.18)}
        .register-agreement a{color:#4a83f6;text-decoration:none}
        .register-form .register-icon-input{padding-left:48px!important;background-repeat:no-repeat;background-position:18px 50%;background-size:16px 16px}
        .register-form .register-icon-phone{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='7' y='2' width='10' height='20' rx='2'/%3E%3Cpath d='M11 18h2'/%3E%3C/svg%3E")}
        .register-form .register-icon-code{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='14' rx='2'/%3E%3Cpath d='m3 7 9 6 9-6'/%3E%3C/svg%3E")}
        .register-form .send-row input.register-icon-code{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='14' rx='2'/%3E%3Cpath d='m3 7 9 6 9-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:18px 50%;background-size:16px 16px}
        .register-form .register-icon-lock{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='5' y='11' width='14' height='10' rx='2'/%3E%3Cpath d='M8 11V7a4 4 0 0 1 8 0v4'/%3E%3C/svg%3E")}
        .register-form .register-icon-check{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3C/svg%3E")}
        .register-form .register-icon-user{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3Cpath d='M4 21c1.8-4 4.5-6 8-6s6.2 2 8 6'/%3E%3C/svg%3E")}
        .register-form + .panel-links{margin-top:24px}

        .captcha-modal{
            position:fixed;
            inset:0;
            display:none;
            align-items:center;
            justify-content:center;
            padding:18px;
            background:rgba(15,23,42,.48);
            z-index:1300;
        }
        .captcha-modal.active{display:flex}
        .captcha-card{
            width:min(360px,100%);
            padding:20px;
            border-radius:18px;
            background:#fff;
            box-shadow:0 24px 64px rgba(15,23,42,.24);
        }
        .captcha-head{
            display:flex;
            justify-content:space-between;
            align-items:center;
            gap:12px;
            margin-bottom:14px;
        }
        .captcha-head strong{color:#0f172a;font-size:17px}
        .captcha-close{
            border:none;
            background:#f1f5f9;
            color:#64748b;
            border-radius:10px;
            width:32px;
            height:32px;
            cursor:pointer;
            font-size:20px;
            line-height:1;
        }
        .captcha-canvas{
            position:relative;
            height:112px;
            border-radius:16px;
            overflow:hidden;
            background:linear-gradient(135deg,#d7f2eb,#f8fafc 48%,#dbeafe);
            border:1px solid #c8dcd7;
        }
        .captcha-pattern{
            position:absolute;
            inset:0;
            background-image:
                radial-gradient(circle at 18% 24%, rgba(15,118,110,.12) 0 12px, transparent 13px),
                radial-gradient(circle at 78% 26%, rgba(37,99,235,.1) 0 16px, transparent 17px),
                radial-gradient(circle at 50% 76%, rgba(20,163,143,.1) 0 18px, transparent 19px);
        }
        .captcha-target,
        .captcha-piece{position:absolute;width:44px;height:44px}
        .captcha-target{filter:drop-shadow(0 0 0 rgba(255,255,255,0)) drop-shadow(0 8px 14px rgba(15,23,42,.14))}
        .captcha-piece{left:0;filter:drop-shadow(0 12px 18px rgba(15,118,110,.34))}
        .captcha-target svg,
        .captcha-piece svg{display:block;width:44px;height:44px;overflow:visible}
        .captcha-track{
            position:relative;
            height:46px;
            margin-top:14px;
            border-radius:999px;
            background:#eef7f4;
            border:1px solid #d8ece6;
            overflow:hidden;
            user-select:none;
            touch-action:none;
        }
        .captcha-track-fill{
            position:absolute;
            left:0;
            top:0;
            bottom:0;
            width:0;
            background:rgba(15,118,110,.16);
        }
        .captcha-thumb{
            position:absolute;
            left:0;
            top:3px;
            width:40px;
            height:40px;
            border:none;
            border-radius:999px;
            background:#0f766e;
            color:#fff;
            font-weight:900;
            cursor:grab;
            box-shadow:0 8px 18px rgba(15,118,110,.22);
        }
        .captcha-track-label{
            position:absolute;
            inset:0;
            display:flex;
            align-items:center;
            justify-content:center;
            color:#64748b;
            font-size:13px;
            pointer-events:none;
        }
        .captcha-status{min-height:20px;margin-top:10px;color:#7a8498;font-size:13px}
        .captcha-status.error{color:#a42828}
        .captcha-status.success{color:#0f766e}

        body.auth-register-page.public-home-page .auth-shell{
            width:min(448px,calc(100vw - 40px));
            right:max(116px,calc((100vw - 1400px)/2 + 104px));
            max-height:calc(100dvh - 116px);
            overflow-y:auto;
        }
        body.auth-register-page .auth-card{padding:36px 38px 34px}
        body.auth-register-page .auth-card-head{margin-bottom:16px}
        body.auth-register-page .auth-card-head h2{font-size:22px;line-height:1.2}
        body.auth-register-page .login-mode-tabs{margin:16px 0 20px}
        body.auth-register-page .login-mode-tab{padding:0 15px 10px;font-size:15px}
        body.auth-register-page .login-mode-tab:after{left:14px;right:14px}
        body.auth-register-page .login-form{gap:12px}
        body.auth-register-page .field > input,
        body.auth-register-page .field > select,
        body.auth-register-page .phone-row input,
        body.auth-register-page .register-form .send-row input{
            height:48px;
            padding:0 16px;
            font-size:14px;
        }
        body.auth-register-page .phone-row{grid-template-columns:72px 1fr}
        body.auth-register-page .phone-row select{font-size:14px;padding-left:10px}
        body.auth-register-page .register-form .send-row{grid-template-columns:1fr 96px;gap:8px}
        body.auth-register-page .register-form .send-btn{height:48px;font-size:13.5px}
        body.auth-register-page .register-form .register-icon-input{
            padding-left:42px!important;
            background-position:15px 50%;
            background-size:15px 15px;
        }
        body.auth-register-page .register-form .field-label{margin-bottom:5px;font-size:12px}
        body.auth-register-page .register-form .field-hint{min-height:0;margin-top:4px;font-size:10.5px;line-height:1.3}
        body.auth-register-page .status-line{min-height:14px;margin-top:4px;font-size:11px}
        body.auth-register-page .register-agreement{font-size:11.5px;line-height:1.4}
        body.auth-register-page .submit-btn{height:48px;margin-top:10px;font-size:15.5px}
        body.auth-register-page .register-form + .panel-links{margin-top:18px;font-size:13px}

        @media (max-width:767px){
            body.auth-register-page.public-home-page .auth-shell{
                width:calc(100% - 48px);
                max-height:none;
                overflow:visible;
                padding-bottom:18px;
            }
            body.auth-register-page .auth-card{padding:0}
            body.auth-register-page .auth-card-head{display:none}
            body.auth-register-page .login-mode-tabs{margin:16px 0 16px}
            body.auth-register-page .login-form{gap:10px}
            .register-form .send-row{grid-template-columns:1fr 108px;gap:10px}
            .register-form .send-row input{height:48px;padding:0 16px;border:2px solid #dfe8f8;border-radius:10px;color:#101010;font-size:14px;font-weight:400}
            .register-form .send-row input:focus{border-color:#9ec7f4}
            .register-form .send-btn{height:48px;border-radius:10px;font-size:13px;font-weight:400}
            .register-form .field > input{height:48px;border:2px solid #dfe8f8;border-radius:10px}
            .register-form .field > input:focus{border-color:#9ec7f4}
            .register-form .field-label{margin-bottom:6px;color:#7c8292;font-size:11px}
            .register-form .register-icon-input{padding-left:42px!important;background-position:16px 50%;background-size:15px 15px}
            .register-agreement{font-size:10.5px;line-height:1.45}
            .register-agreement input{width:12px;height:12px;margin-top:1px}
            .register-form + .panel-links{margin-top:24px}
        }
