:root{--ds-font: "Be Vietnam Pro", "Inter", -apple-system, sans-serif;--ds-font-serif: "Noto Serif SC", "KaiTi", Georgia, serif;--ds-font-mono: "Fira Mono", monospace;--ds-bg: #f5ede0;--ds-bg-pattern: #ede0c8;--ds-card: #ffffff;--ds-card-secondary: #faf6ee;--ds-card-border: #c4a878;--ds-header-bg: #3a1a0a;--ds-header-text: #f0c060;--ds-header-border: rgba(240,192,96,.15);--ds-primary: #8B1E1E;--ds-primary-hover: #6d1717;--ds-primary-light: rgba(139,30,30,.08);--ds-text: #2a1a0e;--ds-text-muted: #7a5a3a;--ds-text-light: #a07840;--ds-gold: #c8960a;--ds-gold-light: #f0d060;--ds-border: #c4a878;--ds-border-strong: #a08050;--ds-green: #27ae60;--ds-green-light: rgba(39,174,96,.1);--ds-red-dot: #c0392b;--ds-blue: #2980b9;--ds-shadow-sm: 0 1px 4px rgba(140,80,20,.12);--ds-shadow-md: 0 3px 12px rgba(140,80,20,.16);--ds-shadow-lg: 0 6px 24px rgba(140,80,20,.2);--ds-shadow-card: 0 2px 10px rgba(0,0,0,.1);--ds-radius-sm: 6px;--ds-radius-md: 10px;--ds-radius-lg: 14px;--ds-radius-xl: 20px;--ds-radius-full: 999px;--ds-page-px: 16px;--ds-transition: .2s ease}[data-theme=dark]{--ds-bg: #1a1008;--ds-bg-pattern: #120b04;--ds-card: #2a1a0e;--ds-card-secondary: #221408;--ds-card-border: #5a3828;--ds-header-bg: #0e0804;--ds-header-text: #f0c060;--ds-header-border: rgba(240,192,96,.12);--ds-primary: #c0302a;--ds-primary-hover: #a02020;--ds-primary-light: rgba(192,48,42,.15);--ds-text: #f0e0c8;--ds-text-muted: #b09070;--ds-text-light: #8a6840;--ds-gold: #e0a820;--ds-gold-light: #f0d060;--ds-border: #5a3828;--ds-border-strong: #7a5030;--ds-green: #2ecc71;--ds-green-light: rgba(46,204,113,.12);--ds-red-dot: #e74c3c;--ds-blue: #3498db;--ds-shadow-sm: 0 1px 4px rgba(0,0,0,.3);--ds-shadow-md: 0 3px 12px rgba(0,0,0,.4);--ds-shadow-lg: 0 6px 24px rgba(0,0,0,.5);--ds-shadow-card: 0 2px 10px rgba(0,0,0,.3)}[data-theme=dark] body{background:#0a0604}.ds-page{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;overflow:hidden;font-family:var(--ds-font);background:var(--ds-bg);max-width:480px;margin:0 auto;z-index:80;transition:background var(--ds-transition),color var(--ds-transition)}@media(min-width:480px){.ds-page{box-shadow:0 0 60px #0006}body{background:#3a1a0a}}@media(min-width:640px){.ds-page{max-width:640px}}@media(min-width:900px){.ds-page{max-width:900px}}@media(min-width:1024px){.ds-page.hp-page{max-width:1360px}}.ds-page-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse at 15% 5%,rgba(200,150,50,.14) 0%,transparent 55%),radial-gradient(ellipse at 85% 90%,rgba(160,90,20,.1) 0%,transparent 55%),linear-gradient(170deg,#f8f0e0,#f2e8d4,#eadfc8)}.ds-page>*:not(.ds-page-bg){position:relative;z-index:1}.ds-header{display:flex;align-items:center;height:52px;padding:0 14px;background:var(--ds-header-bg);border-bottom:2px solid var(--ds-header-border);flex-shrink:0;gap:8px}.ds-header-title{flex:1;text-align:center;font-family:var(--ds-font-serif);font-size:1.05rem;font-weight:700;color:var(--ds-header-text);letter-spacing:2px;margin:0}.ds-header-back,.ds-header-icon{width:36px;height:36px;border:none;border-radius:50%;background:#ffffff14;color:var(--ds-gold-light);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .18s;flex-shrink:0}.ds-header-back:hover,.ds-header-icon:hover{background:#ffffff26}.ds-header-spacer{width:36px}.ds-scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.ds-scroll::-webkit-scrollbar{width:3px}.ds-scroll::-webkit-scrollbar-thumb{background:#a0642833;border-radius:2px}.ds-card{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-card)}.ds-card-secondary{background:var(--ds-card-secondary);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg)}.ds-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;border-radius:var(--ds-radius-md);font-family:var(--ds-font);font-weight:700;font-size:.88rem;letter-spacing:.5px;cursor:pointer;transition:background .18s,transform .1s,box-shadow .18s;padding:12px 22px;white-space:nowrap}.ds-btn:active{transform:scale(.97)}.ds-btn-primary{background:var(--ds-primary);color:#fff;box-shadow:0 2px 8px #8b1e1e59}.ds-btn-primary:hover{background:var(--ds-primary-hover)}.ds-btn-outline{background:transparent;color:var(--ds-primary);border:2px solid var(--ds-primary)}.ds-btn-outline:hover{background:var(--ds-primary-light)}.ds-btn-ghost{background:transparent;color:var(--ds-text-muted);border:2px solid var(--ds-border)}.ds-btn-ghost:hover{background:#0000000a}.ds-btn-block{width:100%}.ds-btn-lg{padding:14px 28px;font-size:.95rem}.ds-btn-sm{padding:8px 16px;font-size:.78rem;border-radius:var(--ds-radius-sm)}.ds-chip-group{display:flex;gap:8px;flex-wrap:wrap}.ds-chip{padding:8px 18px;border-radius:var(--ds-radius-full);border:2px solid var(--ds-border-strong);background:transparent;font-family:var(--ds-font);font-size:.85rem;font-weight:600;color:var(--ds-text-muted);cursor:pointer;transition:all .18s}.ds-chip:hover{border-color:var(--ds-primary);color:var(--ds-primary)}.ds-chip.active{background:var(--ds-primary);border-color:var(--ds-primary);color:#fff;box-shadow:0 2px 6px #8b1e1e4d}.ds-section-label{font-size:.75rem;font-weight:700;letter-spacing:2px;color:var(--ds-text-light);margin-bottom:10px;display:flex;align-items:center;gap:8px}.ds-section-label:before,.ds-section-label:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--ds-border),transparent)}.ds-input{width:100%;padding:12px 14px;border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-md);font-family:var(--ds-font);font-size:.9rem;color:var(--ds-text);background:var(--ds-card);transition:border-color .18s,box-shadow .18s;outline:none}.ds-input::placeholder{color:var(--ds-text-light)}.ds-input:focus{border-color:var(--ds-primary);box-shadow:0 0 0 3px #8b1e1e14}.ds-input:error,.ds-input.error{border-color:var(--ds-red-dot)}.ds-toggle{position:relative;display:inline-block;width:50px;height:28px;flex-shrink:0}.ds-toggle input{opacity:0;width:0;height:0}.ds-toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#ccc;border-radius:28px;transition:background .25s;cursor:pointer}.ds-toggle-slider:before{content:"";position:absolute;width:22px;height:22px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .25s;box-shadow:0 1px 4px #0003}.ds-toggle input:checked+.ds-toggle-slider{background:var(--ds-primary)}.ds-toggle input:checked+.ds-toggle-slider:before{transform:translate(22px)}.ds-divider{display:flex;align-items:center;gap:10px;font-size:.78rem;color:var(--ds-text-light)}.ds-divider:before,.ds-divider:after{content:"";flex:1;height:1px;background:var(--ds-border)}.ds-bottom-nav{display:flex;align-items:stretch;height:56px;background:var(--ds-header-bg);border-top:2px solid rgba(255,255,255,.08);flex-shrink:0}.ds-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border:none;background:none;color:#f0c06080;font-family:var(--ds-font);font-size:.62rem;font-weight:600;cursor:pointer;transition:color .18s,background .18s;padding:7px 4px 5px;border-radius:0}.ds-nav-item:hover{color:#f0c060cc}.ds-nav-item.active{color:var(--ds-gold-light)}.ds-nav-item svg{width:22px;height:22px;display:block;margin:0 auto}.ds-dot{display:inline-block;width:9px;height:9px;border-radius:50%;flex-shrink:0}.ds-dot-red{background:var(--ds-red-dot);box-shadow:0 0 0 2px #c0392b33}.ds-dot-black{background:var(--ds-text)}.ds-dot-green{background:var(--ds-green);box-shadow:0 0 0 2px #27ae6033}.ds-avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--ds-font-serif);overflow:hidden;flex-shrink:0}.ds-avatar img{width:100%;height:100%;object-fit:cover}.ds-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--ds-radius-full);font-size:.75rem;font-weight:700;letter-spacing:.3px}.ds-badge-gold{background:#c8960a1f;color:var(--ds-gold);border:1px solid rgba(200,150,10,.25)}.ds-badge-red{background:#8b1e1e1a;color:var(--ds-primary);border:1px solid rgba(139,30,30,.2)}.ds-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%) translateY(20px);background:var(--ds-header-bg);color:var(--ds-gold-light);padding:12px 22px;border-radius:var(--ds-radius-full);font-size:.85rem;font-weight:600;white-space:nowrap;z-index:200;box-shadow:var(--ds-shadow-lg);opacity:0;transition:opacity .3s,transform .3s;pointer-events:none}.ds-toast.visible{opacity:1;transform:translate(-50%) translateY(0)}.gi{display:inline-block;vertical-align:middle;flex-shrink:0;line-height:1}.gi-rank-glow{filter:drop-shadow(0 0 3px var(--gi-glow-color, rgba(255,215,0,.4)));animation:giRankPulse 3s ease-in-out infinite}@keyframes giRankPulse{0%,to{filter:drop-shadow(0 0 3px var(--gi-glow-color, rgba(255,215,0,.3)))}50%{filter:drop-shadow(0 0 8px var(--gi-glow-color, rgba(255,215,0,.6)))}}.dev-banner-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;display:flex;align-items:center;justify-content:center;background:#0a0604d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:dbFadeIn .4s ease;padding:20px}@keyframes dbFadeIn{0%{opacity:0}to{opacity:1}}.dev-banner-card{background:linear-gradient(160deg,#2a1408,#1a0c04);border:1.5px solid rgba(240,192,96,.35);border-radius:20px;padding:36px 28px 28px;max-width:340px;width:100%;text-align:center;box-shadow:0 16px 60px #000000b3,0 0 0 1px #f0c0601a;animation:dbSlideUp .4s cubic-bezier(.34,1.56,.64,1)}@keyframes dbSlideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dev-banner-logo{display:flex;justify-content:center;margin-bottom:16px}.dev-banner-logo-circle{width:64px;height:64px;border-radius:50%;background:linear-gradient(145deg,#c8960a,#8b1e1e);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #c8960a66}.dev-banner-logo-char{font-family:var(--ds-font-serif);font-size:2rem;color:#fff;line-height:1}.dev-banner-title{font-family:var(--ds-font-serif);font-size:1.1rem;font-weight:700;color:#f0c060;letter-spacing:3px;margin:0 0 12px}.dev-banner-badge{display:inline-block;background:#c8960a26;border:1px solid rgba(200,150,10,.35);color:#e0a820;font-size:.72rem;font-weight:700;letter-spacing:1.5px;padding:4px 14px;border-radius:999px;margin-bottom:16px}.dev-banner-desc{font-size:.84rem;color:#f0e0c8cc;line-height:1.6;margin:0 0 10px}.dev-banner-sub{font-size:.78rem;color:#f0c06099;margin:0 0 24px}.dev-banner-btn{width:100%;padding:13px;font-size:.88rem;letter-spacing:.5px;margin-bottom:10px}.dev-banner-auto{font-size:.72rem;color:#f0c06059;margin:0}[data-theme=dark] .ds-page-bg{background:radial-gradient(ellipse at 15% 5%,rgba(200,100,20,.08) 0%,transparent 55%),radial-gradient(ellipse at 85% 90%,rgba(120,60,10,.08) 0%,transparent 55%),linear-gradient(170deg,#1a1008,#120c06,#0e0804)}[data-theme=dark] .ds-card,[data-theme=dark] .ds-card-secondary{color:var(--ds-text)}[data-theme=dark] .ds-input{background:var(--ds-card);color:var(--ds-text);border-color:var(--ds-card-border)}[data-theme=dark] .ds-bottom-nav{background:var(--ds-header-bg);border-top-color:#ffffff0a}.stp-dark-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border:1.5px solid var(--ds-card-border);border-radius:var(--ds-radius-md);margin-bottom:12px;background:var(--ds-card-secondary);gap:12px}.stp-dark-toggle-label{display:flex;align-items:center;gap:8px;font-size:.87rem;font-weight:600;color:var(--ds-text)}.go-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#0a0500cc;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);opacity:0;transition:opacity .35s ease;padding:20px}.go-overlay.go-visible{opacity:1}.go-card{background:#1c1408;border:1.5px solid rgba(240,192,96,.22);border-radius:20px;padding:36px 28px 28px;max-width:320px;width:100%;display:flex;flex-direction:column;align-items:center;gap:10px;box-shadow:0 20px 60px #000000a6;animation:goSlideUp .38s cubic-bezier(.34,1.4,.64,1);color:#f0e0c8}@keyframes goSlideUp{0%{transform:translateY(28px) scale(.94);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.go-icon{font-size:3.2rem;line-height:1;margin-bottom:2px;filter:drop-shadow(0 4px 16px rgba(240,192,96,.4))}.go-icon--win{filter:drop-shadow(0 4px 16px rgba(240,192,96,.6))}.go-icon--lose{filter:drop-shadow(0 4px 16px rgba(200,60,40,.3));opacity:.8}.go-icon--draw{filter:none;opacity:.9}.go-title{font-family:var(--ds-font);font-size:1.1rem;font-weight:800;color:#f0c060;text-align:center;margin:0;letter-spacing:.5px}.go-reason{font-size:.75rem;color:#f0c0608c;text-align:center;margin:0;line-height:1.5}.go-reason-label{font-weight:600}.go-elo-row{display:flex;align-items:center;gap:4px;padding:5px 16px;border-radius:999px;font-size:.85rem;font-weight:700}.go-elo--pos{color:#4caf50;background:#4caf501f;border:1px solid rgba(76,175,80,.25)}.go-elo--neg{color:#ef5350;background:#ef53501f;border:1px solid rgba(239,83,80,.25)}.go-elo-label{font-size:.72rem;opacity:.75}.go-elo-delta{font-weight:800}.go-elo-total{font-size:.75rem;opacity:.7}.go-actions{display:flex;gap:10px;width:100%;margin-top:6px}.go-btn-rematch{flex:1}.go-btn-home{flex:1;color:#f0c060d9;border-color:#f0c0604d}.go-btn-home:hover{background:#f0c06014}.stp-page{font-family:var(--ds-font)}.stp-scroll{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:18px 10px 0}.stp-card{width:100%;max-width:100%;padding:22px 16px;container-type:inline-size}.stp-section-label{font-size:clamp(.68rem,3cqi,.95rem);font-weight:700;letter-spacing:1.5px;color:var(--ds-text-light);text-transform:uppercase;margin-bottom:12px}.stp-theme-row{display:flex;gap:10px;margin-bottom:16px}.stp-theme-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;border:2.5px solid var(--ds-card-border);border-radius:var(--ds-radius-md);background:var(--ds-card-secondary);cursor:pointer;padding:clamp(6px,2cqi,12px);transition:border-color .18s,box-shadow .18s,transform .12s;font-family:var(--ds-font);font-size:clamp(.72rem,3cqi,1rem);font-weight:600;color:var(--ds-text-muted)}.stp-theme-btn:hover{border-color:var(--ds-border-strong);transform:translateY(-1px)}.stp-theme-btn.active{border-color:var(--ds-primary);box-shadow:0 0 0 3px #8b1e1e1f;color:var(--ds-primary)}.stp-theme-preview{width:100%;height:clamp(40px,14cqi,72px);border-radius:6px;overflow:hidden;background:var(--ds-bg-pattern)}.stp-dark-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:clamp(10px,3.5cqi,18px) 16px;border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-md);margin-bottom:12px;background:var(--ds-card-secondary)}.stp-dark-toggle-label{display:flex;align-items:center;gap:10px;font-size:clamp(.82rem,3.5cqi,1.15rem);font-weight:600;color:var(--ds-text)}.stp-sound-row{display:flex;align-items:center;justify-content:space-between;padding:clamp(10px,3.5cqi,18px) 16px;border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-md);margin-bottom:18px;background:var(--ds-card-secondary)}.stp-sound-label{display:flex;align-items:center;gap:10px;font-size:clamp(.82rem,3.5cqi,1.15rem);font-weight:600;color:var(--ds-text)}.stp-sound-icon{font-size:clamp(.95rem,4cqi,1.4rem)}.stp-btn-row{display:flex;gap:10px;margin-top:6px}.stp-save-btn,.stp-back-btn{flex:1;font-size:clamp(.78rem,3.5cqi,1.1rem);padding:clamp(10px,3cqi,16px)}.stp-status{margin-top:12px;text-align:center;font-size:.85rem;font-weight:600;color:var(--ds-green);animation:stp-fade-in .3s ease}@keyframes stp-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.hp-page{font-family:var(--ds-font)}.hp-header{display:flex;align-items:center;justify-content:space-between;height:54px;padding:0 14px;gap:8px;background:var(--ds-header-bg);border-bottom:2px solid var(--ds-header-border);flex-shrink:0}.hp-logo{display:flex;align-items:center;gap:8px;flex-shrink:0}.hp-logo-circle{width:36px;height:36px;border-radius:50%;background:var(--ds-primary);display:flex;align-items:center;justify-content:center;border:2.5px solid rgba(240,192,96,.5)}.hp-logo-char{font-family:var(--ds-font-serif);font-size:1.2rem;color:#fff;line-height:1}.hp-logo-text{display:flex;flex-direction:column;line-height:1.1}.hp-logo-title{font-family:var(--ds-font-serif);font-size:.78rem;font-weight:700;color:var(--ds-gold-light);letter-spacing:1.5px}.hp-logo-sub{font-size:.6rem;font-weight:600;color:#f0c0608c;letter-spacing:2px}.hp-header-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.hp-user-btn{display:flex;align-items:center;gap:7px;border:none;background:#ffffff12;border-radius:24px;padding:4px 10px 4px 4px;cursor:pointer;transition:background .18s;margin-left:4px}.hp-user-btn:hover{background:#ffffff21}.hp-user-avatar{width:30px;height:30px;border-radius:50%;background:var(--ds-primary);overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hp-user-avatar img{width:100%;height:100%;object-fit:cover}.hp-user-avatar span{font-size:.78rem;font-weight:700;color:#fff}.hp-user-info{display:flex;flex-direction:column;line-height:1.2;text-align:left}.hp-user-name{font-size:.78rem;font-weight:700;color:var(--ds-gold-light);white-space:nowrap}.hp-user-elo{font-size:.62rem;color:#f0c0608c;white-space:nowrap}.hp-scroll{padding:10px;display:flex;flex-direction:column;gap:10px;justify-content:center}.hp-card{display:flex;align-items:center;gap:12px;background:var(--ds-card);border-radius:var(--ds-radius-lg);border:2px solid var(--ds-card-border);box-shadow:var(--ds-shadow-card);padding:16px 14px 16px 0;cursor:pointer;transition:box-shadow .2s,transform .15s;overflow:hidden;position:relative;flex:1;container-type:size}.hp-card:hover{box-shadow:var(--ds-shadow-md);transform:translateY(-1px)}.hp-card:active{transform:translateY(0)}.hp-card-stripe{width:7px;align-self:stretch;border-radius:0 4px 4px 0;flex-shrink:0}.hp-stripe--online{background:var(--ds-primary)}.hp-stripe--ai{background:#27ae60}.hp-stripe--puzzle{background:#c8960a}.hp-stripe--tournament{background:#8e44ad}.hp-card-icon{width:clamp(48px,45cqh,90px);height:clamp(48px,45cqh,90px);border-radius:clamp(10px,8cqh,18px);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.hp-icon--online{background:#8b1e1e14}.hp-icon--ai{background:#27ae6017}.hp-icon--puzzle{background:#c8960a17}.hp-icon--tournament{background:#8e44ad17}.hp-card-icon svg{width:clamp(36px,32cqh,68px);height:clamp(36px,32cqh,68px)}.hp-piece-big{font-family:var(--ds-font-serif);font-size:clamp(1.6rem,22cqh,3.5rem);color:var(--ds-primary);line-height:1}.hp-piece-small{position:absolute;bottom:5px;right:5px;font-family:var(--ds-font-serif);font-size:clamp(.6rem,6cqh,1.1rem);color:#8b1e1e80}.hp-card-body{flex:1;min-width:0}.hp-card-title{font-size:clamp(.85rem,9cqh,1.5rem);font-weight:800;color:var(--ds-text);margin:0 0 clamp(2px,2cqh,6px);letter-spacing:.5px}.hp-card-desc{font-size:clamp(.7rem,7cqh,1.15rem);color:var(--ds-text-muted);margin:0 0 clamp(3px,3cqh,8px);line-height:1.45}.hp-card-stat{font-size:clamp(.65rem,6cqh,1.05rem);color:var(--ds-text-light);margin:0;display:flex;align-items:center;gap:6px}.hp-stat-dot{width:clamp(5px,4cqh,10px);height:clamp(5px,4cqh,10px);border-radius:50%;background:var(--ds-green);animation:hp-pulse 2s ease infinite}@keyframes hp-pulse{0%,to{opacity:1}50%{opacity:.5}}.hp-card-btn{flex-shrink:0;font-size:clamp(.72rem,7cqh,1.1rem);padding:clamp(7px,6cqh,16px) clamp(12px,10cqh,24px);border-radius:var(--ds-radius-md)}.hp-btn--ai{background:#27ae60;box-shadow:0 2px 8px #27ae604d}.hp-btn--ai:hover{background:#1e9651}.hp-btn--puzzle{background:var(--ds-gold);box-shadow:0 2px 8px #c8960a4d}.hp-btn--puzzle:hover{background:#a87a08}.hp-btn--tournament{background:#8e44ad;box-shadow:0 2px 8px #8e44ad4d}.hp-btn--tournament:hover{background:#7d3c98}.hp-bottom-nav,.hp-nav-center{position:relative}.hp-nav-center-wrap{width:44px;height:44px;border-radius:50%;background:var(--ds-primary);display:flex;align-items:center;justify-content:center;margin-bottom:-6px;box-shadow:0 3px 12px #8b1e1e80}.hp-nav-center-wrap svg{color:#fff}.hp-desktop-layout{display:none}@media(min-width:1024px){.hp-page.ds-page{max-width:1360px;border-radius:0}.hp-page .hp-scroll,.hp-page .ds-bottom-nav{display:none}.hp-desktop-layout{display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0}.hp-dt-wrapper{display:grid;grid-template-columns:160px 1fr;flex:1;overflow:hidden;min-height:0}.hp-sidebar{background:var(--ds-card);border-right:2px solid var(--ds-card-border);display:flex;flex-direction:column;padding:12px 0;overflow-y:auto;scrollbar-width:thin}.hp-sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:0 8px}.hp-sidebar-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border:none;background:transparent;border-radius:var(--ds-radius-md);font-family:var(--ds-font);font-size:.82rem;font-weight:600;color:var(--ds-text-muted);cursor:pointer;transition:all .18s;text-align:left;white-space:nowrap;position:relative}.hp-sidebar-item:hover{background:var(--ds-primary-light);color:var(--ds-text)}.hp-sidebar-item.active{background:var(--ds-primary-light);color:var(--ds-primary);font-weight:700}.hp-sidebar-item.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:0 3px 3px 0;background:var(--ds-primary)}.hp-sidebar-item svg{width:18px;height:18px;flex-shrink:0}.hp-sidebar-badge{font-size:.58rem;font-weight:700;background:var(--ds-green);color:#fff;padding:1px 6px;border-radius:8px;margin-left:auto;letter-spacing:.3px}.hp-sidebar-divider{height:1px;background:var(--ds-border);margin:10px 14px;opacity:.5}.hp-sidebar-settings{margin-top:auto;padding:10px 8px 6px}.hp-sidebar-settings-label{font-size:.65rem;font-weight:700;letter-spacing:1.5px;color:var(--ds-text-light);padding:0 14px 6px;text-transform:uppercase}.hp-sidebar-toggle-row{display:flex;align-items:center;justify-content:center;gap:8px;padding:6px 14px}.hp-sidebar-toggle-row svg{width:16px;height:16px;color:var(--ds-text-muted)}.hp-sidebar-themes{display:flex;flex-direction:column;gap:4px;padding:4px 8px}.hp-theme-btn{display:flex;align-items:center;gap:8px;padding:8px 10px;border:2px solid transparent;border-radius:var(--ds-radius-md);background:transparent;font-family:var(--ds-font);font-size:.75rem;font-weight:600;color:var(--ds-text-muted);cursor:pointer;transition:all .18s}.hp-theme-btn:hover{background:#0000000a;border-color:var(--ds-border)}.hp-theme-btn.active{background:var(--ds-primary-light);border-color:var(--ds-primary);color:var(--ds-primary);font-weight:700}.hp-theme-icon{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}.hp-theme-icon--wood{background:linear-gradient(145deg,#c8a060,#8a6820)}.hp-theme-icon--classic{background:linear-gradient(145deg,#d4b896,#a08060)}.hp-theme-icon--dark{background:linear-gradient(145deg,#2a1a0e,#1a1008)}.hp-dt-main{display:grid;grid-template-columns:1.2fr 1fr .9fr;gap:14px;padding:14px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;-webkit-overflow-scrolling:touch}.hp-dt-main::-webkit-scrollbar{width:4px}.hp-dt-main::-webkit-scrollbar-thumb{background:#a0642833;border-radius:2px}.hp-dt-col{display:flex;flex-direction:column;gap:12px;min-width:0}.hp-dt-col-header{text-align:center;padding:0 0 8px;border-bottom:2px solid var(--ds-border);margin-bottom:4px}.hp-dt-col-title{font-family:var(--ds-font-serif);font-size:.95rem;font-weight:700;color:var(--ds-text);letter-spacing:1px;margin:0}.hp-dt-col-subtitle{font-size:.65rem;color:var(--ds-text-light);font-style:italic;margin:2px 0 0}.hp-dt-online-hero{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);padding:18px;text-align:center;box-shadow:var(--ds-shadow-card)}.hp-dt-online-calligraphy{font-family:var(--ds-font-serif);font-size:2.2rem;font-weight:700;color:var(--ds-primary);line-height:1.1;margin-bottom:4px;letter-spacing:2px;text-shadow:1px 1px 0 rgba(139,30,30,.1)}.hp-dt-online-pieces{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:10px}.hp-dt-online-pieces span{font-family:var(--ds-font-serif);font-size:1.6rem;color:var(--ds-primary);opacity:.7}.hp-dt-online-stat{font-size:1rem;font-weight:700;color:var(--ds-text);margin:0 0 2px;display:flex;align-items:center;justify-content:center;gap:6px}.hp-dt-online-stat .hp-stat-dot{width:8px;height:8px}.hp-dt-online-games{font-size:.78rem;color:var(--ds-text-muted);margin:0}.hp-dt-leaderboard{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);padding:14px;box-shadow:var(--ds-shadow-card)}.hp-dt-leaderboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.hp-dt-leaderboard-title{font-family:var(--ds-font-serif);font-size:.85rem;font-weight:700;color:var(--ds-text);letter-spacing:.5px}.hp-dt-leaderboard-more{background:none;border:none;color:var(--ds-text-light);cursor:pointer;padding:4px;font-size:1rem}.hp-dt-lb-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid rgba(196,168,120,.2)}.hp-dt-lb-row:last-child{border-bottom:none}.hp-dt-lb-rank{width:22px;font-size:.82rem;font-weight:700;color:var(--ds-text-muted);text-align:center}.hp-dt-lb-avatar{width:26px;height:26px;border-radius:50%;background:var(--ds-primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}.hp-dt-lb-avatar svg{width:14px;height:14px;color:var(--ds-text-muted)}.hp-dt-lb-name{flex:1;font-size:.8rem;font-weight:600;color:var(--ds-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hp-dt-lb-elo{font-size:.78rem;font-weight:700;color:var(--ds-gold);font-family:var(--ds-font-mono)}.hp-dt-action-row{display:flex;gap:10px}.hp-dt-action-row .ds-btn{flex:1;font-size:.85rem;padding:12px 14px}.hp-dt-spectate{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);padding:14px;box-shadow:var(--ds-shadow-card)}.hp-dt-spectate-title{font-size:.78rem;font-weight:700;color:var(--ds-text-muted);margin:0 0 10px;letter-spacing:.5px}.hp-dt-spectate-row{display:flex;align-items:center;gap:6px;padding:7px 0;border-bottom:1px solid rgba(196,168,120,.15);font-size:.75rem}.hp-dt-spectate-row:last-child{border-bottom:none}.hp-dt-spectate-player{display:flex;align-items:center;gap:4px;font-weight:600;color:var(--ds-text);flex:1;min-width:0}.hp-dt-spectate-player .ds-dot{width:6px;height:6px}.hp-dt-spectate-vs{font-size:.7rem;font-weight:700;color:var(--ds-text-light);padding:0 4px}.hp-dt-spectate-elo{font-size:.72rem;color:var(--ds-text-muted)}.hp-dt-spectate-view{font-size:.7rem;padding:3px 10px;border-radius:var(--ds-radius-sm);background:transparent;border:1.5px solid var(--ds-primary);color:var(--ds-primary);font-weight:600;cursor:pointer;transition:all .15s;flex-shrink:0}.hp-dt-spectate-view:hover{background:var(--ds-primary);color:#fff}.hp-dt-ai-card{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);padding:16px;box-shadow:var(--ds-shadow-card)}.hp-dt-ai-subtitle{text-align:center;font-size:.78rem;font-weight:600;color:var(--ds-text-muted);margin:0 0 12px;letter-spacing:.3px}.hp-dt-ai-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.hp-dt-ai-avatar{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:transform .15s;padding:6px;border-radius:var(--ds-radius-md)}.hp-dt-ai-avatar:hover{transform:scale(1.04)}.hp-dt-ai-circle{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid transparent;transition:border-color .18s,box-shadow .18s}.hp-dt-ai-avatar.selected .hp-dt-ai-circle{box-shadow:0 0 0 3px #8b1e1e33}.hp-dt-ai-char{font-family:var(--ds-font-serif);font-size:1.6rem;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.3)}.hp-dt-ai-name{font-size:.72rem;font-weight:600;color:var(--ds-text-muted);text-align:center}.hp-dt-ai-viewall{text-align:center;margin-bottom:10px}.hp-dt-ai-viewall a{font-size:.78rem;font-weight:600;color:var(--ds-blue);text-decoration:none;cursor:pointer}.hp-dt-ai-viewall a:hover{text-decoration:underline}.hp-dt-diff-label{text-align:center;font-size:.72rem;color:var(--ds-text-light);margin:0 0 8px;display:flex;align-items:center;gap:6px;justify-content:center}.hp-dt-diff-label:before,.hp-dt-diff-label:after{content:"";width:20px;height:1px;background:var(--ds-border)}.hp-dt-diff-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:12px}.hp-dt-diff-pill{padding:6px 8px;border-radius:var(--ds-radius-full);border:1.5px solid var(--ds-border);background:transparent;font-family:var(--ds-font);font-size:.72rem;font-weight:600;color:var(--ds-text-muted);cursor:pointer;transition:all .15s;text-align:center}.hp-dt-diff-pill:hover{border-color:var(--ds-primary);color:var(--ds-primary)}.hp-dt-diff-pill.active{background:var(--ds-primary);border-color:var(--ds-primary);color:#fff}.hp-dt-side-label{text-align:center;font-size:.72rem;color:var(--ds-text-light);margin:0 0 8px;display:flex;align-items:center;gap:6px;justify-content:center}.hp-dt-side-label:before,.hp-dt-side-label:after{content:"";width:20px;height:1px;background:var(--ds-border)}.hp-dt-side-row{display:flex;gap:6px;justify-content:center;margin-bottom:12px}.hp-dt-side-opt{display:flex;align-items:center;gap:4px;padding:5px 12px;border-radius:var(--ds-radius-full);border:1.5px solid var(--ds-border);background:transparent;font-size:.72rem;font-weight:600;color:var(--ds-text-muted);cursor:pointer;transition:all .15s}.hp-dt-side-opt:hover{border-color:var(--ds-primary)}.hp-dt-side-opt.active{background:var(--ds-primary);border-color:var(--ds-primary);color:#fff}.hp-dt-side-opt input{display:none}.hp-dt-side-radio{width:10px;height:10px;border-radius:50%;border:2px solid currentColor;position:relative}.hp-dt-side-opt.active .hp-dt-side-radio:after{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:50%;background:currentColor}.hp-dt-ai-start{width:100%;font-size:.88rem;padding:10px;background:#27ae60;border:none;color:#fff;font-weight:700;border-radius:var(--ds-radius-md);cursor:pointer;transition:background .15s;letter-spacing:1px}.hp-dt-ai-start:hover{background:#1e9651}.hp-dt-puzzle-card{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);padding:16px;text-align:center;box-shadow:var(--ds-shadow-card)}.hp-dt-puzzle-icon{font-family:var(--ds-font-serif);font-size:2rem;color:var(--ds-gold);margin-bottom:4px;display:flex;align-items:center;justify-content:center;gap:8px}.hp-dt-puzzle-icon-label{font-size:.75rem;font-weight:700;color:var(--ds-text-muted);letter-spacing:.3px}.hp-dt-puzzle-title{font-family:var(--ds-font-serif);font-size:1.5rem;font-weight:700;color:var(--ds-text);margin:6px 0 2px;letter-spacing:1px}.hp-dt-puzzle-subtitle{font-size:.85rem;font-weight:600;color:var(--ds-text-muted);margin:0 0 8px}.hp-dt-puzzle-today{font-size:.78rem;color:var(--ds-text-light);margin:0 0 10px}.hp-dt-puzzle-btn{font-size:.82rem;padding:8px 20px;background:var(--ds-gold);border:none;color:#fff;font-weight:700;border-radius:var(--ds-radius-md);cursor:pointer;transition:background .15s;letter-spacing:.5px}.hp-dt-puzzle-btn:hover{background:#a87a08}.hp-dt-tournament-card{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);padding:16px;text-align:center;box-shadow:var(--ds-shadow-card)}.hp-dt-tournament-icon{font-size:1.8rem;margin-bottom:4px}.hp-dt-tournament-title{font-family:var(--ds-font-serif);font-size:1.05rem;font-weight:700;color:var(--ds-text);margin:0 0 4px;letter-spacing:.5px}.hp-dt-tournament-sub{font-size:.78rem;color:var(--ds-text-light);margin:0 0 2px;font-style:italic}.hp-dt-tournament-desc{font-size:.75rem;color:var(--ds-text-muted);margin:0 0 10px;font-weight:600}.hp-dt-tournament-btn{font-size:.78rem;padding:7px 18px;background:var(--ds-primary);border:none;color:#fff;font-weight:700;border-radius:var(--ds-radius-md);cursor:pointer;transition:background .15s;letter-spacing:.5px}.hp-dt-tournament-btn:hover{background:var(--ds-primary-hover)}.hp-dt-news-card{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);padding:14px;box-shadow:var(--ds-shadow-card)}.hp-dt-news-title{font-family:var(--ds-font-serif);font-size:.88rem;font-weight:700;color:var(--ds-text);margin:0 0 8px;letter-spacing:.3px}.hp-dt-news-list{list-style:disc;padding-left:16px;margin:0}.hp-dt-news-list li{font-size:.75rem;color:var(--ds-text-muted);line-height:1.6}.hp-dt-footer{text-align:center;padding:8px 14px;font-size:.68rem;color:var(--ds-text-light);border-top:1px solid var(--ds-border);background:var(--ds-card);flex-shrink:0}.hp-dt-decoration{position:absolute;top:52px;right:0;width:120px;height:80px;pointer-events:none;z-index:2;opacity:.15}.hp-dt-music-note{position:absolute;bottom:36px;left:8px;font-family:var(--ds-font-serif);font-size:1.2rem;color:var(--ds-text-light);opacity:.3;pointer-events:none}}.pop-section{margin:14px 10px 0}.pop-scroll{padding:0}.pop-chips{padding:14px 10px 0;gap:8px}.pop-stats-row{display:flex;align-items:center;gap:12px;padding:10px 14px;font-size:.85rem;flex-wrap:wrap}.pop-stat-item{display:flex;align-items:center;gap:6px;color:var(--ds-text-muted)}.pop-stat-item strong{color:var(--ds-text);font-weight:700}.pop-stat-sep{color:var(--ds-border-strong);font-size:.85rem}.pop-my-rank-card{display:flex;align-items:center;gap:14px;margin:10px 10px 0;padding:14px 16px;background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-sm)}.pop-my-rank-avatar{width:48px;height:48px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;color:#fff;background:linear-gradient(145deg,#8b1e1e,#c0392b);border:2.5px solid var(--ds-primary);box-shadow:0 3px 10px #0006;overflow:hidden}.pop-my-rank-info{display:flex;flex-direction:column;gap:3px}.pop-my-rank-name{font-weight:700;font-size:1rem}.pop-my-rank-badge{display:flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600}.pop-my-rank-elo{color:var(--ds-text-muted);font-size:.72rem}.pop-find-btn{margin:12px 10px 0;border-radius:var(--ds-radius-lg);font-size:.95rem;letter-spacing:1px;padding:14px}.pop-action-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 10px 0}.pop-action-card{display:flex;flex-direction:column;align-items:center;gap:5px;padding:16px 10px;background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);cursor:pointer;text-align:center;transition:box-shadow .18s,transform .15s;box-shadow:var(--ds-shadow-sm);container-type:inline-size}.pop-action-card:hover{box-shadow:var(--ds-shadow-md);transform:translateY(-1px)}.pop-action-icon{font-size:clamp(1.4rem,12cqi,2.4rem)}.pop-action-label{font-size:clamp(.75rem,6cqi,1.1rem);font-weight:700;color:var(--ds-text)}.pop-action-sub{font-size:clamp(.6rem,5cqi,.88rem);color:var(--ds-text-muted)}.pop-join-row{display:flex;gap:8px;margin:10px 10px 0;align-items:stretch}.pop-join-input{flex:1;text-transform:uppercase;letter-spacing:2px;font-weight:700}.pop-join-btn{flex-shrink:0;padding:12px 20px}.pop-rooms-list{display:flex;flex-direction:column;gap:8px}.pop-room-row{display:flex;align-items:center;gap:8px;background:var(--ds-card);border-radius:var(--ds-radius-md);border:2px solid var(--ds-card-border);padding:10px 12px;font-size:.82rem;container-type:inline-size}.pop-room-side{display:flex;align-items:center;gap:5px;flex:1}.pop-room-side--red .pop-room-player{color:var(--ds-primary);font-weight:600}.pop-room-side--black .pop-room-player{color:var(--ds-text);font-weight:600}.pop-room-vs{font-size:.7rem;font-weight:700;color:var(--ds-text-muted)}.pop-room-meta{font-size:.68rem;color:var(--ds-text-light);background:var(--ds-card-secondary);padding:3px 8px;border-radius:var(--ds-radius-full);border:1px solid var(--ds-border)}.pop-room-view{border-color:var(--ds-primary);color:var(--ds-primary);flex-shrink:0}.pop-empty-rooms{text-align:center;padding:24px;color:var(--ds-text-muted);font-size:.85rem}.pop-mm-search-page{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:24px;background:radial-gradient(ellipse at center,#1e140af2,#0a0500fa 70%)}.pop-mm-back-btn{position:absolute;top:16px;left:16px;width:40px;height:40px;border-radius:12px;border:1.5px solid rgba(255,255,255,.15);background:#0006;color:#ffffffb3;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:2}.pop-mm-back-btn:hover{background:#ffffff1a;color:#fff}.pop-mm-my-card{display:flex;flex-direction:column;align-items:center;gap:6px;animation:popMmMyAppear .5s ease-out}@keyframes popMmMyAppear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pop-mm-my-avatar{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.8rem;color:#fff;background:linear-gradient(145deg,#8b1e1e,#c0392b);border:3px solid var(--ds-primary);overflow:hidden;transition:all .3s}.pop-mm-my-name{font-weight:700;font-size:1.1rem;color:#fff}.pop-mm-my-rank{font-size:.85rem;font-weight:600}.pop-mm-my-elo{font-size:.72rem;color:#ffffff73}.pop-mm-radar-wrap{position:relative;width:140px;height:140px}.pop-mm-radar-lg{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.pop-mm-ring{position:absolute;border-radius:50%;border:2px solid rgba(240,192,96,.3)}.pop-mm-ring-lg{width:140px;height:140px;animation:pop-radar 2.4s ease-out infinite}.pop-mm-ring-md{width:90px;height:90px;animation:pop-radar 2.4s ease-out infinite .6s}.pop-mm-ring-sm{width:50px;height:50px;animation:pop-radar 2.4s ease-out infinite 1.2s}@keyframes pop-radar{0%{opacity:.8;transform:scale(.4)}to{opacity:0;transform:scale(1)}}.pop-mm-radar-icon{font-size:2rem;position:relative;z-index:2;animation:pop-spin 4s linear infinite}@keyframes pop-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pop-mm-search-info{display:flex;flex-direction:column;align-items:center;gap:4px}.pop-mm-search-title{font-size:1rem;font-weight:700;color:var(--ds-gold-light, #f0c060);animation:popMmPulse 2s ease-in-out infinite}@keyframes popMmPulse{0%,to{opacity:1}50%{opacity:.6}}.pop-mm-search-sub{font-size:.78rem;color:#f0c06080}.pop-mm-search-timer{font-family:var(--ds-font-mono, "Fira Mono", monospace);font-size:2rem;font-weight:700;color:var(--ds-gold-light, #f0c060);letter-spacing:4px}.pop-mm-search-tip{font-size:.75rem;color:#ffffff59;text-align:center;max-width:280px;line-height:1.5;padding:12px 16px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;animation:popTipFade .5s ease-out}@keyframes popTipFade{0%{opacity:0}to{opacity:1}}.pop-mm-cancel-main{border-radius:var(--ds-radius-full, 999px);padding:10px 32px;font-size:.85rem}.pop-mm-found-page{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:24px;background:radial-gradient(ellipse at center,#1e140af2,#0a0500fa 70%);animation:popFoundFlash .5s ease-out}@keyframes popFoundFlash{0%{opacity:0}30%{opacity:1;background:radial-gradient(ellipse at center,#ffc83c26,#0a0500f2)}to{opacity:1}}.pop-mm-found-title{font-size:1.3rem;font-weight:900;color:gold;text-shadow:0 0 20px rgba(255,215,0,.4);letter-spacing:2px;animation:popFoundBounce .6s cubic-bezier(.34,1.56,.64,1)}@keyframes popFoundBounce{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.pop-mm-vs-row{display:flex;align-items:center;gap:20px;width:100%;max-width:400px;justify-content:center}.pop-mm-vs-player{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;animation:popVsSlideIn .5s ease-out}.pop-mm-vs-player:first-child{animation-name:popVsSlideLeft}.pop-mm-vs-player:last-child{animation-name:popVsSlideRight}@keyframes popVsSlideLeft{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}@keyframes popVsSlideRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.pop-mm-vs-avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.5rem;color:#fff;background:linear-gradient(145deg,#8b1e1e,#c0392b);border:3px solid var(--ds-primary);overflow:hidden}.pop-mm-vs-name{font-weight:700;font-size:.95rem;color:#fff}.pop-mm-vs-rank{font-size:.75rem;font-weight:600}.pop-mm-vs-elo{font-size:.68rem;color:#fff6}.pop-mm-vs-icon{display:flex;align-items:center;justify-content:center;width:50px;height:50px;border-radius:50%;background:#ffd7001f;border:2px solid rgba(255,215,0,.3);box-shadow:0 0 20px #ffd70026;flex-shrink:0}.pop-mm-vs-icon span{font-size:1rem;font-weight:900;color:gold;letter-spacing:1px}.pop-mm-countdown-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}.pop-mm-countdown-num{font-size:3.5rem;font-weight:900;color:gold;text-shadow:0 0 30px rgba(255,215,0,.5);animation:popCountBounce 1s cubic-bezier(.34,1.56,.64,1);font-family:var(--ds-font-mono, "Fira Mono", monospace)}@keyframes popCountBounce{0%{transform:scale(2);opacity:0}50%{transform:scale(.9)}to{transform:scale(1);opacity:1}}.pop-mm-countdown-label{font-size:.78rem;color:#ffd70080;font-weight:500}.ph-scroll{display:flex;align-items:center;justify-content:center;padding:24px}.ph-card{padding:40px 32px;text-align:center;max-width:340px;width:100%}.ph-title{font-family:var(--ds-font-serif);font-size:1.2rem;font-weight:700;color:var(--ds-primary);letter-spacing:1px;margin-bottom:5px}.ph-subtitle{font-size:1rem;font-weight:700;color:var(--ds-text);margin-bottom:14px}.ph-desc{font-size:.85rem;color:var(--ds-text-muted);line-height:1.6;margin-bottom:22px}.ph-loading{display:flex;align-items:center;justify-content:center;gap:7px;color:var(--ds-gold);font-size:.9rem;font-weight:600}.ph-chess-icon{font-size:1.2rem}.ph-dots span{animation:ph-dot 1.4s ease-in-out infinite}.ph-dots span:nth-child(2){animation-delay:.2s}.ph-dots span:nth-child(3){animation-delay:.4s}@keyframes ph-dot{0%,80%,to{opacity:0}40%{opacity:1}}.pcp-page{font-family:var(--ds-font)}.pcp-scroll{padding:0}.pcp-section-label{margin:14px 10px 8px}.pcp-hero-card{display:flex;align-items:center;gap:14px;margin:12px 10px 0;padding:14px 16px;background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-card);container-type:inline-size}.pcp-hero-av-wrap{flex-shrink:0}.pcp-hero-circle{width:clamp(50px,18cqi,80px);height:clamp(50px,18cqi,80px);border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid rgba(255,255,255,.3);box-shadow:0 3px 12px #00000038}.pcp-hero-char{font-family:var(--ds-font-serif);font-size:clamp(1.4rem,8cqi,2.8rem);color:#fff;line-height:1;text-shadow:0 1px 4px rgba(0,0,0,.35)}.pcp-hero-info{flex:1;min-width:0}.pcp-hero-level{font-size:clamp(.85rem,4.5cqi,1.3rem);font-weight:800;color:var(--ds-text);margin-bottom:4px}.pcp-hero-desc{font-size:clamp(.72rem,3.5cqi,1rem);color:var(--ds-text-muted);line-height:1.5;margin:0}.pcp-av-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:0 10px;container-type:inline-size}.pcp-av-btn{display:flex;flex-direction:column;align-items:center;gap:5px;border:none;background:none;cursor:pointer;padding:4px;border-radius:var(--ds-radius-md);transition:transform .15s}.pcp-av-btn:hover{transform:translateY(-2px)}.pcp-av-circle{width:clamp(42px,20cqi,72px);height:clamp(42px,20cqi,72px);border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid transparent;box-shadow:0 2px 10px #0003;transition:border-color .18s,box-shadow .18s}.pcp-av-btn.selected .pcp-av-circle{box-shadow:0 3px 16px #0000004d}.pcp-av-char{font-family:var(--ds-font-serif);font-size:clamp(1rem,8cqi,2rem);color:#fff;line-height:1;text-shadow:0 1px 3px rgba(0,0,0,.3)}.pcp-av-name{font-size:clamp(.55rem,3cqi,.8rem);font-weight:600;color:var(--ds-text-muted);text-align:center;white-space:nowrap}.pcp-side-row{display:flex;gap:8px;padding:0 10px;container-type:inline-size}.pcp-side-opt{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:clamp(8px,3cqi,14px) 8px;background:var(--ds-card);border:2px solid var(--ds-border);border-radius:var(--ds-radius-md);cursor:pointer;font-size:clamp(.7rem,3.5cqi,1rem);font-weight:600;color:var(--ds-text-muted);transition:all .18s}.pcp-side-opt input{display:none}.pcp-side-opt.active{border-color:var(--ds-primary);background:var(--ds-primary-light);color:var(--ds-primary)}.pcp-side-piece{font-size:clamp(1rem,5cqi,1.6rem)}.pcp-piece--red{color:var(--ds-primary)}.pcp-piece--black{color:var(--ds-text)}.pcp-piece--rand{color:var(--ds-gold)}.pcp-bottom-bar{flex-shrink:0;display:flex;gap:10px;padding:12px 10px;background:var(--ds-bg);border-top:2px solid var(--ds-border);transition:background var(--ds-transition)}.pcp-btn-start{flex:2;border-radius:var(--ds-radius-full);letter-spacing:1px;font-size:.92rem;padding:13px}.pcp-btn-custom{flex:1;border-radius:var(--ds-radius-full);font-size:.82rem}.pcp-settings-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;background:#00000080;display:flex;align-items:flex-end;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.pcp-settings-sheet{width:100%;background:var(--ds-card);border-radius:20px 20px 0 0;padding:10px 0 0;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);max-height:70vh;overflow-y:auto}.pcp-settings-sheet.open{transform:translateY(0)}.pcp-sheet-handle{width:36px;height:5px;border-radius:3px;background:var(--ds-border);margin:0 auto 12px}.pcp-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:0 16px 10px;font-size:.95rem;font-weight:700;color:var(--ds-text);border-bottom:2px solid var(--ds-border)}.pcp-sheet-close{border:none;background:var(--ds-card-secondary);width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:.9rem;color:var(--ds-text-muted);display:flex;align-items:center;justify-content:center;transition:background .18s}.pcp-sheet-close:hover{background:var(--ds-border)}.pcp-levels-grid{display:flex;flex-direction:column;gap:6px;padding:0 14px;container-type:inline-size}.pcp-level-pill{display:flex;align-items:center;gap:10px;padding:clamp(8px,3cqi,16px) 14px;border-radius:var(--ds-radius-md);border:2px solid var(--ds-border);background:var(--ds-card-secondary);cursor:pointer;font-family:var(--ds-font);font-size:clamp(.78rem,3.5cqi,1.1rem);font-weight:600;color:var(--ds-text);text-align:left;transition:all .18s}.pcp-level-pill:hover{border-color:var(--ds-border-strong)}.pcp-level-pill.active{border-color:var(--ds-primary);background:var(--ds-primary-light);color:var(--ds-primary)}.pcp-level-elo{margin-left:auto;font-size:clamp(.65rem,3cqi,.95rem);color:var(--ds-text-muted)}.pcp-time-grid{display:flex;flex-wrap:wrap;gap:8px;padding:0 14px;container-type:inline-size}.pcp-time-pill{display:flex;align-items:center;gap:6px;padding:clamp(7px,2.5cqi,12px) clamp(12px,5cqi,22px);border-radius:var(--ds-radius-full);border:2px solid var(--ds-border);background:transparent;cursor:pointer;font-family:var(--ds-font);font-size:clamp(.72rem,3cqi,1.05rem);font-weight:600;color:var(--ds-text-muted);transition:all .18s}.pcp-time-pill:hover{border-color:var(--ds-border-strong);color:var(--ds-text)}.pcp-time-pill.active{border-color:var(--ds-primary);background:var(--ds-primary);color:#fff;box-shadow:0 2px 8px #8b1e1e4d}.pcp-mode-tabs{display:flex;gap:8px;padding:10px 10px 6px;flex-shrink:0;container-type:inline-size}.pcp-mode-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:clamp(8px,3cqi,14px) 12px;border:2px solid var(--ds-border);border-radius:var(--ds-radius-lg);background:transparent;font-family:var(--ds-font);font-size:clamp(.78rem,3.5cqi,1.1rem);font-weight:600;color:var(--ds-text-muted);cursor:pointer;transition:all .22s ease;position:relative;overflow:hidden}.pcp-mode-tab:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity .22s;border-radius:inherit}.pcp-mode-tab:hover{border-color:var(--ds-border-strong);color:var(--ds-text)}.pcp-mode-tab.active{background:var(--ds-primary);border-color:var(--ds-primary);color:#fff;box-shadow:0 2px 10px #8b1e1e59;font-weight:700}.pcp-mode-tab-icon{font-size:clamp(.9rem,4cqi,1.3rem);line-height:1}.lp-page{font-family:var(--ds-font)}.lp-scroll{padding:0}.lp-top-row{padding:14px 10px 10px;display:flex;flex-direction:column;gap:10px;container-type:inline-size}.lp-tip-block{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-md);padding:clamp(10px,3cqi,16px) 14px;box-shadow:var(--ds-shadow-sm)}.lp-tip-label{display:flex;align-items:center;gap:6px;font-size:clamp(.68rem,3cqi,.95rem);font-weight:700;color:var(--ds-gold);letter-spacing:.5px;margin-bottom:6px}.lp-tip-text{font-size:clamp(.72rem,3.5cqi,1rem);color:var(--ds-text-muted);line-height:1.5;margin:0}.lp-search-wrap{position:relative;display:flex;align-items:center}.lp-search-icon{position:absolute;left:12px;color:var(--ds-text-light);pointer-events:none;font-size:clamp(.85rem,3.5cqi,1.2rem)}.lp-search-input{width:100%;padding:clamp(8px,3cqi,14px) 14px clamp(8px,3cqi,14px) 34px;border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-full);font-family:var(--ds-font);font-size:clamp(.78rem,3.5cqi,1.05rem);color:var(--ds-text);background:var(--ds-card);outline:none;transition:border-color .18s,box-shadow .18s}.lp-search-input::placeholder{color:var(--ds-text-light)}.lp-search-input:focus{border-color:var(--ds-primary);box-shadow:0 0 0 3px #8b1e1e14}.lp-lessons-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 10px;container-type:inline-size}.lp-lesson-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:5px;padding:clamp(14px,5cqi,24px) 10px clamp(10px,3cqi,16px);background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-md);cursor:pointer;transition:box-shadow .18s,transform .12s,border-color .18s;box-shadow:var(--ds-shadow-sm);overflow:hidden}.lp-lesson-card:hover:not(.lp-locked){box-shadow:var(--ds-shadow-md);transform:translateY(-1px);border-color:var(--ds-primary)}.lp-lesson-card:active:not(.lp-locked){transform:translateY(0)}.lp-locked{opacity:.7;cursor:not-allowed}.lp-lock-badge{position:absolute;top:6px;right:6px;font-size:clamp(.7rem,3cqi,1rem);z-index:1;line-height:1;opacity:.8}.lp-lesson-icon{font-size:clamp(1.5rem,8cqi,3rem);line-height:1}.lp-lesson-title{font-size:clamp(.72rem,3.5cqi,1.05rem);font-weight:700;color:var(--ds-text);text-align:center;line-height:1.35}.lp-progress-bar{width:100%;height:clamp(3px,1.5cqi,6px);background:var(--ds-border);border-radius:3px;overflow:hidden}.lp-progress-fill{height:100%;background:var(--ds-primary);border-radius:3px;transition:width .4s ease}.lp-progress-pct{font-size:clamp(.58rem,2.5cqi,.82rem);color:var(--ds-text-light);font-weight:600;min-height:14px}.lp-section-label{margin-bottom:10px}.lp-videos-section{padding:14px 10px 0;container-type:inline-size}.lp-videos-row{display:flex;gap:10px}.lp-video-card{flex:1;border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-md);background:var(--ds-card);overflow:hidden;cursor:pointer;transition:box-shadow .18s,transform .12s;padding:0}.lp-video-card:hover{box-shadow:var(--ds-shadow-md);transform:translateY(-1px)}.lp-video-thumb{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#2a1a0e,#1a0c06);display:flex;align-items:center;justify-content:center;position:relative}.lp-video-play{width:clamp(30px,10cqi,52px);height:clamp(30px,10cqi,52px);border-radius:50%;background:#c8960ad9;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 2px 12px #0006;transition:background .18s,transform .12s}.lp-video-card:hover .lp-video-play{background:var(--ds-gold);transform:scale(1.08)}.lnp-page{font-family:var(--ds-font)}.lnp-scroll{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 10px 0}.lnp-card{width:100%;max-width:100%;padding:22px 16px;container-type:inline-size}.lnp-tabs{display:flex;border-bottom:2.5px solid var(--ds-border);margin-bottom:20px}.lnp-tab{flex:1;padding:clamp(8px,3cqi,14px);border:none;background:none;font-family:var(--ds-font);font-size:clamp(.78rem,4cqi,1.1rem);font-weight:700;letter-spacing:1px;color:var(--ds-text-muted);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2.5px;transition:color .18s,border-color .18s}.lnp-tab.active{color:var(--ds-primary);border-bottom-color:var(--ds-primary)}.lnp-form{display:flex;flex-direction:column;gap:clamp(10px,4cqi,18px)}.lnp-form.hidden{display:none}.lnp-field{display:flex;flex-direction:column;gap:5px}.lnp-label{font-size:clamp(.72rem,3.5cqi,1rem);font-weight:600;color:var(--ds-text-muted)}.lnp-pw-wrap{position:relative}.lnp-pw-wrap .ds-input{padding-right:40px}.lnp-eye-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);border:none;background:none;font-size:.95rem;cursor:pointer;color:var(--ds-text-muted);padding:3px}.lnp-submit-btn{margin-top:6px;font-size:clamp(.82rem,4cqi,1.1rem);padding:clamp(10px,3.5cqi,16px)}.lnp-guest-btn{margin-top:10px;border-radius:var(--ds-radius-full);font-size:clamp(.78rem,4cqi,1.1rem);padding:clamp(10px,3.5cqi,16px)}.lnp-divider{margin:14px 0}.lnp-social-row{display:flex;gap:10px}.lnp-social-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:clamp(9px,3cqi,14px) 14px;border-radius:var(--ds-radius-md);border:2px solid var(--ds-border);background:var(--ds-card);font-family:var(--ds-font);font-size:clamp(.72rem,3.5cqi,1rem);font-weight:600;color:var(--ds-text);cursor:pointer;transition:background .18s}.lnp-social-btn:hover{background:var(--ds-card-secondary)}.lnp-social-disabled{opacity:.55;cursor:not-allowed}.lnp-social-disabled:hover{background:var(--ds-card)}.lnp-forgot{display:block;width:100%;margin-top:12px;border:none;background:none;font-family:var(--ds-font);font-size:clamp(.72rem,3.5cqi,1rem);color:var(--ds-primary);cursor:pointer;text-decoration:underline;text-underline-offset:3px}.lnp-status{margin-top:10px;padding:10px 14px;border-radius:var(--ds-radius-md);font-size:.82rem;font-weight:600;text-align:center}.lnp-status.hidden{display:none}.lnp-status--success{background:var(--ds-green-light);color:var(--ds-green)}.lnp-status--error{background:#c0392b14;color:var(--ds-red-dot)}.lnp-status--loading{background:#8b1e1e0f;color:var(--ds-primary);display:flex;align-items:center;justify-content:center;gap:8px}.lnp-spinner{width:15px;height:15px;border:2.5px solid rgba(139,30,30,.2);border-top-color:var(--ds-primary);border-radius:50%;animation:lnp-spin .7s linear infinite;display:inline-block}@keyframes lnp-spin{to{transform:rotate(360deg)}}.pp-page{font-family:var(--ds-font)}.pp-scroll{padding:16px 10px 0}.pp-card{padding:20px 16px;container-type:inline-size}.pp-hero{display:flex;align-items:center;gap:16px;padding-bottom:16px;border-bottom:2px solid var(--ds-border);margin-bottom:16px}.pp-avatar{width:clamp(50px,16cqi,80px);height:clamp(50px,16cqi,80px);background:var(--ds-primary);flex-shrink:0}.pp-avatar span{font-size:clamp(1.2rem,5cqi,2rem);color:#fff;font-weight:700}.pp-hero-info{flex:1;min-width:0}.pp-hero-name{font-size:clamp(.95rem,5cqi,1.4rem);font-weight:800;color:var(--ds-text);margin:0 0 3px}.pp-hero-date{font-size:clamp(.68rem,3cqi,.95rem);color:var(--ds-text-muted);margin:0}.pp-section-label{font-size:clamp(.62rem,2.5cqi,.85rem);font-weight:700;letter-spacing:2px;color:var(--ds-text-light);margin-bottom:10px}.pp-elo-row{display:flex;gap:8px;margin-bottom:16px}.pp-elo-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:clamp(8px,3cqi,14px) 6px;border-radius:var(--ds-radius-md);background:var(--ds-card-secondary);border:2px solid var(--ds-border)}.pp-elo-card--main{background:#8b1e1e0f;border-color:#8b1e1e40}.pp-elo-icon{font-size:clamp(.95rem,4cqi,1.5rem)}.pp-elo-mode{font-size:clamp(.55rem,2.5cqi,.8rem);font-weight:700;color:var(--ds-text-muted)}.pp-elo-val{font-size:clamp(.82rem,3.5cqi,1.2rem);font-weight:800;color:var(--ds-text)}.pp-stats-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:16px}.pp-stat-box{display:flex;flex-direction:column;align-items:center;gap:4px;padding:clamp(8px,3cqi,14px) 6px;background:var(--ds-card-secondary);border-radius:var(--ds-radius-md);border:2px solid var(--ds-border)}.pp-stat-label{font-size:clamp(.55rem,2.5cqi,.8rem);font-weight:700;color:var(--ds-text-muted);text-align:center}.pp-stat-val{font-size:clamp(.78rem,3cqi,1.1rem);font-weight:800;color:var(--ds-text)}.pp-stat-wdl{font-size:clamp(.65rem,2.5cqi,.9rem)}.pp-mini-bar{width:100%;height:4px;background:var(--ds-border);border-radius:2px;overflow:hidden}.pp-mini-fill{height:100%;border-radius:2px;max-width:100%}.pp-fill-win{background:var(--ds-green)}.pp-fill-draw{background:var(--ds-gold)}.pp-history-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.pp-history-row{display:flex;align-items:center;gap:8px;padding:clamp(8px,3cqi,14px) 12px;background:var(--ds-card-secondary);border-radius:var(--ds-radius-md);border:2px solid var(--ds-border);font-size:clamp(.75rem,3.5cqi,1.05rem)}.pp-history-icon{font-size:clamp(.85rem,4cqi,1.3rem);flex-shrink:0}.pp-history-text{flex:1;color:var(--ds-text);font-weight:500}.pp-history-elo{font-size:clamp(.72rem,3cqi,1rem);font-weight:700;flex-shrink:0}.pp-elo-pos{color:var(--ds-green)}.pp-elo-neg{color:var(--ds-red-dot)}.pp-no-history{text-align:center;color:var(--ds-text-muted);font-size:clamp(.75rem,3.5cqi,1.05rem);padding:18px}.pp-logout-btn{border-radius:var(--ds-radius-full);font-size:clamp(.75rem,3.5cqi,1.05rem);padding:clamp(10px,3cqi,16px)}.rp-page{font-family:var(--ds-font)}.rp-loading{text-align:center;padding:40px;color:var(--ds-text-muted);font-size:.92rem}.rp-tab-bar{display:flex;background:var(--ds-card);border-bottom:2.5px solid var(--ds-border);flex-shrink:0;container-type:inline-size}.rp-tab{flex:1;padding:clamp(8px,3cqi,14px) 8px;border:none;background:none;font-family:var(--ds-font);font-size:clamp(.78rem,3.5cqi,1.1rem);font-weight:700;letter-spacing:.5px;color:var(--ds-text-muted);cursor:pointer;border-bottom:3px solid transparent;transition:color .18s,border-color .18s}.rp-tab.active{color:var(--ds-primary);border-bottom-color:var(--ds-primary)}.rp-scroll{padding:0}.rp-podium{display:flex;align-items:flex-end;justify-content:center;gap:6px;padding:24px 10px 0;background:linear-gradient(180deg,rgba(200,150,10,.07) 0%,transparent 100%);container-type:inline-size}.rp-pod{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;max-width:130px}.rp-pod-av{border-radius:50%;background:var(--ds-card-secondary);border:3px solid var(--ds-border-strong);display:flex;align-items:center;justify-content:center;font-family:var(--ds-font);font-weight:700;font-size:clamp(.85rem,4cqi,1.3rem);color:var(--ds-text);overflow:hidden;flex-shrink:0;box-shadow:var(--ds-shadow-md);width:clamp(36px,12cqi,60px);height:clamp(36px,12cqi,60px)}.rp-pod-av img{width:100%;height:100%;object-fit:cover}.rp-pod--1 .rp-pod-av{border-color:#f0c060;box-shadow:0 0 0 4px #f0c0604d,var(--ds-shadow-md);width:clamp(42px,15cqi,72px);height:clamp(42px,15cqi,72px)}.rp-pod--2 .rp-pod-av{border-color:silver}.rp-pod--3 .rp-pod-av{border-color:#cd7f32}.rp-pod-medal{font-size:clamp(.95rem,4cqi,1.4rem);line-height:1}.rp-pod-crown{font-size:clamp(1.1rem,5cqi,1.8rem)}.rp-pod-name{font-size:clamp(.6rem,2.8cqi,.9rem);font-weight:700;color:var(--ds-text);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.rp-pod-elo{font-size:clamp(.55rem,2.5cqi,.82rem);font-weight:600;color:var(--ds-text-muted)}.rp-pod-bar{width:100%;border-radius:5px 5px 0 0}.rp-bar--1{height:clamp(40px,14cqi,72px);background:linear-gradient(180deg,#f0c060,#c8960a)}.rp-bar--2{height:clamp(28px,10cqi,50px);background:linear-gradient(180deg,#d8d8d8,#a0a0a0)}.rp-bar--3{height:clamp(18px,7cqi,35px);background:linear-gradient(180deg,#e0a060,#b07840)}.rp-table-header{display:flex;align-items:center;padding:10px 14px;border-top:2px solid var(--ds-border);border-bottom:2px solid var(--ds-border);background:var(--ds-card-secondary);gap:8px;container-type:inline-size}.rp-th-rank{width:36px;font-size:clamp(.6rem,2.5cqi,.85rem);font-weight:700;color:var(--ds-text-light)}.rp-th-name{flex:1;font-size:clamp(.6rem,2.5cqi,.85rem);font-weight:700;color:var(--ds-text-light)}.rp-th-winpct{width:52px;text-align:right;font-size:clamp(.6rem,2.5cqi,.85rem);font-weight:700;color:var(--ds-text-light)}.rp-th-elo{width:48px;text-align:right;font-size:clamp(.6rem,2.5cqi,.85rem);font-weight:700;color:var(--ds-text-light)}.rp-list{display:flex;flex-direction:column;container-type:inline-size}.rp-row{display:flex;align-items:center;gap:8px;padding:clamp(8px,3cqi,16px) 14px;border-bottom:1.5px solid var(--ds-border);transition:background .15s}.rp-row:hover{background:#8b1e1e08}.rp-row--me{background:#8b1e1e0f;border-left:4px solid var(--ds-primary)}.rp-row-rank{width:36px;font-size:clamp(.72rem,3cqi,1.05rem);font-weight:700;color:var(--ds-text-light)}.rp-row-player{flex:1;display:flex;align-items:center;gap:8px;min-width:0}.rp-row-av{width:clamp(28px,8cqi,44px);height:clamp(28px,8cqi,44px);border-radius:50%;background:var(--ds-card-secondary);border:2px solid var(--ds-border);display:flex;align-items:center;justify-content:center;font-size:clamp(.6rem,2.5cqi,.9rem);font-weight:700;color:var(--ds-text-muted);overflow:hidden;flex-shrink:0}.rp-row-av img{width:100%;height:100%;object-fit:cover}.rp-row-name{font-size:clamp(.78rem,3.5cqi,1.1rem);font-weight:600;color:var(--ds-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-you{font-size:clamp(.58rem,2.5cqi,.82rem);color:var(--ds-primary);font-weight:700}.rp-row-winpct{width:52px;text-align:right;font-size:clamp(.72rem,3cqi,1.05rem);color:var(--ds-text-muted);font-weight:600}.rp-row-elo{width:48px;text-align:right;font-size:clamp(.78rem,3.5cqi,1.1rem);font-weight:700;color:var(--ds-text)}.rp-my-rank-footer{position:absolute;bottom:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 16px;background:linear-gradient(180deg,transparent 0%,var(--ds-bg) 40%)}.rp-my-rank-chess{font-size:1.05rem;color:var(--ds-primary);opacity:.7}.rp-my-rank-label{font-family:var(--ds-font-serif);font-size:.9rem;font-weight:700;color:var(--ds-text-muted);letter-spacing:1px}.rp-my-rank-num{font-family:var(--ds-font);font-size:.95rem;font-weight:800;color:var(--ds-primary)}.gr-gameover-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0a0500c7;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:grGoFadeIn .3s ease-out}@keyframes grGoFadeIn{0%{opacity:0}to{opacity:1}}.gr-go-card{background:#1c1408;border:1px solid rgba(240,192,96,.18);border-radius:20px;padding:36px 32px 28px;display:flex;flex-direction:column;align-items:center;gap:10px;min-width:280px;max-width:340px;width:90vw;box-shadow:0 16px 60px #0009;animation:grGoSlideUp .35s cubic-bezier(.32,.72,0,1)}@keyframes grGoSlideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.gr-go-icon{font-size:3rem;line-height:1;margin-bottom:4px}.gr-go-title{font-family:var(--ds-font, "Be Vietnam Pro", sans-serif);font-size:1.1rem;font-weight:800;color:#f0c060;text-align:center;margin:0;letter-spacing:.5px}.gr-go-reason{font-size:.75rem;color:#f0c06080;text-align:center;margin:0;line-height:1.5}.gr-go-elo{font-size:.85rem;font-weight:700;padding:6px 18px;border-radius:999px;margin:4px 0}.gr-go-elo--pos{color:#4caf50;background:#4caf501f;border:1px solid rgba(76,175,80,.25)}.gr-go-elo--neg{color:#ef5350;background:#ef53501f;border:1px solid rgba(239,83,80,.25)}.gr-go-actions{display:flex;gap:10px;width:100%;margin-top:8px}.gr-go-btn{flex:1;padding:11px 16px;border-radius:999px;font-family:var(--ds-font, "Be Vietnam Pro", sans-serif);font-size:.82rem;font-weight:700;cursor:pointer;transition:background .18s,transform .1s;border:none}.gr-go-btn:active{transform:scale(.97)}.gr-go-btn--primary{background:#8b1e1e;color:#fff;box-shadow:0 2px 10px #8b1e1e73}.gr-go-btn--primary:hover{background:#6d1717}.gr-go-btn--outline{background:transparent;color:#f0c060;border:1.5px solid rgba(240,192,96,.35)}.gr-go-btn--outline:hover{background:#f0c06014}.gr-go-home-link{background:none;border:none;color:#f0c06066;font-size:.72rem;cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:0;margin-top:2px;transition:color .18s}.gr-go-home-link:hover{color:#f0c060b3}.gr-dark{--gr-bg: #1a1a24;--gr-panel: rgba(22, 22, 38, .96);--gr-panel-border: rgba(255,255,255,.08);--gr-text: #e0e0e6;--gr-text-muted: #888;--gr-card-bg: rgba(28, 28, 44, .82);--gr-card-border: rgba(255,255,255,.1);--gr-header-bg: rgba(40, 40, 60, .92);--gr-timer-opp-bg: rgba(42, 42, 52, .94);--gr-timer-me-bg: rgba(120, 18, 22, .94);--gr-icon-bg: rgba(255,255,255,.06);--gr-icon-hover: rgba(255,255,255,.12);--gr-badge-bg: #b07030;--gr-glass-blur: 14px}.gr-light{--gr-bg: #d8cfc0;--gr-panel: rgba(245, 240, 232, .96);--gr-panel-border: rgba(0,0,0,.08);--gr-text: #2c2c2c;--gr-text-muted: #777;--gr-card-bg: rgba(255, 252, 245, .88);--gr-card-border: rgba(0,0,0,.1);--gr-header-bg: rgba(92, 58, 30, .92);--gr-timer-opp-bg: rgba(55, 55, 65, .92);--gr-timer-me-bg: rgba(140, 25, 25, .92);--gr-icon-bg: rgba(0,0,0,.05);--gr-icon-hover: rgba(0,0,0,.1);--gr-badge-bg: #b07030;--gr-glass-blur: 10px}.game-room{position:relative;width:100%;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;overflow:hidden;z-index:1;background-color:var(--gr-bg);background-image:url(/assets/bg-landscape.png);background-size:cover;background-position:center bottom;color:var(--gr-text);font-family:var(--font-sans);display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:1fr;align-items:stretch}.game-room:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0a0a14b3,#0a0a148c,#0a0a1466);z-index:0;pointer-events:none}.gr-board-area{position:relative;z-index:1;grid-column:2;grid-row:1;min-width:0;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:8px;height:100%;max-height:100vh;max-height:100dvh}.gr-canvas{border-radius:12px;cursor:pointer;max-height:calc(100vh - 32px);max-width:calc(100vw - 32px);width:auto;height:auto;box-shadow:0 16px 60px #0009,0 0 0 1px #a0783c1f;transition:transform .35s cubic-bezier(.4,0,.2,1)}.gr-btn-back{width:42px;height:42px;border-radius:12px;border:1.5px solid rgba(180,160,140,.25);background:#00000073;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#dcd2c8e6;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.gr-btn-back:hover{background:#000000a6;color:#fff;border-color:#b4a08c80;transform:scale(1.05)}.gr-btn-back:active{transform:scale(.95)}.gr-btn-back svg{width:20px;height:20px}.gr-left-col{position:relative;z-index:10;grid-column:1;grid-row:1;display:flex;flex-direction:column;justify-content:center;gap:8px;padding:16px 12px 16px 16px;width:230px;flex-shrink:0}.gr-player-card{display:flex;align-items:center;gap:12px;background:var(--gr-card-bg);backdrop-filter:blur(var(--gr-glass-blur));-webkit-backdrop-filter:blur(var(--gr-glass-blur));border-radius:16px;padding:12px 16px;border:1px solid var(--gr-card-border);transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 20px #0000004d}.gr-player-card.active-turn{border-color:#b0703073;box-shadow:0 4px 20px #0000004d,0 0 24px #b070301f}.gr-avatar-circle{width:46px;height:46px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;box-shadow:0 2px 8px #00000059}.gr-avatar-circle--red{background:linear-gradient(145deg,#4caf50,#66bb6a);color:#fff;border:2.5px solid rgba(76,175,80,.6)}.gr-avatar-circle--black{background:linear-gradient(145deg,#9c27b0,#ab47bc);color:#fff;border:2.5px solid rgba(156,39,176,.5)}.gr-avatar-img{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2.5px solid rgba(180,140,80,.6);box-shadow:0 2px 8px #00000059}.gr-player-info{display:flex;flex-direction:column;gap:2px;min-width:0}.gr-player-name{font-weight:700;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}.gr-player-elo{font-size:.72rem;color:#ffffff73;font-weight:500;letter-spacing:.3px}.gr-player-rank{font-size:.72rem;color:#ffffff73}.gr-timer-block{border-radius:14px;padding:8px 16px;text-align:left;box-shadow:0 4px 20px #00000059;transition:all .3s ease}.gr-timer-block--black{background:var(--gr-timer-opp-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.gr-timer-block--red{background:var(--gr-timer-me-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.gr-timer-inner{display:flex;align-items:baseline;gap:10px}.gr-timer-inc{font-family:Fira Mono,Roboto Mono,monospace;font-size:.72rem;color:#fff6;font-weight:500;letter-spacing:.5px}.gr-clock-value{font-family:Fira Mono,Roboto Mono,monospace;font-size:3.4rem;font-weight:900;color:#fff;letter-spacing:3px;line-height:1.1;text-shadow:0 2px 10px rgba(0,0,0,.35)}.gr-timer-active{box-shadow:0 0 24px #b070304d}.gr-timer-danger{animation:grPulse 1s ease-in-out infinite;color:#ff6b6b!important;text-shadow:0 0 14px rgba(255,100,100,.5)}@keyframes grPulse{0%,to{opacity:1}50%{opacity:.6}}.gr-mid-controls{display:flex;gap:8px;padding:4px 0}.gr-ctrl-btn{width:44px;height:44px;border-radius:12px;border:1.5px solid rgba(255,255,255,.12);background:#ffffff0f;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#fff9;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.gr-ctrl-btn svg{width:20px;height:20px}.gr-ctrl-btn:hover{background:#ffffff24;color:#fff;border-color:#ffffff40;transform:translateY(-1px)}.gr-ctrl-btn:active{transform:scale(.92) translateY(0)}.gr-ctrl-btn--danger{border-color:#b43c3c40}.gr-ctrl-btn--danger:hover{border-color:#dc505073;color:#ff6b6b}.gr-icon-btn{width:42px;height:42px;border-radius:10px;border:1.5px solid rgba(180,160,140,.25);background:#0006;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#c8beb4cc;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;position:relative}.gr-icon-btn svg{width:20px;height:20px}.gr-icon-btn:hover{background:#0000008c;border-color:#b4a08c80;color:#fff;transform:translateY(-1px)}.gr-icon-btn:active{transform:scale(.94)}.gr-chat-accent{background:#9b232dcc;border-color:#c8374180;color:#fff;width:56px;height:56px;border-radius:14px;box-shadow:0 4px 16px #b4283259}.gr-chat-accent svg{width:24px;height:24px}.gr-chat-accent:hover{background:#b42d37e6;box-shadow:0 6px 20px #b4283273;transform:translateY(-2px)}.gr-icon-sq{width:56px;height:56px;border-radius:10px;border:2px solid rgba(100,80,50,.45);background:#1c160ee0;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#c8aa78bf;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.gr-icon-sq svg{width:24px;height:24px}.gr-icon-sq:hover{background:#32281ceb;border-color:#c8a05aa6;color:#e0c070;transform:translateY(-2px);box-shadow:0 4px 16px #8c642833}.gr-icon-sq:active{transform:scale(.94) translateY(0)}.gr-right-bar,.gr-icon-bar{position:relative;z-index:10;grid-column:3;grid-row:1;display:flex;flex-direction:column;justify-content:center;gap:10px;padding:16px 16px 16px 12px;flex-shrink:0}.gr-bottom-extras{position:absolute;right:18px;bottom:18px;display:flex;align-items:flex-end;gap:8px;z-index:10}.gr-bottom-extras .gr-btn-theme,.gr-bottom-extras .gr-btn-chat,.gr-bottom-extras .gr-btn-invite{width:42px;height:42px;border-radius:10px;border:1.5px solid rgba(180,160,140,.25);background:#0006;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#c8beb4cc;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.gr-bottom-extras button:hover{background:#0000008c;border-color:#b4a08c80;color:#fff;transform:translateY(-1px)}.gr-bottom-extras button svg{width:20px;height:20px}.gr-bottom-right{position:absolute;right:18px;bottom:18px;display:flex;align-items:flex-end;gap:8px;z-index:10}.gr-status-float{position:absolute;top:14px;left:50%;transform:translate(-50%);z-index:15;font-size:.82rem;font-weight:600;padding:5px 16px;border-radius:20px;background:#0000008c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fffc;border:1px solid rgba(255,255,255,.1);white-space:nowrap;transition:all .3s ease}.gr-status-idle{opacity:0;pointer-events:none}.gr-status-win{opacity:1;pointer-events:auto;color:gold;background:#ffd70026;border-color:#ffd7004d;animation:statusAppear .4s ease-out}.gr-status-check{opacity:1;pointer-events:auto;color:#ff6b6b;background:#ff50501f;border-color:#ff505040;animation:grPulse .5s ease-in-out 3}.gr-status-draw{opacity:1;pointer-events:auto;color:#fff9;animation:statusAppear .4s ease-out}@keyframes statusAppear{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.gr-mode-float{position:absolute;top:14px;right:80px;display:flex;gap:8px;align-items:center;z-index:10}.gr-mode-badge{font-size:.7rem;padding:4px 12px;border-radius:20px;color:#fff;font-weight:600;letter-spacing:.3px;box-shadow:0 2px 8px #0000004d}.gr-room-code{font-size:.7rem;color:#ffffff73;font-family:Fira Mono,Roboto Mono,monospace;letter-spacing:1px}.gr-ai-float{position:absolute;bottom:65px;left:50%;transform:translate(-50%);z-index:15;display:flex;align-items:center;gap:10px;padding:8px 18px;background:#000000a6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:24px;font-size:.82rem;color:#ffffffb3;border:1px solid rgba(255,255,255,.08)}.gr-ai-thinking-dots{display:flex;gap:4px}.gr-ai-thinking-dots span{width:7px;height:7px;border-radius:50%;background:#b07030;animation:aiDot 1.4s ease-in-out infinite}.gr-ai-thinking-dots span:nth-child(2){animation-delay:.2s}.gr-ai-thinking-dots span:nth-child(3){animation-delay:.4s}@keyframes aiDot{0%,80%,to{opacity:.3}40%{opacity:1}}.gr-draw-float{position:absolute;bottom:72px;left:50%;transform:translate(-50%);z-index:20;display:flex;align-items:center;gap:14px;padding:10px 18px;background:#000000bf;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(176,112,48,.3);border-radius:14px;font-size:.85rem;box-shadow:0 4px 20px #0006}.gr-draw-actions{display:flex;gap:8px}.gr-btn-accept{border-color:#4caf5066!important;color:#4caf50!important}.gr-btn-accept:hover{background:#4caf5026!important}.gr-slide-panel{position:absolute;top:0;right:0;width:320px;height:100%;background:var(--gr-panel);border-left:1px solid var(--gr-panel-border);z-index:30;display:flex;flex-direction:column;transform:translate(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:-4px 0 24px #0000004d}.gr-slide-panel.open{transform:translate(0)}.gr-slide-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;font-weight:700;font-size:.85rem;background:var(--gr-header-bg);color:#fff;flex-shrink:0;gap:8px}.gr-slide-close{width:30px;height:30px;border-radius:8px;border:none;background:#ffffff1a;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.gr-slide-close svg{width:16px;height:16px}.gr-slide-close:hover{background:#fff3}.gr-move-nav{display:flex;gap:4px}.gr-nav-btn{width:28px;height:28px;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#fff;font-size:.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.gr-nav-btn svg{width:14px;height:14px}.gr-nav-btn:hover{background:#ffffff2e}.gr-move-list{flex:1;overflow-y:auto;padding:8px 10px}.gr-move-list::-webkit-scrollbar{width:4px}.gr-move-list::-webkit-scrollbar-track{background:transparent}.gr-move-list::-webkit-scrollbar-thumb{background:var(--gr-panel-border);border-radius:2px}.move-entry{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:6px;font-size:.82rem;font-family:var(--font-serif);transition:background .15s}.move-entry:hover{background:var(--gr-icon-hover)}.move-number{color:var(--gr-text-muted);font-size:.72rem;min-width:22px;font-family:var(--font-sans)}.move-piece{font-size:.95rem}.move-piece.red{color:#b07030}.move-piece.black{color:var(--gr-text)}.move-notation{color:var(--gr-text-muted);font-family:var(--font-sans);font-size:.78rem}.move-capture-icon{font-size:.68rem;color:#b07030;opacity:.7}.move-history-empty{text-align:center;color:var(--gr-text-muted);font-size:.82rem;padding:20px}.gr-captures{display:flex;flex-direction:column;gap:2px;font-family:var(--font-serif);font-size:.78rem;color:var(--gr-text-muted);padding:4px 16px}.gr-theme-section{padding:10px 16px;border-top:1px solid var(--gr-panel-border)}.gr-theme-label{font-size:.72rem;color:var(--gr-text-muted);display:block;margin-bottom:6px}.gr-theme-options{display:flex;gap:6px}.gr-theme-opt{flex:1;padding:6px;border-radius:6px;border:1px solid var(--gr-panel-border);background:var(--gr-icon-bg);color:var(--gr-text);font-size:.7rem;cursor:pointer;text-align:center;transition:all .2s}.gr-theme-opt:hover{background:var(--gr-icon-hover)}.gr-theme-opt.active{border-color:#b07030;color:#b07030;background:#b070301a}.gr-chat-popup{position:absolute;bottom:80px;right:18px;width:340px;max-height:420px;background:var(--gr-panel);border:1px solid var(--gr-panel-border);border-radius:16px;z-index:25;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 12px 40px #00000080;animation:chatPopIn .25s cubic-bezier(.4,0,.2,1)}.gr-chat-popup.hidden{display:none!important}@keyframes chatPopIn{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.gr-chat-popup-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;font-weight:700;font-size:.85rem;background:var(--gr-header-bg);color:#fff}.gr-chat-popup-body{flex:1;overflow-y:auto;padding:8px 10px;min-height:200px}.gr-chat-placeholder{text-align:center;color:var(--gr-text-muted);font-size:.82rem;padding:24px 12px}.gr-chat-popup-body .chat-panel{margin:0;border:none;border-radius:0;background:transparent}.gr-layout-a .gr-left-col{width:230px}.gr-layout-a .gr-mid-controls{display:flex}.gr-layout-a .gr-clock-value{font-size:3.4rem}.gr-layout-b .gr-left-col{width:170px}.gr-layout-b .gr-player-card{padding:8px 12px;gap:8px}.gr-layout-b .gr-player-card .gr-player-elo,.gr-layout-b .gr-player-card .gr-player-rank{display:none}.gr-layout-b .gr-avatar-circle{width:36px;height:36px;font-size:.85rem}.gr-layout-b .gr-avatar-img{width:36px;height:36px}.gr-layout-b .gr-timer-block{padding:6px 12px}.gr-layout-b .gr-clock-value{font-size:2rem;letter-spacing:2px}.gr-layout-b .gr-mid-controls{display:none}.gr-layout-b .gr-icon-sq{width:44px;height:44px;border-width:2px}.gr-layout-b .gr-icon-sq svg{width:20px;height:20px}.gr-layout-b .gr-right-bar{gap:8px}.gr-layout-b .gr-btn-back{width:36px;height:36px}.gr-layout-b .gr-status-float{font-size:.72rem;padding:3px 10px}@media(max-width:767px){.gr-left-col,.gr-right-bar,.gr-btn-back,.gr-bottom-extras{display:none!important}.game-room{display:block!important;position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100vw!important;height:100vh!important;height:100dvh!important;overflow:hidden!important;grid-template-columns:unset!important;grid-template-rows:unset!important}.gr-board-area{position:absolute!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100%!important;height:100%!important;max-height:100vh!important;max-height:100dvh!important;grid-column:unset!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:1;background:transparent!important;overflow:hidden!important;padding:0!important}.gr-mobile-top{display:flex!important;position:absolute;top:0;left:0;right:0;z-index:20;align-items:center;justify-content:space-between;padding:8px 14px 14px;padding-top:max(8px,env(safe-area-inset-top,8px));background:linear-gradient(180deg,#000000c7,#0000);gap:10px;min-height:60px;max-height:80px;pointer-events:auto;box-sizing:border-box;overflow:hidden}.gr-mobile-bottom{display:flex!important;position:absolute;bottom:0;left:0;right:0;z-index:20;align-items:center;justify-content:space-between;padding:14px 14px 10px;padding-bottom:max(10px,env(safe-area-inset-bottom,10px));background:linear-gradient(0deg,#000000d9,#0000);gap:10px;min-height:68px;max-height:88px;pointer-events:auto;box-sizing:border-box;overflow:hidden}.gr-mb-player{display:flex;align-items:center;gap:7px;min-width:0;flex:1;overflow:hidden}.gr-mb-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;color:#fff;box-shadow:0 3px 10px #0000008c;overflow:hidden}.gr-mb-avatar img{width:100%;height:100%;object-fit:cover}.gr-mb-avatar--red{background:linear-gradient(145deg,#8b1e1e,#c0392b);border:2.5px solid rgba(200,70,70,.6)}.gr-mb-avatar--black{background:linear-gradient(145deg,#1a1830,#3a1a6e);border:2.5px solid rgba(110,70,180,.6)}.gr-mb-info{display:flex;flex-direction:column;gap:1px;min-width:0}.gr-mb-name{font-weight:700;font-size:.88rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;text-shadow:0 1px 5px rgba(0,0,0,.8)}.gr-mb-elo{font-size:.67rem;color:#ffffff6b;font-weight:500}.gr-mb-player.active-turn .gr-mb-name{color:#f0c060;text-shadow:0 0 12px rgba(240,192,96,.55)}.gr-mb-player.active-turn .gr-mb-avatar{box-shadow:0 0 0 2.5px #f0c06099,0 3px 10px #0000008c}.gr-mb-clock{font-family:Fira Mono,Roboto Mono,monospace;font-size:clamp(1.2rem,4vw,1.7rem);font-weight:900;letter-spacing:1px;color:#fff;padding:4px 10px;border-radius:12px;min-width:80px;text-align:center;transition:all .25s ease;flex-shrink:0;text-shadow:0 2px 8px rgba(0,0,0,.5)}.gr-mb-clock--black{background:#12102ecc;border:1.5px solid rgba(120,100,200,.25)}.gr-mb-clock--red{background:#5a0810d9;border:1.5px solid rgba(200,60,60,.32)}.gr-mb-clock.gr-timer-active{box-shadow:0 0 22px #b0703080;border-color:#d2a03c99!important}.gr-mb-clock.gr-timer-danger{color:#ff6060!important;text-shadow:0 0 16px rgba(255,80,80,.65);animation:grPulse .9s ease-in-out infinite}.gr-mb-top-actions,.gr-mb-bottom-actions{display:flex;gap:7px;align-items:center;flex-shrink:0}.gr-mb-btn{width:38px;height:38px;border-radius:11px;border:1.5px solid rgba(255,255,255,.15);background:#0000006b;color:#ffffffc7;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s;flex-shrink:0;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.gr-mb-btn svg{width:17px;height:17px}.gr-mb-btn:hover{background:#ffffff2e;color:#fff}.gr-mb-btn:active{transform:scale(.9)}.gr-mb-btn--menu{width:42px;height:42px;border-radius:13px;background:#b0703047;border-color:#c8964673;color:#d4a040}.gr-mb-btn--menu:hover{background:#b0703080;color:#f0c060}.gr-mobile-popup{display:none;position:absolute;bottom:88px;right:14px;z-index:999;background:#0e0c1cf7;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:8px 6px;box-shadow:0 20px 60px #000c;flex-direction:column;gap:2px;min-width:190px;animation:mbPopIn .22s cubic-bezier(.34,1.56,.64,1);pointer-events:auto}.gr-mobile-popup.open{display:flex}@keyframes mbPopIn{0%{opacity:0;transform:translateY(14px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}.gr-popup-item{display:flex;align-items:center;gap:12px;padding:11px 16px;border-radius:13px;background:none;border:none;color:#ebe1d7e0;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s;text-align:left;width:100%;font-family:var(--font-sans)}.gr-popup-item svg{width:18px;height:18px;flex-shrink:0;opacity:.72}.gr-popup-item:hover{background:#ffffff17}.gr-popup-item:active{transform:scale(.97)}.gr-popup-item--danger{color:#ff7575}.gr-popup-item--danger svg{opacity:.92}.gr-popup-item--danger:hover{background:#dc3c3c29}.gr-popup-divider{height:1px;background:#ffffff12;margin:2px 10px}.gr-popup-backdrop{display:none;position:absolute;top:0;right:0;bottom:0;left:0;z-index:998;background:#00000040}.gr-popup-backdrop.open{display:block}.gr-status-float{position:absolute;top:auto;bottom:90px;left:50%;transform:translate(-50%);z-index:25;font-size:.76rem;padding:4px 16px;white-space:nowrap;max-width:90vw;overflow:hidden;text-overflow:ellipsis}.gr-status-idle{opacity:0;pointer-events:none}.gr-slide-panel{width:100%}.gr-chat-popup{position:absolute;bottom:92px;left:10px;right:10px;width:auto;max-height:50vh}.gr-mobile-popup{max-height:calc(100vh - 180px);max-height:calc(100dvh - 180px);overflow-y:auto}}@media(min-width:768px)and (max-width:1023px){.gr-left-col{width:190px;gap:7px}.gr-clock-value{font-size:2.5rem!important}}@media(min-width:1280px){.gr-left-col{width:255px}.gr-clock-value{font-size:3.8rem}}@media(min-width:768px){.gr-mobile-top,.gr-mobile-bottom,.gr-mobile-popup,.gr-popup-backdrop{display:none!important}}.game-bg{background:linear-gradient(180deg,#0c0c18,#141422,#0a0a14)}.game-topbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:#0a0a19f2;border-bottom:1px solid rgba(255,255,255,.08);position:relative;z-index:200;flex-wrap:wrap;flex-shrink:0}.theme-option.active{border-color:var(--accent-gold);color:var(--accent-gold);background:#ffd70014}.move-nav{display:flex;justify-content:center;gap:var(--space-xs);padding:4px 0}.game-room:fullscreen{background-size:cover}.game-room:fullscreen .game-container{height:calc(100vh - 50px)}.game-container{display:flex;flex:1;gap:var(--space-lg);padding:var(--space-sm) var(--space-lg);max-width:1200px;margin:0 auto;width:100%;align-items:flex-start;overflow:hidden;min-height:0}.board-wrapper{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);flex-shrink:0;max-height:100%;overflow:hidden}.player-card.active{border-color:var(--accent-gold);box-shadow:var(--shadow-glow-gold)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.game-canvas{border-radius:var(--radius-md);cursor:pointer;max-width:100%!important;max-height:calc(100vh - 200px)!important;object-fit:contain;height:auto!important;width:auto!important}.game-sidebar{display:flex;flex-direction:column;gap:var(--space-md);flex:1;min-width:260px;max-width:320px}@keyframes checkFlash{0%,to{opacity:1}50%{opacity:.5}}.game-controls{display:flex;gap:var(--space-sm);flex-wrap:wrap}.game-controls .btn{flex:1;min-width:0}.move-history{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-subtle);overflow:hidden;flex:1}.move-history-header{padding:var(--space-sm) var(--space-md);font-weight:600;font-size:.875rem;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:var(--space-sm)}.move-history-list{max-height:300px;overflow-y:auto;padding:var(--space-sm)}.move-history-list::-webkit-scrollbar{width:4px}.move-history-list::-webkit-scrollbar-track{background:transparent}.move-history-list::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:2px}.gr-chat-react{display:flex;flex-direction:column;height:100%}.gr-chat-header-row{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-weight:600;font-size:.85rem;color:#fff9;border-bottom:1px solid var(--gr-panel-border)}.gr-chat-spectator{font-size:.72rem;color:var(--gr-text-muted)}.gr-chat-messages{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px;min-height:120px;max-height:250px}.gr-chat-messages::-webkit-scrollbar{width:4px}.gr-chat-messages::-webkit-scrollbar-track{background:transparent}.gr-chat-messages::-webkit-scrollbar-thumb{background:var(--gr-panel-border);border-radius:2px}.gr-chat-msg{display:flex;align-items:baseline;gap:6px;font-size:.8rem;line-height:1.4;padding:2px 0}.gr-chat-role{font-size:.7rem;flex-shrink:0}.gr-chat-sender{font-weight:600;flex-shrink:0}.gr-chat-text{color:#fff;word-break:break-word}.gr-chat-time{font-size:.65rem;color:var(--gr-text-muted);margin-left:auto;flex-shrink:0}.gr-chat-system{font-size:.75rem;color:#d4a017;font-style:italic;padding:2px 0}.gr-chat-input-row{display:flex;gap:4px;padding:8px;border-top:1px solid var(--gr-panel-border)}.gr-chat-input{flex:1;background:#ffffff0d;border:1px solid var(--gr-panel-border);border-radius:8px;color:#fff;padding:4px 8px;font-size:.8rem;outline:none;transition:border-color .15s}.gr-chat-input:focus{border-color:#c8a05080}.gr-chat-send{padding:4px 8px;font-size:.85rem;background:#ffd70026;border:1px solid rgba(255,215,0,.3);border-radius:8px;color:#d4a017;cursor:pointer;transition:background .15s}.gr-chat-send:hover{background:#ffd70040}.gr-check-popup{animation:grCheckAppear .3s cubic-bezier(.34,1.56,.64,1)}.gr-check-popup.gr-check-fading{animation:grCheckFadeOut .5s ease-out forwards}@keyframes grCheckAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.7)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes grCheckFadeOut{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.9) translateY(-10px)}}@keyframes grCheckShake{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-4px) rotate(-3deg)}75%{transform:translate(4px) rotate(3deg)}}.gr-player-card.active-turn{animation:grActiveTurnPulse 1.8s ease-in-out infinite}@keyframes grActiveTurnPulse{0%,to{box-shadow:0 4px 20px #0000004d,0 0 #b0703000}50%{box-shadow:0 4px 20px #0000004d,0 0 18px 3px #b0703040}}@media(max-width:767px){.gr-mb-player.active-turn .gr-mb-avatar{animation:grActiveMbPulse 1.8s ease-in-out infinite}@keyframes grActiveMbPulse{0%,to{box-shadow:0 0 0 2.5px #f0c06080,0 3px 10px #0000008c}50%{box-shadow:0 0 0 4px #f0c060b3,0 0 16px #f0c06066,0 3px 10px #0000008c}}.gr-mb-player.active-turn .gr-mb-name{animation:grActiveNameBlink 1.8s ease-in-out infinite}@keyframes grActiveNameBlink{0%,to{opacity:1}50%{opacity:.7}}}@keyframes grLastMoveAppear{0%{opacity:0;transform:translate(-50%) translateY(6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.ghm-container{flex:1;padding:0 0 20px;overflow-y:auto}.ghm-player-banner{margin:10px 14px;padding:16px 18px;background:linear-gradient(135deg,var(--ds-header-bg) 0%,#4a2010 100%);border-radius:var(--ds-radius-lg);box-shadow:0 4px 16px #00000040;color:var(--ds-header-text)}.ghm-player-title-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.ghm-player-icon{font-size:1.2rem;line-height:1}.ghm-player-title{font-family:var(--ds-font-serif);font-size:1.05rem;font-weight:800;letter-spacing:.5px}.ghm-player-stats{display:flex;align-items:center;gap:8px;font-size:.72rem;opacity:.8}.ghm-stat-sep{opacity:.4}.ghm-tier-progress{display:flex;align-items:flex-start;justify-content:center;padding:16px 14px 8px;gap:0;position:relative}.ghm-tier-node{display:flex;flex-direction:column;align-items:center;position:relative;flex:1;min-width:0}.ghm-tier-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;background:var(--ds-card);border:2px solid var(--ds-border);box-shadow:var(--ds-shadow-sm);transition:all .3s ease;position:relative;z-index:2}.ghm-tier-icon{font-size:.9rem;line-height:1}.ghm-tier-label{font-size:.55rem;font-weight:700;color:var(--ds-text-muted);margin-top:5px;text-align:center;letter-spacing:.3px;white-space:nowrap}.ghm-tier-line{position:absolute;top:18px;left:calc(50% + 18px);right:calc(-50% + 18px);width:calc(100% - 36px);left:calc(50% + 20px);height:2px;background:var(--ds-border);z-index:1}.ghm-tier-scene{position:relative;margin:10px 14px;border-radius:var(--ds-radius-xl);overflow:hidden;height:140px;box-shadow:var(--ds-shadow-card)}.ghm-tier-scene-img{width:100%;height:100%;object-fit:cover;display:block}.ghm-tier-scene-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000a6,#0003,#0000000d)}.ghm-tier-scene-title{position:absolute;bottom:12px;left:16px;display:flex;align-items:center;gap:8px;z-index:2}.ghm-tier-scene-icon{font-size:1.3rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.ghm-tier-scene-label{font-family:var(--ds-font-serif);font-size:1.1rem;font-weight:900;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5);letter-spacing:1px}.ghm-opponents-list{display:flex;flex-direction:column;gap:8px;padding:0 14px}.ghm-opp-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-sm);cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.ghm-opp-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ds-border);transition:background .2s}.ghm-opp-card:hover{border-color:var(--ds-border-strong);box-shadow:var(--ds-shadow-md);transform:translateY(-1px)}.ghm-opp-card:hover:before{background:var(--ds-primary)}.ghm-opp-card.defeated{opacity:.55;cursor:default}.ghm-opp-card.defeated:hover{transform:none;box-shadow:var(--ds-shadow-sm)}.ghm-opp-card.boss:before{background:var(--ds-gold);width:3px}.ghm-opp-card.boss{border-color:#c8960a4d;background:linear-gradient(135deg,var(--ds-card) 0%,rgba(200,150,10,.04) 100%)}.ghm-opp-avatar{width:44px;height:44px;border-radius:50%;background:var(--ds-card-secondary);border:1.5px solid var(--ds-border);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.ghm-opp-card.boss .ghm-opp-avatar{border-color:var(--ds-gold);box-shadow:0 0 0 2px #c8960a26}.ghm-opp-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.ghm-opp-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.ghm-opp-name{font-size:.85rem;font-weight:700;color:var(--ds-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ghm-opp-title{font-size:.68rem;font-weight:500;color:var(--ds-text-muted)}.ghm-opp-location{font-size:.62rem;color:var(--ds-text-light);margin-top:1px}.ghm-opp-status{flex-shrink:0}.ghm-opp-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--ds-radius-full);font-size:.68rem;font-weight:700}.ghm-opp-badge--done{font-size:1rem}.ghm-opp-badge--boss{background:#c8960a1f;color:var(--ds-gold);border:1px solid rgba(200,150,10,.25)}.ghm-opp-badge--go{font-size:1.1rem;color:var(--ds-text-light)}.ghm-empty{text-align:center;padding:40px 20px;color:var(--ds-text-muted);font-size:.82rem}.ghm-empty span{font-size:2rem;display:block;margin-bottom:12px}.ghm-empty p{margin:0;line-height:1.5}@keyframes ghm-pulse{0%,to{box-shadow:0 0 0 4px #8b1e1e1f,var(--ds-shadow-md)}50%{box-shadow:0 0 0 8px #8b1e1e0f,var(--ds-shadow-md)}}.ghm-player-banner{cursor:pointer}.ghm-player-expand{margin-left:auto;font-size:.65rem;opacity:.5;transition:transform .2s}.ghm-stats-expanded{margin-top:12px;padding-top:10px;border-top:1px solid rgba(255,255,255,.1)}.ghm-stats-grid{display:flex;gap:12px;margin-bottom:10px}.ghm-stat-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.ghm-stat-icon{font-size:1rem}.ghm-stat-val{font-size:.85rem;font-weight:800}.ghm-stat-label{font-size:.55rem;opacity:.7}.ghm-reset-btn{width:100%;padding:6px 12px;border:1px solid rgba(255,255,255,.15);border-radius:var(--ds-radius-md);background:#ffffff0f;color:#fff9;font-family:var(--ds-font);font-size:.7rem;font-weight:600;cursor:pointer;transition:all .2s}.ghm-reset-btn:hover{background:#c8323226;border-color:#c832324d;color:#f08080}.ghm-reset-confirm{margin:8px 14px;padding:14px;background:#c8323214;border:1px solid rgba(200,50,50,.2);border-radius:var(--ds-radius-md);text-align:center}.ghm-reset-confirm p{margin:0 0 10px;font-size:.82rem;font-weight:600;color:var(--ds-text)}.ghm-reset-actions{display:flex;gap:8px;justify-content:center}.ghm-duyen-banner{position:relative;display:flex;align-items:center;gap:10px;margin:8px 14px;padding:14px 16px;background:linear-gradient(135deg,#3a2a0a,#604010);border:1px solid rgba(200,160,50,.3);border-radius:var(--ds-radius-lg);cursor:pointer;overflow:hidden;transition:transform .2s;animation:ghm-shimmer 3s ease-in-out infinite}.ghm-duyen-banner:hover{transform:scale(1.01)}@keyframes ghm-shimmer{0%,to{box-shadow:0 4px 16px #c8a03226}50%{box-shadow:0 4px 24px #c8a0324d}}.ghm-duyen-glow{position:absolute;top:-50%;right:-20%;width:120px;height:120px;background:radial-gradient(circle,rgba(200,160,50,.25) 0%,transparent 70%);pointer-events:none}.ghm-duyen-icon{font-size:1.5rem;flex-shrink:0;animation:rpgIconPulse 1.5s ease-in-out infinite}@keyframes rpgIconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.ghm-duyen-info{flex:1;display:flex;flex-direction:column;gap:2px}.ghm-duyen-title{font-size:.72rem;font-weight:700;color:#f0d070}.ghm-duyen-name{font-size:.82rem;font-weight:600;color:#ffffffd9}.ghm-duyen-arrow{font-size:1.1rem;color:#f0d070;flex-shrink:0}.omp-page{font-family:var(--ds-font)}.omp-scroll{padding:0}.omp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px;color:var(--ds-text-muted)}.omp-header-transparent{position:relative;z-index:10;background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important}.omp-scene{position:relative;height:280px;margin:-52px 0 0;overflow:hidden;opacity:0;transform:scale(1.05);transition:all .8s cubic-bezier(.25,1,.5,1)}.omp-scene.visible{opacity:1;transform:scale(1)}.omp-scene-bg{width:100%;height:100%;object-fit:cover;display:block}.omp-scene-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#00000026,#0000000d,#0003 60%,#000000b3)}.omp-entrance{position:absolute;bottom:65px;left:50%;transform:translate(-50%) translateY(30px) scale(.8);opacity:0;transition:all .7s cubic-bezier(.34,1.56,.64,1) .3s;z-index:3}.omp-entrance.visible{opacity:1;transform:translate(-50%) translateY(0) scale(1)}.omp-avatar-large{width:90px;height:90px;border-radius:50%;background:var(--ds-card-secondary);border:3px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-size:2.4rem;box-shadow:0 6px 30px #0006,0 0 0 5px #ffffff1a;overflow:hidden;animation:omp-avatar-glow 3s ease-in-out infinite}@keyframes omp-avatar-glow{0%,to{box-shadow:0 6px 30px #0006,0 0 0 5px #ffffff1a}50%{box-shadow:0 6px 40px #00000080,0 0 0 8px #ffffff26}}.omp-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.omp-scene-name{position:absolute;bottom:12px;left:0;right:0;text-align:center;z-index:4;opacity:0;transform:translateY(10px);transition:all .5s ease .6s}.omp-scene-name.visible{opacity:1;transform:translateY(0)}.omp-name{font-family:var(--ds-font-serif);font-size:1.25rem;font-weight:900;color:#fff;margin:0;letter-spacing:1px;text-shadow:0 2px 12px rgba(0,0,0,.6)}.omp-title-badge{font-size:.72rem;font-weight:600;color:#ffffffbf;text-shadow:0 1px 4px rgba(0,0,0,.5);display:block;margin-top:2px}.omp-boss-tag{display:inline-flex;align-items:center;gap:4px;margin-top:6px;padding:3px 12px;border-radius:var(--ds-radius-full);background:#c8960a40;border:1px solid rgba(200,150,10,.4);color:#f0d070;font-size:.65rem;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.3)}.omp-location-tag{display:flex;align-items:center;gap:6px;padding:8px 16px;margin:0 14px 4px;font-size:.7rem;color:var(--ds-text-muted);opacity:0;transform:translateY(6px);transition:all .4s ease .8s}.omp-location-tag.visible{opacity:1;transform:translateY(0)}.omp-location-pin{font-size:.85rem}.omp-narration{padding:8px 18px 4px;cursor:pointer;animation:omp-fadein .3s ease}.omp-narration p{margin:0;font-size:.78rem;line-height:1.65;color:var(--ds-text-muted);text-align:center;font-style:italic}.omp-cursor{display:inline-block;color:var(--ds-primary);animation:omp-blink .5s steps(2) infinite;font-weight:400;margin-left:1px;font-size:.75rem}.omp-cursor.hidden{display:none}@keyframes omp-blink{0%{opacity:1}50%{opacity:0}}.omp-dialogue-animated{animation:omp-bubble-enter .4s cubic-bezier(.34,1.4,.64,1);cursor:pointer}@keyframes omp-bubble-enter{0%{opacity:0;transform:translate(-12px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}.omp-dialogue{display:flex;gap:10px;padding:8px 14px}.omp-dialogue-avatar{width:40px;height:40px;border-radius:50%;background:var(--ds-card-secondary);border:2px solid var(--ds-primary);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;overflow:hidden;box-shadow:0 2px 8px #00000026}.omp-dialogue-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.omp-dialogue-bubble{flex:1;padding:12px 16px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:4px var(--ds-radius-lg) var(--ds-radius-lg) var(--ds-radius-lg);box-shadow:var(--ds-shadow-sm);position:relative}.omp-dialogue-bubble:before{content:"";position:absolute;left:-8px;top:12px;width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-right:8px solid var(--ds-card-border)}.omp-dialogue-bubble:after{content:"";position:absolute;left:-7px;top:12px;width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-right:8px solid var(--ds-card)}.omp-dialogue-name{font-size:.7rem;font-weight:700;color:var(--ds-primary);display:block;margin-bottom:4px}.omp-dialogue-text{margin:0;font-size:.82rem;line-height:1.6;color:var(--ds-text);font-style:italic}.omp-fadein{animation:omp-fadein .5s ease}@keyframes omp-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.omp-mystery-hint{display:flex;gap:10px;margin:8px 14px;padding:12px 14px;background:#c8960a0f;border:1px dashed rgba(200,150,10,.2);border-radius:var(--ds-radius-md)}.omp-mystery-icon{font-size:1.2rem;flex-shrink:0}.omp-mystery-hint p{margin:0;font-size:.75rem;line-height:1.5;color:var(--ds-gold);font-style:italic}.omp-event-box{margin:8px 14px;padding:16px;background:linear-gradient(135deg,var(--ds-card) 0%,rgba(200,100,10,.05) 100%);border:1px solid rgba(200,100,10,.2);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-sm)}.omp-event-badge{font-size:.72rem;font-weight:700;color:var(--ds-primary);margin-bottom:8px}.omp-event-desc{margin:0 0 12px;font-size:.78rem;line-height:1.55;color:var(--ds-text)}.omp-choices{display:flex;flex-direction:column;gap:8px}.omp-choice-btn{display:flex;flex-direction:column;gap:2px;padding:12px 14px;border:1.5px solid var(--ds-border);border-radius:var(--ds-radius-md);background:var(--ds-card-secondary);cursor:pointer;text-align:left;font-family:var(--ds-font);transition:all .2s}.omp-choice-btn:hover{border-color:var(--ds-primary);background:var(--ds-primary-light)}.omp-choice-btn.selected{border-color:var(--ds-primary);background:var(--ds-primary-light);box-shadow:0 0 0 2px #8b1e1e1f}.omp-choice-label{font-size:.82rem;font-weight:700;color:var(--ds-text)}.omp-choice-effect{font-size:.65rem;color:var(--ds-text-muted)}.omp-reward-preview{display:flex;align-items:center;gap:10px;margin:10px 14px;padding:10px 14px;background:#c8960a0f;border:1px solid rgba(200,150,10,.15);border-radius:var(--ds-radius-md)}.omp-reward-tag{font-size:.7rem;font-weight:700;color:var(--ds-gold);flex-shrink:0}.omp-reward-name{font-size:.78rem;font-weight:600;color:var(--ds-text)}.omp-bottom-bar{position:fixed;bottom:0;left:0;right:0;display:flex;gap:10px;padding:12px 14px;padding-bottom:max(12px,env(safe-area-inset-bottom));background:linear-gradient(to top,var(--ds-bg) 80%,transparent);z-index:30}.omp-fight-btn{flex:2;border-radius:var(--ds-radius-full);letter-spacing:.5px;font-weight:700;animation:omp-fight-pulse 2s ease-in-out infinite}@keyframes omp-fight-pulse{0%,to{box-shadow:0 2px 10px #8b1e1e4d}50%{box-shadow:0 4px 20px #8b1e1e80}}.omp-skip-btn{flex:1;border-radius:var(--ds-radius-full);font-size:.75rem}.rpg-result-page{font-family:var(--ds-font)}.rpg-result-scroll{padding:0}.rpg-result-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px;color:var(--ds-text-muted)}.rpg-result-banner{display:flex;flex-direction:column;align-items:center;padding:32px 20px 24px;margin:14px;border-radius:var(--ds-radius-xl);box-shadow:var(--ds-shadow-card);animation:rpgBannerSlideIn .6s cubic-bezier(.34,1.56,.64,1)}@keyframes rpgBannerSlideIn{0%{opacity:0;transform:scale(.85) translateY(-16px)}to{opacity:1;transform:scale(1) translateY(0)}}.rpg-result-icon{font-size:2.5rem;line-height:1;margin-bottom:8px;animation:rpgIconPulse 1.5s ease-in-out infinite}@keyframes rpgIconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.rpg-result-title{font-family:var(--ds-font-serif);font-size:1.6rem;font-weight:900;margin:0;letter-spacing:2px}.rpg-result-reason{font-size:.72rem;color:#fff9;margin-top:6px}.rpg-result-opponent{display:flex;align-items:center;gap:12px;margin:10px 14px;padding:12px 16px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:var(--ds-radius-lg)}.rpg-result-opp-avatar{width:44px;height:44px;border-radius:50%;background:var(--ds-card-secondary);border:1.5px solid var(--ds-border);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;overflow:hidden}.rpg-result-opp-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.rpg-result-opp-info{display:flex;flex-direction:column;gap:2px}.rpg-result-opp-name{font-size:.85rem;font-weight:700;color:var(--ds-text)}.rpg-result-opp-title{font-size:.68rem;color:var(--ds-text-muted)}.rpg-result-dialogue{display:flex;gap:10px;padding:8px 14px;animation:rpgFadeIn .5s ease .4s both}@keyframes rpgFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.rpg-result-dialogue-avatar{width:32px;height:32px;border-radius:50%;background:var(--ds-card-secondary);border:1px solid var(--ds-border);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;overflow:hidden}.rpg-result-dialogue-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.rpg-result-dialogue-bubble{flex:1;padding:10px 14px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:2px var(--ds-radius-lg) var(--ds-radius-lg) var(--ds-radius-lg)}.rpg-result-dialogue-bubble p{margin:0;font-size:.78rem;line-height:1.55;color:var(--ds-text);font-style:italic}.rpg-result-reward{position:relative;margin:10px 14px;padding:18px 16px;background:linear-gradient(135deg,var(--ds-card) 0%,rgba(200,150,10,.06) 100%);border:1px solid rgba(200,150,10,.25);border-radius:var(--ds-radius-lg);overflow:hidden;animation:rpgRewardReveal .6s cubic-bezier(.34,1.56,.64,1) .8s both}@keyframes rpgRewardReveal{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.rpg-result-reward-glow{position:absolute;top:-30%;left:50%;transform:translate(-50%);width:200px;height:200px;background:radial-gradient(circle,rgba(200,160,50,.15) 0%,transparent 70%);pointer-events:none;animation:rpgGlowPulse 2s ease-in-out infinite}@keyframes rpgGlowPulse{0%,to{opacity:.6}50%{opacity:1}}.rpg-result-reward-badge{display:inline-block;font-size:.72rem;font-weight:700;color:var(--ds-gold);margin-bottom:8px;position:relative;z-index:2}.rpg-result-reward-card{position:relative;z-index:2}.rpg-result-reward-name{display:block;font-family:var(--ds-font-serif);font-size:.95rem;font-weight:800;color:var(--ds-text);margin-bottom:4px}.rpg-result-reward-desc{margin:0;font-size:.72rem;line-height:1.5;color:var(--ds-text-muted)}.rpg-result-stats{margin:10px 14px;padding:10px 14px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:var(--ds-radius-md)}.rpg-result-stat-row{display:flex;align-items:center;justify-content:space-between;font-size:.78rem;font-weight:600;color:var(--ds-text)}.rpg-result-bottom{position:fixed;bottom:0;left:0;right:0;display:flex;gap:10px;padding:12px 14px;background:var(--ds-bg);border-top:1px solid var(--ds-border);z-index:30}.rpg-result-btn-map{flex:2;border-radius:var(--ds-radius-full);letter-spacing:.5px;font-weight:700}.rpg-result-btn-retry{flex:1;border-radius:var(--ds-radius-full);font-size:.75rem}.tn-page{background:var(--ds-bg)}.tn-xu-badge{display:flex;align-items:center;gap:4px;padding:4px 12px;background:#c8960a26;border:1px solid rgba(200,150,10,.3);border-radius:var(--ds-radius-full);font-size:.82rem;font-weight:700;color:var(--ds-gold)}.tn-xu-icon{font-size:.9rem}.tn-scroll{padding:0 var(--ds-page-px)}.tn-resume-banner{display:flex;align-items:center;gap:12px;padding:14px 16px;margin:12px 0;background:linear-gradient(135deg,var(--ds-primary),#6d1717);border-radius:var(--ds-radius-lg);color:#fff;cursor:pointer;position:relative;overflow:hidden;animation:tn-pulse 2s ease infinite}@keyframes tn-pulse{0%,to{box-shadow:0 0 #8b1e1e66}50%{box-shadow:0 0 0 8px #8b1e1e00}}.tn-resume-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 80% 50%,rgba(255,255,255,.12) 0%,transparent 60%);pointer-events:none}.tn-resume-icon{font-size:1.5rem}.tn-resume-info{flex:1;display:flex;flex-direction:column;gap:2px}.tn-resume-label{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;opacity:.8}.tn-resume-name{font-size:.95rem;font-weight:700}.tn-resume-arrow{font-size:1.2rem;opacity:.7}.tn-filters{margin:12px 0;display:flex;flex-direction:column;gap:10px}.tn-filter-row{display:flex;flex-direction:column;gap:6px}.tn-filter-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--ds-text-light)}.tn-filters .ds-chip-group{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px}.tn-filters .ds-chip{font-size:.75rem;padding:6px 14px;flex-shrink:0}.tn-list{display:flex;flex-direction:column;gap:16px;margin-top:8px}.tn-card{overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s}.tn-card:hover{transform:translateY(-2px);box-shadow:var(--ds-shadow-lg)}.tn-card:active{transform:scale(.98)}.tn-card-header{display:flex;align-items:center;gap:12px;padding:16px;color:#fff;position:relative;overflow:hidden}.tn-card-bg-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:.35;z-index:0;pointer-events:none}.tn-card-icon{font-size:2rem;position:relative;z-index:1}.tn-card-title-area{flex:1;position:relative;z-index:1}.tn-card-name{font-family:var(--ds-font-serif);font-size:1.05rem;font-weight:700;margin:0;line-height:1.3}.tn-card-province{font-size:.75rem;opacity:.85;margin-top:2px}.tn-card-body{padding:12px 16px 16px}.tn-card-desc{font-size:.82rem;color:var(--ds-text-muted);line-height:1.5;margin:0 0 12px}.tn-card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.tn-card-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--ds-radius-full);font-size:.72rem;font-weight:700;border:1px solid}.tn-card-players,.tn-card-level{font-size:.75rem;color:var(--ds-text-muted);display:flex;align-items:center;gap:4px}.tn-card-prizes{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;padding:10px 12px;background:var(--ds-card-secondary);border-radius:var(--ds-radius-md);border:1px solid var(--ds-border)}.tn-card-prize{font-size:.78rem;color:var(--ds-text);font-weight:600}.tn-prize-1{color:var(--ds-gold)}.tn-prize-2{color:var(--ds-text-muted)}.tn-prize-3{color:var(--ds-text-light)}.tn-card-footer{display:flex;align-items:center;justify-content:space-between}.tn-card-fee{font-size:.82rem;font-weight:700;color:var(--ds-gold)}.tn-card-join{min-width:100px}.tn-empty{text-align:center;padding:60px 20px;color:var(--ds-text-muted)}.tn-empty span{font-size:3rem;display:block;margin-bottom:12px}.tn-card--active{border-color:var(--ds-primary)!important;box-shadow:0 0 0 2px #8b1e1e26,var(--ds-shadow-md)}.tn-card-active-badge{position:absolute;top:8px;right:10px;z-index:2;background:#0009;color:#fff;font-size:.68rem;font-weight:700;padding:4px 10px;border-radius:var(--ds-radius-full);letter-spacing:.5px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:tn-pulse 2s ease infinite}.tn-card-join--resume{background:var(--ds-green)!important;box-shadow:0 2px 8px #27ae604d}.tn-card-join--resume:hover{background:#1e9651!important}.tn-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:tn-fade-in .2s ease}@keyframes tn-fade-in{0%{opacity:0}to{opacity:1}}.tn-confirm-dialog{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);padding:28px 24px;max-width:380px;width:100%;text-align:center;box-shadow:0 20px 60px #0006;animation:tn-dialog-in .3s ease}@keyframes tn-dialog-in{0%{transform:scale(.9) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.tn-confirm-icon{color:var(--ds-gold);margin-bottom:8px}.tn-confirm-title{font-size:1.1rem;font-weight:700;font-family:var(--ds-font-serif);color:var(--ds-text);margin:0 0 10px}.tn-confirm-text{font-size:.85rem;color:var(--ds-text-muted);line-height:1.6;margin:0 0 8px}.tn-confirm-warning{font-size:.78rem;color:var(--ds-red-dot, #e74c3c);background:#e74c3c14;border:1px solid rgba(231,76,60,.2);border-radius:var(--ds-radius-md);padding:10px 14px;margin:0 0 20px;line-height:1.5}.tn-confirm-actions{display:flex;gap:10px;justify-content:center}.tn-confirm-cancel{flex:1;padding:10px 16px!important;font-size:.85rem!important}.tn-confirm-switch{flex:1;padding:10px 16px!important;font-size:.85rem!important;background:var(--ds-primary)!important}.tp-page{background:var(--ds-bg)}.tp-scroll{padding:0 var(--ds-page-px);position:relative;background:linear-gradient(180deg,transparent 0%,rgba(var(--ds-bg-rgb, 245,240,230),.15) 100%),url(/tournament/bg_scroll_texture.png) top center / cover no-repeat;background-attachment:local}.tp-scroll:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--ds-bg);opacity:.65;pointer-events:none;z-index:0}.tp-scroll>*{position:relative;z-index:1}.tp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 20px;text-align:center;color:var(--ds-text-muted)}.tp-info-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;color:#fff}.tp-info-icon{font-size:1.5rem}.tp-info-text{flex:1;display:flex;flex-direction:column;gap:2px}.tp-info-format{font-size:.78rem;font-weight:700;opacity:.9}.tp-info-detail{font-size:.72rem;opacity:.7}.tp-result-btn{background:#fff3!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important}.tp-tabs{display:flex;border-bottom:2px solid var(--ds-border)}.tp-tab{flex:1;padding:12px;border:none;background:none;font-family:var(--ds-font);font-size:.82rem;font-weight:700;color:var(--ds-text-muted);cursor:pointer;transition:all .2s;border-bottom:3px solid transparent}.tp-tab.active{color:var(--ds-primary);border-bottom-color:var(--ds-primary)}.tp-swiss-pairings{margin-top:16px}.tp-round-label{text-align:center;font-size:.85rem;font-weight:700;color:var(--ds-primary);margin-bottom:12px;letter-spacing:1px}.tp-pairings-table{width:100%}.tp-pair-header,.tp-pair-row{display:grid;grid-template-columns:36px 1fr 30px 1fr 70px;gap:4px;align-items:center;padding:8px}.tp-pair-header{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--ds-text-light);border-bottom:2px solid var(--ds-border)}.tp-pair-row{border-bottom:1px solid var(--ds-border);font-size:.82rem;transition:background .15s}.tp-pair-row:last-child{border-bottom:none}.tp-pair-highlight{background:var(--ds-primary-light)!important;border-radius:var(--ds-radius-md)}.tp-pair-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-pair-num{text-align:center;font-weight:700;color:var(--ds-text-light)}.tp-pair-vs{text-align:center;font-size:.7rem}.tp-pair-result{text-align:center;font-weight:700}.tp-pair-result.done{color:var(--ds-primary)}.tp-player-name{font-weight:700;color:var(--ds-primary)!important}.tp-play-btn{font-size:.68rem!important;padding:4px 8px!important}.tp-standings{margin-top:16px}.tp-standings-table{width:100%}.tp-standings-header,.tp-standings-row{display:grid;grid-template-columns:36px 1fr 50px 50px 50px 40px;gap:2px;align-items:center;padding:8px 6px}.tp-standings-header{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--ds-text-light);border-bottom:2px solid var(--ds-border)}.tp-standings-row{font-size:.8rem;border-bottom:1px solid var(--ds-border);transition:background .15s}.tp-player-row{background:var(--ds-primary-light);border-radius:var(--ds-radius-sm);font-weight:700}.tp-st-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-st-rank{text-align:center;font-size:.9rem}.tp-st-name{display:flex;align-items:center;gap:4px}.tp-st-avatar{font-size:.9rem}.tp-st-pts,.tp-st-bh,.tp-st-bh1,.tp-st-win{text-align:center;font-size:.75rem}.tp-you-badge{background:var(--ds-primary);color:#fff;font-size:.6rem;padding:1px 6px;border-radius:var(--ds-radius-full);font-weight:700}.tp-bracket{margin-top:16px}.tp-bracket-scroll{display:flex;gap:8px;overflow-x:auto;padding:8px 0 16px;-webkit-overflow-scrolling:touch}.tp-bracket-round{min-width:160px;flex-shrink:0;display:flex;flex-direction:column;gap:8px}.tp-bracket-round-label{text-align:center;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--ds-text-light);padding:6px 0;border-bottom:2px solid var(--ds-border);margin-bottom:4px}.tp-bracket-matches{display:flex;flex-direction:column;gap:8px;justify-content:space-around;flex:1}.tp-bracket-match{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-md);padding:8px;display:flex;flex-direction:column;gap:4px;position:relative;transition:all .2s}.tp-bracket-match.done{opacity:.85}.tp-bracket-highlight{border-color:var(--ds-primary)!important;box-shadow:0 0 0 2px #8b1e1e26}.tp-bracket-slot{display:flex;align-items:center;gap:6px;padding:4px 6px;border-radius:var(--ds-radius-sm);font-size:.78rem;transition:background .15s}.tp-bracket-slot.winner{background:var(--ds-green-light);font-weight:700}.tp-bracket-slot.is-player{color:var(--ds-primary);font-weight:700}.tp-bracket-seed{font-size:.85rem}.tp-bracket-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-char-img{width:28px;height:28px;border-radius:50%;object-fit:cover;border:2px solid var(--ds-card-border);flex-shrink:0}.tp-st-avatar.tp-char-img{width:24px;height:24px;border-width:1.5px}.tp-bracket-slot .tp-char-img{width:26px;height:26px}.tp-bracket-win-icon{color:var(--ds-green);font-weight:700}.tp-bracket-vs{text-align:center;font-size:.65rem;color:var(--ds-text-light);letter-spacing:1px}.tp-bracket-play{width:100%;margin-top:4px;font-size:.72rem!important}.tp-bracket-bye{text-align:center;font-size:.68rem;color:var(--ds-text-light);font-weight:700;letter-spacing:1px}.tp-double-bracket{margin-top:12px;display:flex;flex-direction:column;gap:20px}.tp-double-section{border:2px solid var(--ds-border);border-radius:var(--ds-radius-lg);overflow:hidden}.tp-double-section-label{padding:10px 14px;font-size:.85rem;font-weight:700;display:flex;align-items:center;gap:8px}.tp-winners-label{background:#27ae601a;color:var(--ds-green);border-bottom:2px solid rgba(39,174,96,.2)}.tp-losers-label{background:#c0392b1a;color:var(--ds-red-dot);border-bottom:2px solid rgba(192,57,43,.2)}.tp-gf-label{background:#c8960a1f;color:var(--ds-gold);border-bottom:2px solid rgba(200,150,10,.25)}.tp-grand-final-section{border-color:var(--ds-gold)!important}.tp-here-badge{font-size:.68rem;background:var(--ds-green);color:#fff;padding:2px 8px;border-radius:var(--ds-radius-full);animation:tn-pulse 2s ease infinite}.tp-here-losers{background:var(--ds-red-dot)}.tp-gf-match{border-color:var(--ds-gold)!important;box-shadow:0 0 12px #c8960a33}.tp-reset-label{text-align:center;padding:8px;font-size:.78rem;font-weight:700;color:var(--ds-gold)}.tp-champion-announce{text-align:center;padding:16px;font-size:1.1rem;font-weight:700;color:var(--ds-gold);animation:tr-glow 1.5s ease infinite}.tp-bottom-area{margin-top:20px}.tp-enter-btn{font-size:1rem!important;padding:16px!important}.tp-eliminated-notice{text-align:center;padding:24px;color:var(--ds-text-muted)}.tp-eliminated-notice span{font-size:2.5rem;display:block;margin-bottom:8px}.tp-abandon-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.tp-abandon-modal{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);padding:24px;max-width:360px;text-align:center}.tp-abandon-modal h3{margin:0 0 8px;font-size:1.1rem;color:var(--ds-text)}.tp-abandon-modal p{font-size:.85rem;color:var(--ds-text-muted);margin:0 0 16px}.tp-abandon-actions{display:flex;gap:8px;justify-content:center}.tr-page{background:var(--ds-bg)}.tr-scroll{padding:0 var(--ds-page-px)}.tr-empty,.tr-claimed{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 20px;text-align:center}.tr-claimed-icon{font-size:4rem;animation:tr-bounce .8s ease}@keyframes tr-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.tr-tournament-name{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;font-family:var(--ds-font-serif);font-size:1.1rem;font-weight:700;color:var(--ds-text)}.tr-tn-icon{font-size:1.5rem}.tr-podium{position:relative;padding:20px 0 0;overflow:hidden}.tr-podium-row{display:flex;align-items:flex-end;justify-content:center;gap:8px;min-height:220px}.tr-podium-item{display:flex;flex-direction:column;align-items:center;gap:4px;width:100px}.tr-podium-crown{font-size:1.8rem;animation:tr-crown 1s ease infinite alternate}@keyframes tr-crown{0%{transform:translateY(0)}to{transform:translateY(-4px)}}.tr-podium-avatar{width:50px;height:50px;border-radius:50%;background:var(--ds-card);border:3px solid var(--ds-border);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.tr-avatar-champion{width:64px;height:64px;border-color:var(--ds-gold);box-shadow:0 0 16px #c8960a66;font-size:2rem}.tr-podium-medal{font-size:1.2rem}.tr-podium-name{font-size:.75rem;font-weight:700;text-align:center;color:var(--ds-text);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tr-podium-you{background:var(--ds-primary);color:#fff;font-size:.6rem;padding:2px 8px;border-radius:var(--ds-radius-full);font-weight:700;animation:tn-pulse 1.5s ease infinite}.tr-podium-block{width:80px;border-radius:var(--ds-radius-sm) var(--ds-radius-sm) 0 0}.tr-block-1{height:100px;background:linear-gradient(180deg,#f0d060,#c8960a)}.tr-block-2{height:70px;background:linear-gradient(180deg,#d0d0d0,#aaa)}.tr-block-3{height:50px;background:linear-gradient(180deg,#d4a76a,#cd7f32)}.tr-your-result{display:flex;align-items:center;gap:16px;padding:20px;margin:20px 0;background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-md)}.tr-result-icon{font-size:2.5rem}.tr-result-text{flex:1}.tr-result-rank{font-size:1.2rem;font-weight:700;font-family:var(--ds-font-serif);color:var(--ds-text)}.tr-result-prize{font-size:.82rem;color:var(--ds-text-muted);margin-top:4px}.tr-section-label{font-size:.85rem;font-weight:700;color:var(--ds-text);margin-bottom:8px}.tr-full-standings{margin-top:20px}.tr-bottom{margin:24px 0}.tr-claim-btn{font-size:1rem!important;padding:16px!important}.tr-confetti-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:10}.tr-confetti-particle{position:absolute;width:8px;height:8px;background:var(--color, #f0d060);left:var(--x, 50%);top:-10px;border-radius:2px;animation:tr-confetti-fall 3s ease-out var(--delay, 0s) both}@keyframes tr-confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(300px) rotate(720deg);opacity:0}}@keyframes tr-glow{0%,to{text-shadow:0 0 4px rgba(200,150,10,.3)}50%{text-shadow:0 0 16px rgba(200,150,10,.6)}}.tr-tn-bg-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:.2;z-index:0;pointer-events:none;border-radius:var(--ds-radius-lg)}.tr-tournament-name .tr-tn-icon,.tr-tournament-name .tr-tn-text{position:relative;z-index:1}.tr-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.tr-prize-showcase{margin:20px 0;padding:20px;background:linear-gradient(135deg,#c8960a0f,#c8960a05);border:2px solid rgba(200,150,10,.2);border-radius:var(--ds-radius-lg)}.tr-prize-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:16px;margin-top:12px}.tr-prize-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:var(--ds-radius-md);transition:transform .2s,box-shadow .2s}.tr-prize-item:hover{transform:translateY(-3px);box-shadow:0 6px 20px #c8960a26}.tr-prize-img{width:80px;height:80px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.2))}.tr-prize-label{font-size:.72rem;font-weight:700;color:var(--ds-gold);text-align:center;line-height:1.3}.vs-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#1a0a0a,#0a0505 70%,#000);animation:vs-overlay-in .3s ease-out}@keyframes vs-overlay-in{0%{opacity:0}to{opacity:1}}.vs-bg-flash{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,rgba(200,150,10,.15) 0%,transparent 60%);animation:vs-flash 1.5s ease infinite;pointer-events:none}@keyframes vs-flash{0%,to{opacity:.3}50%{opacity:.8}}.vs-tournament-name{position:absolute;top:12%;font-family:var(--ds-font-serif);font-size:clamp(.9rem,3vw,1.4rem);font-weight:700;color:var(--ds-gold);text-transform:uppercase;letter-spacing:3px;text-shadow:0 0 20px rgba(200,150,10,.5);animation:vs-fade-in .6s .3s ease both;z-index:2}.vs-cards-row{display:flex;align-items:center;gap:clamp(16px,4vw,40px);z-index:2}.vs-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 20px;background:#140a0ab3;border:2px solid rgba(200,150,10,.3);border-radius:16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;overflow:hidden;min-width:clamp(120px,25vw,180px)}.vs-card-left{animation:vs-slide-left .6s .15s cubic-bezier(.16,1,.3,1) both}.vs-card-right{animation:vs-slide-right .6s .15s cubic-bezier(.16,1,.3,1) both}@keyframes vs-slide-left{0%{opacity:0;transform:translate(-120px) scale(.8)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes vs-slide-right{0%{opacity:0;transform:translate(120px) scale(.8)}to{opacity:1;transform:translate(0) scale(1)}}.vs-card-glow{position:absolute;top:-50%;right:-50%;bottom:-50%;left:-50%;border-radius:50%;pointer-events:none;filter:blur(40px);opacity:.3}.vs-glow-red{background:radial-gradient(circle,#c0392b 0%,transparent 70%)}.vs-glow-black{background:radial-gradient(circle,#2c3e50 0%,transparent 70%)}.vs-card-avatar{width:clamp(72px,15vw,100px);height:clamp(72px,15vw,100px);border-radius:50%;border:3px solid var(--ds-gold);overflow:hidden;display:flex;align-items:center;justify-content:center;background:#1e140a99;box-shadow:0 0 24px #c8960a4d;animation:vs-avatar-glow 1.5s ease infinite}@keyframes vs-avatar-glow{0%,to{box-shadow:0 0 16px #c8960a4d}50%{box-shadow:0 0 32px #c8960a99}}.vs-avatar-img{width:100%;height:100%;object-fit:cover}.vs-avatar-emoji{font-size:clamp(2.2rem,6vw,3rem)}.vs-card-info{display:flex;flex-direction:column;align-items:center;gap:4px;animation:vs-fade-in .5s .5s ease both}.vs-card-name{font-family:var(--ds-font-serif);font-size:clamp(.9rem,2.5vw,1.15rem);font-weight:700;color:#fff;text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.6)}.vs-card-title{font-size:clamp(.65rem,1.8vw,.78rem);color:var(--ds-gold);font-weight:600;letter-spacing:.5px;text-shadow:0 0 8px rgba(200,150,10,.3)}.vs-badge{position:relative;animation:vs-badge-pop .5s .5s cubic-bezier(.34,1.56,.64,1) both}@keyframes vs-badge-pop{0%{opacity:0;transform:scale(0) rotate(-20deg)}to{opacity:1;transform:scale(1) rotate(0)}}.vs-badge-text{display:block;font-family:var(--ds-font-serif);font-size:clamp(2rem,6vw,3.2rem);font-weight:900;color:#fff;text-shadow:0 0 12px rgba(200,150,10,.8),0 0 40px rgba(200,150,10,.4),0 2px 4px rgba(0,0,0,.5);letter-spacing:4px;animation:vs-badge-pulse 1s 1s ease infinite}@keyframes vs-badge-pulse{0%,to{text-shadow:0 0 12px rgba(200,150,10,.8),0 0 40px rgba(200,150,10,.4)}50%{text-shadow:0 0 24px rgba(200,150,10,1),0 0 60px rgba(200,150,10,.7)}}.vs-badge-sparks{position:absolute;top:-30px;right:-30px;bottom:-30px;left:-30px;background:radial-gradient(circle,rgba(200,150,10,.2) 0%,transparent 50%);animation:vs-sparks 1.2s ease infinite;pointer-events:none}@keyframes vs-sparks{0%,to{transform:scale(1);opacity:.3}50%{transform:scale(1.3);opacity:.6}}.vs-bottom-text{position:absolute;bottom:12%;font-size:clamp(.75rem,2vw,.9rem);color:#fff9;letter-spacing:2px;animation:vs-fade-in .5s .8s ease both,vs-bottom-blink 1.5s 1.3s ease infinite;z-index:2}@keyframes vs-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes vs-bottom-blink{0%,to{opacity:.6}50%{opacity:1}}
