: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)}.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-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-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-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}.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-find-btn{margin:0 10px;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-dev-banner{margin:14px 10px 0;display:flex;align-items:center;gap:8px;background:#c8960a14;border:2px solid rgba(200,150,10,.25);border-radius:var(--ds-radius-md);padding:10px 14px;font-size:.78rem;color:var(--ds-text-muted)}.pop-dev-banner em{color:var(--ds-gold);font-style:normal}.pop-mm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;background:#140a05e0;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pop-mm-overlay.hidden{display:none}.pop-mm-card{background:#1a1008;border:2px solid rgba(240,192,96,.2);border-radius:20px;padding:32px 30px;display:flex;flex-direction:column;align-items:center;gap:16px;min-width:260px;box-shadow:0 8px 40px #00000080}.pop-mm-title{font-size:1.05rem;font-weight:700;color:var(--ds-gold-light);margin:0;text-align:center}.pop-mm-radar{position:relative;width:100px;height:100px;display:flex;align-items:center;justify-content:center}.pop-mm-ring{position:absolute;border-radius:50%;border:2px solid rgba(240,192,96,.3);animation:pop-radar 2.4s ease-out infinite}.pop-mm-ring{width:100px;height:100px}.pop-mm-ring-2{width:65px;height:65px;animation-delay:.6s}.pop-mm-ring-3{width:38px;height:38px;animation-delay:1.2s}@keyframes pop-radar{0%{opacity:.8;transform:scale(.4)}to{opacity:0;transform:scale(1)}}.pop-mm-center{font-size:1.6rem;position:relative;z-index:2;animation:pop-spin 4s linear infinite}@keyframes pop-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pop-mm-timer{font-family:var(--ds-font-mono);font-size:1.5rem;font-weight:700;color:var(--ds-gold-light);letter-spacing:3px;margin:0}.pop-mm-cancel-btn{width:100%;background:var(--ds-primary);border-radius:var(--ds-radius-full)}.pop-mm-found-card{gap:14px}.pop-mm-found-icon{font-size:2.2rem}.pop-mm-opponent{display:flex;align-items:center;gap:12px}.pop-mm-opp-avatar{width:46px;height:46px;border-radius:50%;background:var(--ds-primary);display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#fff;font-weight:700}.pop-mm-opp-name{font-weight:700;color:var(--ds-gold-light);font-size:.95rem}.pop-mm-opp-elo{font-size:.78rem;color:#f0c06099}.pop-mm-redirect{font-size:.82rem;color:#f0c06099;margin:0}.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;max-height:100vh;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}.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;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;grid-column:unset!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:1;background:transparent!important;overflow:visible!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;background:linear-gradient(180deg,#000000c7,#0000);gap:10px;min-height:68px;pointer-events:auto}.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;background:linear-gradient(0deg,#000000d9,#0000);gap:10px;min-height:76px;pointer-events:auto}.gr-mb-player{display:flex;align-items:center;gap:9px;min-width:0;flex:1}.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:1.7rem;font-weight:900;letter-spacing:2px;color:#fff;padding:5px 14px;border-radius:12px;min-width:100px;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:84px;left:50%;transform:translate(-50%);z-index:25;font-size:.76rem;padding:4px 16px;white-space:nowrap}.gr-status-idle{opacity:0;pointer-events:none}.gr-slide-panel{width:100%}.gr-chat-popup{position:absolute;bottom:84px;left:10px;right:10px;width:auto;max-height:55vh}}@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}.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}
