.lang-switch{position:relative}.lang-switch.row{width:100%}.ls-pill{display:flex;align-items:center;gap:5px;padding:6px 10px;border-radius:50px;border:1.5px solid #E8E4DE;background:transparent;font-size:12px;font-weight:700;color:var(--muted);cursor:pointer}.ls-pill:hover{background:#f7f5f0;color:var(--text)}.ls-pill .ls-chev{font-size:13px}.ls-row{width:100%;padding:13px 16px;border-radius:14px;border:1.5px solid var(--border);background:#fff;color:var(--text);font-family:Nunito,sans-serif;font-weight:700;font-size:13.5px;cursor:pointer;display:flex;align-items:center;justify-content:space-between}.ls-row:hover{background:#faf9f7}.ls-row-l{display:flex;align-items:center;gap:9px}.ls-row-l i{color:var(--muted);font-size:17px}.ls-row-r{display:flex;align-items:center;gap:6px;color:var(--muted);font-weight:700;font-size:12.5px}.ls-menu{position:absolute;z-index:30;background:#fff;border:1.5px solid var(--border);border-radius:14px;box-shadow:0 12px 30px #00000024;overflow:hidden}.lang-switch.pill .ls-menu{top:calc(100% + 6px);right:0;width:160px}.lang-switch.row .ls-menu{top:calc(100% + 6px);left:0;right:0}.ls-item{display:flex;align-items:center;width:100%;padding:11px 13px;font-size:13px;font-weight:700;color:var(--text);cursor:pointer;background:none;border:none;text-align:left}.ls-item:hover{background:#f7f5f0}.ls-item.active{color:var(--coral)}.ls-item:not(:last-child){border-bottom:1px solid var(--border)}.ls-ck{margin-left:auto;color:var(--coral);font-size:16px}.seven-stage{--coral:#FF6B6B;--coral-l:#FFE8E8;--coral-d:#E84848;--mint:#4ECDC4;--mint-l:#E0F7F5;--mint-d:#0A7A70;--sky:#4A90D9;--sky-l:#E3F0FB;--lemon-l:#FFFBE0;--navy:#2C3E50;--green:#27AE60;--green-l:#E3F7EC;--bg:#F7F5F0;--card:#FFFFFF;--text:#2C3E50;--muted:#7F8C8D;--border:#F0EDE8;--accent:#4ECDC4;--accent-l:#E0F7F5;--accent-d:#0A7A70;--accent2:#3FB8AF;--slate:#46586C;min-height:100dvh;background:#e8e4dc;overflow-y:auto;font-family:Nunito Sans,sans-serif;color:var(--text);display:flex;justify-content:center;align-items:flex-start;padding:24px 16px 40px}.seven-stage *{box-sizing:border-box}.seven-shell{position:relative;width:100%;max-width:420px;height:calc(100dvh - 64px);max-height:calc(100dvh - 64px);background:var(--bg);border-radius:40px;box-shadow:0 32px 80px #00000038,0 0 0 1px #00000014;overflow:hidden;display:flex;flex-direction:column}@media(min-width:640px){.seven-shell{max-width:560px}}@media(min-width:1024px){.seven-shell{max-width:720px}}.seven-stage .topbar{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--card);border-bottom:1.5px solid var(--border);flex-shrink:0}.seven-stage .back-btn{width:32px;height:32px;border-radius:9px;border:1.5px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);font-size:17px;flex-shrink:0}.seven-stage .topbar-title{font-family:Nunito,sans-serif;font-weight:900;font-size:17px;color:var(--text);flex:1}.seven-stage .help-btn{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border);background:var(--lemon-l);display:flex;align-items:center;justify-content:center;color:#b9770b;font-size:17px;cursor:pointer;flex-shrink:0}.seven-stage .elo-badge{display:flex;align-items:center;gap:4px;padding:5px 11px;border-radius:50px;background:var(--mint-l);font-family:Nunito,sans-serif;font-weight:800;font-size:12px;color:var(--mint-d)}.seven-stage .notice{display:flex;align-items:center;gap:7px;padding:9px 16px;background:var(--lemon-l);color:#8a6d00;font-size:12.5px;font-weight:700;flex-shrink:0}.seven-stage .scroll-area{flex:1;overflow-y:auto;padding-bottom:16px}.seven-stage .scroll-area::-webkit-scrollbar{width:0}.seven-stage .hero-strip{background:linear-gradient(135deg,#5bdbd2,#2aada4);padding:18px 18px 20px;position:relative;overflow:hidden;display:flex;align-items:center;gap:14px}.seven-stage .hero-strip:before{content:"";position:absolute;top:-22px;right:-22px;width:110px;height:110px;border-radius:50%;background:#ffffff17}.seven-stage .hboard{flex-shrink:0;width:64px;height:64px;border-radius:15px;background:#ffffff29;display:flex;align-items:center;justify-content:center}.seven-stage .hinfo h2{font-family:Nunito,sans-serif;font-weight:900;font-size:20px;color:#fff}.seven-stage .hinfo p{font-size:11.5px;color:#ffffffe6;line-height:1.45;margin-top:3px}.seven-stage .hstats{display:flex;gap:16px;margin-top:8px}.seven-stage .hs{display:flex;flex-direction:column}.seven-stage .hs-n{font-family:Nunito,sans-serif;font-weight:800;font-size:14px;color:#fff}.seven-stage .hs-l{font-size:10px;color:#ffffffbd;font-weight:600}.seven-stage .rules-link{display:inline-flex;align-items:center;gap:6px;margin-top:11px;padding:6px 12px;border-radius:50px;background:#ffffff2e;border:1.5px solid rgba(255,255,255,.4);color:#fff;font-family:Nunito,sans-serif;font-weight:800;font-size:12px;cursor:pointer}.seven-stage .rules-link:hover{background:#ffffff47}.seven-stage .rules-link .ti-chevron-right{font-size:14px;opacity:.8}.seven-stage .tab-bar{display:flex;border-bottom:1.5px solid var(--border);background:var(--card);flex-shrink:0}.seven-stage .tab{flex:1;padding:11px 0;text-align:center;font-family:Nunito,sans-serif;font-weight:700;font-size:13px;color:var(--muted);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent}.seven-stage .tab.active{color:var(--mint-d);border-bottom-color:var(--mint-d)}.seven-stage .tab .ti{font-size:15px;vertical-align:-2px;margin-right:3px}.seven-stage .rules-body{padding:16px 16px 28px}.seven-stage .section{padding:16px 16px 0}.seven-stage .sec-title{font-family:Nunito,sans-serif;font-weight:900;font-size:15px;margin-bottom:11px}.seven-stage .mode-list{display:flex;flex-direction:column;gap:11px}.seven-stage .mode-card{background:var(--card);border-radius:18px;border:1.5px solid var(--border);padding:14px;cursor:pointer;display:flex;align-items:center;gap:13px;position:relative;transition:transform .14s}.seven-stage .mode-card:hover{transform:translateY(-2px)}.seven-stage .mode-card.selected{border-color:var(--mint);border-width:2px;box-shadow:0 4px 16px #4ecdc429}.seven-stage .m-icon{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:23px}.seven-stage .m-icon.ai{background:linear-gradient(135deg,var(--mint-l),#B3EDE8);color:var(--mint-d)}.seven-stage .m-icon.invite{background:linear-gradient(135deg,#e7f7e9,#c6ebcb);color:var(--green)}.seven-stage .m-icon.random{background:linear-gradient(135deg,var(--sky-l),#B8D7F5);color:var(--sky)}.seven-stage .m-body{flex:1;min-width:0}.seven-stage .m-name{font-family:Nunito,sans-serif;font-weight:800;font-size:14px}.seven-stage .m-desc{font-size:11.5px;color:var(--muted);line-height:1.4;margin-top:2px}.seven-stage .m-tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:7px}.seven-stage .mtag{display:inline-flex;align-items:center;gap:3px;padding:3px 7px;border-radius:50px;font-size:10px;font-weight:700;font-family:Nunito,sans-serif}.seven-stage .diff-row{display:flex;gap:6px;margin-top:9px}.seven-stage .diff-btn{flex:1;padding:7px 0;border-radius:9px;border:1.5px solid var(--border);background:transparent;font-family:Nunito,sans-serif;font-weight:700;font-size:12px;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:4px}.seven-stage .diff-btn.on{border-color:var(--mint);background:var(--mint-l);color:var(--mint-d)}.seven-stage .online-row{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:11px;color:var(--muted);font-weight:600}.seven-stage .odot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px #27ae6029}.seven-stage .m-arrow{margin-left:auto;color:#cbd3d9;font-size:18px}.seven-stage .players{display:flex;align-items:stretch;gap:8px;padding:13px 16px 11px;background:var(--card);border-bottom:1.5px solid var(--border);flex-shrink:0}.seven-stage .pcard{flex:1;display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:14px;border:1.5px solid var(--border);background:#fff}.seven-stage .pcard.me{border-color:var(--mint)}.seven-stage .pav{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:Nunito,sans-serif;font-weight:800;font-size:12px;color:#fff;flex-shrink:0}.seven-stage .pav.me{background:var(--mint)}.seven-stage .pav.op{background:var(--slate)}.seven-stage .pname{font-family:Nunito,sans-serif;font-weight:800;font-size:13px}.seven-stage .pmeta{font-size:11px;color:var(--muted);font-weight:600;margin-top:1px}.seven-stage .vs{display:flex;align-items:center;font-family:Nunito,sans-serif;font-weight:900;font-size:12px;color:#c7cdd2}.seven-stage .board-area{flex:1;min-height:0;display:flex;justify-content:center;align-items:center;padding:14px 18px}.seven-stage .board-wrap{width:100%;max-width:min(440px,calc(100dvh - 285px));aspect-ratio:1/1;background:linear-gradient(160deg,#fbf7ef,#f1eadc);border:1.5px solid #E6DCC8;border-radius:20px;box-shadow:inset 0 2px 10px #0000000a;padding:6px}.seven-stage .hint{padding:0 16px 16px;flex-shrink:0}.seven-stage .hint-box{display:flex;align-items:center;gap:9px;background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:11px 13px}.seven-stage .hint-ic{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;background:var(--lemon-l);color:#8a6d00}.seven-stage .hint-tx{font-size:11.5px;line-height:1.45;color:#5a6b76}.seven-stage .hint-tx b{font-family:Nunito,sans-serif;color:var(--navy)}.seven-stage .banner{display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 16px;font-family:Nunito,sans-serif;font-weight:800;font-size:12.5px;flex-shrink:0}.seven-stage .banner.turn{background:var(--mint-l);color:var(--mint-d)}.seven-stage .banner.cap{background:linear-gradient(90deg,#fef6de,#fbefc8);color:#b9770b}.seven-stage .pcard.active.me{box-shadow:0 4px 14px #4ecdc42e}.seven-stage .pcard.active:not(.me){border-color:var(--slate);box-shadow:0 4px 14px #46586c2e}.seven-stage .overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:transparent;display:flex;align-items:center;justify-content:center;padding:22px;z-index:5}.seven-stage .result{width:100%;max-width:360px;background:var(--card);border-radius:26px;padding:24px 22px 20px;text-align:center;box-shadow:0 24px 60px #0000004d,0 0 0 1px #0000000f}.seven-stage .r-emoji{font-size:42px}.seven-stage .r-title{font-family:Nunito,sans-serif;font-weight:900;font-size:23px;margin:6px 0 4px}.seven-stage .result.win .r-title{color:var(--green)}.seven-stage .result.lose .r-title{color:var(--coral-d)}.seven-stage .result.draw .r-title{color:var(--muted)}.seven-stage .r-sub{font-size:12.5px;color:var(--muted);margin-bottom:16px}.seven-stage .r-elo{background:linear-gradient(135deg,#fff8f2,#fdf0e8);border:1.5px solid #F6E3D4;border-radius:16px;padding:12px 15px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}.seven-stage .re-l{font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}.seven-stage .re-v{font-family:Nunito,sans-serif;font-weight:900;font-size:24px;color:var(--navy)}.seven-stage .re-d{font-family:Nunito,sans-serif;font-weight:900;font-size:13px;padding:3px 9px;border-radius:50px;display:inline-flex;align-items:center;gap:2px}.seven-stage .re-d.up{background:var(--green-l);color:var(--green)}.seven-stage .re-d.down{background:var(--coral-l);color:var(--coral-d)}.seven-stage .r-elo.guest{justify-content:center;gap:7px;background:var(--sky-l);border-color:#cfe3f6;color:#185fa5;font-family:Nunito,sans-serif;font-weight:800;font-size:12.5px}.seven-stage .r-actions{display:flex;flex-direction:column;gap:9px}.seven-stage .btn{padding:12px 0;border-radius:13px;font-family:Nunito,sans-serif;font-weight:800;font-size:14px;cursor:pointer;border:none;display:flex;align-items:center;justify-content:center;gap:7px}.seven-stage .btn.primary{background:var(--mint);color:#fff}.seven-stage .btn.ghost{background:transparent;color:var(--muted);border:1.5px solid var(--border)}.seven-stage .btn.danger{background:var(--coral);color:#fff}.seven-stage .resign-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:50px;border:1.5px solid var(--coral-l);background:var(--coral-l);color:var(--coral-d);font-family:Nunito,sans-serif;font-weight:800;font-size:12px;cursor:pointer;flex-shrink:0}.seven-stage .resign-btn:hover{background:#ffd9d9}.seven-stage .result.confirm .r-title{color:var(--navy)}.seven-stage .cf-actions{display:flex;gap:9px}.seven-stage .cf-actions .btn{flex:1}.seven-stage .rematch-hint{display:inline-flex;align-items:center;gap:6px;background:var(--lemon-l);color:#9a7b1a;border:1.5px solid #F2E6B8;font-size:12px;font-weight:800;font-family:Nunito,sans-serif;padding:8px 13px;border-radius:50px;margin-bottom:14px}.seven-stage .rematch-hint.muted{background:#faf8f4;color:var(--muted);border-color:var(--border)}.seven-stage .room-input-row{display:flex;gap:7px;margin-top:9px}.seven-stage .room-input{flex:1;background:#f7f5f0;border-radius:9px;border:1.5px solid var(--border);padding:7px 11px;font-family:Nunito,sans-serif;font-weight:600;font-size:12px;color:var(--muted)}.seven-stage input.room-input{color:var(--text);text-transform:uppercase;letter-spacing:1px}.seven-stage .room-join-btn{padding:7px 13px;border-radius:9px;border:none;background:var(--mint);color:#fff;font-family:Nunito,sans-serif;font-weight:800;font-size:12px;cursor:pointer}.seven-stage .room-join-btn:disabled{opacity:.5;cursor:not-allowed}.seven-stage .room-scan-btn{flex-shrink:0;width:36px;border:1.5px solid var(--mint);border-radius:9px;background:var(--mint-l);color:var(--mint-d);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.seven-stage .room-scan-btn:hover{background:var(--mint);color:#fff}.seven-stage .thinking-dots{display:inline-flex;gap:3px;align-items:center}.seven-stage .thinking-dots i{width:5px;height:5px;border-radius:50%;background:currentColor;display:inline-block;animation:svbd 1s infinite;opacity:.4}.seven-stage .thinking-dots i:nth-child(2){animation-delay:.18s}.seven-stage .thinking-dots i:nth-child(3){animation-delay:.36s}@keyframes svbd{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-2px)}}.seven-stage .tt-btn{padding:13px 0;border-radius:14px;font-family:Nunito,sans-serif;font-weight:800;font-size:14px;cursor:pointer;border:none;display:flex;align-items:center;justify-content:center;gap:7px}.seven-stage .tt-btn:disabled{opacity:.6;cursor:default}.seven-stage .tt-btn-primary,.seven-stage .tt-btn-danger{background:var(--mint);color:#fff}.seven-stage .tt-btn-ghost{background:transparent;color:var(--muted);border:1.5px solid var(--border)}.seven-stage .tt-btn-sky{background:var(--sky);color:#fff}.seven-stage .tt-btn-sky:disabled{opacity:.5;cursor:not-allowed}.seven-stage .tt-btn-outline{background:var(--card);color:var(--mint-d);border:1.5px solid var(--mint)}.seven-stage .room-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:22px 24px;text-align:center;gap:4px;overflow-y:auto}.seven-stage .room-loading{display:flex;align-items:center;gap:8px;color:var(--muted);font-weight:700;font-size:13px}.seven-stage .r-ic{width:54px;height:54px;border-radius:17px;display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:4px}.seven-stage .r-ic.create{background:linear-gradient(135deg,var(--mint-l),#B3EDE8);color:var(--mint-d)}.seven-stage .r-ic.join{background:linear-gradient(135deg,var(--sky-l),#B8D7F5);color:#185fa5}.seven-stage .r-desc{font-size:12.5px;color:var(--muted);line-height:1.5;max-width:270px;margin-bottom:8px}.seven-stage .code-box{display:flex;align-items:center;gap:10px;background:var(--card);border:2px dashed var(--mint);border-radius:14px;padding:11px 16px;margin:2px 0}.seven-stage .code-val{font-family:Nunito,sans-serif;font-weight:900;font-size:26px;letter-spacing:6px;color:var(--navy)}.seven-stage .copy-ic{width:34px;height:34px;border-radius:10px;border:none;background:var(--mint-l);color:var(--mint-d);font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.seven-stage .qr-wrap{background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:9px;margin:8px 0 2px;line-height:0}.seven-stage .qr-img{width:118px;height:118px;display:block}.seven-stage .copy-row{display:flex;gap:8px;width:100%;max-width:300px;margin-top:8px}.seven-stage .cbtn{flex:1;padding:9px 0;border-radius:11px;border:1.5px solid var(--border);background:var(--card);color:var(--text);font-family:Nunito,sans-serif;font-weight:700;font-size:11px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px}.seven-stage .cbtn i{font-size:16px;color:var(--mint)}.seven-stage .copied-tip{min-height:16px;font-size:11px;font-weight:700;color:var(--green);margin-top:4px}.seven-stage .waiting{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--muted);font-weight:700;font-size:13px;margin-top:8px}.seven-stage .room-actions{display:flex;flex-direction:column;gap:9px;width:100%;max-width:290px;margin-top:14px}.seven-stage .code-input{width:100%;max-width:280px;text-align:center;font-family:Nunito,sans-serif;font-weight:900;font-size:25px;letter-spacing:7px;text-transform:uppercase;color:var(--navy);background:var(--card);border:2px solid var(--sky);border-radius:16px;padding:13px 10px;margin:6px 0}.seven-stage .code-input::placeholder{color:#cfc7b8;letter-spacing:2px;font-size:14px}.seven-stage .code-input:focus{outline:none;border-color:var(--sky)}.seven-stage .hint-line{font-size:11.5px;color:var(--muted);max-width:270px;line-height:1.5;display:flex;align-items:center;gap:5px;justify-content:center}.seven-stage .scan-area{flex:1;width:100%;background:#1c2530;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;position:relative;overflow:hidden}.seven-stage .scan-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.seven-stage .viewfinder{width:210px;height:210px;border-radius:18px;position:relative;z-index:1}.seven-stage .corner{position:absolute;width:34px;height:34px;border:4px solid var(--mint)}.seven-stage .corner.tl{top:-2px;left:-2px;border-right:none;border-bottom:none;border-radius:14px 0 0}.seven-stage .corner.tr{top:-2px;right:-2px;border-left:none;border-bottom:none;border-radius:0 14px 0 0}.seven-stage .corner.bl{bottom:-2px;left:-2px;border-right:none;border-top:none;border-radius:0 0 0 14px}.seven-stage .corner.br{bottom:-2px;right:-2px;border-left:none;border-top:none;border-radius:0 0 14px}.seven-stage .scanline{position:absolute;left:8px;right:8px;top:24px;height:2px;background:var(--mint);box-shadow:0 0 8px var(--mint)}.seven-stage .scan-hint{position:relative;z-index:1;color:#fff;font-size:12.5px;font-weight:700;display:flex;align-items:center;gap:6px;background:#0006;padding:6px 12px;border-radius:50px}.seven-stage .scan-denied{color:#cfd6dd;font-size:13px;font-weight:700;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:0 30px}.seven-stage .scan-foot{padding:14px 24px;background:var(--card);border-top:1.5px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;gap:9px}.seven-stage .scan-foot .tt-btn{width:100%}.seven-stage .scan-imgerr{position:relative;z-index:1;color:#ffd2d2;font-size:12px;font-weight:700;background:#e848488c;padding:5px 12px;border-radius:50px}@media(orientation:landscape)and (max-height:600px){.seven-stage{padding:12px;align-items:center}.seven-shell{width:calc(100vw - 24px);max-width:calc(100vw - 24px);height:calc(100dvh - 24px);max-height:calc(100dvh - 24px);border-radius:22px}.seven-shell:has(.board-area){display:grid;grid-template-columns:1fr 200px;grid-template-rows:auto auto auto 1fr}.seven-shell:has(.board-area) .topbar{grid-column:1/-1;grid-row:1;padding:8px 14px}.seven-shell:has(.board-area) .topbar-title{font-size:14px}.seven-shell:has(.board-area) .players{grid-column:2;grid-row:2;padding:6px 10px;flex-direction:column;gap:4px}.seven-shell:has(.board-area) .players .pcard{flex:none;width:100%}.seven-shell:has(.board-area) .banner{grid-column:2;grid-row:3;padding:6px 10px;font-size:11.5px}.seven-shell:has(.board-area) .board-area{grid-column:1;grid-row:2/5;padding:8px;overflow:hidden}.seven-shell:has(.board-area) .board-wrap{height:100%;aspect-ratio:1/1;width:auto;max-width:100%}.seven-shell:has(.board-area) .hint{grid-column:2;grid-row:4;align-self:start;padding:0 10px 8px}.seven-shell:has(.board-area) .overlay{align-items:center;overflow-y:auto;padding:10px 14px;background:#2c3e5080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.seven-shell:has(.board-area) .result{padding:13px 15px 11px}.seven-shell:has(.board-area) .r-emoji{font-size:26px;margin-bottom:2px}.seven-shell:has(.board-area) .r-title{font-size:16px;margin-bottom:3px}.seven-shell:has(.board-area) .r-sub{font-size:11px;margin-bottom:10px}.seven-shell:has(.board-area) .btn{padding:9px 0;font-size:13px}}.sudoku-stage{--sky:#4A90D9;--sky-l:#E3F0FB;--sky-d:#185FA5;--sky-xl:#F0F7FD;--coral:#FF6B6B;--mint:#4ECDC4;--lemon-l:#FFFBE0;--navy:#2C3E50;--green:#27AE60;--green-l:#E3F7EC;--red:#E74C3C;--red-l:#FDECEA;--bg:#F7F5F0;--card:#FFFFFF;--text:#2C3E50;--muted:#7F8C8D;--border:#F0EDE8;--grid-line:#D9D3C8;--grid-bold:#9AA4AD;min-height:100dvh;background:#e8e4dc;overflow-y:auto;font-family:Nunito Sans,sans-serif;color:var(--text);display:flex;justify-content:center;align-items:flex-start;padding:24px 16px 40px}.sudoku-stage *{box-sizing:border-box}.sudoku-shell{position:relative;width:100%;max-width:420px;height:calc(100dvh - 64px);max-height:calc(100dvh - 64px);background:var(--bg);border-radius:40px;box-shadow:0 32px 80px #00000038,0 0 0 1px #00000014;overflow:hidden;display:flex;flex-direction:column}@media(min-width:640px){.sudoku-shell{max-width:560px}}@media(min-width:1024px){.sudoku-shell{max-width:720px}}.sudoku-stage .topbar{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--card);border-bottom:1.5px solid var(--border);flex-shrink:0}.sudoku-stage .back-btn{width:32px;height:32px;border-radius:9px;border:1.5px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);font-size:17px;flex-shrink:0}.sudoku-stage .topbar-title{font-family:Nunito,sans-serif;font-weight:900;font-size:17px;color:var(--text);flex:1}.sudoku-stage .chip{display:flex;align-items:center;gap:5px;padding:5px 11px;border-radius:50px;font-family:Nunito,sans-serif;font-weight:800;font-size:12px}.sudoku-stage .chip-diff{background:var(--sky-l);color:var(--sky-d)}.sudoku-stage .chip-timer{background:#f5f2ee;color:var(--muted);font-family:JetBrains Mono,Courier New,monospace}.sudoku-stage .scroll-area{flex:1;overflow-y:auto;padding-bottom:16px}.sudoku-stage .scroll-area::-webkit-scrollbar{width:0}.sudoku-stage .hero{background:linear-gradient(135deg,#4a90d9,#2c6fac);padding:20px 20px 24px;position:relative;overflow:hidden;display:flex;align-items:center;gap:16px}.sudoku-stage .hero:before{content:"";position:absolute;top:-26px;right:-26px;width:120px;height:120px;border-radius:50%;background:#ffffff14}.sudoku-stage .hero .ic{flex-shrink:0;width:64px;height:64px;border-radius:15px;background:#ffffff26;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.sudoku-stage .hero h2{font-family:Nunito,sans-serif;font-weight:900;font-size:19px;color:#fff;margin-bottom:3px}.sudoku-stage .hero p{font-size:12px;color:#ffffffd9;line-height:1.45}.sudoku-stage .hero .hinfo{position:relative;z-index:1}.sudoku-stage .hero .rules-link{display:inline-flex;align-items:center;gap:6px;margin-top:11px;padding:6px 12px;border-radius:50px;background:#ffffff2e;border:1.5px solid rgba(255,255,255,.4);color:#fff;font-family:Nunito,sans-serif;font-weight:800;font-size:12px;cursor:pointer}.sudoku-stage .hero .rules-link:hover{background:#ffffff47}.sudoku-stage .hero .rules-link .ti-chevron-right{font-size:14px;opacity:.8}.sudoku-stage .help-btn{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border);background:var(--lemon-l);display:flex;align-items:center;justify-content:center;color:#b9770b;font-size:17px;cursor:pointer;flex-shrink:0}.sudoku-stage .help-btn:hover{background:#fff4cc}.sudoku-stage .elo-badge{display:flex;align-items:center;gap:4px;padding:5px 11px;border-radius:50px;background:var(--sky-l);font-family:Nunito,sans-serif;font-weight:800;font-size:12px;color:var(--sky-d)}.sudoku-stage .tab-bar{display:flex;border-bottom:1.5px solid var(--border);background:var(--card);flex-shrink:0}.sudoku-stage .tab{flex:1;padding:11px 0;text-align:center;font-family:Nunito,sans-serif;font-weight:700;font-size:13px;color:var(--muted);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent}.sudoku-stage .tab.active{color:var(--sky-d);border-bottom-color:var(--sky-d)}.sudoku-stage .tab .ti{font-size:15px;vertical-align:-2px;margin-right:3px}.sudoku-stage .rules-body{padding:16px 16px 28px}.sudoku-stage .section{padding:18px 16px 0}.sudoku-stage .sec-title{font-family:Nunito,sans-serif;font-weight:800;font-size:15px;color:var(--text);margin-bottom:12px}.sudoku-stage .diff-list{display:flex;flex-direction:column;gap:10px}.sudoku-stage .diff-card{background:var(--card);border-radius:16px;border:1.5px solid var(--border);cursor:pointer;padding:14px 16px;display:flex;align-items:center;gap:13px;transition:transform .14s;text-align:left;width:100%}.sudoku-stage .diff-card:hover{transform:translateY(-2px)}.sudoku-stage .diff-card.sel{border:2px solid var(--sky);box-shadow:0 4px 16px #4a90d929}.sudoku-stage .diff-ic{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.sudoku-stage .diff-ic.easy{background:var(--sky-l);color:var(--sky)}.sudoku-stage .diff-ic.medium{background:var(--lemon-l);color:#c07800}.sudoku-stage .diff-ic.hard{background:var(--red-l);color:var(--coral)}.sudoku-stage .diff-name{font-family:Nunito,sans-serif;font-weight:800;font-size:14px}.sudoku-stage .diff-desc{font-size:11px;color:var(--muted);margin-top:2px}.sudoku-stage .radio{width:18px;height:18px;border-radius:50%;border:2px solid #D4C9B5;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sudoku-stage .diff-card.sel .radio{border-color:var(--sky)}.sudoku-stage .diff-card.sel .radio:after{content:"";width:9px;height:9px;border-radius:50%;background:var(--sky)}.sudoku-stage .start-btn{width:100%;margin-top:16px;padding:15px 0;border-radius:16px;background:var(--sky);border:none;font-family:Nunito,sans-serif;font-weight:800;font-size:15px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 8px 20px #4a90d94d}.sudoku-stage .start-btn:disabled{opacity:.6;cursor:default}.sudoku-stage .toggle-row{display:flex;align-items:center;justify-content:space-between;margin-top:11px;background:var(--card);border:1.5px solid var(--border);border-radius:13px;padding:12px 14px}.sudoku-stage .tg{width:42px;height:24px;border-radius:50px;background:#d4c9b5;position:relative;cursor:pointer;flex-shrink:0;border:none;transition:background .15s}.sudoku-stage .tg.on{background:var(--sky)}.sudoku-stage .tg:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .15s}.sudoku-stage .tg.on:after{transform:translate(18px)}.sudoku-stage .hint-note{font-size:11px;color:var(--muted);text-align:center;margin-top:18px;padding:0 8px;line-height:1.5}.sudoku-stage .sd-resume{margin:14px 16px 0;background:var(--lemon-l);border-radius:16px;border:1.5px solid #FFE066;padding:12px 14px;display:flex;align-items:center;gap:11px}.sudoku-stage .sd-resume .r-ic{width:38px;height:38px;border-radius:11px;background:#e6b800;display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff;flex-shrink:0}.sudoku-stage .sd-resume .r-body{flex:1;min-width:0}.sudoku-stage .sd-resume .r-t{font-family:Nunito,sans-serif;font-weight:800;font-size:13.5px;color:#6b5a00}.sudoku-stage .sd-resume .r-d{font-size:11px;color:#7a5800;margin-top:2px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.sudoku-stage .sd-resume .r-d b{font-family:JetBrains Mono,Courier New,monospace;font-weight:700}.sudoku-stage .sd-resume .r-cont{flex-shrink:0;padding:9px 13px;border-radius:11px;background:#e6b800;border:none;color:#fff;font-family:Nunito,sans-serif;font-weight:800;font-size:12.5px;cursor:pointer;display:flex;align-items:center;gap:5px}.sudoku-stage .sd-resume .r-discard{flex-shrink:0;width:30px;height:30px;border-radius:9px;border:1.5px solid #F0D97A;background:transparent;color:#b9770b;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:15px}.sudoku-stage .board-stage{padding:16px 16px 0;display:flex;flex-direction:column;align-items:center}.sudoku-stage .board{width:100%;max-width:360px;aspect-ratio:1/1;background:#fff;border:2.5px solid var(--grid-bold);border-radius:10px;overflow:hidden;display:grid;grid-template-columns:repeat(9,1fr);grid-template-rows:repeat(9,1fr);touch-action:manipulation}.sudoku-stage .sd-cell{display:flex;align-items:center;justify-content:center;font-family:Nunito,sans-serif;font-weight:700;font-size:clamp(18px,5.2vw,22px);cursor:pointer;border-right:1px solid var(--grid-line);border-bottom:1px solid var(--grid-line);background:#fff;-webkit-user-select:none;user-select:none;position:relative;color:var(--sky-d)}.sudoku-stage .sd-cell.given{color:var(--text);font-weight:800}.sudoku-stage .sd-cell:nth-child(9n){border-right:none}.sudoku-stage .sd-cell.br3{border-right:2.5px solid var(--grid-bold)}.sudoku-stage .sd-cell.bb3{border-bottom:2.5px solid var(--grid-bold)}.sudoku-stage .sd-cell.peer{background:var(--sky-xl)}.sudoku-stage .sd-cell.same{background:#cfe4f7}.sudoku-stage .sd-cell.sel{background:var(--sky-l);box-shadow:inset 0 0 0 2.5px var(--sky);z-index:2}.sudoku-stage .sd-cell.err{background:var(--red-l);color:var(--red)}.sudoku-stage .sd-cell.sel.err{box-shadow:inset 0 0 0 2.5px var(--red)}.sudoku-stage .sd-cell.hint{background:#fff4d6;color:#e6a100;font-weight:800}.sudoku-stage .sd-cell.hint:after{content:"✨";position:absolute;top:1px;right:2px;font-size:8px}.sudoku-stage .sd-notes{display:grid;grid-template-columns:repeat(3,1fr);width:100%;height:100%;padding:2px}.sudoku-stage .sd-notes span{font-size:8.5px;font-weight:600;color:var(--muted);display:flex;align-items:center;justify-content:center;font-family:JetBrains Mono,Courier New,monospace}.sudoku-stage .statusbar{display:flex;align-items:center;justify-content:center;gap:8px;margin:12px 0 2px;font-size:12px;font-weight:700;color:var(--muted)}.sudoku-stage .err-flag{color:var(--red);background:var(--red-l);padding:3px 9px;border-radius:50px}.sudoku-stage .pad{padding:14px 16px 22px}.sudoku-stage .pad-row{display:grid;grid-template-columns:repeat(9,1fr);gap:6px}.sudoku-stage .numbtn{aspect-ratio:1/1.15;border-radius:11px;border:1.5px solid var(--border);background:var(--card);font-family:Nunito,sans-serif;font-weight:800;font-size:clamp(16px,4.6vw,20px);color:var(--sky-d);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px}.sudoku-stage .numbtn small{font-size:8px;color:var(--muted);font-weight:700}.sudoku-stage .numbtn.done{color:#c8cdd2;background:#faf8f4;cursor:default}.sudoku-stage .tools{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}.sudoku-stage .toolbtn{padding:11px 0;border-radius:13px;border:1.5px solid var(--border);background:var(--card);font-family:Nunito,sans-serif;font-weight:700;font-size:12px;color:var(--text);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;position:relative}.sudoku-stage .toolbtn:disabled{opacity:.45;cursor:default}.sudoku-stage .toolbtn.active{background:var(--sky-l);border-color:var(--sky);color:var(--sky-d)}.sudoku-stage .toolbtn i{font-size:18px}.sudoku-stage .toolbtn.hint{background:var(--lemon-l);border-color:#f0d97a;color:#9a6b00}.sudoku-stage .toolbtn.hint .badge{position:absolute;top:-7px;right:-6px;min-width:19px;height:19px;border-radius:50px;background:#e6a100;color:#fff;font-family:Nunito,sans-serif;font-weight:800;font-size:11px;display:flex;align-items:center;justify-content:center;padding:0 5px;box-shadow:0 2px 5px #0003}.sudoku-stage .toolbtn.hint.spent{background:#faf8f4;border-color:var(--border);color:#c8cdd2}.sudoku-stage .toolbtn.hint.spent .badge{background:#c8cdd2}.sudoku-stage .solved{position:absolute;top:0;right:0;bottom:0;left:0;background:#2c3e508c;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:20;padding:20px}.sudoku-stage .solved-card{width:300px;max-width:100%;background:#fff;border-radius:24px;padding:26px 22px;text-align:center;box-shadow:0 24px 60px #0000004d}.sudoku-stage .solved-card .badge{width:64px;height:64px;border-radius:50%;background:var(--green-l);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:34px;color:var(--green)}.sudoku-stage .solved-card h3{font-family:Nunito,sans-serif;font-weight:900;font-size:21px;margin-bottom:5px}.sudoku-stage .solved-card p{font-size:12.5px;color:var(--muted);line-height:1.5;margin-bottom:18px}.sudoku-stage .ghost-btn{width:100%;margin-top:9px;padding:12px 0;border-radius:13px;border:1.5px solid var(--border);background:#fff;font-family:Nunito,sans-serif;font-weight:700;font-size:13px;color:var(--muted);cursor:pointer}.sudoku-stage .solved-card .badge.win{background:var(--green-l);color:var(--green)}.sudoku-stage .solved-card .badge.record{background:linear-gradient(135deg,#ffe066,#e6b800);color:#fff;box-shadow:0 6px 18px #e6b80066}.sudoku-stage .record-tag{display:inline-flex;align-items:center;gap:4px;background:var(--lemon-l);color:#8a6d00;font-family:Nunito,sans-serif;font-weight:800;font-size:11px;padding:3px 10px;border-radius:50px;margin-bottom:10px}.sudoku-stage .stat-row{display:flex;gap:10px;margin:4px 0 16px}.sudoku-stage .stat{flex:1;background:#f7f5f0;border-radius:14px;padding:11px 8px}.sudoku-stage .stat .k{font-size:9.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}.sudoku-stage .stat .v{font-family:JetBrains Mono,Courier New,monospace;font-weight:700;font-size:19px;color:var(--text);margin-top:3px}.sudoku-stage .stat .v.sky{color:var(--sky)}.sudoku-stage .stat .v.gold{color:#e6b800}.sudoku-stage .guest-cta{display:flex;align-items:center;gap:9px;width:100%;background:var(--sky-xl);border:1.5px solid #CFE4F7;border-radius:13px;padding:11px 12px;margin-bottom:14px;text-align:left;cursor:pointer}.sudoku-stage .guest-cta i{font-size:20px;color:var(--sky);flex-shrink:0}.sudoku-stage .guest-cta .g-t{font-family:Nunito,sans-serif;font-weight:800;font-size:12px;color:var(--sky-d)}.sudoku-stage .guest-cta .g-d{font-size:10.5px;color:var(--muted);margin-top:1px}.sudoku-stage .submit-warn{font-size:11px;color:#b9770b;background:var(--lemon-l);border-radius:10px;padding:7px 10px;margin-bottom:12px}.sudoku-stage .sd-toast{position:absolute;left:50%;bottom:26px;transform:translate(-50%);width:calc(100% - 48px);max-width:320px;background:var(--navy);color:#fff;border-radius:16px;padding:13px 15px;display:flex;align-items:center;gap:11px;box-shadow:0 16px 40px #0000004d;z-index:30}.sudoku-stage .sd-toast i{font-size:24px;color:#ffe66d;flex-shrink:0}.sudoku-stage .sd-toast .t-t{font-family:Nunito,sans-serif;font-weight:800;font-size:13px}.sudoku-stage .sd-toast .t-d{font-size:11px;color:#fffc;margin-top:2px;line-height:1.4}.sudoku-stage .loading{padding:60px 0;text-align:center;color:var(--muted);font-weight:700;font-size:13px}@media(orientation:landscape)and (max-height:600px){.sudoku-stage{padding:12px;align-items:center}.sudoku-shell{max-width:calc(100vw - 24px);height:calc(100dvh - 24px);max-height:calc(100dvh - 24px);border-radius:22px}.sudoku-stage .topbar{padding:9px 14px}.sudoku-stage .topbar-title{font-size:15px}.sudoku-stage .chip{padding:4px 9px;font-size:11px}.sudoku-stage .scroll-area:has(.board-stage){overflow:hidden;display:grid;grid-template-columns:1fr 200px;padding-bottom:0}.sudoku-stage .scroll-area:not(:has(.board-stage)){overflow:hidden;display:flex;flex-direction:row;padding:0}.sudoku-stage .scroll-area:not(:has(.board-stage)) .hero{flex:1;min-width:0;flex-direction:column;justify-content:center;align-items:flex-start;padding:14px 16px;gap:8px}.sudoku-stage .scroll-area:not(:has(.board-stage)) .hero p{display:none}.sudoku-stage .scroll-area:not(:has(.board-stage)) .hero h2{font-size:15px;margin-bottom:2px}.sudoku-stage .scroll-area:not(:has(.board-stage)) .hero .ic{width:44px;height:44px}.sudoku-stage .scroll-area:not(:has(.board-stage)) .hero .rules-link{margin-top:8px;padding:5px 10px;font-size:11px}.sudoku-stage .select-right{width:200px;flex-shrink:0;overflow-y:auto;display:flex;flex-direction:column;padding:8px 10px 10px 8px}.sudoku-stage .select-right::-webkit-scrollbar{width:0}.sudoku-stage .select-right .sd-resume{margin:0 0 6px;padding:7px 9px;gap:6px;border-radius:10px}.sudoku-stage .select-right .sd-resume .r-ic{width:26px;height:26px;border-radius:7px;font-size:13px}.sudoku-stage .select-right .sd-resume .r-t{font-size:11.5px}.sudoku-stage .select-right .sd-resume .r-d{display:none}.sudoku-stage .select-right .sd-resume .r-cont{padding:6px 8px;font-size:11px}.sudoku-stage .select-right .sd-resume .r-discard{width:24px;height:24px;font-size:13px}.sudoku-stage .select-right .section{padding:0;flex:1}.sudoku-stage .select-right .sec-title{font-size:13px;margin-bottom:6px}.sudoku-stage .select-right .diff-list{gap:4px}.sudoku-stage .select-right .diff-card{padding:6px 10px;border-radius:10px;gap:8px}.sudoku-stage .select-right .diff-ic{width:26px;height:26px;font-size:14px;border-radius:7px}.sudoku-stage .select-right .diff-desc{display:none}.sudoku-stage .select-right .start-btn{margin-top:7px;padding:9px 0;font-size:13px;border-radius:12px}.sudoku-stage .select-right .toggle-row{padding:6px 10px;margin-top:6px;border-radius:10px}.sudoku-stage .board-stage{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 6px 4px 10px;overflow:hidden}.sudoku-stage .board{height:calc(100% - 18px);width:auto;max-width:100%;aspect-ratio:1/1;grid-template-rows:repeat(9,minmax(0,1fr))}.sudoku-stage .sd-cell{font-size:clamp(11px,4.5dvh,22px)}.sudoku-stage .statusbar{margin:4px 0 0;font-size:11px}.sudoku-stage .pad{height:100%;display:flex;flex-direction:column;justify-content:center;padding:8px 12px 8px 8px}.sudoku-stage .pad-row{grid-template-columns:repeat(3,1fr);gap:4px}.sudoku-stage .numbtn{aspect-ratio:unset;height:clamp(36px,calc((100dvh - 200px) / 3),60px);border-radius:9px;font-size:clamp(12px,2.4vh,17px)}.sudoku-stage .numbtn small{font-size:7px}.sudoku-stage .tools{grid-template-columns:repeat(2,1fr);gap:4px;margin-top:5px}.sudoku-stage .toolbtn{padding:6px 0;border-radius:9px;font-size:10px;gap:1px}.sudoku-stage .toolbtn i{font-size:15px}.sudoku-stage .solved{padding:10px}.sudoku-stage .solved-card{padding:12px 16px;overflow-y:auto;max-height:calc(100dvh - 44px)}.sudoku-stage .solved-card .badge{width:36px;height:36px;font-size:20px;margin-bottom:6px}.sudoku-stage .solved-card h3{font-size:15px;margin-bottom:3px}.sudoku-stage .solved-card p{font-size:11.5px;margin-bottom:8px}.sudoku-stage .record-tag{font-size:10px;padding:2px 8px;margin-bottom:6px}.sudoku-stage .stat-row{gap:8px;margin:3px 0 8px}.sudoku-stage .stat{padding:7px 6px}.sudoku-stage .stat .v{font-size:15px}.sudoku-stage .stat .k{font-size:9px}.sudoku-stage .guest-cta{padding:7px 10px;margin-bottom:8px}.sudoku-stage .ghost-btn{padding:8px 0;margin-top:5px}}.profile-stage{--coral:#FF6B6B;--coral-l:#FFE8E8;--coral-d:#E84848;--mint:#4ECDC4;--mint-l:#E0F7F5;--mint-d:#0A7A70;--sky:#4A90D9;--sky-l:#E3F0FB;--sky-d:#185FA5;--lemon-l:#FFFBE0;--gold:#E6B800;--navy:#2C3E50;--bg:#F7F5F0;--card:#FFFFFF;--text:#2C3E50;--muted:#7F8C8D;--border:#F0EDE8;min-height:100dvh;background:#e8e4dc;font-family:Nunito Sans,sans-serif;color:var(--text);display:flex;justify-content:center;align-items:flex-start;padding:24px 16px 40px}.profile-stage *{box-sizing:border-box}.profile-shell{position:relative;width:100%;max-width:420px;height:calc(100dvh - 64px);background:var(--bg);border-radius:40px;box-shadow:0 32px 80px #00000038,0 0 0 1px #00000014;overflow:hidden;display:flex;flex-direction:column}@media(min-width:640px){.profile-shell{max-width:560px}}@media(min-width:1024px){.profile-shell{max-width:720px}}.profile-stage .topbar{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--card);border-bottom:1.5px solid var(--border);flex-shrink:0}.profile-stage .back-btn{width:32px;height:32px;border-radius:9px;border:1.5px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);font-size:17px}.profile-stage .topbar-title{font-family:Nunito,sans-serif;font-weight:900;font-size:17px;flex:1}.profile-stage .scroll-area{flex:1;overflow-y:auto;padding-bottom:16px}.profile-stage .scroll-area::-webkit-scrollbar{width:0}.profile-stage .phead{background:linear-gradient(135deg,#3a4a5e,#2c3e50);padding:24px 20px 22px;display:flex;align-items:center;gap:15px;position:relative;overflow:hidden}.profile-stage .phead:before{content:"";position:absolute;top:-30px;right:-20px;width:130px;height:130px;border-radius:50%;background:#ffffff0f}.profile-stage .pavatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--coral),#E84848);display:flex;align-items:center;justify-content:center;font-family:Nunito,sans-serif;font-weight:900;font-size:26px;color:#fff;flex-shrink:0;border:3px solid rgba(255,255,255,.25);position:relative;z-index:1;overflow:hidden}.profile-stage .pavatar img{width:100%;height:100%;object-fit:cover}.profile-stage .pinfo{position:relative;z-index:1;min-width:0}.profile-stage .pname{font-family:Nunito,sans-serif;font-weight:900;font-size:20px;color:#fff}.profile-stage .pmail{font-size:11.5px;color:#ffffffb3;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:230px}.profile-stage .pmeta{display:flex;gap:8px;margin-top:9px;flex-wrap:wrap}.profile-stage .pchip{display:inline-flex;align-items:center;gap:4px;background:#ffffff26;color:#fff;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:50px}.profile-stage .pchip i{font-size:11px}.profile-stage .section{padding:16px 16px 0}.profile-stage .sec-title{font-family:Nunito,sans-serif;font-weight:800;font-size:15px;color:var(--text);margin-bottom:11px;display:flex;align-items:center;gap:6px}.profile-stage .sec-title i{color:var(--sky)}.profile-stage .gcard{background:var(--card);border-radius:16px;border:1.5px solid var(--border);padding:14px 15px;margin-bottom:10px}.profile-stage .gtop{display:flex;align-items:center;gap:11px}.profile-stage .gicon{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:21px;flex-shrink:0}.profile-stage .gicon.tt{background:var(--coral-l);color:var(--coral-d)}.profile-stage .gicon.seven{background:var(--mint-l);color:var(--mint-d)}.profile-stage .gicon.sudoku{background:var(--sky-l);color:var(--sky-d)}.profile-stage .gname{font-family:Nunito,sans-serif;font-weight:800;font-size:14px;flex:1}.profile-stage .grank{display:inline-flex;align-items:center;gap:3px;font-size:10.5px;font-weight:800;padding:3px 9px;border-radius:50px;background:var(--lemon-l);color:#8a6d00}.profile-stage .grank i{font-size:9px}.profile-stage .gbigrow{display:flex;align-items:baseline;gap:6px;margin-top:9px}.profile-stage .gbig{font-family:Nunito,sans-serif;font-weight:900;font-size:24px}.profile-stage .gbig.tt{color:var(--coral-d)}.profile-stage .gbig.seven{color:var(--mint-d)}.profile-stage .gbig.sudoku{color:var(--sky-d)}.profile-stage .gunit{font-size:11px;color:var(--muted);font-weight:700}.profile-stage .gstats{display:flex;gap:14px;margin-top:11px;padding-top:11px;border-top:1px solid var(--border)}.profile-stage .gst{display:flex;flex-direction:column}.profile-stage .gst .v{font-family:Nunito,sans-serif;font-weight:800;font-size:14px;color:var(--text)}.profile-stage .gst .k{font-size:10px;color:var(--muted);font-weight:600;margin-top:1px}.profile-stage .gnorec{font-size:12px;color:var(--muted);font-weight:700;padding:10px 0 2px}.profile-stage .tbest{display:flex;gap:7px;margin-top:11px;padding-top:11px;border-top:1px solid var(--border)}.profile-stage .tbest .b{flex:1;background:#f7f5f0;border-radius:11px;padding:7px 9px;text-align:center}.profile-stage .tbest .b .bl{font-size:9.5px;color:var(--muted);font-weight:700;text-transform:uppercase}.profile-stage .tbest .b .bv{font-family:JetBrains Mono,Courier New,monospace;font-weight:700;font-size:14px;color:var(--sky-d);margin-top:2px}.profile-stage .ach-prog{margin-left:auto;font-family:Nunito,sans-serif;font-weight:800;font-size:12px;color:var(--gold);background:#fff4d6;padding:3px 10px;border-radius:50px}.profile-stage .pa-group{margin-bottom:6px}.profile-stage .pa-group-title{font-family:Nunito,sans-serif;font-weight:800;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin:4px 0 8px}.profile-stage .pa-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.profile-stage .pa-card{background:var(--card);border-radius:15px;border:1.5px solid var(--border);padding:13px 12px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;position:relative}.profile-stage .pa-card.locked{opacity:.62}.profile-stage .pa-badge{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:25px;color:#fff}.profile-stage .pa-badge.tt{background:linear-gradient(135deg,#FF8E8E,var(--coral))}.profile-stage .pa-badge.seven{background:linear-gradient(135deg,#6FE0D7,var(--mint))}.profile-stage .pa-badge.sudoku{background:linear-gradient(135deg,#6FA8E6,var(--sky))}.profile-stage .pa-badge.off{background:#e2dcd2;color:#b8ac98}.profile-stage .pa-name{font-family:Nunito,sans-serif;font-weight:800;font-size:12.5px;line-height:1.2}.profile-stage .pa-desc{font-size:10px;color:var(--muted);line-height:1.35}.profile-stage .pa-mark{position:absolute;top:8px;right:8px;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px}.profile-stage .pa-card .pa-mark{background:var(--green);color:#fff}.profile-stage .pa-card.locked .pa-mark{background:transparent;color:#c8bca6;font-size:13px}.profile-stage .pf-row{margin:16px 16px 0;width:calc(100% - 32px);padding:13px 16px;border-radius:14px;border:1.5px solid var(--border);background:#fff;color:var(--text);font-family:Nunito,sans-serif;font-weight:700;font-size:13.5px;cursor:pointer;display:flex;align-items:center;justify-content:space-between}.profile-stage .pf-row:hover{background:#faf9f7}.profile-stage .pf-row .pf-row-l{display:flex;align-items:center;gap:9px}.profile-stage .pf-row i{color:var(--muted);font-size:17px}.profile-stage .pf-lang{margin:16px 16px 0}.profile-stage .pf-signout{margin:12px 16px 8px;width:calc(100% - 32px);padding:13px 0;border-radius:14px;border:1.5px solid var(--coral-l);background:#fff;color:var(--coral-d);font-family:Nunito,sans-serif;font-weight:800;font-size:13.5px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px}.profile-stage .pf-guest{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:50px 36px;text-align:center}.profile-stage .pf-guest .gi{width:74px;height:74px;border-radius:50%;background:var(--sky-l);display:flex;align-items:center;justify-content:center;font-size:36px;color:var(--sky)}.profile-stage .pf-guest h3{font-family:Nunito,sans-serif;font-weight:900;font-size:18px}.profile-stage .pf-guest p{font-size:13px;color:var(--muted);line-height:1.6}.profile-stage .pf-signin{margin-top:8px;padding:13px 26px;border-radius:14px;background:var(--sky);border:none;color:#fff;font-family:Nunito,sans-serif;font-weight:800;font-size:14px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;box-shadow:0 8px 20px #4a90d94d}.score-stage{--coral:#FF6B6B;--coral-l:#FFE8E8;--coral-d:#E84848;--mint:#4ECDC4;--sky:#4A90D9;--lemon:#FFE66D;--navy:#2C3E50;--muted:#7F8C8D;--border:#F0EDE8;--bg:#F7F5F0;--card:#FFFFFF;--gold:#F5B731;--silver:#9AA7B4;--bronze:#C97F45;min-height:100dvh;background:#e8e4dc;font-family:Nunito Sans,sans-serif;color:var(--navy);display:flex;justify-content:center;align-items:flex-start;padding:24px 16px 40px}.score-stage *{box-sizing:border-box}.score-shell{position:relative;width:100%;max-width:420px;height:calc(100dvh - 64px);background:var(--bg);border-radius:40px;box-shadow:0 32px 80px #00000038,0 0 0 1px #00000014;overflow:hidden;display:flex;flex-direction:column}@media(min-width:640px){.score-shell{max-width:560px}}@media(min-width:1024px){.score-shell{max-width:720px}}.sc-topbar{display:flex;align-items:center;gap:10px;padding:16px 18px;background:var(--card);border-bottom:1.5px solid var(--border);flex-shrink:0}.sc-back{width:32px;height:32px;border-radius:9px;border:1.5px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:17px;cursor:pointer}.sc-title{font-family:Nunito,sans-serif;font-weight:900;font-size:17px;flex:1}.sc-tabs{display:flex;border-bottom:1.5px solid var(--border);background:var(--card);flex-shrink:0}.sc-tab{flex:1;padding:13px 0;text-align:center;font-family:Nunito,sans-serif;font-weight:800;font-size:12.5px;color:var(--muted);cursor:pointer;border:none;background:none;border-bottom:2.5px solid transparent;display:flex;align-items:center;justify-content:center;gap:4px}.sc-tab.active{color:var(--coral);border-bottom-color:var(--coral)}.sc-scroll{flex:1;overflow-y:auto}.sc-scroll::-webkit-scrollbar{width:0}.sc-podium{background:linear-gradient(160deg,#FFF6DF 0%,var(--bg) 78%);padding:20px 18px 18px;display:flex;align-items:flex-end;justify-content:center;gap:10px}.sc-pod{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}.sc-pod.empty{visibility:hidden}.sc-pod-av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Nunito,sans-serif;font-weight:900;color:#fff;position:relative}.sc-medal{position:absolute;bottom:-4px;right:-4px;width:22px;height:22px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;box-shadow:0 2px 5px #00000026}.sc-pod.p1 .sc-pod-av{width:68px;height:68px;font-size:20px;background:linear-gradient(135deg,#FFD96B,var(--gold));box-shadow:0 6px 18px #f5b73173}.sc-pod.p2 .sc-pod-av{width:56px;height:56px;font-size:17px;background:linear-gradient(135deg,#C2CCD6,var(--silver));box-shadow:0 5px 14px #9aa7b466}.sc-pod.p3 .sc-pod-av{width:56px;height:56px;font-size:17px;background:linear-gradient(135deg,#E0A06A,var(--bronze));box-shadow:0 5px 14px #c97f4566}.sc-pod-name{font-family:Nunito,sans-serif;font-weight:800;font-size:12px;color:var(--navy);max-width:84px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sc-pod-elo{font-family:Nunito,sans-serif;font-weight:900;font-size:15px}.sc-pod.p1 .sc-pod-elo{color:var(--gold)}.sc-pod.p2 .sc-pod-elo{color:var(--silver)}.sc-pod.p3 .sc-pod-elo{color:var(--bronze)}.sc-pod-base{width:100%;border-radius:12px 12px 0 0;display:flex;align-items:flex-start;justify-content:center;padding-top:7px;font-family:Nunito,sans-serif;font-weight:900;font-size:16px;color:#fff}.sc-pod.p1 .sc-pod-base{height:54px;background:linear-gradient(135deg,#FFD96B,var(--gold))}.sc-pod.p2 .sc-pod-base{height:40px;background:linear-gradient(135deg,#C2CCD6,var(--silver))}.sc-pod.p3 .sc-pod-base{height:32px;background:linear-gradient(135deg,#E0A06A,var(--bronze))}.sc-list{padding:14px 16px 96px;display:flex;flex-direction:column;gap:8px}.sc-row{display:flex;align-items:center;gap:11px;background:var(--card);border:1.5px solid var(--border);border-radius:15px;padding:10px 13px}.sc-rank{width:26px;text-align:center;font-family:Nunito,sans-serif;font-weight:900;font-size:15px;color:var(--muted);flex-shrink:0}.sc-av{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Nunito,sans-serif;font-weight:800;font-size:13px;color:#fff;flex-shrink:0}.sc-mid{flex:1;min-width:0}.sc-name{font-family:Nunito,sans-serif;font-weight:800;font-size:14px;color:var(--navy);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sc-rec{font-size:11px;color:var(--muted);font-weight:600;margin-top:1px}.sc-elo{font-family:Nunito,sans-serif;font-weight:900;font-size:16px;color:var(--coral-d);flex-shrink:0;text-align:right}.sc-elo small{display:block;font-size:9px;color:var(--muted);font-weight:700;letter-spacing:.3px}.sc-me{position:absolute;left:14px;right:14px;bottom:14px;display:flex;align-items:center;gap:11px;background:var(--navy);border-radius:16px;padding:11px 14px;box-shadow:0 10px 28px #2c3e5052}.sc-me .sc-rank,.sc-me .sc-name{color:#fff}.sc-me .sc-rec{color:#fff9}.sc-me .sc-elo{color:var(--lemon)}.sc-me .sc-elo small{color:#ffffff80}.sc-me-tag{font-family:Nunito,sans-serif;font-weight:800;font-size:9px;color:var(--navy);background:var(--lemon);padding:2px 6px;border-radius:50px;margin-left:6px}.sc-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:60px 30px;text-align:center}.sc-ei{width:74px;height:74px;border-radius:22px;background:var(--card);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:34px;color:var(--silver)}.sc-empty h3{font-family:Nunito,sans-serif;font-weight:900;font-size:17px;color:var(--navy)}.sc-empty p{font-size:13px;color:var(--muted);line-height:1.6}.sc-spin{width:42px;height:42px;border-radius:50%;border:5px solid var(--border);border-top-color:var(--coral);animation:scspin .9s linear infinite}@keyframes scspin{to{transform:rotate(360deg)}}.sc-diffseg{display:flex;gap:6px;padding:10px 14px;background:var(--card);border-bottom:1.5px solid var(--border);flex-shrink:0}.sc-seg{flex:1;padding:8px 0;border-radius:10px;border:1.5px solid var(--border);background:transparent;font-family:Nunito,sans-serif;font-weight:700;font-size:12px;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px}.sc-seg.on{border-color:var(--sky);background:#e3f0fb;color:#185fa5}.sc-empty-cta{margin-top:4px;padding:11px 22px;border-radius:12px;background:var(--sky);border:none;color:#fff;font-family:Nunito,sans-serif;font-weight:800;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.sc-play-wrap{display:flex;justify-content:center;padding:14px 16px 20px}.sc-play-wrap .sc-play-cta{width:100%;justify-content:center;box-shadow:0 8px 20px #4a90d94d}.legal-shell{display:flex;flex-direction:column;height:100%}.legal-topbar{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--card);border-bottom:1.5px solid var(--border);flex-shrink:0}.legal-back{width:32px;height:32px;border-radius:50%;background:#f2efea;border:none;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:17px;cursor:pointer}.legal-back:hover{background:#eae6df}.legal-title{font-family:Nunito,sans-serif;font-weight:900;font-size:16px;color:var(--text)}.legal-tabs{display:flex;gap:6px;padding:12px 16px 0;background:var(--card);flex-shrink:0}.legal-tab{flex:1;padding:9px 8px 11px;text-align:center;font-family:Nunito,sans-serif;font-weight:800;font-size:13px;color:var(--muted);border:none;background:none;cursor:pointer;border-bottom:2.5px solid transparent;transition:color .12s,border-color .12s}.legal-tab:hover{color:var(--text)}.legal-tab.active{color:var(--coral);border-bottom-color:var(--coral)}.legal-body{flex:1;overflow-y:auto;padding:20px 20px 16px}.legal-body .md{font-size:13px;color:#5a6b76;line-height:1.7}.legal-body .md h2{font-family:Nunito,sans-serif;font-weight:900;font-size:15px;color:var(--navy);margin:22px 0 10px;padding-left:11px;border-left:4px solid var(--coral);line-height:1.3}.legal-body .md h2:first-child{margin-top:2px;font-size:18px}.legal-body .md p{color:#5a6b76;font-weight:500;margin:0 0 11px}.legal-body .md em{font-style:normal;color:var(--muted);font-size:12px}.legal-body .md strong{color:var(--navy);font-weight:800}.legal-body .md ul{list-style:none;margin:0 0 13px;padding:0;display:flex;flex-direction:column;gap:7px}.legal-body .md li{position:relative;padding-left:16px}.legal-body .md li:before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:2px;background:var(--sky)}.legal-body .md a{color:var(--coral);text-decoration:none;word-break:break-all}.legal-body .md a:hover{text-decoration:underline}.legal-consent{flex-shrink:0;background:var(--card);border-top:1.5px solid var(--border);padding:12px 16px 14px}.lc-hint{font-size:11.5px;color:var(--muted);text-align:center;margin-bottom:10px;display:flex;align-items:center;justify-content:center;gap:5px}.lc-actions{display:flex;gap:10px}.lc-btn{flex:1;padding:11px 12px;border-radius:50px;border:none;font-family:Nunito,sans-serif;font-weight:800;font-size:13.5px;cursor:pointer;transition:background .12s,transform .1s}.lc-accept{background:var(--coral);color:#fff;box-shadow:0 5px 14px #ff6b6b4d}.lc-accept:hover{background:var(--coral-d);transform:translateY(-1px)}.lc-accept:active{transform:translateY(0)}.lc-reject{background:#f2efea;color:#5a6570;border:1.5px solid #E4E0DA}.lc-reject:hover{background:#eae6df}.lc-decided{display:flex;align-items:center;justify-content:space-between;gap:8px}.lc-status{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:#2f9b92}.lc-status.denied{color:var(--muted)}.lc-status i{font-size:17px}.lc-change{font-size:12px;font-weight:700;color:var(--coral);background:none;border:none;cursor:pointer}.lc-change:hover{text-decoration:underline}@media(prefers-reduced-motion:reduce){.lc-accept:hover{transform:none}}.ach-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#2c3e509e;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);padding:24px;font-family:Nunito Sans,sans-serif;animation:achFade .2s ease-out}@keyframes achFade{0%{opacity:0}to{opacity:1}}.ach-card{width:300px;max-width:100%;background:#fff;border-radius:26px;padding:30px 24px 24px;text-align:center;box-shadow:0 24px 60px #00000059;position:relative;overflow:hidden;animation:achPop .32s cubic-bezier(.16,1,.3,1)}@keyframes achPop{0%{transform:scale(.82);opacity:0}to{transform:scale(1);opacity:1}}.ach-card:before{content:"";position:absolute;top:-60px;left:50%;transform:translate(-50%);width:200px;height:160px;background:radial-gradient(circle,rgba(230,184,0,.22),transparent 70%)}.ach-ray{position:absolute;top:18px;left:50%;width:120px;height:120px;border-radius:50%;background:conic-gradient(from 0deg,rgba(230,184,0,.18),transparent 30%,rgba(230,184,0,.18) 50%,transparent 80%,rgba(230,184,0,.18));transform:translate(-50%);animation:achSpin 8s linear infinite}@keyframes achSpin{to{transform:translate(-50%) rotate(360deg)}}.ach-ubadge{position:relative;width:84px;height:84px;border-radius:24px;display:flex;align-items:center;justify-content:center;font-size:42px;color:#fff;margin:0 auto 8px;z-index:1;animation:achBadge .5s cubic-bezier(.16,1,.3,1) .08s both}@keyframes achBadge{0%{transform:scale(.4) rotate(-12deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.ach-ubadge.tt{background:linear-gradient(135deg,#ff8e8e,#ff6b6b);box-shadow:0 10px 26px #ff6b6b73}.ach-ubadge.seven{background:linear-gradient(135deg,#6fe0d7,#4ecdc4);box-shadow:0 10px 26px #4ecdc473}.ach-ubadge.sudoku{background:linear-gradient(135deg,#6fa8e6,#4a90d9);box-shadow:0 10px 26px #4a90d973}.ach-kicker{font-family:Nunito,sans-serif;font-weight:800;font-size:11px;color:#e6a100;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px;position:relative;z-index:1}.ach-utitle{font-family:Nunito,sans-serif;font-weight:900;font-size:20px;color:#2c3e50;position:relative;z-index:1}.ach-udesc{font-size:12.5px;color:#7f8c8d;line-height:1.5;margin-top:5px;position:relative;z-index:1}.ach-ubtn{margin-top:18px;width:100%;padding:13px 0;border-radius:14px;background:#4a90d9;border:none;color:#fff;font-family:Nunito,sans-serif;font-weight:800;font-size:14px;cursor:pointer;position:relative;z-index:1}@media(prefers-reduced-motion:reduce){.ach-overlay,.ach-card,.ach-ubadge,.ach-ray{animation:none}}.cc-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#1c1e268c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:18px;animation:cc-fade .18s ease-out}.cc-modal{width:340px;max-width:100%;background:#fff;border-radius:26px;padding:24px 22px 18px;box-shadow:0 24px 60px #00000047;text-align:center;animation:cc-rise .22s cubic-bezier(.16,1,.3,1)}.cc-badge{width:60px;height:60px;margin:0 auto 14px;border-radius:50%;background:#fffbe0;display:flex;align-items:center;justify-content:center;font-size:30px}.cc-title{font-family:Nunito,sans-serif;font-weight:900;font-size:20px;color:#2c3e50;margin-bottom:8px}.cc-body{font-size:13px;color:#7f8c8d;line-height:1.55;margin:0 2px 18px}.cc-actions{display:flex;flex-direction:column;gap:10px}.cc-btn{width:100%;padding:12px 16px;border-radius:50px;border:none;font-family:Nunito,sans-serif;font-weight:800;font-size:14px;cursor:pointer;transition:transform .1s,box-shadow .12s,background .12s}.cc-accept{background:#ff6b6b;color:#fff;box-shadow:0 6px 16px #ff6b6b52}.cc-accept:hover{background:#e84848;transform:translateY(-1px)}.cc-accept:active{transform:translateY(0)}.cc-reject{background:#f2efea;color:#5a6570;border:1.5px solid #E4E0DA}.cc-reject:hover{background:#eae6df}.cc-legal{margin-top:15px;font-size:11px;color:#a6a6a6;display:flex;justify-content:center;gap:6px}.cc-legal a{color:#ff6b6b;text-decoration:none;font-weight:700}.cc-legal a:hover{text-decoration:underline}.cc-dot{color:#cfcac2}@keyframes cc-fade{0%{opacity:0}to{opacity:1}}@keyframes cc-rise{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.cc-overlay,.cc-modal{animation:none}.cc-accept:hover{transform:none}}/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.table{display:table}.flex-shrink{flex-shrink:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.italic{font-style:italic}.ordinal{--tw-ordinal:ordinal;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.invert{--tw-invert:invert(100%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}}html,body,#root{height:100%}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}.lobby-stage{--coral:#FF6B6B;--coral-l:#FFE8E8;--coral-d:#E84848;--mint:#4ECDC4;--mint-l:#E0F7F5;--sky:#4A90D9;--sky-l:#E3F0FB;--lemon:#FFE66D;--lemon-l:#FFFBE0;--navy:#2C3E50;--green:#27AE60;--green-l:#E3F7EC;--purple:#9B59B6;--purple-l:#F0E6F6;--bg:#F7F5F0;--card:#FFFFFF;--text:#2C3E50;--muted:#7F8C8D;--border:#F0EDE8;--r-card:20px;--r-btn:50px;min-height:100dvh;background:#e8e4dc;overflow-y:auto;font-family:Nunito Sans,sans-serif;color:var(--text);display:flex;justify-content:center;align-items:flex-start;padding:24px 16px 40px}.lobby-stage *{box-sizing:border-box}.shell{width:390px;max-width:100%;height:calc(100dvh - 64px);max-height:calc(100dvh - 64px);background:var(--bg);border-radius:40px;box-shadow:0 32px 80px #00000038,0 0 0 1px #00000014;overflow:hidden;display:flex;flex-direction:column}.scroll-area{flex:1;overflow-y:auto;padding-bottom:8px}.scroll-area::-webkit-scrollbar{width:0}.topbar{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--card);border-bottom:1.5px solid var(--border);flex-shrink:0}.brand-name{font-family:Nunito,sans-serif;font-weight:900;font-size:19px;color:var(--coral);letter-spacing:-.3px}.lang-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border-radius:50px;border:1.5px solid #E8E4DE;background:transparent;font-size:12px;font-family:Nunito Sans,sans-serif;font-weight:600;color:var(--muted);cursor:pointer}.guest-banner{display:flex;align-items:center;justify-content:space-between;background:var(--lemon-l);border-bottom:1.5px solid #FFE066;padding:10px 18px;gap:12px}.guest-banner span{font-size:12px;color:#6b5a00;font-weight:600;display:flex;align-items:center;gap:5px}.guest-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.guest-signin{padding:5px 13px;border-radius:50px;background:#e6b800;border:none;font-family:Nunito,sans-serif;font-weight:700;font-size:11px;color:#fff;cursor:pointer}.guest-close{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:transparent;border:none;color:#6b5a00;font-size:15px;line-height:1;cursor:pointer}.guest-close:hover{background:#00000012}.hero{background:linear-gradient(135deg,#ff6b6b,#ff8e53);padding:22px 20px 26px;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:-28px;right:-28px;width:140px;height:140px;border-radius:50%;background:#ffffff14}.hero:after{content:"";position:absolute;bottom:-36px;left:36px;width:90px;height:90px;border-radius:50%;background:#ffffff0f}.hero-tag{display:inline-flex;align-items:center;gap:4px;background:#ffffff38;border-radius:50px;padding:4px 11px;font-family:Nunito,sans-serif;font-weight:700;font-size:11px;color:#fff;letter-spacing:.4px;margin-bottom:10px}.hero h1{font-family:Nunito,sans-serif;font-weight:900;font-size:24px;color:#fff;line-height:1.2;margin-bottom:6px;position:relative;z-index:1}.hero p{font-size:13px;color:#ffffffd9;line-height:1.5;position:relative;z-index:1;max-width:280px}.hero-stats{display:flex;gap:18px;margin-top:16px;position:relative;z-index:1}.hstat{display:flex;flex-direction:column;gap:1px}.hstat-num{font-family:Nunito,sans-serif;font-weight:800;font-size:17px;color:#fff}.hstat-lbl{font-size:11px;color:#ffffffbf;font-weight:600}.announce{margin:18px 18px 0;background:var(--navy);border-radius:15px;padding:13px 16px;display:flex;align-items:center;gap:11px}.ann-icon{width:34px;height:34px;border-radius:9px;background:#ffffff1a;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--lemon);font-size:17px}.ann-text p:first-child{font-family:Nunito,sans-serif;font-weight:800;font-size:13px;color:#fff;margin-bottom:2px}.ann-text p:last-child{font-size:11px;color:#fff9}.section{padding:18px 18px 0}.sec-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}.sec-title{font-family:Nunito,sans-serif;font-weight:800;font-size:15px;color:var(--text)}.sec-link{font-size:12px;font-weight:700;color:var(--coral);cursor:pointer}.game-grid{display:flex;flex-direction:column;gap:12px}.game-card{background:var(--card);border-radius:var(--r-card);border:1.5px solid var(--border);padding:16px 16px 14px;cursor:pointer;transition:transform .14s,box-shadow .14s}.game-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000012}.game-card-inner{display:flex;align-items:flex-start;gap:12px}.icon-wrap{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.icon-wrap.coral{background:var(--coral-l)}.icon-wrap.mint{background:var(--mint-l)}.icon-wrap.sky{background:var(--sky-l)}.icon-wrap img{width:40px;height:40px}.game-info{flex:1;min-width:0}.game-name{font-family:Nunito,sans-serif;font-weight:800;font-size:14px;color:var(--text);margin-bottom:3px}.game-desc{font-size:12px;color:var(--muted);line-height:1.4;margin-bottom:9px}.game-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.gtag{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:50px;font-size:10px;font-weight:700;font-family:Nunito,sans-serif}.gtag.online{background:var(--coral-l);color:var(--coral-d)}.gtag.solo{background:var(--sky-l);color:var(--sky)}.gtag.hot{background:var(--lemon-l);color:#c07800}.gtag.ranked{background:#e0f7f5;color:#0a7a70}.game-online{display:flex;align-items:center;gap:3px;font-size:10px;color:var(--muted);font-weight:600;margin-left:auto}.odot{width:6px;height:6px;border-radius:50%;background:var(--green)}.score-row{display:flex;margin-top:11px;padding-top:11px;border-top:1px solid #F5F2EE}.score-item{display:flex;flex-direction:column;gap:2px;flex:1;text-align:center}.score-item:not(:last-child){border-right:1px solid var(--border)}.slbl{font-size:10px;color:var(--muted);font-weight:700;letter-spacing:.3px;text-transform:uppercase}.sval{font-family:Nunito,sans-serif;font-weight:800;font-size:14px;color:var(--text)}.card-actions{flex-shrink:0;display:flex;flex-direction:column;gap:5px;align-self:center}.play-btn{display:flex;align-items:center;gap:4px;padding:7px 15px;border-radius:var(--r-btn);border:none;font-family:Nunito,sans-serif;font-weight:700;font-size:12px;cursor:pointer;color:#fff}.play-btn.coral{background:var(--coral)}.play-btn.mint{background:var(--mint)}.play-btn.sky{background:var(--sky)}.rules-btn{display:flex;align-items:center;justify-content:center;gap:4px;padding:5px 10px;border-radius:var(--r-btn);border:1.5px solid var(--border);background:transparent;font-family:Nunito,sans-serif;font-weight:600;font-size:11px;cursor:pointer;color:var(--muted)}.rules-btn:hover{background:var(--surface);color:var(--text)}.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px}.quick-card{background:var(--card);border-radius:15px;border:1.5px solid var(--border);padding:13px 14px;cursor:pointer;display:flex;align-items:center;gap:9px;transition:transform .12s}.quick-card:hover{transform:translateY(-1px)}.q-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}.q-icon.coral{background:var(--coral-l);color:var(--coral)}.q-icon.purple{background:var(--purple-l);color:var(--purple)}.q-icon.mint{background:var(--mint-l);color:var(--mint)}.q-icon.lemon{background:var(--lemon-l);color:#b07a00}.qlbl{font-family:Nunito,sans-serif;font-weight:700;font-size:12px;color:var(--text);line-height:1.2}.qsub{font-size:10px;color:var(--muted);margin-top:1px}.bottom-nav{position:sticky;bottom:0;background:var(--card);border-top:1.5px solid var(--border);display:flex;padding:10px 0 8px;flex-shrink:0}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:4px 0;background:none;border:none}.nav-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--muted)}.nav-item.active .nav-icon{color:var(--coral);background:var(--coral-l)}.nav-label{font-size:10px;font-weight:700;color:var(--muted);font-family:Nunito,sans-serif}.nav-item.active .nav-label{color:var(--coral)}.lm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c1e268c;display:flex;align-items:center;justify-content:center;padding:20px;z-index:200}.lm-modal{position:relative;width:330px;max-width:100%;background:var(--card);border-radius:26px;padding:26px 22px 18px;box-shadow:0 24px 60px #00000047;text-align:center}.lm-close{position:absolute;top:14px;right:14px;width:30px;height:30px;border:none;background:#f2efea;border-radius:50%;color:var(--muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.lm-logo{width:64px;height:64px;margin:4px auto 14px}.lm-logo img{width:64px;height:64px;object-fit:contain}.lm-title{font-family:Nunito,sans-serif;font-weight:900;font-size:21px;color:var(--text);margin-bottom:7px}.lm-sub{font-size:13px;color:var(--muted);line-height:1.5;margin:0 6px 18px}.lm-gbtn{display:flex;justify-content:center;min-height:40px}.lm-error{color:var(--coral-d);font-size:12px;font-weight:600;margin-top:10px}.lm-guest{display:inline-block;margin-top:14px;font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;background:none;border:none}.lm-guest:hover{color:var(--text)}.lm-legal{margin-top:16px;font-size:10.5px;color:#a6a6a6;line-height:1.5}.user-wrap{position:relative}.user-chip{display:flex;align-items:center;gap:6px;padding:3px 8px 3px 3px;border-radius:50px;border:1.5px solid #EFEBE4;cursor:pointer;background:none}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--coral);display:flex;align-items:center;justify-content:center;font-family:Nunito,sans-serif;font-weight:800;font-size:12px;color:#fff;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-name{font-weight:700;font-size:13px;color:var(--text);max-width:84px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu{position:absolute;top:42px;right:0;width:190px;background:#fff;border:1.5px solid var(--border);border-radius:14px;box-shadow:0 12px 30px #00000024;overflow:hidden;z-index:50}.user-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:11px 14px;font-size:13px;font-weight:600;color:var(--text);cursor:pointer;background:none;border:none;text-align:left;font-family:Nunito Sans,sans-serif}.user-menu button:hover{background:#f7f5f0}.user-menu button.danger{color:var(--coral-d);border-top:1px solid var(--border)}.user-menu i{font-size:17px}.topbar>div:first-child{flex-shrink:0}.topbar>div:last-child{min-width:0}.conn-dot,.lang-btn{flex-shrink:0}.user-wrap,.user-chip{min-width:0}.user-avatar,.user-chip>i{flex-shrink:0}.user-name{flex:0 1 auto;min-width:0;max-width:96px}.user-wrap{display:flex;align-items:center}.user-chip{max-width:100%}.shell{width:100%;max-width:420px}@media(min-width:640px){.shell{max-width:560px}}@media(min-width:1024px){.shell{max-width:720px}}.lobby-toast{position:fixed;left:50%;bottom:84px;transform:translate(-50%);z-index:1000;display:flex;align-items:center;gap:8px;max-width:calc(100% - 40px);padding:11px 16px;background:var(--navy);color:#fff;border-radius:14px;font-size:13px;font-weight:700;box-shadow:0 12px 30px #00000047;animation:lobby-toast-in .2s ease-out}.lobby-toast i{font-size:16px}@keyframes lobby-toast-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}@media(prefers-reduced-motion:reduce){.lobby-toast{animation:none}}.lobby-footer{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 0 6px;font-size:12px}.lobby-footer a{color:#9aa0a6;font-weight:600;text-decoration:none}.lobby-footer a:hover{color:var(--text);text-decoration:underline}.lobby-footer .lf-dot{color:#c4c8cc}.cg-badge{position:absolute;bottom:-2px;right:-2px;width:14px;height:14px;border-radius:50%;background:#fff;border:1.5px solid #e8e8e8;display:flex;align-items:center;justify-content:center;overflow:hidden;pointer-events:none}.cg-badge-icon{font-size:6px;color:#e74c3c;font-weight:900;line-height:1;letter-spacing:-.5px}.menu-cg-info{display:flex;align-items:center;gap:6px;padding:8px 14px 6px;font-size:11px;color:#9aa0a6;border-bottom:1px solid var(--border)}.cg-platform-tag{font-size:10px;font-weight:700;padding:2px 6px;background:#ffeaea;color:#c0392b;border-radius:6px;white-space:nowrap}.tt-stage{--coral:#FF6B6B;--coral-l:#FFE8E8;--coral-d:#E84848;--mint:#4ECDC4;--mint-l:#E0F7F5;--sky:#4A90D9;--sky-l:#E3F0FB;--lemon:#FFE66D;--lemon-l:#FFFBE0;--navy:#2C3E50;--green:#27AE60;--green-l:#E3F7EC;--purple:#9B59B6;--bg:#F7F5F0;--card:#FFFFFF;--text:#2C3E50;--muted:#7F8C8D;--border:#F0EDE8;--accent:#FF6B6B;--accent-l:#FFE8E8;--accent-d:#E84848;--accent2:#FF8E72;min-height:100dvh;background:#e8e4dc;overflow-y:auto;font-family:Nunito Sans,sans-serif;color:var(--text);display:flex;justify-content:center;align-items:flex-start;padding:24px 16px 40px}.tt-stage *{box-sizing:border-box}.tt-shell{position:relative;width:390px;max-width:100%;height:calc(100dvh - 64px);max-height:calc(100dvh - 64px);background:var(--bg);border-radius:40px;box-shadow:0 32px 80px #00000038,0 0 0 1px #00000014;overflow:hidden;display:flex;flex-direction:column}.tt-stage .topbar{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--card);border-bottom:1.5px solid var(--border);flex-shrink:0}.tt-stage .back-btn{width:32px;height:32px;border-radius:9px;border:1.5px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);font-size:17px;flex-shrink:0}.tt-stage .topbar-title{font-family:Nunito,sans-serif;font-weight:900;font-size:17px;color:var(--text);flex:1}.tt-stage .elo-badge{display:flex;align-items:center;gap:4px;padding:5px 11px;border-radius:50px;background:var(--coral-l);font-family:Nunito,sans-serif;font-weight:800;font-size:12px;color:var(--coral-d)}.tt-stage .tab-bar{display:flex;border-bottom:1.5px solid var(--border);background:var(--card);flex-shrink:0}.tt-stage .tab{flex:1;padding:11px 0;text-align:center;font-family:Nunito,sans-serif;font-weight:700;font-size:13px;color:var(--muted);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent}.tt-stage .tab.active{color:var(--coral);border-bottom-color:var(--coral)}.tt-stage .scroll-area{flex:1;overflow-y:auto;padding-bottom:16px}.tt-stage .scroll-area::-webkit-scrollbar{width:0}.tt-stage .hero-strip{background:linear-gradient(135deg,#ff6b6b,#ff8e53);padding:18px 18px 22px;position:relative;overflow:hidden;display:flex;align-items:center;gap:14px}.tt-stage .hero-strip:before{content:"";position:absolute;top:-22px;right:-22px;width:100px;height:100px;border-radius:50%;background:#ffffff14}.tt-stage .hboard{flex-shrink:0;width:66px;height:66px;border-radius:14px;background:#ffffff26;display:flex;align-items:center;justify-content:center}.tt-stage .hinfo h2{font-family:Nunito,sans-serif;font-weight:900;font-size:18px;color:#fff;margin-bottom:4px}.tt-stage .hinfo p{font-size:12px;color:#ffffffd1;line-height:1.4}.tt-stage .hstats{display:flex;gap:14px;margin-top:9px}.tt-stage .hs{display:flex;flex-direction:column;gap:1px}.tt-stage .hs-n{font-family:Nunito,sans-serif;font-weight:800;font-size:14px;color:#fff}.tt-stage .hs-l{font-size:10px;color:#ffffffb8;font-weight:600}.tt-stage .section{padding:18px 18px 0}.tt-stage .sec-title{font-family:Nunito,sans-serif;font-weight:800;font-size:15px;color:var(--text)}.tt-stage .mode-list{display:flex;flex-direction:column;gap:11px;margin-top:12px}.tt-stage .mode-card{background:var(--card);border-radius:20px;border:1.5px solid var(--border);padding:16px;cursor:pointer;transition:transform .14s;display:flex;align-items:center;gap:14px;position:relative;overflow:hidden}.tt-stage .mode-card:hover{transform:translateY(-2px)}.tt-stage .mode-card.selected{border-color:var(--coral);border-width:2px;box-shadow:0 4px 16px #ff6b6b24}.tt-stage .m-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:24px}.tt-stage .m-icon.ai{background:linear-gradient(135deg,var(--coral-l),#FFCECE)}.tt-stage .m-icon.invite{background:linear-gradient(135deg,var(--mint-l),#B3EDE8)}.tt-stage .m-icon.random{background:linear-gradient(135deg,var(--sky-l),#B8D7F5)}.tt-stage .m-body{flex:1;min-width:0}.tt-stage .m-name{font-family:Nunito,sans-serif;font-weight:800;font-size:14px;color:var(--text);margin-bottom:3px}.tt-stage .m-desc{font-size:12px;color:var(--muted);line-height:1.4;margin-bottom:8px}.tt-stage .m-tags{display:flex;gap:5px;flex-wrap:wrap}.tt-stage .mtag{display:inline-flex;align-items:center;gap:2px;padding:3px 7px;border-radius:50px;font-size:10px;font-weight:700;font-family:Nunito,sans-serif}.tt-stage .diff-row{display:flex;gap:6px;margin-top:9px}.tt-stage .diff-btn{flex:1;padding:7px 0;border-radius:9px;border:1.5px solid var(--border);background:transparent;font-family:Nunito,sans-serif;font-weight:700;font-size:12px;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:4px}.tt-stage .diff-btn.easy{border-color:var(--mint);background:var(--mint-l);color:#0a7a70}.tt-stage .diff-btn.hard{border-color:var(--coral);background:var(--coral-l);color:var(--coral-d)}.tt-stage .online-row{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);font-weight:600;margin-top:7px}.tt-stage .odot{width:6px;height:6px;border-radius:50%;background:var(--green)}.tt-stage .room-input-row{display:flex;gap:7px;margin-top:9px}.tt-stage .room-input{flex:1;background:#f7f5f0;border-radius:9px;border:1.5px solid var(--border);padding:7px 11px;font-family:Nunito,sans-serif;font-weight:600;font-size:12px;color:var(--muted)}.tt-stage .room-join-btn{padding:7px 13px;border-radius:9px;background:var(--mint);border:none;font-family:Nunito,sans-serif;font-weight:700;font-size:12px;color:#fff;cursor:pointer}.tt-stage .m-arrow{color:var(--muted);font-size:17px;flex-shrink:0;opacity:.45}.tt-stage .recent-list{display:flex;flex-direction:column;gap:7px;margin-top:11px}.tt-stage .match-row{display:flex;align-items:center;gap:9px;background:var(--card);border-radius:13px;border:1.5px solid var(--border);padding:9px 13px}.tt-stage .m-av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Nunito,sans-serif;font-weight:800;font-size:11px;color:#fff;flex-shrink:0}.tt-stage .m-info{flex:1}.tt-stage .m-pname{font-family:Nunito,sans-serif;font-weight:700;font-size:12px;color:var(--text)}.tt-stage .m-sub{font-size:10px;color:var(--muted);margin-top:1px}.tt-stage .res{font-family:Nunito,sans-serif;font-weight:800;font-size:11px;padding:3px 8px;border-radius:50px}.tt-stage .res.w{background:var(--green-l);color:var(--green)}.tt-stage .res.l{background:var(--coral-l);color:var(--coral-d)}.tt-stage .res.d{background:#f5f2ee;color:var(--muted)}.tt-stage .elo-d{font-family:Nunito,sans-serif;font-weight:700;font-size:11px;margin-left:3px;color:var(--muted)}.tt-stage .elo-d.up{color:var(--green)}.tt-stage .elo-d.dn{color:var(--coral)}.tt-stage .board-area{flex:1;min-height:0;display:flex;justify-content:center;align-items:center;padding:18px;overflow:auto}.tt-stage .board-wrap{width:100%;max-width:min(320px,calc(100dvh - 366px));aspect-ratio:1/1;margin:auto}.tt-toast{position:fixed;bottom:60px;left:50%;transform:translate(-50%);background:#2c3e50;color:#fff;padding:10px 18px;border-radius:50px;font-family:Nunito,sans-serif;font-weight:700;font-size:12px;z-index:99;white-space:nowrap}.tt-shell{width:100%;max-width:420px}@media(min-width:640px){.tt-shell{max-width:560px}}@media(min-width:1024px){.tt-shell{max-width:720px}}.tt-stage .board-wrap{max-width:min(480px,calc(100dvh - 366px))}@media(min-width:1024px){.tt-stage .board-wrap{max-width:min(560px,calc(100dvh - 366px))}}.tt-stage .diff-badge{display:flex;align-items:center;gap:4px;padding:5px 11px;border-radius:50px;background:var(--mint-l);font-family:Nunito,sans-serif;font-weight:800;font-size:11px;color:#0a7a70}.tt-stage .resign-btn{display:flex;align-items:center;gap:4px;padding:5px 11px;border-radius:50px;border:1.5px solid var(--coral-l);background:var(--coral-l);color:var(--coral-d);font-family:Nunito,sans-serif;font-weight:800;font-size:11px;cursor:pointer}.tt-stage .resign-btn:hover{background:var(--coral);color:#fff;border-color:var(--coral)}.tt-stage .diff-btn.disabled{opacity:.55;cursor:not-allowed;position:relative}.tt-stage .soon-tag{font-size:8px;font-weight:800;letter-spacing:.4px;background:#f5f2ee;color:var(--muted);padding:1px 5px;border-radius:50px;margin-left:3px}.tt-stage .players{display:flex;align-items:stretch;gap:8px;padding:14px 16px 12px;background:var(--card);border-bottom:1.5px solid var(--border);flex-shrink:0}.tt-stage .pcard{flex:1;min-width:0;display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:14px;border:1.5px solid var(--border);background:var(--bg);transition:.15s}.tt-stage .pcard.active{border-color:var(--coral);background:#fff;box-shadow:0 4px 14px #ff6b6b29}.tt-stage .pcard.blue.active{border-color:var(--sky);box-shadow:0 4px 14px #4a90d929}.tt-stage .pav{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Nunito,sans-serif;font-weight:800;font-size:13px;color:#fff;flex-shrink:0}.tt-stage .pav.red{background:linear-gradient(135deg,#ff6b6b,#ff8e53)}.tt-stage .pav.blue{background:linear-gradient(135deg,#4a90d9,#5b6bd6)}.tt-stage .pinfo{min-width:0}.tt-stage .pname{font-family:Nunito,sans-serif;font-weight:800;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tt-stage .pmeta{font-size:10.5px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:4px;margin-top:1px;white-space:nowrap}.tt-stage .pmeta .muted{color:var(--muted);opacity:.75}.tt-stage .dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.tt-stage .dot.red{background:var(--coral)}.tt-stage .dot.blue{background:var(--sky)}.tt-stage .pcount{font-family:Nunito,sans-serif;font-weight:800;color:var(--text)}.tt-stage .vs{display:flex;align-items:center;justify-content:center;font-family:Nunito,sans-serif;font-weight:900;font-size:12px;color:var(--muted)}.tt-stage .banner{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;font-family:Nunito,sans-serif;font-weight:800;font-size:13px;flex-shrink:0}.tt-stage .banner.you{background:var(--coral-l);color:var(--coral-d)}.tt-stage .banner.ai{background:#f3f0eb;color:var(--muted)}.tt-stage .banner.capture{background:var(--lemon);color:#8a6d00}.tt-stage .banner .ti{font-size:16px}.tt-stage .thinking-dots{display:inline-flex;gap:3px;align-items:center}.tt-stage .thinking-dots i{width:5px;height:5px;border-radius:50%;background:currentColor;display:inline-block;animation:ttbd 1s infinite;opacity:.4}.tt-stage .thinking-dots i:nth-child(2){animation-delay:.18s}.tt-stage .thinking-dots i:nth-child(3){animation-delay:.36s}@keyframes ttbd{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-2px)}}.tt-stage .tt-loading{display:flex;align-items:center;gap:8px;color:var(--muted);font-weight:700;font-size:13px}.tt-stage .hint{padding:0 18px 18px;flex-shrink:0}.tt-stage .hint-box{display:flex;align-items:center;gap:9px;background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:11px 14px}.tt-stage .hint-ic{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;background:var(--lemon-l,#FFFBE0);color:#8a6d00}.tt-stage .hint-tx{font-size:12px;line-height:1.4;color:var(--text)}.tt-stage .tt-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#2c3e508c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:20}.tt-stage .tt-result{width:100%;background:var(--card);border-radius:28px;padding:26px 22px 22px;text-align:center;box-shadow:0 24px 60px #0000004d;position:relative;overflow:hidden}.tt-stage .tt-result:before{content:"";position:absolute;top:-40px;left:50%;transform:translate(-50%);width:200px;height:120px;border-radius:50%;opacity:.16}.tt-stage .tt-result.win:before{background:var(--green)}.tt-stage .tt-result.lose:before{background:var(--coral)}.tt-stage .tt-result.draw:before{background:var(--muted)}.tt-stage .r-emoji{font-size:46px;margin-bottom:8px;position:relative}.tt-stage .r-title{font-family:Nunito,sans-serif;font-weight:900;font-size:24px;margin-bottom:5px;position:relative}.tt-stage .tt-result.win .r-title{color:var(--green)}.tt-stage .tt-result.lose .r-title{color:var(--coral-d)}.tt-stage .tt-result.draw .r-title{color:var(--muted)}.tt-stage .r-sub{font-size:13px;color:var(--muted);margin-bottom:18px;position:relative}.tt-stage .r-stats{display:flex;gap:10px;margin-bottom:20px;position:relative}.tt-stage .r-stat{flex:1;background:var(--bg);border-radius:14px;padding:11px 6px}.tt-stage .r-stat .n{font-family:Nunito,sans-serif;font-weight:900;font-size:18px}.tt-stage .r-stat .l{font-size:10px;color:var(--muted);font-weight:700;margin-top:2px}.tt-stage .r-actions{display:flex;flex-direction:column;gap:9px;position:relative}.tt-stage .r-hint{font-size:12px;color:var(--muted);font-weight:700;text-align:center;margin:-2px 0 2px}.tt-stage .tt-btn:disabled{opacity:.6;cursor:default}.tt-stage .tt-btn{padding:13px 0;border-radius:14px;font-family:Nunito,sans-serif;font-weight:800;font-size:14px;cursor:pointer;border:none;display:flex;align-items:center;justify-content:center;gap:7px}.tt-stage .tt-btn-primary{background:var(--coral);color:#fff}.tt-stage .tt-btn-ghost{background:transparent;color:var(--muted);border:1.5px solid var(--border)}.tt-stage .tt-btn-danger{background:var(--coral);color:#fff}.tt-stage .tt-confirm{width:100%;background:var(--card);border-radius:24px;padding:24px 22px 20px;text-align:center;box-shadow:0 24px 60px #0000004d}.tt-stage .c-icon{width:52px;height:52px;border-radius:50%;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;background:var(--coral-l);color:var(--coral-d);font-size:24px}.tt-stage .c-title{font-family:Nunito,sans-serif;font-weight:900;font-size:18px;color:var(--text);margin-bottom:6px}.tt-stage .c-body{font-size:13px;color:var(--muted);line-height:1.5;margin-bottom:18px}.tt-stage .c-actions{display:flex;gap:9px}.tt-stage .c-actions .tt-btn{flex:1}.tt-stage .room-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:22px 24px;text-align:center;gap:4px;overflow-y:auto}.tt-stage .room-loading{display:flex;align-items:center;gap:8px;color:var(--muted);font-weight:700;font-size:13px}.tt-stage .r-ic{width:54px;height:54px;border-radius:17px;display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:4px}.tt-stage .r-ic.create{background:linear-gradient(135deg,var(--mint-l),#B3EDE8);color:#0a7a70}.tt-stage .r-ic.join{background:linear-gradient(135deg,var(--sky-l),#B8D7F5);color:#185fa5}.tt-stage .r-title{font-family:Nunito,sans-serif;font-weight:900;font-size:19px;color:var(--text)}.tt-stage .r-desc{font-size:12.5px;color:var(--muted);line-height:1.5;max-width:270px;margin-bottom:8px}.tt-stage .code-box{display:flex;align-items:center;gap:10px;background:var(--card);border:2px dashed var(--mint);border-radius:14px;padding:11px 16px;margin:2px 0}.tt-stage .code-val{font-family:Nunito,sans-serif;font-weight:900;font-size:26px;letter-spacing:6px;color:var(--navy)}.tt-stage .copy-ic{width:34px;height:34px;border-radius:10px;border:none;background:var(--mint-l);color:#0a7a70;font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.tt-stage .qr-wrap{background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:9px;margin:8px 0 2px;line-height:0}.tt-stage .qr-img{width:118px;height:118px;display:block}.tt-stage .copy-row{display:flex;gap:8px;width:100%;max-width:300px;margin-top:8px}.tt-stage .cbtn{flex:1;padding:9px 0;border-radius:11px;border:1.5px solid var(--border);background:var(--card);color:var(--text);font-family:Nunito,sans-serif;font-weight:700;font-size:11px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px}.tt-stage .cbtn i{font-size:16px;color:var(--mint)}.tt-stage .copied-tip{min-height:16px;font-size:11px;font-weight:700;color:var(--green);margin-top:4px}.tt-stage .waiting{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--muted);font-weight:700;font-size:13px;margin-top:8px}.tt-stage .room-actions{display:flex;flex-direction:column;gap:9px;width:100%;max-width:290px;margin-top:14px}.tt-stage .code-input{width:100%;max-width:280px;text-align:center;font-family:Nunito,sans-serif;font-weight:900;font-size:25px;letter-spacing:7px;text-transform:uppercase;color:var(--navy);background:var(--card);border:2px solid var(--sky);border-radius:16px;padding:13px 10px;margin:6px 0}.tt-stage .code-input::placeholder{color:#cfc7b8;letter-spacing:2px;font-size:14px}.tt-stage .code-input:focus{outline:none;border-color:var(--sky)}.tt-stage .hint-line{font-size:11.5px;color:var(--muted);max-width:270px;line-height:1.5;display:flex;align-items:center;gap:5px;justify-content:center}.tt-stage .tt-btn-sky{background:var(--sky);color:#fff}.tt-stage .tt-btn-sky:disabled{opacity:.5;cursor:not-allowed}.tt-stage .tt-btn-outline{background:var(--card);color:var(--sky);border:1.5px solid var(--sky)}.tt-stage input.room-input{color:var(--text);text-transform:uppercase;letter-spacing:1px}.tt-stage .room-join-btn:disabled{opacity:.5;cursor:not-allowed}.tt-stage .room-scan-btn{flex-shrink:0;width:36px;border:1.5px solid var(--mint);border-radius:9px;background:var(--mint-l);color:#0a7a70;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.tt-stage .room-scan-btn:hover{background:var(--mint);color:#fff}.tt-stage .scan-area{flex:1;width:100%;background:#1c2530;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;position:relative;overflow:hidden}.tt-stage .scan-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.tt-stage .viewfinder{width:210px;height:210px;border-radius:18px;position:relative;z-index:1}.tt-stage .corner{position:absolute;width:34px;height:34px;border:4px solid var(--mint)}.tt-stage .corner.tl{top:-2px;left:-2px;border-right:none;border-bottom:none;border-radius:14px 0 0}.tt-stage .corner.tr{top:-2px;right:-2px;border-left:none;border-bottom:none;border-radius:0 14px 0 0}.tt-stage .corner.bl{bottom:-2px;left:-2px;border-right:none;border-top:none;border-radius:0 0 0 14px}.tt-stage .corner.br{bottom:-2px;right:-2px;border-left:none;border-top:none;border-radius:0 0 14px}.tt-stage .scanline{position:absolute;left:8px;right:8px;top:24px;height:2px;background:var(--mint);box-shadow:0 0 8px var(--mint)}.tt-stage .scan-hint{position:relative;z-index:1;color:#fff;font-size:12.5px;font-weight:700;display:flex;align-items:center;gap:6px;background:#0006;padding:6px 12px;border-radius:50px}.tt-stage .scan-denied{color:#cfd6dd;font-size:13px;font-weight:700;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:0 30px}.tt-stage .scan-foot{padding:14px 24px;background:var(--card);border-top:1.5px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;gap:9px}.tt-stage .scan-foot .tt-btn{width:100%}.tt-stage .scan-imgerr{position:relative;z-index:1;color:#ffd2d2;font-size:12px;font-weight:700;background:#e848488c;padding:5px 12px;border-radius:50px}.tt-stage{--amber:#F39C12;--amber-l:#FEF3E0;--amber-d:#B9770B}.tt-stage .pcard.offline{border-color:var(--amber);background:var(--amber-l)}.tt-stage .pav.grey{background:linear-gradient(135deg,#b6ae9e,#9e968a)}.tt-stage .pav{position:relative}.tt-stage .pav .badge-off{position:absolute;right:-3px;bottom:-3px;width:16px;height:16px;border-radius:50%;background:var(--amber);border:2px solid #fff;display:flex;align-items:center;justify-content:center;color:#fff;font-size:9px}.tt-stage .pmeta .warn{color:var(--amber-d);display:flex;align-items:center;gap:4px}.tt-stage .disc-banner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:9px 16px;background:var(--amber-l);color:var(--amber-d);flex-shrink:0;border-bottom:1.5px solid #F4E2C2}.tt-stage .disc-banner .row1{display:flex;align-items:center;gap:7px;font-family:Nunito,sans-serif;font-weight:800;font-size:13px}.tt-stage .disc-banner .cd{font-family:Nunito,sans-serif;font-weight:900;font-size:17px;letter-spacing:.5px}.tt-stage .disc-banner .ti{font-size:16px}.tt-stage .board-area{position:relative}.tt-stage .board-wrap.dimmed{filter:grayscale(.55) brightness(.82);opacity:.65;transition:.2s}.tt-stage .pause-pill{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;align-items:center;gap:6px;padding:7px 15px;border-radius:50px;background:#2c3e50d1;color:#fff;font-family:Nunito,sans-serif;font-weight:800;font-size:12px;z-index:2}.tt-stage .tt-recon-toast{position:absolute;top:120px;left:50%;transform:translate(-50%);z-index:25;display:flex;align-items:center;gap:7px;padding:9px 16px;border-radius:50px;background:var(--green);color:#fff;font-family:Nunito,sans-serif;font-weight:800;font-size:12.5px;box-shadow:0 8px 22px #27ae6059}.tt-stage .tt-recon{width:100%;background:var(--card);border-radius:28px;padding:30px 24px 24px;text-align:center;box-shadow:0 24px 60px #0000004d}.tt-stage .tt-recon-spin{width:54px;height:54px;margin:0 auto 16px;border-radius:50%;border:5px solid var(--amber-l);border-top-color:var(--amber);animation:ttspin .9s linear infinite}.tt-stage .tt-recon-spin.fail{border:5px solid var(--coral-l);border-top-color:transparent;animation:none;display:flex;align-items:center;justify-content:center;color:var(--coral);font-size:26px}@keyframes ttspin{to{transform:rotate(360deg)}}.tt-stage .tt-recon-title{font-family:Nunito,sans-serif;font-weight:900;font-size:20px;color:var(--navy);margin-bottom:6px}.tt-stage .tt-recon-cd{font-family:Nunito,sans-serif;font-weight:900;font-size:15px;color:var(--amber-d);margin-bottom:10px}.tt-stage .tt-recon-sub{font-size:12.5px;color:var(--muted);line-height:1.5;margin-bottom:22px}.tt-stage .tt-recon .tt-btn{width:100%}.tt-stage .r-elo{position:relative;background:linear-gradient(135deg,#fff8f2,#fdf0e8);border:1.5px solid #F6E3D4;border-radius:18px;padding:13px 15px;margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;gap:10px;overflow:hidden}.tt-stage .re-left{display:flex;flex-direction:column;align-items:flex-start;gap:3px}.tt-stage .re-label{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.3px;text-transform:uppercase}.tt-stage .re-valrow{display:flex;align-items:baseline;gap:7px}.tt-stage .re-val{font-family:Nunito,sans-serif;font-weight:900;font-size:26px;color:var(--navy);line-height:1}.tt-stage .re-delta{font-family:Nunito,sans-serif;font-weight:900;font-size:13px;display:inline-flex;align-items:center;gap:1px;padding:2px 7px;border-radius:50px}.tt-stage .re-delta .ti{font-size:12px}.tt-stage .re-delta.up{background:var(--green-l);color:var(--green)}.tt-stage .re-delta.down{background:var(--coral-l);color:var(--coral-d)}.tt-stage .re-record{display:flex;flex-direction:column;gap:5px;align-items:flex-end}.tt-stage .re-wld{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}.tt-stage .re-pill{font-family:Nunito,sans-serif;font-weight:800;font-size:10.5px;padding:3px 8px;border-radius:50px;white-space:nowrap}.tt-stage .re-pill.w{background:var(--green-l);color:var(--green)}.tt-stage .re-pill.l{background:var(--coral-l);color:var(--coral-d)}.tt-stage .re-pill.d{background:#eef1f4;color:#8a97a4}.tt-stage .r-elo.guest{background:linear-gradient(135deg,var(--sky-l),#EAF3FC);border-color:#cfe3f6;justify-content:flex-start;cursor:pointer}.tt-stage .r-elo.guest:hover{filter:brightness(.985)}.tt-stage .re-gicon{width:38px;height:38px;border-radius:11px;background:#fff;display:flex;align-items:center;justify-content:center;color:var(--sky);font-size:20px;flex-shrink:0;box-shadow:0 2px 6px #4a90d92e}.tt-stage .re-gtext{text-align:left;flex:1}.tt-stage .re-gtitle{font-family:Nunito,sans-serif;font-weight:800;font-size:13px;color:var(--navy)}.tt-stage .re-gsub{font-size:11px;color:#5d7894;margin-top:2px;line-height:1.4}.tt-stage .re-garrow{color:var(--sky);font-size:18px;flex-shrink:0}.tt-stage .help-btn{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border);background:var(--lemon-l);display:flex;align-items:center;justify-content:center;cursor:pointer;color:#b9770b;font-size:17px;flex-shrink:0}.tt-stage .help-btn:hover{background:#fff4cc}.tt-stage .rules-link{display:inline-flex;align-items:center;gap:6px;margin-top:11px;padding:6px 12px;border-radius:50px;background:#ffffff2e;border:1.5px solid rgba(255,255,255,.4);color:#fff;font-family:Nunito,sans-serif;font-weight:800;font-size:12px;cursor:pointer}.tt-stage .rules-link:hover{background:#ffffff47}.tt-stage .rules-link .ti-chevron-right{font-size:14px;opacity:.8}.tt-stage .tab .ti{font-size:15px;vertical-align:-2px;margin-right:3px}.tt-stage .rules-body{padding:16px 16px 28px}.tt-stage .md{font-size:13px;color:#5a6b76;line-height:1.65}.tt-stage .md h2{font-family:Nunito,sans-serif;font-weight:900;font-size:15px;color:var(--navy);margin:20px 0 9px;padding-left:11px;border-left:4px solid var(--coral);line-height:1.3}.tt-stage .md h2:first-child{margin-top:2px}.tt-stage .md p{margin:0 0 10px}.tt-stage .md strong{color:var(--navy);font-weight:800}.tt-stage .md em{font-style:normal;color:var(--coral-d);font-weight:700}.tt-stage .md ul{list-style:none;margin:0 0 12px;padding:0;display:flex;flex-direction:column;gap:6px}.tt-stage .md li{position:relative;padding-left:16px}.tt-stage .md li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:2px;background:var(--mint)}.tt-stage .md blockquote{margin:0 0 14px;padding:12px 14px;background:var(--lemon-l);border:1.5px solid #F2E4A8;border-radius:14px}.tt-stage .md blockquote p{margin:0;font-size:12.5px;color:#7a6520}.tt-stage .md blockquote strong{color:#8a6d10}.tt-stage .md table{width:100%;border-collapse:collapse;font-size:12px;background:var(--card);border:1.5px solid var(--border);border-radius:12px;overflow:hidden;margin:0 0 14px}.tt-stage .md th{background:#faf8f4;font-family:Nunito,sans-serif;font-weight:800;font-size:11px;color:var(--muted);padding:9px 10px;text-align:left;border-bottom:1.5px solid var(--border)}.tt-stage .md td{padding:9px 10px;border-bottom:1px solid var(--border)}.tt-stage .md tr:last-child td{border-bottom:none}.tt-stage .md td strong{color:var(--navy)}.tt-stage .md td.md-pos{color:var(--green);font-weight:800}.tt-stage .md td.md-neg{color:var(--coral-d);font-weight:800}.tt-stage .md pre{background:var(--navy);border-radius:14px;padding:14px 16px;overflow-x:auto;margin:0 0 14px}.tt-stage .md pre code{font-family:SFMono-Regular,Consolas,monospace;font-size:11.5px;line-height:1.8;color:#dfe8ef;white-space:pre}.tt-stage .md :not(pre)>code{background:#f0ede8;border-radius:5px;padding:1px 5px;font-size:12px;font-family:SFMono-Regular,Consolas,monospace;color:var(--navy)}.tt-stage .md hr{border:none;border-top:1.5px solid var(--border);margin:14px 0}.tt-stage .md a{color:var(--coral-d);font-weight:700}@media(orientation:landscape)and (max-height:600px){.tt-stage{padding:12px;align-items:center}.tt-shell{width:calc(100vw - 24px);max-width:calc(100vw - 24px);height:calc(100dvh - 24px);max-height:calc(100dvh - 24px);border-radius:22px}.tt-shell:has(.board-area){display:grid;grid-template-columns:1fr 200px;grid-template-rows:auto auto auto 1fr}.tt-shell:has(.board-area) .topbar{grid-column:1/-1;grid-row:1;padding:8px 14px}.tt-shell:has(.board-area) .topbar-title{font-size:14px}.tt-shell:has(.board-area) .players{grid-column:2;grid-row:2;padding:6px 10px;flex-direction:column;gap:4px}.tt-shell:has(.board-area) .players .pcard{flex:none;width:100%}.tt-shell:has(.board-area) .banner,.tt-shell:has(.board-area) .disc-banner{grid-column:2;grid-row:3}.tt-shell:has(.board-area) .banner{padding:6px 10px;font-size:11.5px}.tt-shell:has(.board-area) .disc-banner{padding:6px 10px}.tt-shell:has(.board-area) .board-area{grid-column:1;grid-row:2/5;padding:8px;overflow:hidden}.tt-shell:has(.board-area) .board-wrap{height:100%;aspect-ratio:1/1;width:auto;max-width:100%}.tt-shell:has(.board-area) .hint{grid-column:2;grid-row:4;align-self:start;padding:0 10px 8px}.tt-shell:has(.board-area) .tt-overlay{align-items:center;overflow-y:auto;padding:10px 14px}.tt-shell:has(.board-area) .tt-result,.tt-shell:has(.board-area) .tt-confirm{padding:13px 15px 11px}.tt-shell:has(.board-area) .r-emoji{font-size:26px;margin-bottom:2px}.tt-shell:has(.board-area) .tt-result .r-title{font-size:16px;margin-bottom:3px}.tt-shell:has(.board-area) .r-sub{font-size:11px;margin-bottom:10px}.tt-shell:has(.board-area) .r-stats{margin-bottom:12px}.tt-shell:has(.board-area) .r-stat{padding:7px 4px}.tt-shell:has(.board-area) .r-stat .n{font-size:15px}.tt-shell:has(.board-area) .tt-btn{padding:9px 0;font-size:13px}.tt-shell:has(.board-area) .c-icon{width:36px;height:36px;font-size:18px;margin-bottom:8px}.tt-shell:has(.board-area) .c-title{font-size:16px;margin-bottom:4px}.tt-shell:has(.board-area) .c-body{font-size:11px;margin-bottom:12px}.tt-shell:has(.board-area) .r-elo{padding:8px 12px;margin-bottom:8px}.tt-shell:has(.board-area) .re-val{font-size:20px}.tt-shell:has(.board-area) .r-actions{flex-direction:row;flex-wrap:wrap;gap:8px}.tt-shell:has(.board-area) .r-actions .tt-btn{flex:1;min-width:80px}.tt-shell:has(.board-area) .r-actions .r-hint{flex-basis:100%;margin:0}}:is(.tt-stage,.seven-stage) .match-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:22px 24px;text-align:center}:is(.tt-stage,.seven-stage) .radar{position:relative;width:188px;height:188px;display:flex;align-items:center;justify-content:center;margin-bottom:26px}:is(.tt-stage,.seven-stage) .radar .ring{position:absolute;width:188px;height:188px;border-radius:50%;border:2px solid var(--accent);opacity:0;animation:mm-pulse 2.4s ease-out infinite}:is(.tt-stage,.seven-stage) .radar .r2{animation-delay:.8s}:is(.tt-stage,.seven-stage) .radar .r3{animation-delay:1.6s}@keyframes mm-pulse{0%{transform:scale(.42);opacity:.55}80%{opacity:0}to{transform:scale(1);opacity:0}}:is(.tt-stage,.seven-stage) .radar .me-av{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-family:Nunito,sans-serif;font-weight:900;font-size:26px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px #ff6b6b66;z-index:2}:is(.tt-stage,.seven-stage) .radar .orbit{position:absolute;width:188px;height:188px;animation:mm-spin 3.2s linear infinite}@keyframes mm-spin{to{transform:rotate(360deg)}}:is(.tt-stage,.seven-stage) .radar .chip{position:absolute;top:-4px;left:50%;transform:translate(-50%);width:34px;height:34px;border-radius:50%;background:var(--sky);display:flex;align-items:center;justify-content:center;font-size:17px;color:#fff;box-shadow:0 6px 14px #00000029}:is(.tt-stage,.seven-stage) .s-title{font-family:Nunito,sans-serif;font-weight:900;font-size:21px;color:var(--navy,#2C3E50);margin-bottom:7px;display:flex;align-items:center;gap:7px;justify-content:center}:is(.tt-stage,.seven-stage) .dots i{display:inline-block;width:6px;height:6px;margin:0 1.5px;border-radius:50%;background:var(--accent);animation:mm-blink 1.2s infinite}:is(.tt-stage,.seven-stage) .dots i:nth-child(2){animation-delay:.2s}:is(.tt-stage,.seven-stage) .dots i:nth-child(3){animation-delay:.4s}@keyframes mm-blink{0%,to{opacity:.25;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}:is(.tt-stage,.seven-stage) .s-sub{font-size:13.5px;color:var(--muted);line-height:1.55;max-width:240px;margin-bottom:28px}:is(.tt-stage,.seven-stage) .rematch-pill{display:inline-flex;align-items:center;gap:7px;background:var(--lemon-l,#FFFBE0);color:#9a7b1a;border:1.5px solid #F2E6B8;font-size:12.5px;font-weight:800;padding:9px 15px;border-radius:20px;margin-bottom:20px}:is(.tt-stage,.seven-stage) .found-title{font-family:Nunito,sans-serif;font-weight:900;font-size:22px;color:var(--green,#27AE60);margin-bottom:6px}:is(.tt-stage,.seven-stage) .found-sub{font-size:13px;color:var(--muted);margin-bottom:4px}:is(.tt-stage,.seven-stage) .vs-wrap{display:flex;align-items:center;justify-content:center;gap:14px;margin:22px 0 6px}:is(.tt-stage,.seven-stage) .vs-wrap .pcol{display:flex;flex-direction:column;align-items:center;gap:9px}:is(.tt-stage,.seven-stage) .big-av{width:78px;height:78px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Nunito,sans-serif;font-weight:900;font-size:24px;color:#fff}:is(.tt-stage,.seven-stage) .big-av.red{background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:0 8px 20px #ff6b6b61}:is(.tt-stage,.seven-stage) .big-av.blue{background:linear-gradient(135deg,var(--sky),#5BA8F0);box-shadow:0 8px 20px #4a90d961}:is(.tt-stage,.seven-stage) .vs-wrap .pn{font-family:Nunito,sans-serif;font-weight:800;font-size:14px;color:var(--navy,#2C3E50)}:is(.tt-stage,.seven-stage) .first-tag{color:var(--accent-d);font-size:11px}:is(.tt-stage,.seven-stage) .vs-wrap .pe{font-size:11.5px;font-weight:700;color:var(--muted);background:#fff;border:1.5px solid var(--border);padding:2px 9px;border-radius:12px}:is(.tt-stage,.seven-stage) .vs-badge{font-family:Nunito,sans-serif;font-weight:900;font-size:17px;color:#fff;background:var(--navy,#2C3E50);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 14px #2c3e504d}:is(.tt-stage,.seven-stage) .match-actions{display:flex;flex-direction:column;gap:10px;width:100%;max-width:280px;margin-top:28px}:is(.tt-stage,.seven-stage) .m-btn{padding:15px;border-radius:16px;font-family:Nunito,sans-serif;font-weight:800;font-size:15px;display:flex;align-items:center;justify-content:center;gap:7px;cursor:pointer;border:1.5px solid transparent}:is(.tt-stage,.seven-stage) .m-btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 8px 18px #ff6b6b57}:is(.tt-stage,.seven-stage) .m-btn.ghost{background:#fff;border-color:var(--border);color:var(--muted)}:is(.tt-stage,.seven-stage) .m-btn:disabled{opacity:.7;cursor:default}:is(.tt-stage,.seven-stage) .m-btn.cancel-wide{width:100%;max-width:280px}:is(.tt-stage,.seven-stage) .m-btn .spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:mm-spin .8s linear infinite}html[lang=zh-CN] body,html[lang=zh-CN] button,html[lang=zh-CN] input,html[lang=zh-CN] textarea,html[lang=zh-CN] select{font-family:Nunito Sans,Noto Sans SC,sans-serif}html[lang=zh-CN] :is(h1,h2,h3,h4,h5,h6){font-family:Nunito,Noto Sans SC,sans-serif}html[lang=zh-TW] body,html[lang=zh-TW] button,html[lang=zh-TW] input,html[lang=zh-TW] textarea,html[lang=zh-TW] select{font-family:Nunito Sans,Noto Sans TC,sans-serif}html[lang=zh-TW] :is(h1,h2,h3,h4,h5,h6){font-family:Nunito,Noto Sans TC,sans-serif}html,body{-webkit-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}input,textarea,[contenteditable]{-webkit-user-select:text;user-select:text}.bottom-nav{padding-bottom:max(8px,env(safe-area-inset-bottom))}.lobby-toast{bottom:max(84px,calc(84px + env(safe-area-inset-bottom)))}[data-theme=cn]{--cn-font: "PingFang SC", "Microsoft YaHei UI", "Microsoft YaHei", -apple-system, "Helvetica Neue", sans-serif;--cn-primary: #C4622D;--cn-primary-d: #A84B20;--cn-primary-l: #FAEAE0;--cn-primary-grad: linear-gradient(135deg, #C4622D, #A84B20);--cn-bg: #F7EDE2;--cn-bg-2: #F0E2D0;--cn-surface: #FFFFFF;--cn-border: #EAD8C8;--cn-text: #3D1F10;--cn-muted: #9A7060;--cn-hint: #B08070;--cn-tt: #C4622D;--cn-seven: #7A9E7E;--cn-sudoku: #B8860B;--cn-wechat: #07C160;--cn-douyin: #FE2C55;--cn-success: #22c55e;--cn-warning: #f59e0b;--cn-error: #ef4444;--cn-shadow-sm: 0 1px 4px rgba(61, 31, 16, .08);--cn-shadow-md: 0 4px 16px rgba(61, 31, 16, .1);--cn-shadow-lg: 0 8px 32px rgba(61, 31, 16, .12);--cn-radius-sm: 8px;--cn-radius-md: 14px;--cn-radius-lg: 20px;--cn-radius-xl: 26px;--cn-bottom-nav-h: 56px;--cn-safe-bottom: env(safe-area-inset-bottom, 0px)}[data-theme=cn],[data-theme=cn] *{font-family:var(--cn-font);-webkit-tap-highlight-color:transparent}.cn-portrait-shell{width:100%;max-width:430px;min-height:100dvh;margin:0 auto;background:var(--cn-bg);display:flex;flex-direction:column;position:relative;overflow:hidden}
