: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;--bg-outer: #e8d8c0;--bg-main: #f5ede0;--bg-card: rgba(255, 255, 255, .15);--bg-card2: rgba(250, 246, 238, .1);--bg-input: #ffffff;--border-gold: #c4a878;--border-bright: #e0a820;--border-dim: #d4c4a0;--text-h: #f0c060;--text-body: #b09070;--text-muted: #7a5830;--accent-red: #c0392b;--accent-green: #27ae60;--btn-cta-bg: #8B1E1E;--btn-cta-text: #fff;--btn-2-bg: #d4c4a0;--btn-2-text: #3a1a0a;--toggle-track: #d4c4a0;--toggle-thumb: #fff;--toggle-on: #27ae60;--pillar-tint: rgba(200,160,80,.08);--header-bg: #3a1a0a;--scrollbar-track: #e8d8c0;--scrollbar-thumb: #c4a878;--shadow-card: 0 2px 10px rgba(0,0,0,.1);--corner-color: #c4a878;--icon-fill: #f0c060;--rank-gold: #e0a820;--rank-silver: #b0b8c0;--rank-bronze: #c87840;--ds-bg: #f5ede0;--ds-bg-pattern: #ede0c8;--ds-card: rgba(255, 255, 255, .15);--ds-card-secondary: rgba(200, 160, 100, .08);--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: #7a5830;--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-space-xs: 4px;--ds-space-sm: 8px;--ds-space-md: 12px;--ds-space-lg: 16px;--ds-space-xl: 24px;--ds-page-px: 12px;--ds-icon-sm: 20px;--ds-icon-md: 28px;--ds-icon-lg: 40px;--ds-icon-xl: 56px;--ds-transition: .2s ease}[data-theme=dark]{--bg-outer: #0a0604;--bg-main: #1a1714;--bg-card: rgba(34, 28, 24, .4);--bg-card2: rgba(26, 23, 20, .3);--bg-input: #1e1208;--border-gold: #5a3828;--border-bright: #c8a96e;--border-dim: #3a2818;--text-h: #f0c060;--text-body: #b09070;--text-muted: #8a6a4a;--accent-red: #e74c3c;--accent-green: #2ecc71;--btn-cta-bg: #8B1E1E;--btn-cta-text: #f0e0c8;--btn-2-bg: #3a2818;--btn-2-text: #b09070;--toggle-track: #3a2818;--toggle-thumb: #b09070;--toggle-on: #2ecc71;--pillar-tint: rgba(200,169,110,.06);--header-bg: #0e0804;--scrollbar-track: #1e1a14;--scrollbar-thumb: #4a3a20;--shadow-card: 0 4px 20px rgba(0,0,0,.6);--corner-color: #c8a96e;--icon-fill: #c8a96e;--rank-gold: #e8c040;--rank-silver: #b0c0c8;--rank-bronze: #c87840;--ds-bg: var(--bg-main);--ds-bg-pattern: var(--bg-outer);--ds-card: var(--bg-card);--ds-card-secondary: var(--bg-card2);--ds-card-border: var(--border-gold);--ds-header-bg: var(--header-bg);--ds-header-text: var(--text-h);--ds-header-border: rgba(200,169,110,.15);--ds-primary: var(--btn-cta-bg);--ds-primary-hover: #6d1414;--ds-primary-light: rgba(139,26,26,.15);--ds-text: var(--text-h);--ds-text-muted: var(--text-body);--ds-text-light: var(--text-muted);--ds-gold: var(--border-gold);--ds-gold-light: var(--border-bright);--ds-border: var(--border-dim);--ds-border-strong: var(--border-bright);--ds-green: var(--accent-green);--ds-green-light: rgba(74,138,58,.12);--ds-red-dot: var(--accent-red);--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: var(--shadow-card)}[data-theme=dark] body,[data-theme=premium] body{background-color:var(--bg-outer)}.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-color:var(--bg-outer)}}@media(min-width:640px){.ds-page{max-width:100%}}@media(min-width:900px){.ds-page{max-width:100%}}@media(min-width:1024px){.ds-page{max-width:100%}}.ds-page-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.ds-page>*:not(.ds-page-bg){position:relative;z-index:1}.ds-header{display:flex;align-items:center;height:52px;padding:0 var(--ds-space-md);background:var(--ds-header-bg);border-bottom:2px solid var(--ds-header-border);flex-shrink:0;gap:var(--ds-space-sm)}.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:1px;margin:0}.ds-header-back,.ds-header-icon{width:44px;height:44px;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:44px}.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-page:has(.ds-bottom-nav)>.ds-scroll{padding-bottom:72px}.ds-card{background-color:#ffffff26;border:1px solid rgba(196,168,120,.3);border-radius:var(--ds-radius-lg);box-shadow:0 2px 8px #643c140d}[data-theme=dark] .ds-card{background-color:#2a1a0e99}[data-theme=premium] .ds-card{background-color:#1a5c4499}.ds-card-secondary{background:#c8a06414;border:1px solid rgba(196,168,120,.2);border-radius:var(--ds-radius-lg)}[data-theme=dark] .ds-card-secondary{background:#0003}[data-theme=premium] .ds-card-secondary{background:#00140a26}.ds-card-header{display:flex;align-items:center;gap:var(--ds-space-md);padding:var(--ds-space-md) var(--ds-space-lg) var(--ds-space-sm)}.ds-card-title{font-size:1rem;font-weight:800;letter-spacing:.5px;color:var(--ds-text);margin:0;line-height:1.2}.ds-card-subtitle{font-size:.82rem;color:var(--ds-text-muted);margin:2px 0 0}.ds-card-body{padding:0 var(--ds-space-lg) var(--ds-space-sm);font-size:.88rem;color:var(--ds-text-muted);line-height:1.5}.ds-card-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--ds-space-sm);padding:var(--ds-space-sm) var(--ds-space-lg) var(--ds-space-md);border-top:1px solid rgba(196,168,120,.15)}.ds-card-icon{width:var(--ds-icon-xl);height:var(--ds-icon-xl);border-radius:var(--ds-radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.ds-card-icon img{width:100%;height:100%;object-fit:contain}.ds-card-icon--red{background:#8b1e1e14}.ds-card-icon--jade{background:#2e8b5714}.ds-card-icon--gold{background:#c8960a14}.ds-card--battle{background:linear-gradient(135deg,#fff9f499,#fff0e899);border-color:#8b1e1e40}.ds-card--jade{background:linear-gradient(135deg,#f4fcf899,#e8f7ef99);border-color:#2e8b5740}.ds-card--imperial{background:linear-gradient(135deg,#2a1a0eb3,#1e1208b3);border-color:#d4a5204d;color:#c4a878}.ds-card--imperial .ds-card-title{color:#f0d060}.ds-card--imperial .ds-card-subtitle{color:#8a7a5a}.ds-card--imperial .ds-card-body{color:#c4a878}.ds-card--scroll{background:linear-gradient(135deg,#faf6ee80,#f5ede080);border-color:#c8960a4d}.ds-card[role=button],.ds-card[tabindex]{cursor:pointer;transition:transform .15s,box-shadow .15s}.ds-card[role=button]:hover,.ds-card[tabindex]:hover{transform:translateY(-2px);box-shadow:var(--ds-shadow-md)}.ds-card[role=button]:active,.ds-card[tabindex]:active{transform:scale(.98)}[data-theme=dark] .ds-card--battle{background:linear-gradient(135deg,#2a1610,#301a0e)}[data-theme=dark] .ds-card--jade{background:linear-gradient(135deg,#0e2a1e,#1a3828)}[data-theme=dark] .ds-card--scroll{background:linear-gradient(135deg,#221a10,#2a1e12)}[data-theme=premium] .ds-card--battle{background:linear-gradient(135deg,#1a3828,#1e4430);border-color:#c8a43240}[data-theme=premium] .ds-card--jade{background:linear-gradient(135deg,#0d3d30,#1a5c44)}[data-theme=premium] .ds-card--scroll{background:linear-gradient(135deg,#1a4030,#236a50);border-color:#c8a4324d}.ds-badge-jade{background:#2e8b571a;color:#2e8b57;border:1px solid rgba(46,139,87,.2)}.ds-badge-gold-dark{background:#c8960a26;color:#c8960a;border:1px solid rgba(200,150,10,.3)}.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;min-height:44px;white-space:nowrap}.ds-btn:active{transform:scale(.97)}.ds-btn-primary{background:linear-gradient(180deg,var(--ds-primary) 0%,rgba(100,20,20,.9) 100%);color:#fff;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 10px #8b1e1e80,inset 0 2px 2px #ffffff40,inset 0 -3px 6px #0006;text-shadow:0 1px 2px rgba(0,0,0,.6)}.ds-btn-primary:hover{background:linear-gradient(180deg,var(--ds-primary-hover) 0%,rgba(120,20,20,.9) 100%)}.ds-btn-jade{background:linear-gradient(180deg,#2e8b57,#1e5a38);color:#fff;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 10px #2e8b5780,inset 0 2px 2px #ffffff40,inset 0 -3px 6px #0006;text-shadow:0 1px 2px rgba(0,0,0,.6)}.ds-btn-jade:hover{background:linear-gradient(180deg,#3cb371,#257a4c)}.ds-btn-gold{background:linear-gradient(180deg,#e8c040,#b8860b);color:#fff;border:1px solid rgba(255,255,255,.3);box-shadow:0 4px 10px #c8960a80,inset 0 2px 2px #fff6,inset 0 -3px 6px #0006;text-shadow:0 1px 2px rgba(0,0,0,.6)}.ds-btn-gold:hover{background:linear-gradient(180deg,gold,#c8960a)}.ds-btn-imperial{background:linear-gradient(180deg,#e8c040,#b8860b);color:#1a0e08;border:1px solid rgba(255,255,255,.3);box-shadow:0 4px 10px #c8960a80,inset 0 2px 2px #ffffff80,inset 0 -3px 6px #0000004d;text-shadow:0 1px 1px rgba(255,255,255,.3)}.ds-btn-imperial:hover{background:linear-gradient(180deg,gold,#c8960a)}.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:10px 18px;font-size:.82rem;border-radius:var(--ds-radius-sm)}.ds-chip-group{display:flex;gap:8px;flex-wrap:wrap}.ds-chip{padding:10px 20px;border-radius:var(--ds-radius-full);border:2px solid var(--ds-border-strong);background:transparent;font-family:var(--ds-font);font-size:.88rem;font-weight:600;color:var(--ds-text-muted);cursor:pointer;transition:all .18s;min-height:44px}.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%;min-width:0;box-sizing:border-box;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:60px;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:4px;border:none;background:none;color:#f0c06080;font-family:var(--ds-font);font-size:.72rem;font-weight:600;cursor:pointer;transition:color .18s,background .18s;padding:6px 2px 5px;border-radius:0;min-width:0;overflow:hidden}.ds-nav-item:hover{color:#f0c060cc}.ds-nav-item.active{color:var(--ds-gold-light)}.ds-nav-item span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.ds-nav-item svg{width:24px;height:24px;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:5px 12px;border-radius:var(--ds-radius-full);font-size:.78rem;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)}[data-theme=premium]{--bg-outer: #061e17;--bg-main: #0d3d30;--bg-card: rgba(15, 60, 45, .4);--bg-card2: rgba(10, 45, 33, .3);--bg-input: #0f4a36;--border-gold: #c8a432;--border-bright: #e8c040;--border-dim: #1e6040;--text-h: #b8f0d8;--text-body: #7ecfb0;--text-muted: #58a880;--accent-red: #e84040;--accent-green: #2aaa6c;--btn-cta-bg: #1e7a52;--btn-cta-text: #b8f0d8;--btn-2-bg: #145e40;--btn-2-text: #7ecfb0;--toggle-track: #0f4a36;--toggle-thumb: #7ecfb0;--toggle-on: #2aaa6c;--pillar-tint: rgba(200,164,50,.18);--header-bg: #092e22;--scrollbar-track: #0f4a36;--scrollbar-thumb: #2aaa6c;--shadow-card: 0 4px 20px rgba(0,0,0,.5);--corner-color: #c8a432;--icon-fill: #7ecfb0;--rank-gold: #e8c040;--rank-silver: #90d0c0;--rank-bronze: #c87840;--ds-bg: var(--bg-main);--ds-bg-pattern: var(--bg-outer);--ds-card: var(--bg-card);--ds-card-secondary: var(--bg-card2);--ds-card-border: var(--border-gold);--ds-header-bg: var(--header-bg);--ds-header-text: var(--text-h);--ds-header-border: rgba(200,164,50,.2);--ds-primary: var(--btn-cta-bg);--ds-primary-hover: #15604a;--ds-primary-light: rgba(30,122,82,.12);--ds-text: var(--text-h);--ds-text-muted: var(--text-body);--ds-text-light: var(--text-muted);--ds-gold: var(--border-gold);--ds-gold-light: var(--border-bright);--ds-border: var(--border-dim);--ds-border-strong: var(--border-bright);--ds-green: var(--accent-green);--ds-green-light: rgba(42,170,108,.12);--ds-red-dot: var(--accent-red);--ds-blue: #2980b9;--ds-shadow-sm: 0 1px 4px rgba(0,0,0,.25);--ds-shadow-md: 0 3px 12px rgba(0,0,0,.35);--ds-shadow-lg: 0 6px 24px rgba(0,0,0,.45);--ds-shadow-card: var(--shadow-card)}@media(max-width:1023px){.app-shell,.app-content{display:contents}.app-shell>.ds-sidebar{display:none}}@media(min-width:1024px){.app-shell{position:fixed;top:3vh;right:4vw;bottom:3vh;left:4vw;max-width:1440px;margin:0 auto;display:grid;grid-template-columns:repeat(12,1fr);background-image:url(/bg/parchment_card_bg.png);background-size:cover;background-position:center;border:none;box-shadow:0 40px 100px #000c,inset 0 0 60px #b4783233;z-index:80;border-radius:16px}[data-theme=dark] .app-shell{background-image:linear-gradient(#1a1410d9,#1a1410d9),url(/bg/parchment_card_bg.png)}[data-theme=premium] .app-shell{box-shadow:0 40px 100px #000000e6,inset 0 0 60px #32b47826;background-image:linear-gradient(#0a2d21d9,#0a2d21d9),url(/bg/parchment_card_bg.png)}.app-shell>.ds-sidebar{grid-column:1 / 3;grid-row:1;overflow:hidden;border-right:1px solid rgba(196,168,120,.4);background:transparent;z-index:2}.app-shell>.app-content{grid-column:3 / 13;grid-row:1;position:relative;overflow:hidden;z-index:1;background:transparent}.app-content .ds-page{position:absolute;top:0;right:0;bottom:0;left:0;max-width:100%;max-height:100%;margin:0;border:none;border-radius:0;box-shadow:none;z-index:1;background:transparent!important}.app-content .ds-page-bg{display:none!important}.app-content .hp-sidebar,.app-content .hp-dt-wrapper>.hp-sidebar,.app-content .dt-sidebar{display:none!important}.app-content .hp-dt-wrapper{grid-template-columns:1fr!important}.app-content .ds-bottom-nav,.app-content .hp-bottom-nav{display:none}.app-shell--nogrid .ds-page{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--ds-bg)!important}.ds-header{border-bottom:2px solid var(--ds-header-border)}.app-content .hp-dt-main,.app-content .pp-dt-wrapper,.app-content .rp-dt-wrapper,.app-content .tn-dt-wrapper,.app-content .lnp-dt-wrapper{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:20px;align-content:start;box-sizing:border-box}.app-content .rp-dt-wrapper>.rp-dt-tab-bar,.app-content .rp-dt-wrapper>.rp-dt-podium,.app-content .rp-dt-wrapper>.rp-dt-table-card,.app-content .tn-dt-wrapper>.tn-dt-top-bar,.app-content .tn-dt-wrapper>.tn-dt-filters,.app-content .pp-dt-wrapper>.pp-dt-hero-card,.app-content .lnp-dt-wrapper>.lnp-dt-branding,.app-content .lnp-dt-wrapper>.lnp-dt-form-card{grid-column:1 / -1}.app-content .ds-content{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:20px;align-content:start}.app-content .ds-content>header,.app-content .ds-content>.ds-section-header,.app-content .ds-content>h1,.app-content .ds-content>h2{grid-column:1 / -1}}.ds-row{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--ds-space-md);width:100%}.ds-row-gap-0{gap:0}.ds-row-gap-sm{gap:var(--ds-space-sm)}.ds-row-gap-md{gap:var(--ds-space-md)}.ds-row-gap-lg{gap:var(--ds-space-lg)}.ds-row-gap-xl{gap:var(--ds-space-xl)}@media(min-width:1024px){.ds-col-1{grid-column:span 1}.ds-col-2{grid-column:span 2}.ds-col-3{grid-column:span 3}.ds-col-4{grid-column:span 4}.ds-col-5{grid-column:span 5}.ds-col-6{grid-column:span 6}.ds-col-7{grid-column:span 7}.ds-col-8{grid-column:span 8}.ds-col-9{grid-column:span 9}.ds-col-10{grid-column:span 10}.ds-col-11{grid-column:span 11}.ds-col-12{grid-column:span 12}.ds-col-full{grid-column:1 / -1}.ds-col-offset-1{grid-column-start:2}.ds-col-offset-2{grid-column-start:3}.ds-col-offset-3{grid-column-start:4}.ds-col-offset-4{grid-column-start:5}.ds-col-offset-5{grid-column-start:6}.ds-col-offset-6{grid-column-start:7}.ds-layout-sidebar{display:grid;grid-template-columns:repeat(12,1fr);gap:0;height:100%;overflow:hidden}.ds-layout-sidebar>.ds-sidebar{grid-column:span 2}.ds-layout-sidebar>.ds-main{grid-column:span 10}.ds-layout-sidebar-wide{display:grid;grid-template-columns:repeat(12,1fr);gap:0;height:100%;overflow:hidden}.ds-layout-sidebar-wide>.ds-sidebar{grid-column:span 3}.ds-layout-sidebar-wide>.ds-main{grid-column:span 9}.ds-layout-3panel{display:grid;grid-template-columns:repeat(12,1fr);gap:0;height:100%;overflow:hidden}.ds-layout-3panel>.ds-sidebar{grid-column:span 2}.ds-layout-3panel>.ds-main{grid-column:span 7}.ds-layout-3panel>.ds-aside{grid-column:span 3}.ds-layout-centered{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--ds-space-md)}.ds-layout-centered>.ds-main{grid-column:3 / 11}}@media(max-width:1023px){.ds-row,.ds-layout-sidebar,.ds-layout-sidebar-wide,.ds-layout-3panel,.ds-layout-centered{display:flex;flex-direction:column}.ds-col-1,.ds-col-2,.ds-col-3,.ds-col-4,.ds-col-5,.ds-col-6,.ds-col-7,.ds-col-8,.ds-col-9,.ds-col-10,.ds-col-11,.ds-col-12,.ds-col-full{grid-column:unset;width:100%}.ds-sidebar{display:none}}.ds-grid-scroll{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.ds-grid-scroll::-webkit-scrollbar{width:3px}.ds-grid-scroll::-webkit-scrollbar-thumb{background:#a0642833;border-radius:2px}.ds-action-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--ds-space-sm)}.ds-action-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 14px;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)}.ds-action-card:hover{box-shadow:var(--ds-shadow-md);transform:translateY(-1px)}.ds-action-card:active{transform:scale(.98)}.ds-action-card-icon{width:var(--ds-icon-lg);height:var(--ds-icon-lg);border-radius:var(--ds-radius-md);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.ds-action-card-title{font-weight:800;font-size:.88rem;color:var(--ds-text)}.ds-action-card-sub{font-size:.78rem;color:var(--ds-text-muted)}.ds-card-compact{display:flex;align-items:center;gap:var(--ds-space-md);padding:var(--ds-space-md) var(--ds-space-lg);background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-sm)}.ds-card-compact-body{flex:1;min-width:0}.ds-card-compact-title{font-weight:800;font-size:.95rem;color:var(--ds-text);margin:0}.ds-card-compact-sub{font-size:.82rem;color:var(--ds-text-muted);margin:2px 0 0}.ds-content{padding:var(--ds-space-md) var(--ds-page-px);display:flex;flex-direction:column;gap:var(--ds-space-sm)}.ds-stat-row{display:flex;align-items:center;gap:var(--ds-space-md);padding:var(--ds-space-sm) var(--ds-page-px);font-size:.88rem;flex-wrap:wrap}.ds-stat-item{display:flex;align-items:center;gap:6px;color:var(--ds-text-muted)}.ds-stat-item strong{color:var(--ds-text);font-weight:700}.ds-stat-sep{color:var(--ds-border-strong);font-size:.85rem}.ds-join-row{display:flex;gap:var(--ds-space-sm);align-items:stretch}.ds-join-row .ds-input{flex:1}.ds-join-row .ds-btn{flex-shrink:0;min-width:80px}.ds-flex{display:flex}.ds-flex-col{display:flex;flex-direction:column}.ds-flex-center{display:flex;align-items:center;justify-content:center}.ds-flex-between{display:flex;align-items:center;justify-content:space-between}.ds-flex-1{flex:1;min-width:0}.ds-flex-wrap{flex-wrap:wrap}.ds-gap-xs{gap:var(--ds-space-xs)}.ds-gap-sm{gap:var(--ds-space-sm)}.ds-gap-md{gap:var(--ds-space-md)}.ds-gap-lg{gap:var(--ds-space-lg)}.ds-text-center{text-align:center}.ds-text-left{text-align:left}.ds-text-bold{font-weight:700}.ds-text-muted{color:var(--ds-text-muted)}.ds-text-primary{color:var(--ds-primary)}.ds-text-gold{color:var(--ds-gold)}.ds-text-green{color:var(--ds-green)}.ds-m-0{margin:0}.ds-mt-sm{margin-top:var(--ds-space-sm)}.ds-mt-md{margin-top:var(--ds-space-md)}.ds-mb-sm{margin-bottom:var(--ds-space-sm)}.ds-mb-md{margin-bottom:var(--ds-space-md)}.ds-w-full{width:100%}.ds-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes rankUpPop{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.ds-header-back:focus-visible,.ds-header-icon:focus-visible,.ds-btn:focus-visible,.ds-chip:focus-visible,.ds-nav-item:focus-visible{outline:2px solid var(--ds-primary);outline-offset:2px}[data-theme=dark] .ds-header-back:focus-visible,[data-theme=dark] .ds-header-icon:focus-visible,[data-theme=premium] .ds-header-back:focus-visible,[data-theme=premium] .ds-header-icon:focus-visible{outline-color:var(--ds-gold-light)}@keyframes ds-pulse-glow{0%{box-shadow:0 0 10px #d4af374d,0 0 20px #d4af371a}50%{box-shadow:0 0 20px #d4af3799,0 0 40px #d4af374d}to{box-shadow:0 0 10px #d4af374d,0 0 20px #d4af371a}}.ds-anim-pulse-glow{animation:ds-pulse-glow 2s infinite}@keyframes ds-float{0%{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(2deg)}to{transform:translateY(0) rotate(0)}}.ds-anim-float{animation:ds-float 4s ease-in-out infinite}@keyframes ds-breathe{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.ds-anim-breathe{animation:ds-breathe 3s ease-in-out infinite}@keyframes ds-slide-up-fade{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.ds-anim-slide-up{animation:ds-slide-up-fade .4s cubic-bezier(.16,1,.3,1) forwards}@keyframes ds-zoom-pop{0%{opacity:0;transform:scale(.85)}60%{opacity:1;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.ds-anim-zoom-pop{animation:ds-zoom-pop .4s cubic-bezier(.16,1,.3,1) forwards}@keyframes ds-bg-pan{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.gi{display:inline-block;vertical-align:middle;flex-shrink:0;line-height:1}.gi-rank-glow{filter:drop-shadow(0 0 3px var(--gi-glow-color, rgba(255,215,0,.4)));animation:giRankPulse 3s ease-in-out infinite}@keyframes giRankPulse{0%,to{filter:drop-shadow(0 0 3px var(--gi-glow-color, rgba(255,215,0,.3)))}50%{filter:drop-shadow(0 0 8px var(--gi-glow-color, rgba(255,215,0,.6)))}}.corner{position:absolute;width:28px;height:28px;pointer-events:none;z-index:2}.corner.tl{top:0;left:0}.corner.tr{top:0;right:0;transform:scaleX(-1)}.corner.bl{bottom:0;left:0;transform:scaleY(-1)}.corner.br{bottom:0;right:0;transform:scale(-1)}.diamond-divider{display:flex;align-items:center;justify-content:center;padding:8px 0}.diamond-divider svg{width:100%;max-width:300px;height:20px}.cloud-border{width:100%;height:16px;pointer-events:none;flex-shrink:0}.cloud-border svg{width:100%;height:100%}.double-frame{position:relative;padding:12px 20px;text-align:center}.double-frame svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.double-frame-text{position:relative;z-index:1;font-family:var(--ds-font-serif);font-size:1rem;font-weight:600;color:var(--text-h);letter-spacing:1px}.grid-texture{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:linear-gradient(var(--border-dim) 1px,transparent 1px),linear-gradient(90deg,var(--border-dim) 1px,transparent 1px);background-size:40px 40px;background-position:center center;opacity:.08}.pillar-ornament{background:var(--pillar-tint);border:1px solid var(--border-dim);position:relative;overflow:hidden}.pillar-ornament svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.dragon-scale-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.5}.decorated-card{position:relative;overflow:hidden;background:var(--bg-card);border:1px solid var(--border-gold);border-radius:8px;box-shadow:var(--shadow-card);transition:background .4s,border-color .4s}.decorated-card>.card-content{position:relative;z-index:1;padding:16px}.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}[data-theme=premium] .ds-page-bg{background:radial-gradient(ellipse at 15% 5%,rgba(30,122,90,.14) 0%,transparent 55%),radial-gradient(ellipse at 85% 90%,rgba(20,100,70,.1) 0%,transparent 55%),linear-gradient(170deg,#daeee6,#c8e4d8,#b8d8cc)}[data-theme=premium] .ds-card,[data-theme=premium] .ds-card-secondary{color:var(--ds-text);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}[data-theme=premium] .ds-input{background:#fff9;color:var(--ds-text);border-color:var(--ds-card-border)}[data-theme=premium] .ds-bottom-nav{background:var(--ds-header-bg);border-top-color:#ffffff14}@media(min-width:480px){[data-theme=premium] body{background:#1a4a3a}}[data-theme=premium] .ds-page{border:3px solid #3a8a6a;box-shadow:inset 0 0 0 1px #d4b84040,inset 0 0 0 4px #1e7a5a1f,0 0 40px #14463259}@media(min-width:480px){[data-theme=premium] .ds-page{border-width:4px;border-radius:12px}}[data-theme=premium] .ds-page:before,[data-theme=premium] .ds-page:after{content:"";position:absolute;width:48px;height:48px;border:3px solid rgba(200,164,50,.5);z-index:100;pointer-events:none;opacity:.7}[data-theme=premium] .ds-page:before{top:4px;left:4px;border-right:none;border-bottom:none;border-radius:8px 0 0}[data-theme=premium] .ds-page:after{bottom:4px;right:4px;border-left:none;border-top:none;border-radius:0 0 8px}[data-theme=premium] .ds-page-bg:before,[data-theme=premium] .ds-page-bg:after{content:"";position:absolute;z-index:2;pointer-events:none}[data-theme=premium] .ds-page-bg:before{top:0;left:0;right:0;height:18px;background:linear-gradient(90deg,transparent 0%,rgba(42,122,96,.3) 10%,rgba(184,150,10,.15) 30%,rgba(42,122,96,.25) 50%,rgba(184,150,10,.15) 70%,rgba(42,122,96,.3) 90%,transparent 100%);border-bottom:1px solid rgba(106,184,154,.3)}[data-theme=premium] .ds-page-bg:after{bottom:0;left:0;right:0;height:18px;background:linear-gradient(90deg,transparent 0%,rgba(42,122,96,.3) 10%,rgba(184,150,10,.15) 30%,rgba(42,122,96,.25) 50%,rgba(184,150,10,.15) 70%,rgba(42,122,96,.3) 90%,transparent 100%);border-top:1px solid rgba(106,184,154,.3)}[data-theme=premium] .ds-header{background:linear-gradient(180deg,#0e3028,#143830 60%,#1a4a3a);border-bottom:2px solid rgba(106,184,154,.35);box-shadow:0 2px 12px #14383066}[data-theme=premium] .ds-header:after{content:"";position:absolute;bottom:-3px;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent,rgba(212,184,64,.4) 20%,rgba(212,184,64,.6) 50%,rgba(212,184,64,.4) 80%,transparent);border-radius:1px}[data-theme=premium] .ds-scroll::-webkit-scrollbar-thumb{background:#2a7a604d}[data-theme=premium] .ds-card{border-color:#4a9a7e80;box-shadow:0 2px 10px #1446321a,inset 0 0 0 1px #6ab89a14}[data-theme=premium] .ds-chip.active{background:var(--ds-primary);border-color:var(--ds-primary);box-shadow:0 2px 8px #1e7a5a59}[data-theme=premium] .ds-btn-primary{box-shadow:0 2px 10px #1e7a5a59}[data-theme=premium] .ds-nav-item{color:#6ab89a80}[data-theme=premium] .ds-nav-item:hover{color:#6ab89acc}[data-theme=premium] .ds-nav-item.active{color:var(--ds-gold-light)}.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:5000;background:#0a0500d9;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-container{background:#1c1408;border-radius:16px;padding:16px;width:min(100%,340px);box-shadow:0 20px 60px #000c;animation:goSlideUp .38s cubic-bezier(.34,1.4,.64,1)}@keyframes goSlideUp{0%{transform:translateY(28px) scale(.94);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.go-card{background-color:#f4efdf;border:2px solid #a68a7a;border-radius:12px;padding:24px 20px;display:flex;flex-direction:column;align-items:center;text-align:center;font-family:var(--ds-font, sans-serif)}.go-icon-wrap{margin-bottom:12px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.go-title{display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--ds-font-serif, serif);font-size:1.15rem;font-weight:700;color:#333;margin:0 0 12px;letter-spacing:.5px}.go-reason{font-size:.9rem;font-weight:600;color:#333;margin:0 0 10px;line-height:1.4;max-width:90%}.go-elo-row{font-size:1.05rem;font-weight:700;color:#1e7a5a;margin:0 0 20px}.go-actions{display:flex;gap:12px;width:100%;margin-bottom:16px}.go-btn-primary{flex:1;background-color:#6f1214;color:#fff;border:none;border-radius:24px;padding:10px;font-size:.95rem;font-weight:700;cursor:pointer;transition:background-color .2s}.go-btn-primary:hover{background-color:#550d0f}.go-btn-outline{flex:1;background-color:transparent;color:#6f1214;border:2px solid #6f1214;border-radius:24px;padding:8px;font-size:.95rem;font-weight:700;cursor:pointer;transition:background-color .2s}.go-btn-outline:hover{background-color:#6f12140d}.go-text-link{font-size:.9rem;font-weight:700;color:#6f1214;cursor:pointer;transition:opacity .2s}.go-text-link:hover{opacity:.7}.dt-sidebar{background:transparent;border-right:none;display:flex;flex-direction:column;padding:12px 0;overflow:hidden;transition:background .4s,border-color .4s;width:100%;height:100%;min-height:0}.dt-sidebar-nav{display:flex;flex-direction:column;gap:4px;padding:0 6px}.dt-sidebar-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 6px 12px;border:2px solid transparent;background:transparent;border-radius:var(--ds-radius-lg);font-family:var(--ds-font);font-size:.72rem;font-weight:700;color:var(--text-body);cursor:pointer;transition:all .2s ease;text-align:center;white-space:nowrap;position:relative;line-height:1.2;letter-spacing:.3px}.dt-sidebar-item:hover{background:#c8a96e1a;border-color:#c8a96e33;color:var(--text-h)}.dt-sidebar-item.active{background:#c8a96e26;border-color:var(--border-bright);color:var(--border-bright);font-weight:800}.dt-sidebar-item.active:before{content:"";position:absolute;left:-2px;top:8px;bottom:8px;width:4px;border-radius:0 4px 4px 0;background:var(--border-bright)}.dt-sidebar-item svg,.dt-sidebar-item img{width:28px;height:28px;flex-shrink:0;color:var(--icon-fill)}.dt-sidebar-item.active svg,.dt-sidebar-item.active img{color:var(--border-bright)}.dt-theme-btn.active{background:#c8a96e24;border-color:var(--border-bright);color:var(--text-h);font-weight:800}.dt-layout{display:none}@media(min-width:1024px){.dt-layout{display:flex;flex:1;overflow:hidden;min-height:0}.dt-content{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--bg-main);position:relative;scrollbar-width:thin;transition:background .4s}.dt-content::-webkit-scrollbar{width:4px}.dt-content::-webkit-scrollbar-track{background:var(--scrollbar-track)}.dt-content::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:2px}}.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-folder-card{background-color:#f4efdf;border:2px solid #a68a7a;border-radius:12px;padding:32px;width:min(100%,800px);margin:auto;box-shadow:0 10px 20px #00000026;font-family:var(--ds-font, sans-serif);box-sizing:border-box}.stp-folder-title{display:flex;align-items:center;justify-content:center;gap:12px;font-family:var(--ds-font-serif, serif);font-size:1.15rem;font-weight:700;color:#333;margin-bottom:20px}.stp-line{flex:1;height:1px;background-color:#a68a7a;opacity:.5}.stp-theme-row{display:flex;gap:12px;margin-bottom:20px}.stp-theme-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;background:transparent;border:none;cursor:pointer;padding:0;font-weight:700;font-size:.85rem;color:#333}.stp-theme-preview{width:100%;aspect-ratio:1;border-radius:12px;overflow:hidden;border:2px solid transparent;transition:all .2s;box-shadow:0 4px 8px #0000001a}.stp-theme-btn.active .stp-theme-preview{border-color:#6f1214;box-shadow:0 0 0 3px #6f121433}.stp-sound-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding:0 10px}.stp-sound-label{display:flex;align-items:center;gap:8px;font-weight:700;font-size:1.05rem;color:#333}.stp-sound-icon{color:#6f1214}.stp-btn-row{display:flex;gap:12px;margin-top:10px}.stp-btn-primary{flex:1;background-color:#6f1214;color:#fff;border:none;border-radius:24px;padding:12px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s}.stp-btn-primary:hover{background-color:#550d0f}.stp-btn-outline{flex:1;background-color:transparent;color:#6f1214;border:2px solid #6f1214;border-radius:24px;padding:10px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s}.stp-btn-outline:hover{background-color:#6f12140d}.stp-status{text-align:center;margin-top:12px;font-weight:700;color:#1e7a5a}.stp-page .ds-page-bg{display:none}@media(min-width:1024px){.stp-page .stp-scroll,.stp-page .ds-bottom-nav{display:none}.stp-page .ds-header{max-width:800px;margin:0 auto;width:100%;background:transparent;border-bottom:none;padding-top:16px;box-sizing:border-box}.stp-page .ds-header-title{font-size:1.25rem;letter-spacing:2px}}.stp-dt-wrapper{max-width:800px;width:100%;margin:0 auto;padding:28px 24px;min-height:calc(100vh - 80px);display:flex;flex-direction:column;box-sizing:border-box}.stp-dt-card{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:14px;padding:28px 24px;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.stp-dt-section-label{font-size:.72rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px;margin-top:20px}.stp-dt-section-label:first-of-type{margin-top:0}.stp-dt-theme-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.stp-dt-theme-card{border:2px solid var(--border-dim);border-radius:12px;padding:10px;cursor:pointer;transition:all .2s;background:transparent;font-family:var(--ds-font)}.stp-dt-theme-card:hover{border-color:var(--border-bright)}.stp-dt-theme-card.active{border-color:var(--btn-cta-bg);box-shadow:0 0 0 2px #c8a96e33}.stp-dt-preview{border-radius:8px;padding:6px;margin-bottom:8px;height:72px;display:flex;flex-direction:column;gap:4px}.stp-dt-preview-header{height:8px;border-radius:4px 4px 0 0}.stp-dt-preview-cards{flex:1;display:flex;flex-direction:column;gap:3px;padding:2px 4px}.stp-dt-preview-nav{height:6px;border-radius:0 0 4px 4px}.stp-dt-theme-label{display:flex;align-items:center;gap:6px;justify-content:center;font-size:.82rem;font-weight:600;color:var(--text-body)}.stp-dt-board-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.stp-dt-board-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:10px;border:2px solid var(--border-dim);border-radius:12px;background:transparent;cursor:pointer;transition:all .2s;font-family:var(--ds-font);font-size:.82rem;font-weight:600;color:var(--text-body)}.stp-dt-board-btn:hover{border-color:var(--border-bright)}.stp-dt-board-btn.active{border-color:var(--btn-cta-bg);box-shadow:0 0 0 2px #c8a96e33}.stp-dt-board-preview{width:100%;height:52px;border-radius:6px;overflow:hidden}.stp-dt-sound-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;margin-top:12px;border-top:1px solid var(--border-dim)}.stp-dt-sound-label{display:flex;align-items:center;gap:8px;font-size:.88rem;font-weight:600;color:var(--text-body)}.stp-dt-save{width:100%;margin-top:20px;padding:14px;font-size:.95rem;letter-spacing:1px}.stp-dt-status{text-align:center;margin-top:12px;font-size:.85rem;font-weight:600;color:var(--accent-green, #48a868);animation:stp-dt-fade .3s ease-out}@keyframes stp-dt-fade{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(--header-bg);border-bottom:1px solid var(--border-gold);flex-shrink:0;transition:background .4s,border-color .4s}.hp-logo{display:flex;align-items:center;gap:8px;flex-shrink:0}.hp-logo-circle{width:36px;height:36px;border-radius:50%;background:var(--btn-cta-bg);display:flex;align-items:center;justify-content:center;border:2px solid var(--border-gold)}[data-theme=premium] .hp-logo-circle{background:transparent;border-color:transparent}.hp-logo-char{font-family:var(--ds-font-serif);font-size:1.2rem;color:#fff;line-height:1}[data-theme=premium] .hp-logo-char{color:var(--border-bright)}.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(--text-h);letter-spacing:1.5px}.hp-logo-sub{font-size:.6rem;font-weight:600;color:var(--text-body);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(--btn-cta-bg);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(--text-h);white-space:nowrap}.hp-user-elo{font-size:.62rem;color:var(--text-body);white-space:nowrap}.hp-scroll{padding:0;padding-bottom:0!important;position:relative;overflow:hidden!important;display:flex;flex-direction:column}.hp-scroll:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 600px 100px at 50% 0%,rgba(212,175,55,.04) 0%,transparent 100%),repeating-linear-gradient(0deg,transparent 0px,transparent 80px,rgba(212,175,55,.02) 80px,rgba(212,175,55,.02) 81px),repeating-linear-gradient(90deg,transparent 0px,transparent 80px,rgba(212,175,55,.015) 80px,rgba(212,175,55,.015) 81px)}.hp-scroll>*{position:relative;z-index:1}.hp-hero-banner{position:relative;margin:0;padding:32px 20px 28px;background:linear-gradient(160deg,#2c1810,#1a0e08 40%,#3a1a10);text-align:center;overflow:hidden;border-bottom:1px solid rgba(212,175,55,.2)}.hp-hero-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.hp-hero-particle{position:absolute;width:3px;height:3px;background:#d4af37;border-radius:50%;opacity:.5;animation:hp-particle-float 4s ease-in-out infinite}.hp-hero-particle:nth-child(odd){background:#c2303099;width:2px;height:2px}@keyframes hp-particle-float{0%,to{transform:translateY(0) scale(1);opacity:.3}50%{transform:translateY(-15px) scale(1.5);opacity:.7}}.hp-hero-content{position:relative;z-index:1}.hp-hero-calligraphy{font-family:var(--ds-font-serif);font-size:3rem;color:#d4af3726;line-height:1;margin-bottom:-8px;letter-spacing:8px;-webkit-user-select:none;user-select:none}.hp-hero-title{font-family:var(--ds-font-serif);font-size:1.3rem;font-weight:800;color:#d4af37;letter-spacing:3px;margin-bottom:4px;text-shadow:0 1px 8px rgba(212,175,55,.3)}.hp-hero-subtitle{font-size:.82rem;color:#fff9;font-weight:500;letter-spacing:1px}[data-theme=dark] .hp-hero-banner{background:linear-gradient(160deg,#1a1714,#0e0c0a 40%,#2a2018)}[data-theme=premium] .hp-hero-banner{background:linear-gradient(160deg,#0d3d30,#061e17 40%,#1a5c44)}[data-theme=premium] .hp-hero-calligraphy{color:#7ecfb01f}[data-theme=premium] .hp-hero-title{color:#7ecfb0;text-shadow:0 1px 8px rgba(126,207,176,.3)}[data-theme=premium] .hp-hero-subtitle{color:#7ecfb080}[data-theme=light] .hp-hero-banner{background:linear-gradient(160deg,#f5ede0,#e8d8c0 40%,#f0e6d2)}[data-theme=light] .hp-hero-calligraphy{color:#8b58201f}[data-theme=light] .hp-hero-title{color:#8b5820;text-shadow:0 1px 4px rgba(139,88,32,.15)}[data-theme=light] .hp-hero-subtitle{color:#64461e80}.hp-cards-area{padding:6px 10px 4px!important;gap:6px!important;flex:1;justify-content:space-between}.hp-big-card{padding:8px 10px!important;min-height:0;flex:1;gap:6px!important;cursor:pointer;transition:transform .15s,box-shadow .15s}.hp-big-card:hover{transform:translateY(-2px);box-shadow:var(--ds-shadow-md)}.hp-big-card:active{transform:scale(.98)}.hp-card-icon-lg{width:40px!important;height:40px!important;border-radius:8px!important}.hp-card-desc{display:none}.hp-big-card .ds-btn-sm{padding:6px 8px;min-height:32px;font-size:.75rem;white-space:nowrap;justify-content:center;flex-shrink:0}.hp-big-card .ds-card-compact-body{min-width:0}.hp-big-card .ds-card-compact-sub{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hp-card-icon-text{font-size:1.4rem;line-height:1}.hp-big-card.ds-card--battle .ds-btn-primary{background:#c43e2a;border-color:#a32a1a;color:#fff}.hp-big-card.ds-card--jade .ds-btn-primary{background:#2d8c5a;border-color:#1e6b42;color:#fff}.hp-big-card.ds-card--imperial .ds-btn-primary{background:#c8a832;border-color:#a88820;color:#fff}.hp-big-card.ds-card--scroll .ds-btn-primary{background:#b48c3c;border-color:#926e2a;color:#fff}.hp-card-kipho{background:linear-gradient(135deg,#2c1810,#3a1a10)!important;border-color:#d4af374d!important}.hp-card-kipho .ds-card-compact-title{color:#d4af37}.hp-card-kipho .ds-card-compact-sub{color:#c4a878}.hp-card-kipho .hp-card-desc{color:#d4af3780}.hp-card-icon-kipho{background:#d4af371a!important}.hp-card-kipho .ds-btn-primary{background:#c84040;border-color:#a82020;color:#fff}[data-theme=dark] .hp-card-kipho{background:linear-gradient(135deg,#1a1208,#2a1a10)!important}[data-theme=premium] .hp-card-kipho{background:linear-gradient(135deg,#1a4030,#236a50)!important;border-color:#c8a4324d!important}[data-theme=premium] .hp-card-kipho .ds-card-compact-title{color:#e8c040}[data-theme=premium] .hp-card-kipho .ds-card-compact-sub{color:#7ecfb0}[data-theme=light] .hp-card-kipho{background:linear-gradient(135deg,#faf6ee,#f5ede0)!important;border-color:#8b58204d!important}[data-theme=light] .hp-card-kipho .ds-card-compact-title{color:#8b5820}[data-theme=light] .hp-card-kipho .ds-card-compact-sub{color:#a08060}.hp-card-giangho{background:linear-gradient(135deg,#1a0e20,#2a1838)!important;border-color:#a870b04d!important}.hp-card-giangho .ds-card-compact-title{color:#c8a0d8}.hp-card-giangho .ds-card-compact-sub{color:#9070a0}.hp-card-giangho .hp-card-desc{color:#a870b080}.hp-card-icon-giangho{background:#a870b01a!important}.hp-card-giangho .ds-btn-primary{background:#a050c8;border-color:#8030a8;color:#fff}[data-theme=dark] .hp-card-giangho{background:linear-gradient(135deg,#0e0810,#1a1020)!important}[data-theme=premium] .hp-card-giangho{background:linear-gradient(135deg,#0d3d30,#1a5c44)!important;border-color:#c8a43240!important}[data-theme=premium] .hp-card-giangho .ds-card-compact-title{color:#b8f0d8}[data-theme=premium] .hp-card-giangho .ds-card-compact-sub{color:#7ecfb0}[data-theme=light] .hp-card-giangho{background:linear-gradient(135deg,#f0e8f4,#e4d8f0)!important;border-color:#7a3a9040!important}[data-theme=light] .hp-card-giangho .ds-card-compact-title{color:#5a2870}[data-theme=light] .hp-card-giangho .ds-card-compact-sub{color:#7a5090}.hp-streak-text{color:#e67e22;font-weight:700}.hp-stat-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--ds-green);animation:hp-pulse 2s ease infinite;vertical-align:middle;margin-right:4px}@keyframes hp-pulse{0%,to{opacity:1}50%{opacity:.5}}.hp-bottom-nav,.hp-nav-center{position:relative}.hp-nav-center-wrap{width:44px;height:44px;border-radius:50%;background:var(--btn-cta-bg);display:flex;align-items:center;justify-content:center;margin-bottom:-6px;box-shadow:0 3px 12px #00000059;border:1px solid var(--border-bright)}.hp-nav-center-wrap svg{color:var(--btn-cta-text)}@media(max-width:380px){.hp-cards-area{padding:4px 8px!important;gap:4px!important}.hp-big-card{padding:6px 8px!important;gap:4px!important}.hp-scroll .ds-card-compact-title{font-size:.8rem}.hp-scroll .ds-card-compact-sub{font-size:.68rem}.hp-scroll .ds-btn-sm{padding:5px 4px;font-size:.7rem;min-height:28px;min-width:70px;white-space:nowrap;justify-content:center}.hp-card-icon-lg{width:34px!important;height:34px!important}}@media(min-width:768px){.hp-scroll{overflow-y:auto!important;overflow-x:hidden!important;display:flex;flex-direction:column}.hp-cards-area{padding:20px 14px 0!important;gap:12px!important;flex:unset;justify-content:flex-start}.hp-big-card{padding:16px 18px!important;min-height:88px;flex:unset;gap:var(--ds-space-md)!important}.hp-big-card .ds-btn-sm{padding:10px 18px;min-height:44px;font-size:.82rem;min-width:120px;white-space:nowrap;justify-content:center}.hp-card-icon-lg{width:60px!important;height:60px!important;border-radius:14px!important}.hp-card-desc{display:block;font-size:.75rem;color:var(--ds-text-light);margin-top:3px;line-height:1.3;opacity:.7}}.hp-desktop-layout{display:none}@media(min-width:1024px){.hp-page.ds-page{max-width:100%}.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-stats-bar{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 24px;background:#ffffff26;border-bottom:1px solid rgba(196,168,120,.3);flex-shrink:0;font-size:.85rem;font-weight:600;color:var(--ds-text)}.hp-dt-stat{display:flex;align-items:center;gap:8px}.hp-dt-stat-sep{color:var(--ds-text-muted);font-size:.7rem}.hp-dt-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:24px 40px;flex:1;align-content:center;overflow-y:auto;scrollbar-width:thin}.hp-dt-feature-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 16px 16px;background:#ffffff26;border:1px solid rgba(196,168,120,.3);border-radius:var(--ds-radius-lg);cursor:pointer;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;position:relative;text-align:center;overflow:hidden}.hp-dt-feature-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #0000002e}.hp-dt-feature-card:focus-visible{outline:2px solid var(--ds-gold);outline-offset:2px}.hp-dt-feature--battle{border-color:#b43c2859}.hp-dt-feature--battle:hover{border-color:#b43c2899;box-shadow:0 12px 32px #b43c281f}.hp-dt-feature--jade{border-color:#328c5a59}.hp-dt-feature--jade:hover{border-color:#328c5a99;box-shadow:0 12px 32px #328c5a1f}.hp-dt-feature--imperial{border-color:#c8a83259}.hp-dt-feature--imperial:hover{border-color:#c8a83299;box-shadow:0 12px 32px #c8a8321f}.hp-dt-feature--scroll{border-color:#b48c3c4d}.hp-dt-feature--scroll:hover{border-color:#b48c3c80;box-shadow:0 12px 32px #b48c3c1a}.hp-dt-feature-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#c8a8640f;border:2px solid rgba(200,168,100,.15);flex-shrink:0;transition:transform .3s ease}.hp-dt-feature-card:hover .hp-dt-feature-icon{transform:scale(1.08)}.hp-dt-feature-icon svg{width:36px;height:36px;color:var(--ds-gold)}.hp-dt-feature-emoji{font-size:2.2rem;line-height:1}.hp-dt-feature-title{font-size:1rem;font-weight:800;letter-spacing:.5px;color:var(--ds-text);margin:0;line-height:1.3}.hp-dt-feature-sub{font-size:.78rem;color:var(--ds-text-muted);margin:0;display:flex;align-items:center;gap:6px;line-height:1.4}.hp-dt-feature-cta{margin-top:auto;min-width:120px}.hp-dt-footer{flex-shrink:0;text-align:center;padding:10px 16px;font-size:.65rem;color:var(--ds-text-muted);border-top:1px solid var(--ds-card-border);letter-spacing:.5px}.hp-dt-feature--battle .hp-dt-feature-icon{background:#b43c2814;border-color:#b43c2833}.hp-dt-feature--battle .hp-dt-feature-icon svg{color:#c43e2a}.hp-dt-feature--battle .hp-dt-feature-title{color:#c43e2a}.hp-dt-feature--battle .ds-btn-primary{background:#c43e2a;border-color:#a32a1a;color:#fff}.hp-dt-feature--battle .ds-btn-primary:hover{background:#a32a1a}.hp-dt-feature--jade .hp-dt-feature-icon{background:#328c5a14;border-color:#328c5a33}.hp-dt-feature--jade .hp-dt-feature-icon svg{color:#2d8c5a}.hp-dt-feature--jade .hp-dt-feature-title{color:#2d8c5a}.hp-dt-feature--jade .ds-btn-primary{background:#2d8c5a;border-color:#1e6b42;color:#fff}.hp-dt-feature--jade .ds-btn-primary:hover{background:#1e6b42}.hp-dt-feature--imperial .hp-dt-feature-icon{background:#c8a83214;border-color:#c8a83233}.hp-dt-feature--imperial .hp-dt-feature-icon svg{color:#c8a832}.hp-dt-feature--imperial .hp-dt-feature-title{color:#c8a832}.hp-dt-feature--imperial .ds-btn-primary{background:#c8a832;border-color:#a88820;color:#fff}.hp-dt-feature--imperial .ds-btn-primary:hover{background:#a88820}.hp-dt-feature--scroll .hp-dt-feature-icon{background:#b48c3c14;border-color:#b48c3c33}.hp-dt-feature--scroll .hp-dt-feature-icon svg{color:#b48c3c}.hp-dt-feature--scroll .hp-dt-feature-title{color:#b48c3c}.hp-dt-feature--scroll .ds-btn-primary{background:#b48c3c;border-color:#926e2a;color:#fff}.hp-dt-feature--scroll .ds-btn-primary:hover{background:#926e2a}.hp-dt-feature--kipho .hp-dt-feature-icon{background:#c83c3c14;border-color:#c83c3c33}.hp-dt-feature--kipho .hp-dt-feature-title{color:#c84040}.hp-dt-feature--kipho .ds-btn-primary{background:#c84040;border-color:#a82020;color:#fff}.hp-dt-feature--kipho .ds-btn-primary:hover{background:#a82020}.hp-dt-feature--giangho .hp-dt-feature-icon{background:#a050c814;border-color:#a050c833}.hp-dt-feature--giangho .hp-dt-feature-title{color:#a050c8}.hp-dt-feature--giangho .ds-btn-primary{background:#a050c8;border-color:#8030a8;color:#fff}.hp-dt-feature--giangho .ds-btn-primary:hover{background:#8030a8}.hp-dt-feature--news{border-color:#3498db59}.hp-dt-feature--news:hover{border-color:#3498db99;box-shadow:0 12px 32px #3498db1f}.hp-dt-feature--news .hp-dt-feature-icon{background:#3498db14;border-color:#3498db33}.hp-dt-feature--news .hp-dt-feature-title{color:#2980b9}.hp-dt-feature--news .ds-btn-primary{background:#2980b9;border-color:#206fa0;color:#fff}.hp-dt-feature--news .ds-btn-primary:hover{background:#206fa0}.hp-dt-feature--community{border-color:#1abc9c59}.hp-dt-feature--community:hover{border-color:#1abc9c99;box-shadow:0 12px 32px #1abc9c1f}.hp-dt-feature--community .hp-dt-feature-icon{background:#1abc9c14;border-color:#1abc9c33}.hp-dt-feature--community .hp-dt-feature-title{color:#16a085}.hp-dt-feature--community .ds-btn-primary{background:#16a085;border-color:#128070;color:#fff}.hp-dt-feature--community .ds-btn-primary:hover{background:#128070}.hp-dt-feature--coach{border-color:#8e44ad59}.hp-dt-feature--coach:hover{border-color:#8e44ad99;box-shadow:0 12px 32px #8e44ad1f}.hp-dt-feature--coach .hp-dt-feature-icon{background:#8e44ad14;border-color:#8e44ad33}.hp-dt-feature--coach .hp-dt-feature-title{color:#8e44ad}.hp-dt-feature--coach .ds-btn-primary{background:#8e44ad;border-color:#6e2c90;color:#fff}.hp-dt-feature--coach .ds-btn-primary:hover{background:#6e2c90}[data-theme=dark] .hp-dt-feature-card,[data-theme=dark] .hp-dt-stats-bar{background:#2a1a0e99}[data-theme=premium] .hp-dt-feature-card,[data-theme=premium] .hp-dt-stats-bar{background:#1a5c4499}}.pop-section{margin:14px 10px 0}.pop-scroll{padding:0}.pop-chips{padding:14px 10px 0;gap:8px}.pop-stats-row{display:flex;align-items:center;gap:12px;padding:10px 14px;font-size:.85rem;flex-wrap:wrap}.pop-stat-item{display:flex;align-items:center;gap:6px;color:var(--ds-text-muted)}.pop-stat-item strong{color:var(--ds-text);font-weight:700}.pop-stat-sep{color:var(--ds-border-strong);font-size:.85rem}.pop-my-rank-card{display:flex;align-items:center;gap:14px;margin:10px 10px 0;padding:14px 16px;background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-sm)}.pop-my-rank-avatar{width:48px;height:48px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;color:#fff;background:linear-gradient(145deg,#8b1e1e,#c0392b);border:2.5px solid var(--ds-primary);box-shadow:0 3px 10px #0006;overflow:hidden}.pop-my-rank-info{display:flex;flex-direction:column;gap:3px}.pop-my-rank-name{font-weight:700;font-size:1rem}.pop-my-rank-badge{display:flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600}.pop-my-rank-elo{color:var(--ds-text-muted);font-size:.72rem}.pop-find-btn{margin:12px 10px 0;border-radius:var(--ds-radius-lg);font-size:.95rem;letter-spacing:1px;padding:14px}.pop-action-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 10px 0}.pop-action-card{display:flex;flex-direction:column;align-items:center;gap:5px;padding:16px 10px;background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);cursor:pointer;text-align:center;transition:box-shadow .18s,transform .15s;box-shadow:var(--ds-shadow-sm);container-type:inline-size}.pop-action-card:hover{box-shadow:var(--ds-shadow-md);transform:translateY(-1px)}.pop-action-icon{font-size:clamp(1.4rem,12cqi,2.4rem)}.pop-action-label{font-size:clamp(.75rem,6cqi,1.1rem);font-weight:700;color:var(--ds-text)}.pop-action-sub{font-size:clamp(.6rem,5cqi,.88rem);color:var(--ds-text-muted)}.pop-join-row{display:flex;gap:8px;margin:10px 10px 0;align-items:stretch}.pop-join-input{flex:1;text-transform:uppercase;letter-spacing:2px;font-weight:700}.pop-join-btn{flex-shrink:0;padding:12px 20px}.pop-rooms-list{display:flex;flex-direction:column;gap:8px}.pop-room-row{display:flex;align-items:center;gap:8px;background:var(--ds-card);border-radius:var(--ds-radius-md);border:2px solid var(--ds-card-border);padding:10px 12px;font-size:.82rem;container-type:inline-size}.pop-room-side{display:flex;align-items:center;gap:5px;flex:1}.pop-room-side--red .pop-room-player{color:var(--ds-primary);font-weight:600}.pop-room-side--black .pop-room-player{color:var(--ds-text);font-weight:600}.pop-room-vs{font-size:.7rem;font-weight:700;color:var(--ds-text-muted)}.pop-room-meta{font-size:.68rem;color:var(--ds-text-light);background:var(--ds-card-secondary);padding:3px 8px;border-radius:var(--ds-radius-full);border:1px solid var(--ds-border)}.pop-room-view{border-color:var(--ds-primary);color:var(--ds-primary);flex-shrink:0}.pop-empty-rooms{text-align:center;padding:24px;color:var(--ds-text-muted);font-size:.85rem}.pop-mm-search-page{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:24px;background:radial-gradient(ellipse at center,#1e140af2,#0a0500fa 70%)}.pop-mm-back-btn{position:absolute;top:16px;left:16px;width:40px;height:40px;border-radius:12px;border:1.5px solid rgba(255,255,255,.15);background:#0006;color:#ffffffb3;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:2}.pop-mm-back-btn:hover{background:#ffffff1a;color:#fff}.pop-mm-search-card{background-color:#f4efdf;border:2px solid #a68a7a;border-radius:12px;padding:30px;display:flex;flex-direction:column;align-items:center;gap:20px;box-shadow:0 10px 30px #00000080;width:min(100%,320px);position:relative;z-index:2}.pop-mm-search-title{font-family:var(--ds-font-serif, serif);font-size:1.25rem;font-weight:700;color:#333}.pop-mm-radar-wrap{position:relative;width:120px;height:120px;margin:10px 0}.pop-mm-radar-green{width:100%;height:100%;border-radius:50%;background-color:#e8eadf;border:1px solid #7c8e76;position:relative;overflow:hidden;box-shadow:inset 0 0 10px #0000001a}.pop-mm-radar-grid{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:radial-gradient(transparent 30%,#7c8e76 31%,transparent 33%) center/100% 100%,radial-gradient(transparent 60%,#7c8e76 61%,transparent 63%) center/100% 100%,linear-gradient(to right,transparent 49.5%,#7c8e76 49.5%,#7c8e76 50.5%,transparent 50.5%),linear-gradient(to bottom,transparent 49.5%,#7c8e76 49.5%,#7c8e76 50.5%,transparent 50.5%);opacity:.5}.pop-mm-radar-sweep{position:absolute;top:0;left:50%;width:50%;height:50%;background:conic-gradient(from 0deg,rgba(124,142,118,0) 0deg,rgba(124,142,118,.8) 90deg,transparent 90deg);transform-origin:0 100%;animation:popMmSweep 2s linear infinite}@keyframes popMmSweep{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pop-mm-search-timer{font-family:var(--ds-font-mono, monospace);font-size:1.4rem;font-weight:800;color:#6f1214;letter-spacing:1px}.pop-mm-cancel-btn{background-color:#6f1214;color:#fff;border:none;border-radius:24px;padding:10px 24px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s;width:100%}.pop-mm-cancel-btn:hover{background-color:#550d0f}.pop-mm-found-page{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:24px;background:radial-gradient(ellipse at center,#1e140af2,#0a0500fa 70%);animation:popFoundFlash .5s ease-out}@keyframes popFoundFlash{0%{opacity:0}30%{opacity:1;background:radial-gradient(ellipse at center,#ffc83c26,#0a0500f2)}to{opacity:1}}.pop-mm-found-title{font-size:1.3rem;font-weight:900;color:gold;text-shadow:0 0 20px rgba(255,215,0,.4);letter-spacing:2px;animation:popFoundBounce .6s cubic-bezier(.34,1.56,.64,1)}@keyframes popFoundBounce{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.pop-mm-vs-row{display:flex;align-items:center;gap:20px;width:100%;max-width:400px;justify-content:center}.pop-mm-vs-player{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;animation:popVsSlideIn .5s ease-out}.pop-mm-vs-player:first-child{animation-name:popVsSlideLeft}.pop-mm-vs-player:last-child{animation-name:popVsSlideRight}@keyframes popVsSlideLeft{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}@keyframes popVsSlideRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.pop-mm-vs-avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.5rem;color:#fff;background:linear-gradient(145deg,#8b1e1e,#c0392b);border:3px solid var(--ds-primary);overflow:hidden}.pop-mm-vs-name{font-weight:700;font-size:.95rem;color:#fff}.pop-mm-vs-rank{font-size:.75rem;font-weight:600}.pop-mm-vs-elo{font-size:.68rem;color:#fff6}.pop-mm-vs-icon{display:flex;align-items:center;justify-content:center;width:50px;height:50px;border-radius:50%;background:#ffd7001f;border:2px solid rgba(255,215,0,.3);box-shadow:0 0 20px #ffd70026;flex-shrink:0}.pop-mm-vs-icon span{font-size:1rem;font-weight:900;color:gold;letter-spacing:1px}.pop-mm-countdown-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}.pop-mm-countdown-num{font-size:3.5rem;font-weight:900;color:gold;text-shadow:0 0 30px rgba(255,215,0,.5);animation:popCountBounce 1s cubic-bezier(.34,1.56,.64,1);font-family:var(--ds-font-mono, "Fira Mono", monospace)}@keyframes popCountBounce{0%{transform:scale(2);opacity:0}50%{transform:scale(.9)}to{transform:scale(1);opacity:1}}.pop-mm-countdown-label{font-size:.78rem;color:#ffd70080;font-weight:500}.ph-scroll{display:flex;align-items:center;justify-content:center;padding:24px}.ph-card{padding:40px 32px;text-align:center;max-width:340px;width:100%}.ph-title{font-family:var(--ds-font-serif);font-size:1.2rem;font-weight:700;color:var(--ds-primary);letter-spacing:1px;margin-bottom:5px}.ph-subtitle{font-size:1rem;font-weight:700;color:var(--ds-text);margin-bottom:14px}.ph-desc{font-size:.85rem;color:var(--ds-text-muted);line-height:1.6;margin-bottom:22px}.ph-loading{display:flex;align-items:center;justify-content:center;gap:7px;color:var(--ds-gold);font-size:.9rem;font-weight:600}.ph-chess-icon{font-size:1.2rem}.ph-dots span{animation:ph-dot 1.4s ease-in-out infinite}.ph-dots span:nth-child(2){animation-delay:.2s}.ph-dots span:nth-child(3){animation-delay:.4s}@keyframes ph-dot{0%,80%,to{opacity:0}40%{opacity:1}}@media(min-width:1024px){.pop-page .pop-scroll,.pop-page .ds-bottom-nav{display:none}}.app-content .pop-dt-wrapper{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:14px;padding:20px;margin:0 auto;width:min(1320px,100%);min-height:100%;align-content:start;box-sizing:border-box}.pop-dt-col{display:flex;flex-direction:column;gap:12px;min-width:0}.pop-dt-col--actions{grid-column:1 / span 4}.pop-dt-col--live{grid-column:5 / span 4}.pop-dt-col--ranking{grid-column:9 / span 4}.pop-dt-stats-bar{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-gold);border-radius:var(--ds-radius-lg);font-size:.88rem;color:var(--text-body);box-shadow:var(--shadow-card)}.pop-dt-stat{display:flex;align-items:center;gap:6px}.pop-dt-stat strong{color:var(--text-h);font-weight:700}.pop-dt-stat-sep{color:var(--border-dim);font-size:.85rem}.pop-dt-rank-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--bg-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);box-shadow:var(--shadow-card);position:relative;overflow:hidden}.pop-dt-rank-avatar{width:52px;height:52px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.25rem;color:#fff;background:linear-gradient(145deg,#8b1e1e,#c0392b);border:3px solid var(--ds-primary);overflow:hidden}.pop-dt-rank-info{display:flex;flex-direction:column;gap:3px;min-width:0}.pop-dt-rank-name{font-weight:700;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pop-dt-rank-badge{display:flex;align-items:center;gap:8px;font-size:.8rem;font-weight:600}.pop-dt-rank-elo{color:var(--text-muted);font-size:.75rem}.pop-dt-mode-section{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:var(--ds-radius-lg);padding:12px 14px;box-shadow:var(--shadow-card)}.pop-dt-mode-label{font-size:.72rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px}.pop-dt-mode-chips{display:flex;flex-wrap:wrap;gap:8px}.pop-dt-mode-chip{padding:8px 14px;border-radius:var(--ds-radius-full);border:1.5px solid var(--border-dim);background:transparent;font-family:var(--ds-font);font-size:.8rem;font-weight:600;color:var(--text-body);cursor:pointer;transition:all .18s}.pop-dt-mode-chip:hover{border-color:var(--border-bright);color:var(--text-h)}.pop-dt-mode-chip.active{background:var(--btn-cta-bg);border-color:var(--btn-cta-bg);color:var(--btn-cta-text)}.pop-dt-find-btn{padding:14px;font-size:.95rem;letter-spacing:1.2px;border-radius:var(--ds-radius-lg);display:flex;align-items:center;justify-content:center;gap:10px}.pop-dt-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pop-dt-action-card{display:flex;align-items:center;gap:10px;padding:14px;background:var(--bg-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);cursor:pointer;transition:box-shadow .18s,transform .15s,border-color .18s;box-shadow:var(--shadow-card)}.pop-dt-action-card:hover{box-shadow:var(--ds-shadow-md);transform:translateY(-2px);border-color:var(--border-bright)}.pop-dt-action-icon{font-size:1.6rem;flex-shrink:0;color:var(--border-gold)}.pop-dt-action-text{display:flex;flex-direction:column;gap:2px;text-align:left;min-width:0}.pop-dt-action-label{font-size:.84rem;font-weight:700;color:var(--text-h)}.pop-dt-action-sub{font-size:.7rem;color:var(--text-muted)}.pop-dt-join{display:flex;gap:10px}.pop-dt-join-input{flex:1;text-transform:uppercase;letter-spacing:2px;font-weight:700;font-size:.9rem}.pop-dt-join-btn{flex-shrink:0;padding:12px 18px;font-weight:700}.pop-dt-live-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:10px;border-bottom:1px solid var(--border-gold)}.pop-dt-live-title{font-family:var(--ds-font-serif);font-size:.95rem;font-weight:700;color:var(--text-h);letter-spacing:1px;margin:0}.pop-dt-live-count{font-size:.74rem;color:var(--text-muted);font-weight:600}.pop-dt-live-list{display:flex;flex-direction:column;gap:8px}.pop-dt-live-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border-gold);border-radius:var(--ds-radius-md);font-size:.82rem;box-shadow:var(--shadow-card)}.pop-dt-live-row:hover{border-color:var(--border-bright)}.pop-dt-live-player{display:flex;align-items:center;gap:6px;flex:1;font-weight:600;color:var(--text-h);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pop-dt-live-player--red .ds-dot{background:var(--ds-primary)}.pop-dt-live-vs{font-size:.72rem;font-weight:700;color:var(--text-muted);padding:0 2px}.pop-dt-live-mode{font-size:.7rem;color:var(--text-light);background:var(--ds-card-secondary, rgba(255,255,255,.05));padding:4px 8px;border-radius:var(--ds-radius-full);border:1px solid var(--border-dim)}.pop-dt-live-spectate{flex-shrink:0}.pop-dt-live-empty,.pop-dt-ranking-empty{text-align:center;padding:32px 14px;color:var(--text-muted);font-size:.84rem;background:var(--bg-card);border:1px dashed var(--border-dim);border-radius:var(--ds-radius-lg)}.pop-dt-ranking-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:10px;border-bottom:1px solid var(--border-gold)}.pop-dt-ranking-title{margin:0;font-family:var(--ds-font-serif);font-size:.95rem;letter-spacing:1px;color:var(--text-h)}.pop-dt-ranking-mode{font-size:.7rem;color:var(--text-muted);border:1px solid var(--border-dim);border-radius:var(--ds-radius-full);padding:3px 9px}.pop-dt-ranking-list{display:flex;flex-direction:column;gap:8px}.pop-dt-ranking-row{display:grid;grid-template-columns:52px 1fr 64px;align-items:center;gap:8px;padding:10px 12px;border-radius:10px;border:1px solid var(--border-dim);background:var(--bg-card);font-size:.8rem}.pop-dt-ranking-row.is-me{border-color:var(--border-bright);background:#c8a96e1f}.pop-dt-ranking-rank{font-weight:700;color:var(--text-muted)}.pop-dt-ranking-name{color:var(--text-h);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pop-dt-ranking-elo{text-align:right;font-weight:700;color:var(--border-gold)}.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{background:var(--ds-primary-light);border-radius:var(--ds-radius-md)}.pcp-av-btn.selected .pcp-av-circle{border-color:var(--ds-gold)!important;box-shadow:0 0 0 3px #c8960a66,0 4px 16px #c8960a4d}.pcp-av-btn.selected .pcp-av-name{color:var(--ds-gold);font-weight:700}.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}@media(min-width:1024px){.pcp-page .pcp-scroll,.pcp-page .pcp-bottom-bar,.pcp-page .pcp-settings-overlay,.pcp-page .ds-bottom-nav{display:none}}.pcp-dt-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:28px;padding:28px 32px;margin:0 auto;min-height:100%;align-content:start;box-sizing:border-box}.pcp-dt-col{display:flex;flex-direction:column;gap:16px}.pcp-dt-hero-card{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:12px;padding:28px 24px;text-align:center;box-shadow:var(--shadow-card);position:relative;overflow:hidden;transition:background .4s,border-color .4s}.pcp-dt-hero-circle{width:100px;height:100px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;border:4px solid rgba(255,255,255,.15);box-shadow:0 6px 20px #0000004d}.pcp-dt-hero-char{font-family:var(--ds-font-serif);font-size:2.8rem;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.pcp-dt-hero-name{font-family:var(--ds-font-serif);font-size:1.3rem;font-weight:700;color:var(--text-h);letter-spacing:1px;margin-bottom:2px}.pcp-dt-hero-level{font-size:.85rem;font-weight:600;color:var(--border-gold);margin-bottom:6px}.pcp-dt-hero-desc{font-size:.82rem;color:var(--text-body);line-height:1.6;margin:0 0 12px}.pcp-dt-hero-label{font-size:.7rem;font-weight:700;color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px}.pcp-dt-hero-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.pcp-dt-av-btn{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;padding:6px;border-radius:var(--ds-radius-md);background:transparent;border:none;transition:transform .15s}.pcp-dt-av-btn:hover{transform:scale(1.06)}.pcp-dt-av-circle{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid transparent;transition:border-color .18s,box-shadow .18s;font-family:var(--ds-font-serif);font-size:1.4rem;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.3)}.pcp-dt-av-btn.selected .pcp-dt-av-circle{border-color:var(--border-bright);box-shadow:0 0 0 3px #c8a96e33}.pcp-dt-av-name{font-size:.68rem;font-weight:600;color:var(--text-body)}.pcp-dt-settings-card{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:12px;padding:18px 20px;box-shadow:var(--shadow-card);position:relative;overflow:hidden;transition:background .4s,border-color .4s}.pcp-dt-settings-label{font-size:.7rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px}.pcp-dt-levels-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.pcp-dt-level-pill{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--ds-radius-md);border:1.5px solid var(--border-dim);background:transparent;font-family:var(--ds-font);font-size:.8rem;font-weight:600;color:var(--text-body);cursor:pointer;transition:all .18s}.pcp-dt-level-pill:hover{border-color:var(--border-bright);color:var(--text-h)}.pcp-dt-level-pill.active{background:var(--btn-cta-bg);border-color:var(--btn-cta-bg);color:var(--btn-cta-text)}.pcp-dt-level-icon{font-size:1rem}.pcp-dt-level-name{flex:1}.pcp-dt-level-elo{font-size:.68rem;opacity:.7;font-family:var(--ds-font-mono)}.pcp-dt-side-row{display:flex;gap:8px}.pcp-dt-side-opt{flex:1;padding:12px;border-radius:var(--ds-radius-md);border:1.5px solid var(--border-dim);background:transparent;font-family:var(--ds-font);font-size:.85rem;font-weight:600;color:var(--text-body);cursor:pointer;transition:all .18s;text-align:center}.pcp-dt-side-opt:hover{border-color:var(--border-bright)}.pcp-dt-side-opt.active{background:var(--btn-cta-bg);border-color:var(--btn-cta-bg);color:var(--btn-cta-text)}.pcp-dt-time-grid{display:flex;flex-wrap:wrap;gap:8px}.pcp-dt-time-pill{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--ds-radius-full);border:1.5px solid var(--border-dim);background:transparent;font-family:var(--ds-font);font-size:.78rem;font-weight:600;color:var(--text-body);cursor:pointer;transition:all .18s}.pcp-dt-time-pill:hover{border-color:var(--border-bright)}.pcp-dt-time-pill.active{background:var(--btn-cta-bg);border-color:var(--btn-cta-bg);color:var(--btn-cta-text)}.pcp-dt-start-btn{padding:16px;font-size:1rem;letter-spacing:1.5px;border-radius:var(--ds-radius-lg);display:flex;align-items:center;justify-content:center;gap:10px}.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)}@media(min-width:1024px){.lp-page .lp-scroll,.lp-page .ds-bottom-nav{display:none}}.dt-content .lp-dt-wrapper{width:min(1320px,100%);margin:0 auto;padding:20px;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:14px;align-content:start;box-sizing:border-box}.dt-content .lp-dt-wrapper>.lp-story-hero{grid-column:1 / -1;margin:0;max-width:none;min-height:250px;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));grid-template-rows:auto auto}.dt-content .lp-story-hero-content{grid-column:1 / span 9;grid-row:1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:center;min-width:0}.dt-content .lp-story-avatar{justify-self:center}.dt-content .lp-story-hero-text{grid-column:2 / 4;min-width:0}.dt-content .lp-story-hero-footer{grid-column:1 / -1;grid-row:2}.lp-dt-grid{grid-column:1 / -1;display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px}.lp-dt-lesson-card{grid-column:span 4;background:var(--bg-card);border:1px solid var(--border-gold);border-radius:12px;padding:18px 14px;text-align:center;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-card);position:relative;overflow:hidden;min-width:0}.lp-dt-lesson-card:hover{transform:translateY(-2px);box-shadow:var(--ds-shadow-md);border-color:var(--border-bright)}.lp-dt-locked{opacity:.6}.lp-dt-lock-badge{position:absolute;top:8px;right:8px;color:var(--text-muted)}.lp-dt-lesson-icon{margin-bottom:10px;color:var(--border-gold)}.lp-dt-lesson-title{font-size:.9rem;font-weight:700;color:var(--text-h);margin-bottom:4px}.lp-dt-lesson-desc{font-size:.75rem;color:var(--text-muted);line-height:1.4;margin:0 0 10px}.lp-dt-progress{display:flex;align-items:center;gap:8px}.lp-dt-progress-bar{flex:1;height:6px;border-radius:3px;background:#ffffff14;overflow:hidden}.lp-dt-progress-fill{height:100%;border-radius:3px;background:var(--accent-green, #48a868);transition:width .4s ease}.lp-dt-progress-pct{font-size:.72rem;font-weight:600;color:var(--text-muted);min-width:28px;text-align:right}.lp-dt-empty{grid-column:1 / -1;background:var(--bg-card);border:1px dashed var(--border-dim);border-radius:12px;padding:18px 20px;text-align:center;color:var(--text-muted)}.lp-dt-content-panel{grid-column:1 / -1;background:var(--bg-card);border:1px solid var(--border-gold);border-radius:12px;padding:24px;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.lp-dt-content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.lp-dt-content-header h3{margin:0;font-size:1.1rem;color:var(--border-gold)}.lp-dt-content-close{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer}.lp-dt-content-body{font-size:.9rem;line-height:1.7;color:var(--text-body);white-space:pre-line}.lp-dt-videos{grid-column:1 / -1}.lp-dt-videos-title{font-size:.72rem;font-weight:700;letter-spacing:1.5px;color:var(--text-muted);text-transform:uppercase;margin:0 0 12px}.lp-dt-videos-row{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px}.lp-dt-video-card{grid-column:span 4;display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:10px;cursor:pointer;transition:all .18s;font-family:var(--ds-font);font-size:.82rem;font-weight:600;color:var(--text-body);min-width:0}.lp-dt-video-card:hover{border-color:var(--border-bright);color:var(--text-h)}.lp-dt-video-thumb{width:36px;height:36px;border-radius:8px;background:#ffffff0d;display:flex;align-items:center;justify-content:center;color:var(--border-gold);flex-shrink:0}.lnp-page{font-family:var(--ds-font)}.lnp-scroll{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:14px 10px 24px;min-height:100%;box-sizing:border-box}.lnp-card{width:min(100%,440px);max-width:440px;padding:22px 16px;container-type:inline-size;min-width:0}.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-form,.lnp-field,.lnp-pw-wrap{min-width:0;width:100%}.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;min-width:0;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)}}@media(max-width:420px){.lnp-social-row{flex-direction:column}}.lnp-folder-container{width:min(100%,360px);margin:auto;font-family:var(--ds-font, sans-serif);position:relative;z-index:1;grid-column:1 / -1;justify-self:center;align-self:center}.lnp-folder-tabs{display:flex;position:relative;z-index:2;margin-bottom:-1px}.lnp-folder-tab{flex:1;padding:12px 0;text-align:center;font-weight:800;font-size:.95rem;border:1px solid #a68a7a;cursor:pointer;transition:all .2s}.lnp-folder-tab:first-child{border-top-left-radius:12px;border-top-right-radius:12px}.lnp-folder-tab:last-child{border-top-left-radius:0;border-top-right-radius:12px;margin-left:-1px}.lnp-folder-tab.active{background-color:#f4efdf;color:#333;border-bottom:1px solid #f4efdf;position:relative;z-index:3}.lnp-folder-tab:not(.active){background-color:#dcd4c3;color:#999;border-bottom:1px solid #a68a7a;z-index:1}.lnp-folder-body{background-color:#f4efdf;border:1px solid #a68a7a;border-radius:0 0 12px 12px;padding:24px 20px;box-shadow:0 10px 20px #00000026;position:relative;z-index:1}.lnp-folder-field{margin-bottom:14px}.lnp-folder-field label{display:block;font-weight:800;font-size:.85rem;color:#333;margin-bottom:6px;text-align:left}.lnp-folder-input-wrap{position:relative}.lnp-folder-input{width:100%;padding:10px 14px;border:1px solid #c3b4a2;border-radius:8px;background-color:#faf7eb;font-size:.9rem;color:#333;box-sizing:border-box;outline:none}.lnp-folder-input:focus{border-color:#a68a7a}.lnp-folder-eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:.9rem;color:#888}.lnp-folder-btn-primary{width:100%;background-color:#6f1214;color:#fff;border:none;border-radius:24px;padding:12px;font-size:1.05rem;font-weight:700;cursor:pointer;margin-top:10px;transition:opacity .2s}.lnp-folder-btn-primary:hover{opacity:.9}.lnp-folder-divider{display:flex;align-items:center;text-align:center;color:#444;font-size:.85rem;margin:20px 0;font-weight:700}.lnp-folder-divider:before,.lnp-folder-divider:after{content:"";flex:1;border-bottom:1px solid #a68a7a}.lnp-folder-divider span{padding:0 10px;display:flex;align-items:center;gap:6px}.lnp-folder-divider span:before,.lnp-folder-divider span:after{content:"♦";font-size:.6rem;color:#a68a7a}.lnp-folder-socials{display:flex;gap:12px}.lnp-folder-social-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border-radius:24px;border:none;font-weight:700;font-size:.9rem;cursor:pointer;transition:opacity .2s}.lnp-folder-social-btn:hover{opacity:.9}.lnp-folder-social-google{background-color:#e3dbce;color:#555}.lnp-folder-social-facebook{background-color:#4b68a1;color:#fff}.lnp-folder-forgot{display:block;text-align:center;margin-top:20px;font-size:.85rem;font-weight:800;color:#333;text-decoration:underline;background:none;border:none;cursor:pointer;width:100%}.lnp-folder-btn-outline{width:100%;background-color:transparent;color:#6f1214;border:2px solid #6f1214;border-radius:24px;padding:10px;font-size:1.05rem;font-weight:700;cursor:pointer;margin-top:10px;transition:all .2s}.lnp-folder-btn-outline:hover{background-color:#6f12140d}@media(min-width:1024px){.lnp-page .lnp-scroll,.lnp-page .ds-bottom-nav{display:none}}.app-content .lnp-dt-wrapper{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:20px;padding:20px;max-width:860px;margin:0 auto;align-items:start;min-height:calc(100dvh - 52px);align-content:center}.app-content .lnp-dt-wrapper>.lnp-dt-branding{grid-column:1 / -1;justify-self:center;width:min(100%,620px);background:var(--bg-card);border:1px solid var(--border-gold);border-radius:14px;padding:32px 24px;text-align:center;box-shadow:var(--shadow-card);position:relative;overflow:hidden;min-width:0}.lnp-dt-logo-img{width:160px;height:auto;margin:0 auto;display:block;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4))}.app-content .lnp-dt-wrapper>.lnp-dt-form-card{grid-column:1 / -1;justify-self:center;width:min(100%,620px);background:var(--bg-card);border:1px solid var(--border-gold);border-radius:14px;padding:28px 24px;box-shadow:var(--shadow-card);position:relative;overflow:hidden;min-width:0}.lnp-dt-tabs{display:flex;gap:0;margin-bottom:20px;border-radius:var(--ds-radius-md);overflow:hidden;border:1px solid var(--border-dim)}.lnp-dt-tab{flex:1;padding:12px;border:none;background:transparent;font-family:var(--ds-font);font-size:.85rem;font-weight:700;color:var(--text-body);cursor:pointer;transition:all .18s;letter-spacing:1px}.lnp-dt-tab:first-child{border-right:1px solid var(--border-dim)}.lnp-dt-tab.active{background:var(--btn-cta-bg);color:var(--btn-cta-text)}.lnp-dt-form{display:flex;flex-direction:column;gap:14px;margin-bottom:14px}.lnp-dt-field{display:flex;flex-direction:column;gap:5px}.lnp-dt-field label{font-size:.75rem;font-weight:700;color:var(--text-muted);letter-spacing:.5px}.lnp-dt-pw-wrap{position:relative}.lnp-dt-pw-wrap .ds-input{padding-right:40px}.lnp-dt-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1rem;padding:4px}.lnp-dt-submit{margin-top:4px;padding:14px;font-size:.92rem;letter-spacing:1px}.lnp-dt-guest{margin-top:6px}.lnp-dt-divider{display:flex;align-items:center;gap:12px;margin:16px 0;font-size:.72rem;color:var(--text-muted)}.lnp-dt-divider:before,.lnp-dt-divider:after{content:"";flex:1;height:1px;background:var(--border-dim)}.lnp-dt-social{display:flex;gap:10px}.lnp-dt-social-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:var(--ds-radius-md);border:1px solid var(--border-dim);background:transparent;font-family:var(--ds-font);font-size:.82rem;font-weight:600;color:var(--text-body);cursor:pointer;transition:all .18s;opacity:.5}.lnp-dt-social-btn:hover{border-color:var(--border-bright);opacity:.7}.lnp-dt-forgot{display:block;margin:12px auto 0;background:none;border:none;font-family:var(--ds-font);font-size:.78rem;color:var(--text-muted);cursor:pointer;text-decoration:underline}.lnp-dt-forgot:hover{color:var(--text-body)}@media(max-width:1220px){.app-content .lnp-dt-wrapper>.lnp-dt-branding,.app-content .lnp-dt-wrapper>.lnp-dt-form-card{width:min(100%,620px)}}.pp-page{font-family:var(--ds-font, sans-serif)}.pp-page .ds-page-bg{display:none}.pp-scroll{display:flex;flex-direction:column;align-items:center;padding:60px 10px 40px;min-height:100vh;box-sizing:border-box;max-width:480px;margin:0 auto}.pp-tabs{display:flex;gap:8px;margin-bottom:16px;width:100%}.pp-tab-btn{flex:1;background:#f4efdfd9;border:1px solid #a68a7a;border-radius:8px;padding:8px;font-family:var(--ds-font, sans-serif);font-weight:700;color:#333;display:flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:background .2s}.pp-tab-btn.active{background:#6f1214;color:#fff;border-color:#6f1214}.pp-folder-card{background-color:#f4efdf;border:2px solid #a68a7a;border-radius:12px;padding:24px 20px;width:100%;box-shadow:0 10px 20px #0003;display:flex;flex-direction:column}.pp-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.pp-avatar{width:64px;height:64px;border-radius:50%;border:2px solid #a68a7a;background-color:#e0e0e0;display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:1.5rem;font-weight:700;color:#666;flex-shrink:0}.pp-avatar img{width:100%;height:100%;object-fit:cover}.pp-info{display:flex;flex-direction:column}.pp-name{font-size:1.3rem;font-weight:800;color:#333;margin-bottom:4px}.pp-date{font-size:.85rem;font-weight:600;color:#666}.pp-fieldset{border:1px solid #a68a7a;border-radius:8px;padding:16px 12px;margin:0 0 20px;width:100%;box-sizing:border-box}.pp-legend{font-size:.95rem;font-weight:800;color:#333;padding:0 10px;margin:0 auto}.pp-modes{display:flex;gap:8px;margin-bottom:16px;justify-content:space-between}.pp-mode-btn{flex:1;background-color:transparent;border:1px solid #a68a7a;border-radius:6px;padding:8px 4px;text-align:center;font-size:.85rem;font-weight:700;color:#333;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:all .2s}.pp-mode-btn.active{background-color:#e8dcc4;border-width:2px}.pp-stats-row{display:flex;justify-content:space-between;margin-bottom:12px}.pp-stat-col{display:flex;flex-direction:column;align-items:center;flex:1}.pp-stat-label{font-size:.8rem;font-weight:700;color:#555;margin-bottom:4px}.pp-stat-val{font-size:.95rem;font-weight:800;color:#333}.pp-progress-bar{display:flex;height:8px;border-radius:4px;overflow:hidden;background-color:#d4c8b8;width:100%}.pp-progress-win{background-color:#1e7a5a;transition:flex .5s}.pp-progress-loss{background-color:#6f1214;transition:flex .5s}.pp-progress-draw{background-color:silver;transition:flex .5s}.pp-history-list{display:flex;flex-direction:column;gap:0}.pp-history-empty{text-align:center;color:#666;font-size:.9rem;margin:10px 0}.pp-history-row{display:flex;align-items:center;padding:10px 4px;border-bottom:1px dashed #d4c8b8}.pp-history-row:last-child{border-bottom:none}.pp-hist-icon{margin-right:12px}.pp-hist-circle{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.8rem}.pp-hist-circle.win{background-color:#1e7a5a}.pp-hist-circle.loss{background-color:#b54040}.pp-hist-circle.draw{background-color:#888}.pp-hist-text{flex:1;font-size:.9rem;font-weight:600;color:#333}.pp-hist-elo{font-size:.9rem;font-weight:800}.pp-hist-elo.pos{color:#1e7a5a}.pp-hist-elo.neg{color:#b54040}.pp-btn-logout{width:120px;margin:0 auto;background-color:transparent;border:2px solid #6f1214;border-radius:20px;color:#6f1214;font-size:.95rem;font-weight:700;padding:8px 0;cursor:pointer;transition:background-color .2s}.pp-btn-logout:hover{background-color:#6f12140d}.pp-inv-card-wrapper,.pp-shop-card-wrapper{color:#333}.pp-inv-section-label{font-weight:700;margin-bottom:10px;display:flex;align-items:center}.pp-inv-empty{font-style:italic;color:#666}.pp-inv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.pp-inv-card{border:1px solid #a68a7a;border-radius:8px;padding:10px;text-align:center}.pp-inv-preview{width:100%;height:60px;border-radius:4px;margin-bottom:8px;background-size:cover;background-position:center}.pp-inv-name{font-weight:700;font-size:.85rem;margin-bottom:8px}.pp-inv-btn{background:transparent;border:1px solid #a68a7a;border-radius:4px;padding:4px 8px;font-size:.8rem;cursor:pointer;width:100%}.pp-inv-btn.equipped{background:#6f1214;color:#fff;border-color:#6f1214}@media(min-width:1024px){.pp-page .pp-scroll,.pp-page .ds-bottom-nav{display:none}}.pp-dt-wrapper{display:grid;grid-template-columns:340px 1fr;gap:24px;padding:24px 28px;margin:0 auto;align-content:start}.pp-dt-col{display:flex;flex-direction:column;gap:16px}.pp-dt-hero-card{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:12px;padding:28px 24px;text-align:center;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.pp-dt-avatar{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:2rem;color:#fff;background:linear-gradient(145deg,#8b1e1e,#c0392b);border:3px solid var(--ds-primary);margin:0 auto 12px;overflow:hidden}.pp-dt-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.pp-dt-name{font-size:1.2rem;font-weight:700;margin:0 0 6px}.pp-dt-rank-badge{display:inline-flex;align-items:center;gap:4px;font-size:.8rem;font-weight:700;padding:4px 14px;border-radius:999px;border:1.5px solid;margin-bottom:8px}.pp-dt-date{font-size:.72rem;color:var(--text-muted);margin:0 0 14px}.pp-dt-elo-row{display:flex;gap:8px;justify-content:center;margin-bottom:12px}.pp-dt-elo-card{flex:1;padding:10px 8px;border-radius:var(--ds-radius-md);border:1.5px solid var(--border-dim);text-align:center;display:flex;flex-direction:column;align-items:center;gap:2px}.pp-dt-elo-icon{font-size:1rem}.pp-dt-elo-mode{font-size:.65rem;color:var(--text-muted);font-weight:600}.pp-dt-elo-val{font-size:1rem;font-weight:700}.pp-dt-progress{margin-bottom:14px}.pp-dt-progress-labels{display:flex;justify-content:space-between;font-size:.65rem;color:var(--text-muted);margin-bottom:4px}.pp-dt-progress-bar{height:6px;border-radius:3px;background:#ffffff14;overflow:hidden}.pp-dt-progress-fill{height:100%;border-radius:3px;transition:width .5s ease}.pp-dt-progress-pct{font-size:.6rem;color:var(--text-muted);text-align:center;margin-top:3px}.pp-dt-logout{margin-top:8px}.pp-dt-stats-card{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:12px;padding:20px;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.pp-dt-stats-title{font-size:.88rem;font-weight:700;color:var(--text-h);margin:0 0 14px}.pp-dt-stats-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px;margin-bottom:14px}.pp-dt-stat{text-align:center;padding:10px 8px;border-radius:var(--ds-radius-md);background:#ffffff08;border:1px solid var(--border-dim)}.pp-dt-stat-label{display:block;font-size:.68rem;color:var(--text-muted);font-weight:600;margin-bottom:4px}.pp-dt-stat-val{display:block;font-size:1.1rem;font-weight:700;color:var(--text-h)}.pp-dt-stat--win .pp-dt-stat-val{color:#48a868}.pp-dt-stat--loss .pp-dt-stat-val{color:#d05060}.pp-dt-winrate{display:flex;align-items:center;gap:10px;font-size:.78rem;color:var(--text-body);font-weight:600}.pp-dt-winrate-bar{flex:1;height:8px;border-radius:4px;background:#ffffff14;overflow:hidden}.pp-dt-winrate-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,#48a868,#2d8a4e)}.pp-dt-history-card{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:12px;padding:20px;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.pp-dt-history-title{font-size:.88rem;font-weight:700;color:var(--text-h);margin:0 0 12px}.pp-dt-history-list{display:flex;flex-direction:column;gap:6px}.pp-dt-no-history{font-size:.82rem;color:var(--text-muted);text-align:center;padding:16px 0;margin:0}.pp-dt-history-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--ds-radius-md);background:#ffffff05;border:1px solid var(--border-dim);font-size:.82rem}.pp-dt-history-icon{font-size:.9rem}.pp-dt-history-text{flex:1;color:var(--text-body);font-weight:600}.pp-dt-history-elo{font-weight:700;font-family:var(--ds-font-mono);font-size:.78rem}.pp-dt-elo-pos{color:#48a868}.pp-dt-elo-neg{color:#d05060}.rp-page{font-family:var(--ds-font)}.rp-loading{text-align:center;padding:40px;color:var(--ds-text-muted);font-size:.92rem}.rp-page{font-family:var(--ds-font, sans-serif)}.rp-page .ds-page-bg{display:none}.rp-scroll{display:flex;flex-direction:column;align-items:center;padding:40px 10px;min-height:100vh;box-sizing:border-box}.rp-folder-card{background-color:#f4efdf;border:2px solid #a68a7a;border-radius:12px;width:min(100%,360px);margin:0 auto;box-shadow:0 10px 20px #0003;display:flex;flex-direction:column;overflow:hidden}.rp-tabs{display:flex;margin:12px 12px 0;border-radius:20px;border:1px solid #a68a7a;overflow:hidden}.rp-tab{flex:1;background:transparent;border:none;padding:10px 0;font-family:var(--ds-font, sans-serif);font-size:.95rem;font-weight:700;color:#333;cursor:pointer;transition:all .2s}.rp-tab.active{background-color:#6f1214;color:#fff}.rp-loading{text-align:center;padding:60px 20px;font-weight:600;color:#666}.rp-podium{display:flex;align-items:flex-end;justify-content:center;padding:30px 12px 10px;gap:0}.rp-pod{display:flex;flex-direction:column;align-items:center;flex:1}.rp-pod-av-wrap{position:relative;display:flex;flex-direction:column;align-items:center;margin-bottom:8px}.rp-pod-medal{position:absolute;top:-20px;z-index:2;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.rp-pod-av{border-radius:50%;border:3px solid #ccc;overflow:hidden;background:#e0e0e0;display:flex;align-items:center;justify-content:center;font-weight:700;color:#333;box-shadow:0 4px 8px #0003;position:relative;z-index:1}.rp-pod-av img{width:100%;height:100%;object-fit:cover}.rp-pod-av-1 .rp-pod-av{border-color:#f0c060}.rp-pod-av-2 .rp-pod-av{border-color:silver}.rp-pod-av-3 .rp-pod-av{border-color:#cd7f32}.rp-pod-rank-badge{position:absolute;bottom:-8px;width:24px;height:24px;border-radius:50%;background:#fff;border:1.5px solid #ccc;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;color:#333;z-index:3}.rp-pod-av-1 .rp-pod-rank-badge{background:#f0c060;border-color:#c8960a;color:#fff}.rp-pod-av-2 .rp-pod-rank-badge{background:silver;border-color:#999;color:#fff}.rp-pod-av-3 .rp-pod-rank-badge{background:#cd7f32;border-color:sienna;color:#fff}.rp-pod-bar{width:100%}.rp-bar-1{height:90px;background:#e8b858}.rp-bar-2{height:60px;background:#d0d0d0}.rp-bar-3{height:40px;background:#c89078}.rp-table-header{display:flex;align-items:center;padding:8px 16px;border-top:1px solid #d4c8b8;border-bottom:1px solid #d4c8b8;background-color:transparent;margin-top:10px}.rp-table-header span{font-size:.8rem;font-weight:700;color:#555}.rp-th-rank{width:40px}.rp-th-name{flex:1}.rp-th-winpct{width:50px;text-align:right}.rp-th-elo{width:45px;text-align:right}.rp-list{display:flex;flex-direction:column;padding-bottom:16px}.rp-row{display:flex;align-items:center;padding:10px 16px;border-bottom:1px dashed #d4c8b8}.rp-row--me{background-color:#6f12140d}.rp-row-rank{width:40px;font-weight:700;font-size:.85rem;color:#333}.rp-row-player{flex:1;display:flex;align-items:center;gap:8px;min-width:0}.rp-row-av{width:32px;height:32px;border-radius:50%;border:1px solid #ccc;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#eee;font-size:.8rem;font-weight:700;flex-shrink:0}.rp-row-av img{width:100%;height:100%;object-fit:cover}.rp-row-name{font-size:.9rem;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-row-winpct{width:50px;text-align:right;font-size:.85rem;font-weight:600;color:#555}.rp-row-elo{width:45px;text-align:right;font-size:.85rem;font-weight:700;color:#333}.rp-footer{background-color:#6f1214;padding:16px;display:flex;align-items:center;justify-content:center;gap:16px}.rp-footer-icon{font-size:1.2rem;color:#f0c060}.rp-footer-text{color:#fff;font-family:var(--ds-font-serif, serif);font-size:1.1rem;font-weight:700}@media(min-width:1024px){.rp-page .rp-scroll,.rp-page .rp-tab-bar,.rp-page .rp-my-rank-footer,.rp-page .ds-bottom-nav{display:none}}.rp-dt-wrapper{margin:0 auto;padding:24px 28px;display:flex;flex-direction:column;gap:20px}.rp-dt-tab-bar{display:flex;gap:8px;justify-content:center}.rp-dt-tab{padding:10px 24px;border-radius:var(--ds-radius-full);border:1.5px solid var(--border-dim);background:transparent;font-family:var(--ds-font);font-size:.85rem;font-weight:600;color:var(--text-body);cursor:pointer;transition:all .18s}.rp-dt-tab:hover{border-color:var(--border-bright);color:var(--text-h)}.rp-dt-tab.active{background:var(--btn-cta-bg);border-color:var(--btn-cta-bg);color:var(--btn-cta-text)}.rp-dt-podium{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:12px;padding:24px;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.rp-dt-table-card{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:12px;padding:18px 20px;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.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-content.gr-desktop-v2{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.game-room{position:relative;width:100%;height:100%;max-height:100%;overflow:hidden;z-index:1;background-color:var(--gr-bg);background-image:url(/assets/bg-landscape.webp);background-size:cover;background-position:center;background-attachment:fixed;color:var(--gr-text);font-family:var(--font-sans);display:grid;grid-template-columns:repeat(12,minmax(0,1fr));grid-template-rows:1fr;align-items:center;justify-items:center;column-gap:10px;padding:0 12px;box-sizing:border-box}.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:3 / span 8;grid-row:1;justify-self:stretch;align-self:stretch;min-width:0;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:0;height:100%;max-height:100vh;max-height:100dvh}.gr-canvas{border-radius:12px;cursor:pointer;max-height:calc(100vh - 32px);max-height:calc(100dvh - 32px);max-width:calc(100vw - 32px);max-width:calc(100dvw - 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:2;grid-row:1;display:flex;flex-direction:column;justify-content:center;gap:8px;padding:16px 12px;width:100%;max-width:230px;min-width:0;justify-self:center;align-self:center;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:11;grid-row:1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:16px 12px;justify-self:center;align-self:center;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,.gr-chat-popup{position:absolute;right:100px;top:24px;bottom:24px;width:340px;background:var(--gr-panel);border:1px solid var(--gr-panel-border);border-radius:14px;z-index:30;display:flex;flex-direction:column;transform:translate(115%);opacity:0;pointer-events:none;transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .2s ease;overflow:hidden;box-shadow:-4px 0 24px #0000004d}.gr-slide-panel.open,.gr-chat-popup.open{transform:translate(0);opacity:1;pointer-events:auto}.gr-chat-popup-body{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--gr-bg-surface)}.gr-chat-placeholder{padding:24px;text-align:center;color:#ffffff80;font-size:.9rem}.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{display:none}.gr-move-list{-ms-overflow-style:none;scrollbar-width:none}.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:relative;grid-column:12;grid-row:1;justify-self:stretch;align-self:end;width:100%;max-height:calc(100% - 16px);margin:8px 0;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:100%;max-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:100%;max-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:100%!important;height:100vh!important;height:100dvh!important;overflow:hidden!important;grid-template-columns:unset!important;grid-template-rows:unset!important}.gr-board-area{position:absolute!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100%!important;height:100%!important;max-height:100vh!important;max-height:100dvh!important;grid-column:unset!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:1;background:transparent!important;overflow:hidden!important;padding:0!important}.gr-mobile-top{display:flex!important;position:absolute;top:0;left:0;right:0;z-index:20;align-items:center;justify-content:space-between;padding:8px 14px 14px;padding-top:max(8px,env(safe-area-inset-top,8px));background:linear-gradient(180deg,#000000c7,#0000);gap:10px;min-height:60px;max-height:80px;pointer-events:auto;box-sizing:border-box;overflow:hidden}.gr-mobile-bottom{display:flex!important;position:absolute;bottom:0;left:0;right:0;z-index:20;align-items:center;justify-content:space-between;padding:14px 14px 10px;padding-bottom:max(10px,env(safe-area-inset-bottom,10px));background:linear-gradient(0deg,#000000d9,#0000);gap:10px;min-height:68px;max-height:88px;pointer-events:auto;box-sizing:border-box;overflow:hidden}.gr-mb-player{display:flex;align-items:center;gap:7px;min-width:0;flex:1;overflow:hidden}.gr-mb-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;color:#fff;box-shadow:0 3px 10px #0000008c;overflow:hidden}.gr-mb-avatar img{width:100%;height:100%;object-fit:cover}.gr-mb-avatar--red{background:linear-gradient(145deg,#8b1e1e,#c0392b);border:2.5px solid rgba(200,70,70,.6)}.gr-mb-avatar--black{background:linear-gradient(145deg,#1a1830,#3a1a6e);border:2.5px solid rgba(110,70,180,.6)}.gr-mb-info{display:flex;flex-direction:column;gap:1px;min-width:0}.gr-mb-name{font-weight:700;font-size:.88rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;text-shadow:0 1px 5px rgba(0,0,0,.8)}.gr-mb-elo{font-size:.67rem;color:#ffffff6b;font-weight:500}.gr-mb-player.active-turn .gr-mb-name{color:#f0c060;text-shadow:0 0 12px rgba(240,192,96,.55)}.gr-mb-player.active-turn .gr-mb-avatar{box-shadow:0 0 0 2.5px #f0c06099,0 3px 10px #0000008c}.gr-mb-clock{font-family:Fira Mono,Roboto Mono,monospace;font-size:clamp(1.2rem,4vw,1.7rem);font-weight:900;letter-spacing:1px;color:#fff;padding:4px 10px;border-radius:12px;min-width:80px;text-align:center;transition:all .25s ease;flex-shrink:0;text-shadow:0 2px 8px rgba(0,0,0,.5)}.gr-mb-clock--black{background:#12102ecc;border:1.5px solid rgba(120,100,200,.25)}.gr-mb-clock--red{background:#5a0810d9;border:1.5px solid rgba(200,60,60,.32)}.gr-mb-clock.gr-timer-active{box-shadow:0 0 22px #b0703080;border-color:#d2a03c99!important}.gr-mb-clock.gr-timer-danger{color:#ff6060!important;text-shadow:0 0 16px rgba(255,80,80,.65);animation:grPulse .9s ease-in-out infinite}.gr-mb-top-actions,.gr-mb-bottom-actions{display:flex;gap:7px;align-items:center;flex-shrink:0}.gr-mb-btn{width:38px;height:38px;border-radius:11px;border:1.5px solid rgba(255,255,255,.15);background:#0000006b;color:#ffffffc7;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .18s;flex-shrink:0;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.gr-mb-btn svg{width:17px;height:17px}.gr-mb-btn:hover{background:#ffffff2e;color:#fff}.gr-mb-btn:active{transform:scale(.9)}.gr-mb-btn--menu{width:42px;height:42px;border-radius:13px;background:#b0703047;border-color:#c8964673;color:#d4a040}.gr-mb-btn--menu:hover{background:#b0703080;color:#f0c060}.gr-mobile-popup{display:none;position:absolute;bottom:88px;right:14px;z-index:999;background:#0e0c1cf7;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:8px 6px;box-shadow:0 20px 60px #000c;flex-direction:column;gap:2px;min-width:190px;animation:mbPopIn .22s cubic-bezier(.34,1.56,.64,1);pointer-events:auto}.gr-mobile-popup.open{display:flex}@keyframes mbPopIn{0%{opacity:0;transform:translateY(14px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}.gr-popup-item{display:flex;align-items:center;gap:12px;padding:11px 16px;border-radius:13px;background:none;border:none;color:#ebe1d7e0;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s;text-align:left;width:100%;font-family:var(--font-sans)}.gr-popup-item svg{width:18px;height:18px;flex-shrink:0;opacity:.72}.gr-popup-item:hover{background:#ffffff17}.gr-popup-item:active{transform:scale(.97)}.gr-popup-item--danger{color:#ff7575}.gr-popup-item--danger svg{opacity:.92}.gr-popup-item--danger:hover{background:#dc3c3c29}.gr-popup-divider{height:1px;background:#ffffff12;margin:2px 10px}.gr-popup-backdrop{display:none;position:absolute;top:0;right:0;bottom:0;left:0;z-index:998;background:#00000040}.gr-popup-backdrop.open{display:block}.gr-status-float{position:absolute;top:auto;bottom:90px;left:50%;transform:translate(-50%);z-index:25;font-size:.76rem;padding:4px 16px;white-space:nowrap;max-width:90vw;overflow:hidden;text-overflow:ellipsis}.gr-status-idle{opacity:0;pointer-events:none}.gr-slide-panel{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;margin:0;border-radius:0;transform:translate(100%);opacity:1;pointer-events:auto}.gr-chat-popup{position:absolute;bottom:92px;left:10px;right:10px;width:auto;max-height:50vh}.gr-mobile-popup{max-height:calc(100vh - 180px);max-height:calc(100dvh - 180px);overflow-y:auto}}@media(min-width:768px)and (max-width:1023px){.gr-left-col{width:100%;max-width:190px;gap:7px}.gr-clock-value{font-size:2.5rem!important}}@media(min-width:1280px){.gr-left-col{width:100%;max-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);height:calc(100dvh - 50px)}.game-container{display:flex;flex:1;gap:var(--space-lg);padding:0 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:100vh!important;max-height:100dvh!important;object-fit:contain}.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}.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;-ms-overflow-style:none;scrollbar-width:none}.gr-chat-messages::-webkit-scrollbar{display:none}.gr-chat-msg{display:flex;align-items:baseline;gap:6px;font-size:.8rem;line-height:1.4;padding:2px 0}.gr-chat-role{font-size:.7rem;flex-shrink:0}.gr-chat-sender{font-weight:600;flex-shrink:0}.gr-chat-text{color:#fff;word-break:break-word}.gr-chat-time{font-size:.65rem;color:var(--gr-text-muted);margin-left:auto;flex-shrink:0}.gr-chat-system{font-size:.75rem;color:#d4a017;font-style:italic;padding:2px 0}.gr-chat-input-row{display:flex;gap:4px;padding:8px;border-top:1px solid var(--gr-panel-border)}.gr-chat-input{flex:1;background:#ffffff0d;border:1px solid var(--gr-panel-border);border-radius:8px;color:#fff;padding:4px 8px;font-size:.8rem;outline:none;transition:border-color .15s}.gr-chat-input:focus{border-color:#c8a05080}.gr-chat-send{padding:4px 8px;font-size:.85rem;background:#ffd70026;border:1px solid rgba(255,215,0,.3);border-radius:8px;color:#d4a017;cursor:pointer;transition:background .15s}.gr-chat-send:hover{background:#ffd70040}.gr-check-popup{animation:grCheckAppear .3s cubic-bezier(.34,1.56,.64,1)}.gr-check-popup.gr-check-fading{animation:grCheckFadeOut .5s ease-out forwards}@keyframes grCheckAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.7)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes grCheckFadeOut{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.9) translateY(-10px)}}@keyframes grCheckShake{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-4px) rotate(-3deg)}75%{transform:translate(4px) rotate(3deg)}}.gr-player-card.active-turn{animation:grActiveTurnPulse 1.8s ease-in-out infinite}@keyframes grActiveTurnPulse{0%,to{box-shadow:0 4px 20px #0000004d,0 0 #b0703000}50%{box-shadow:0 4px 20px #0000004d,0 0 18px 3px #b0703040}}@media(max-width:767px){.gr-mb-player.active-turn .gr-mb-avatar{animation:grActiveMbPulse 1.8s ease-in-out infinite}@keyframes grActiveMbPulse{0%,to{box-shadow:0 0 0 2.5px #f0c06080,0 3px 10px #0000008c}50%{box-shadow:0 0 0 4px #f0c060b3,0 0 16px #f0c06066,0 3px 10px #0000008c}}.gr-mb-player.active-turn .gr-mb-name{animation:grActiveNameBlink 1.8s ease-in-out infinite}@keyframes grActiveNameBlink{0%,to{opacity:1}50%{opacity:.7}}}@keyframes grLastMoveAppear{0%{opacity:0;transform:translate(-50%) translateY(6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.gr-v2{display:flex!important;flex-direction:row!important;align-items:stretch!important;justify-content:center!important;gap:32px!important;padding:24px!important;box-sizing:border-box!important;grid-template-columns:unset!important;position:relative!important}.gr-v2-board-section{flex:1;min-width:0;position:relative;display:flex;align-items:stretch;justify-content:center;z-index:1;height:100%}.gr-v2-board-wrap{display:flex;align-items:center;justify-content:center;width:100%;height:100%;padding:0;box-sizing:border-box;background:transparent!important}.gr-v2-canvas{display:block;cursor:pointer;border-radius:8px;max-height:100vh;max-height:100dvh;max-width:100%;width:auto;height:auto;background:transparent!important;box-shadow:none!important;transition:transform .3s ease}.gr-v2-back-wrap{position:absolute;top:0;left:0;z-index:20}.gr-v2-back{width:44px;height:44px;border-radius:12px;border:1.5px solid rgba(180,160,140,.25);background:#00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#dcd2c8e6;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.gr-v2-back:hover{background:#000000b3;color:#fff;transform:scale(1.05)}.gr-v2-back:active{transform:scale(.95)}.gr-v2-back svg{width:20px;height:20px}.gr-v2-ai-thinking{position:absolute;bottom:64px;left:50%;transform:translate(-50%);z-index:15;display:flex;align-items:center;gap:10px;padding:8px 20px;background:#1e1e20cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:24px;font-size:.82rem;color:#ffffffb3;border:1px solid rgba(255,255,255,.08)}.gr-v2-ai-dots{display:flex;gap:4px}.gr-v2-ai-dots span{width:7px;height:7px;border-radius:50%;background:#b07030;animation:aiDot 1.4s ease-in-out infinite}.gr-v2-ai-dots span:nth-child(2){animation-delay:.2s}.gr-v2-ai-dots span:nth-child(3){animation-delay:.4s}.gr-v2-draw-bar{position:absolute;bottom:72px;left:50%;transform:translate(-50%);z-index:20;display:flex;align-items:center;gap:14px;padding:10px 20px;background:#1e1e20e0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(176,112,48,.3);border-radius:12px;font-size:.85rem;color:#ffffffd9;box-shadow:0 4px 20px #0006}.gr-v2-draw-actions{display:flex;gap:8px}.gr-v2-draw-accept,.gr-v2-draw-decline{width:36px;height:36px;border-radius:8px;border:1.5px solid rgba(255,255,255,.15);background:#ffffff14;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.gr-v2-draw-accept{border-color:#4caf5066;color:#4caf50}.gr-v2-draw-accept:hover{background:#4caf5026}.gr-v2-draw-decline:hover{background:#ff50501a;color:#ff6b6b}.gr-v2-left-bar{display:flex;flex-direction:column;justify-content:center;gap:24px;width:240px;height:100%;position:relative;flex-shrink:0;z-index:10}.gr-v2-player-box{display:flex;flex-direction:column;gap:12px}.gr-v2-left-bar .gr-player-card{border-radius:12px;padding:10px 14px;background:#1e1e20d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08)}.gr-v2-left-bar .gr-avatar-circle,.gr-v2-left-bar .gr-avatar-img{width:44px;height:44px;font-size:1.1rem}.gr-v2-timer-box{background:#1e1e20;border-radius:12px;padding:18px;border:2px solid transparent;display:flex;align-items:center;justify-content:center;transition:border-color .3s}.gr-v2-timer-box.active{border-color:#b07030}.gr-v2-timer-box--red{background:#4a1c1c}.gr-v2-timer-box--red.active{border-color:#e74c3c}.gr-v2-timer-box .gr-timer-block{padding:0;background:transparent;border:none}.gr-v2-timer-box .gr-clock-value{font-size:2.8rem;letter-spacing:2px;font-weight:700;font-family:Fira Mono,monospace;color:#fff}.gr-v2-left-actions{display:flex;gap:12px;padding:0 4px}.gr-v2-action-btn{width:48px;height:48px;border-radius:12px;background:#ffffff0d;border:1.5px solid rgba(255,255,255,.1);color:#ffffffa6;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.gr-v2-action-btn svg{width:22px;height:22px}.gr-v2-action-btn:hover{background:#ffffff1f;color:#fff;transform:translateY(-2px)}.gr-v2-action-btn:active{transform:scale(.92)}.gr-v2-right-bar-wrap{width:240px;display:flex;justify-content:flex-start;align-items:center;flex-shrink:0}.gr-v2-right-bar{display:flex;flex-direction:column;gap:12px;padding:16px 10px;background:#0000008c;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:16px;flex-shrink:0;z-index:10}.gr-v2-right-bar .gr-v2-tool{width:52px;height:52px;border-radius:12px;background:transparent;border:none;color:#ffffffa6;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.gr-v2-right-bar .gr-v2-tool svg{width:24px;height:24px}.gr-v2-right-bar .gr-v2-tool:hover{background:#ffffff14;color:#fff}.gr-v2-right-bar .gr-v2-tool:active{transform:scale(.92)}.gr-v2-right-bar .gr-v2-tool.active{color:#f0c060;background:#f0c0601f}.gr-v2-mode-badge{position:absolute;top:16px;right:16px;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:6px 16px;border-radius:999px;color:#fff;box-shadow:0 4px 12px #0000004d;z-index:20}.gr-v2-reconnect{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#000000d9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.gr-v2-reconnect-icon{font-size:2rem}.gr-v2-reconnect-title{font-size:1.1rem;font-weight:600;margin:0}.gr-v2-reconnect-desc{font-size:.85rem;opacity:.7;margin:0}@media(min-width:768px)and (max-width:1099px){.gr-v2{gap:16px!important;padding:12px!important}.gr-v2-left-bar{width:200px;gap:16px}.gr-v2-right-bar-wrap{width:70px}.gr-v2-timer-box{padding:12px}.gr-v2-timer-box .gr-clock-value{font-size:2.2rem}.gr-v2-left-bar .gr-player-card{padding:8px 10px;gap:8px}.gr-v2-left-bar .gr-avatar-circle,.gr-v2-left-bar .gr-avatar-img{width:38px;height:38px}}@media(min-width:1100px)and (max-width:1399px){.gr-v2{gap:24px!important;padding:16px!important}.gr-v2-left-bar,.gr-v2-right-bar-wrap{width:220px}}.gr-light.gr-v2 .gr-v2-toolbar{background:#ffffffb3;border-color:#00000014}.gr-light.gr-v2 .gr-v2-tool{color:#00000080}.gr-light.gr-v2 .gr-v2-tool:hover{background:#0000000f;color:#000c}.gr-light.gr-v2 .gr-v2-tool.active{color:#8b1e1e;background:#8b1e1e14}.gr-light.gr-v2 .gr-v2-back{background:#fff9;border-color:#0000001a;color:#000000b3}.gr-light.gr-v2 .gr-v2-back:hover{background:#ffffffd9;color:#000}.gr-light.gr-v2 .gr-v2-tab.active{color:#8b1e1e}.gr-light.gr-v2 .gr-v2-tab.active:after{background:#8b1e1e}.gr-light.gr-v2 .gr-v2-moves-col-red.gr-v2-move-cell{color:#8b1e1e}.gr-light.gr-v2 .gr-v2-action-btn{border-color:#0000001a;background:#0000000a;color:#00000073}.gr-light.gr-v2 .gr-v2-action-btn:hover{background:#00000014;color:#000c}.gr-light.gr-v2 .gr-v2-nav-btn{border-color:#0000001a;background:#0000000a;color:#0009}.gr-light.gr-v2 .gr-v2-nav-btn:hover{background:#00000014;color:#000000e6}@media(min-width:768px){.gr-v2-panel-column{display:flex;flex-direction:column;gap:16px;width:0!important;height:65vh!important;max-height:800px;align-self:center!important;opacity:0!important;pointer-events:none!important;overflow:hidden!important;transition:width .35s cubic-bezier(.4,0,.2,1),opacity .25s ease!important}.gr-v2-panel-column.open{width:clamp(200px,20vw,280px)!important;opacity:1!important;pointer-events:auto!important}.gr-v2 .gr-slide-panel,.gr-v2 .gr-chat-popup{position:relative!important;right:auto!important;top:auto!important;bottom:auto!important;transform:none!important;width:100%!important;height:auto!important;flex:1;min-height:0;margin:0!important;padding:0!important;border:1px solid rgba(255,255,255,.08)!important;opacity:1!important;pointer-events:auto!important;background:#1e1e20f2!important;-webkit-backdrop-filter:blur(16px)!important;backdrop-filter:blur(16px)!important;box-shadow:0 4px 20px #0000004d!important;border-radius:12px!important}.gr-v2.gr-panel-open .gr-v2-right-bar-wrap{width:48px!important;justify-content:flex-end!important}.gr-v2.gr-panel-open .gr-v2-left-bar{width:100px!important}.gr-v2.gr-panel-open .gr-v2-left-bar .gr-player-card{padding:8px 4px!important;flex-direction:column!important;text-align:center!important}.gr-v2.gr-panel-open .gr-v2-left-bar .gr-player-info{display:none!important}.gr-v2.gr-panel-open .gr-v2-timer-box{padding:12px 4px!important}.gr-v2.gr-panel-open .gr-v2-timer-box .gr-clock-value{font-size:1.5rem!important}}.ghm-container{flex:1;padding:0 0 20px;overflow-y:auto}.ghm-player-banner{margin:10px 14px;padding:16px 18px;background:linear-gradient(135deg,var(--ds-header-bg) 0%,#4a2010 100%);border-radius:var(--ds-radius-lg);box-shadow:0 4px 16px #00000040;color:var(--ds-header-text)}.ghm-player-title-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.ghm-player-icon{font-size:1.2rem;line-height:1}.ghm-player-title{font-family:var(--ds-font-serif);font-size:1.05rem;font-weight:800;letter-spacing:.5px}.ghm-player-stats{display:flex;align-items:center;gap:8px;font-size:.72rem;opacity:.8}.ghm-stat-sep{opacity:.4}.ghm-tier-progress{display:flex;align-items:flex-start;justify-content:center;padding:16px 14px 8px;gap:0;position:relative}.ghm-tier-node{display:flex;flex-direction:column;align-items:center;position:relative;flex:1;min-width:0}.ghm-tier-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;background:var(--ds-card);border:2px solid var(--ds-border);box-shadow:var(--ds-shadow-sm);transition:all .3s ease;position:relative;z-index:2}.ghm-tier-icon{font-size:.9rem;line-height:1}.ghm-tier-label{font-size:.55rem;font-weight:700;color:var(--ds-text-muted);margin-top:5px;text-align:center;letter-spacing:.3px;white-space:nowrap}.ghm-tier-line{position:absolute;top:18px;left:calc(50% + 18px);right:calc(-50% + 18px);width:calc(100% - 36px);left:calc(50% + 20px);height:2px;background:var(--ds-border);z-index:1}.ghm-tier-scene{position:relative;margin:10px 14px;border-radius:var(--ds-radius-xl);overflow:hidden;height:140px;box-shadow:var(--ds-shadow-card)}.ghm-tier-scene-img{width:100%;height:100%;object-fit:cover;display:block}.ghm-tier-scene-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000a6,#0003,#0000000d)}.ghm-tier-scene-title{position:absolute;bottom:12px;left:16px;display:flex;align-items:center;gap:8px;z-index:2}.ghm-tier-scene-icon{font-size:1.3rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.ghm-tier-scene-label{font-family:var(--ds-font-serif);font-size:1.1rem;font-weight:900;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5);letter-spacing:1px}.ghm-opponents-list{display:flex;flex-direction:column;gap:8px;padding:0 14px}.ghm-opp-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-sm);cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.ghm-opp-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ds-border);transition:background .2s}.ghm-opp-card:hover{border-color:var(--ds-border-strong);box-shadow:var(--ds-shadow-md);transform:translateY(-1px)}.ghm-opp-card:hover:before{background:var(--ds-primary)}.ghm-opp-card.defeated{opacity:.55;cursor:default}.ghm-opp-card.defeated:hover{transform:none;box-shadow:var(--ds-shadow-sm)}.ghm-opp-card.boss:before{background:var(--ds-gold);width:3px}.ghm-opp-card.boss{border-color:#c8960a4d;background:linear-gradient(135deg,var(--ds-card) 0%,rgba(200,150,10,.04) 100%)}.ghm-opp-avatar{width:44px;height:44px;border-radius:50%;background:var(--ds-card-secondary);border:1.5px solid var(--ds-border);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.ghm-opp-card.boss .ghm-opp-avatar{border-color:var(--ds-gold);box-shadow:0 0 0 2px #c8960a26}.ghm-opp-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.ghm-opp-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.ghm-opp-name{font-size:.85rem;font-weight:700;color:var(--ds-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ghm-opp-title{font-size:.68rem;font-weight:500;color:var(--ds-text-muted)}.ghm-opp-location{font-size:.62rem;color:var(--ds-text-light);margin-top:1px}.ghm-opp-status{flex-shrink:0}.ghm-opp-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--ds-radius-full);font-size:.68rem;font-weight:700}.ghm-opp-badge--done{font-size:1rem}.ghm-opp-badge--boss{background:#c8960a1f;color:var(--ds-gold);border:1px solid rgba(200,150,10,.25)}.ghm-opp-badge--go{font-size:1.1rem;color:var(--ds-text-light)}.ghm-empty{text-align:center;padding:40px 20px;color:var(--ds-text-muted);font-size:.82rem}.ghm-empty span{font-size:2rem;display:block;margin-bottom:12px}.ghm-empty p{margin:0;line-height:1.5}@keyframes ghm-pulse{0%,to{box-shadow:0 0 0 4px #8b1e1e1f,var(--ds-shadow-md)}50%{box-shadow:0 0 0 8px #8b1e1e0f,var(--ds-shadow-md)}}.ghm-player-banner{cursor:pointer}.ghm-player-expand{margin-left:auto;font-size:.65rem;opacity:.5;transition:transform .2s}.ghm-stats-expanded{margin-top:12px;padding-top:10px;border-top:1px solid rgba(255,255,255,.1)}.ghm-stats-grid{display:flex;gap:12px;margin-bottom:10px}.ghm-stat-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.ghm-stat-icon{font-size:1rem}.ghm-stat-val{font-size:.85rem;font-weight:800}.ghm-stat-label{font-size:.55rem;opacity:.7}.ghm-reset-btn{width:100%;padding:6px 12px;border:1px solid rgba(255,255,255,.15);border-radius:var(--ds-radius-md);background:#ffffff0f;color:#fff9;font-family:var(--ds-font);font-size:.7rem;font-weight:600;cursor:pointer;transition:all .2s}.ghm-reset-btn:hover{background:#c8323226;border-color:#c832324d;color:#f08080}.ghm-reset-confirm{margin:8px 14px;padding:14px;background:#c8323214;border:1px solid rgba(200,50,50,.2);border-radius:var(--ds-radius-md);text-align:center}.ghm-reset-confirm p{margin:0 0 10px;font-size:.82rem;font-weight:600;color:var(--ds-text)}.ghm-reset-actions{display:flex;gap:8px;justify-content:center}.ghm-duyen-banner{position:relative;display:flex;align-items:center;gap:10px;margin:8px 14px;padding:14px 16px;background:linear-gradient(135deg,#3a2a0a,#604010);border:1px solid rgba(200,160,50,.3);border-radius:var(--ds-radius-lg);cursor:pointer;overflow:hidden;transition:transform .2s;animation:ghm-shimmer 3s ease-in-out infinite}.ghm-duyen-banner:hover{transform:scale(1.01)}@keyframes ghm-shimmer{0%,to{box-shadow:0 4px 16px #c8a03226}50%{box-shadow:0 4px 24px #c8a0324d}}.ghm-duyen-glow{position:absolute;top:-50%;right:-20%;width:120px;height:120px;background:radial-gradient(circle,rgba(200,160,50,.25) 0%,transparent 70%);pointer-events:none}.ghm-duyen-icon{font-size:1.5rem;flex-shrink:0;animation:rpgIconPulse 1.5s ease-in-out infinite}@keyframes rpgIconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.ghm-duyen-info{flex:1;display:flex;flex-direction:column;gap:2px}.ghm-duyen-title{font-size:.72rem;font-weight:700;color:#f0d070}.ghm-duyen-name{font-size:.82rem;font-weight:600;color:#ffffffd9}.ghm-duyen-arrow{font-size:1.1rem;color:#f0d070;flex-shrink:0}.omp-page{font-family:var(--ds-font)}.omp-scroll{padding:0}.omp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px;color:var(--ds-text-muted)}.omp-header-transparent{position:relative;z-index:10;background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important}.omp-scene{position:relative;height:280px;margin:-52px 0 0;overflow:hidden;opacity:0;transform:scale(1.05);transition:all .8s cubic-bezier(.25,1,.5,1)}.omp-scene.visible{opacity:1;transform:scale(1)}.omp-scene-bg{width:100%;height:100%;object-fit:cover;display:block}.omp-scene-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#00000026,#0000000d,#0003 60%,#000000b3)}.omp-entrance{position:absolute;bottom:65px;left:50%;transform:translate(-50%) translateY(30px) scale(.8);opacity:0;transition:all .7s cubic-bezier(.34,1.56,.64,1) .3s;z-index:3}.omp-entrance.visible{opacity:1;transform:translate(-50%) translateY(0) scale(1)}.omp-avatar-large{width:90px;height:90px;border-radius:50%;background:var(--ds-card-secondary);border:3px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-size:2.4rem;box-shadow:0 6px 30px #0006,0 0 0 5px #ffffff1a;overflow:hidden;animation:omp-avatar-glow 3s ease-in-out infinite}@keyframes omp-avatar-glow{0%,to{box-shadow:0 6px 30px #0006,0 0 0 5px #ffffff1a}50%{box-shadow:0 6px 40px #00000080,0 0 0 8px #ffffff26}}.omp-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.omp-scene-name{position:absolute;bottom:12px;left:0;right:0;text-align:center;z-index:4;opacity:0;transform:translateY(10px);transition:all .5s ease .6s}.omp-scene-name.visible{opacity:1;transform:translateY(0)}.omp-name{font-family:var(--ds-font-serif);font-size:1.25rem;font-weight:900;color:#fff;margin:0;letter-spacing:1px;text-shadow:0 2px 12px rgba(0,0,0,.6)}.omp-title-badge{font-size:.72rem;font-weight:600;color:#ffffffbf;text-shadow:0 1px 4px rgba(0,0,0,.5);display:block;margin-top:2px}.omp-boss-tag{display:inline-flex;align-items:center;gap:4px;margin-top:6px;padding:3px 12px;border-radius:var(--ds-radius-full);background:#c8960a40;border:1px solid rgba(200,150,10,.4);color:#f0d070;font-size:.65rem;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.3)}.omp-location-tag{display:flex;align-items:center;gap:6px;padding:8px 16px;margin:0 14px 4px;font-size:.7rem;color:var(--ds-text-muted);opacity:0;transform:translateY(6px);transition:all .4s ease .8s}.omp-location-tag.visible{opacity:1;transform:translateY(0)}.omp-location-pin{font-size:.85rem}.omp-narration{padding:8px 18px 4px;cursor:pointer;animation:omp-fadein .3s ease}.omp-narration p{margin:0;font-size:.78rem;line-height:1.65;color:var(--ds-text-muted);text-align:center;font-style:italic}.omp-cursor{display:inline-block;color:var(--ds-primary);animation:omp-blink .5s steps(2) infinite;font-weight:400;margin-left:1px;font-size:.75rem}.omp-cursor.hidden{display:none}@keyframes omp-blink{0%{opacity:1}50%{opacity:0}}.omp-dialogue-animated{animation:omp-bubble-enter .4s cubic-bezier(.34,1.4,.64,1);cursor:pointer}@keyframes omp-bubble-enter{0%{opacity:0;transform:translate(-12px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}.omp-dialogue{display:flex;gap:10px;padding:8px 14px}.omp-dialogue-avatar{width:40px;height:40px;border-radius:50%;background:var(--ds-card-secondary);border:2px solid var(--ds-primary);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;overflow:hidden;box-shadow:0 2px 8px #00000026}.omp-dialogue-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.omp-dialogue-bubble{flex:1;padding:12px 16px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:4px var(--ds-radius-lg) var(--ds-radius-lg) var(--ds-radius-lg);box-shadow:var(--ds-shadow-sm);position:relative}.omp-dialogue-bubble:before{content:"";position:absolute;left:-8px;top:12px;width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-right:8px solid var(--ds-card-border)}.omp-dialogue-bubble:after{content:"";position:absolute;left:-7px;top:12px;width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-right:8px solid var(--ds-card)}.omp-dialogue-name{font-size:.7rem;font-weight:700;color:var(--ds-primary);display:block;margin-bottom:4px}.omp-dialogue-text{margin:0;font-size:.82rem;line-height:1.6;color:var(--ds-text);font-style:italic}.omp-fadein{animation:omp-fadein .5s ease}@keyframes omp-fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.omp-mystery-hint{display:flex;gap:10px;margin:8px 14px;padding:12px 14px;background:#c8960a0f;border:1px dashed rgba(200,150,10,.2);border-radius:var(--ds-radius-md)}.omp-mystery-icon{font-size:1.2rem;flex-shrink:0}.omp-mystery-hint p{margin:0;font-size:.75rem;line-height:1.5;color:var(--ds-gold);font-style:italic}.omp-event-box{margin:8px 14px;padding:16px;background:linear-gradient(135deg,var(--ds-card) 0%,rgba(200,100,10,.05) 100%);border:1px solid rgba(200,100,10,.2);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-sm)}.omp-event-badge{font-size:.72rem;font-weight:700;color:var(--ds-primary);margin-bottom:8px}.omp-event-desc{margin:0 0 12px;font-size:.78rem;line-height:1.55;color:var(--ds-text)}.omp-choices{display:flex;flex-direction:column;gap:8px}.omp-choice-btn{display:flex;flex-direction:column;gap:2px;padding:12px 14px;border:1.5px solid var(--ds-border);border-radius:var(--ds-radius-md);background:var(--ds-card-secondary);cursor:pointer;text-align:left;font-family:var(--ds-font);transition:all .2s}.omp-choice-btn:hover{border-color:var(--ds-primary);background:var(--ds-primary-light)}.omp-choice-btn.selected{border-color:var(--ds-primary);background:var(--ds-primary-light);box-shadow:0 0 0 2px #8b1e1e1f}.omp-choice-label{font-size:.82rem;font-weight:700;color:var(--ds-text)}.omp-choice-effect{font-size:.65rem;color:var(--ds-text-muted)}.omp-reward-preview{display:flex;align-items:center;gap:10px;margin:10px 14px;padding:10px 14px;background:#c8960a0f;border:1px solid rgba(200,150,10,.15);border-radius:var(--ds-radius-md)}.omp-reward-tag{font-size:.7rem;font-weight:700;color:var(--ds-gold);flex-shrink:0}.omp-reward-name{font-size:.78rem;font-weight:600;color:var(--ds-text)}.omp-bottom-bar{position:fixed;bottom:0;left:0;right:0;display:flex;gap:10px;padding:12px 14px;padding-bottom:max(12px,env(safe-area-inset-bottom));background:linear-gradient(to top,var(--ds-bg) 80%,transparent);z-index:30}.omp-fight-btn{flex:2;border-radius:var(--ds-radius-full);letter-spacing:.5px;font-weight:700;animation:omp-fight-pulse 2s ease-in-out infinite}@keyframes omp-fight-pulse{0%,to{box-shadow:0 2px 10px #8b1e1e4d}50%{box-shadow:0 4px 20px #8b1e1e80}}.omp-skip-btn{flex:1;border-radius:var(--ds-radius-full);font-size:.75rem}.rpg-result-page{font-family:var(--ds-font)}.rpg-result-scroll{padding:0}.rpg-result-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px;color:var(--ds-text-muted)}.rpg-result-banner{display:flex;flex-direction:column;align-items:center;padding:32px 20px 24px;margin:14px;border-radius:var(--ds-radius-xl);box-shadow:var(--ds-shadow-card);animation:rpgBannerSlideIn .6s cubic-bezier(.34,1.56,.64,1)}@keyframes rpgBannerSlideIn{0%{opacity:0;transform:scale(.85) translateY(-16px)}to{opacity:1;transform:scale(1) translateY(0)}}.rpg-result-icon{font-size:2.5rem;line-height:1;margin-bottom:8px;animation:rpgIconPulse 1.5s ease-in-out infinite}@keyframes rpgIconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.rpg-result-title{font-family:var(--ds-font-serif);font-size:1.6rem;font-weight:900;margin:0;letter-spacing:2px}.rpg-result-reason{font-size:.72rem;color:#fff9;margin-top:6px}.rpg-result-opponent{display:flex;align-items:center;gap:12px;margin:10px 14px;padding:12px 16px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:var(--ds-radius-lg)}.rpg-result-opp-avatar{width:44px;height:44px;border-radius:50%;background:var(--ds-card-secondary);border:1.5px solid var(--ds-border);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;overflow:hidden}.rpg-result-opp-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.rpg-result-opp-info{display:flex;flex-direction:column;gap:2px}.rpg-result-opp-name{font-size:.85rem;font-weight:700;color:var(--ds-text)}.rpg-result-opp-title{font-size:.68rem;color:var(--ds-text-muted)}.rpg-result-dialogue{display:flex;gap:10px;padding:8px 14px;animation:rpgFadeIn .5s ease .4s both}@keyframes rpgFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.rpg-result-dialogue-avatar{width:32px;height:32px;border-radius:50%;background:var(--ds-card-secondary);border:1px solid var(--ds-border);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;overflow:hidden}.rpg-result-dialogue-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.rpg-result-dialogue-bubble{flex:1;padding:10px 14px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:2px var(--ds-radius-lg) var(--ds-radius-lg) var(--ds-radius-lg)}.rpg-result-dialogue-bubble p{margin:0;font-size:.78rem;line-height:1.55;color:var(--ds-text);font-style:italic}.rpg-result-reward{position:relative;margin:10px 14px;padding:18px 16px;background:linear-gradient(135deg,var(--ds-card) 0%,rgba(200,150,10,.06) 100%);border:1px solid rgba(200,150,10,.25);border-radius:var(--ds-radius-lg);overflow:hidden;animation:rpgRewardReveal .6s cubic-bezier(.34,1.56,.64,1) .8s both}@keyframes rpgRewardReveal{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.rpg-result-reward-glow{position:absolute;top:-30%;left:50%;transform:translate(-50%);width:200px;height:200px;background:radial-gradient(circle,rgba(200,160,50,.15) 0%,transparent 70%);pointer-events:none;animation:rpgGlowPulse 2s ease-in-out infinite}@keyframes rpgGlowPulse{0%,to{opacity:.6}50%{opacity:1}}.rpg-result-reward-badge{display:inline-block;font-size:.72rem;font-weight:700;color:var(--ds-gold);margin-bottom:8px;position:relative;z-index:2}.rpg-result-reward-card{position:relative;z-index:2}.rpg-result-reward-name{display:block;font-family:var(--ds-font-serif);font-size:.95rem;font-weight:800;color:var(--ds-text);margin-bottom:4px}.rpg-result-reward-desc{margin:0;font-size:.72rem;line-height:1.5;color:var(--ds-text-muted)}.rpg-result-stats{margin:10px 14px;padding:10px 14px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:var(--ds-radius-md)}.rpg-result-stat-row{display:flex;align-items:center;justify-content:space-between;font-size:.78rem;font-weight:600;color:var(--ds-text)}.rpg-result-bottom{position:fixed;bottom:0;left:0;right:0;display:flex;gap:10px;padding:12px 14px;background:var(--ds-bg);border-top:1px solid var(--ds-border);z-index:30}.rpg-result-btn-map{flex:2;border-radius:var(--ds-radius-full);letter-spacing:.5px;font-weight:700}.rpg-result-btn-retry{flex:1;border-radius:var(--ds-radius-full);font-size:.75rem}.tn-page{background:var(--ds-bg)}.tn-xu-badge{display:flex;align-items:center;gap:4px;padding:4px 12px;background:#c8960a26;border:1px solid rgba(200,150,10,.3);border-radius:var(--ds-radius-full);font-size:.82rem;font-weight:700;color:var(--ds-gold)}.tn-xu-icon{font-size:.9rem}.tn-scroll{padding:0 var(--ds-page-px)}.tn-resume-banner{display:flex;align-items:center;gap:12px;padding:14px 16px;margin:12px 0;background:linear-gradient(135deg,var(--ds-primary),#6d1717);border-radius:var(--ds-radius-lg);color:#fff;cursor:pointer;position:relative;overflow:hidden;animation:tn-pulse 2s ease infinite}@keyframes tn-pulse{0%,to{box-shadow:0 0 #8b1e1e66}50%{box-shadow:0 0 0 8px #8b1e1e00}}.tn-resume-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 80% 50%,rgba(255,255,255,.12) 0%,transparent 60%);pointer-events:none}.tn-resume-icon{font-size:1.5rem}.tn-resume-info{flex:1;display:flex;flex-direction:column;gap:2px}.tn-resume-label{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;opacity:.8}.tn-resume-name{font-size:.95rem;font-weight:700}.tn-resume-arrow{font-size:1.2rem;opacity:.7}.tn-filters{margin:12px 0;display:flex;flex-direction:column;gap:10px}.tn-filter-row{display:flex;flex-direction:column;gap:6px}.tn-filter-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--ds-text-light)}.tn-filters .ds-chip-group{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px}.tn-filters .ds-chip{font-size:.75rem;padding:6px 14px;flex-shrink:0}.tn-list{display:flex;flex-direction:column;gap:16px;margin-top:8px}.tn-card{overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s}.tn-card:hover{transform:translateY(-2px);box-shadow:var(--ds-shadow-lg)}.tn-card:active{transform:scale(.98)}.tn-card-header{display:flex;align-items:center;gap:12px;padding:16px;color:#fff;position:relative;overflow:hidden}.tn-card-bg-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:.35;z-index:0;pointer-events:none}.tn-card-icon{font-size:2rem;position:relative;z-index:1}.tn-card-title-area{flex:1;position:relative;z-index:1}.tn-card-name{font-family:var(--ds-font-serif);font-size:1.05rem;font-weight:700;margin:0;line-height:1.3}.tn-card-province{font-size:.75rem;opacity:.85;margin-top:2px}.tn-card-body{padding:12px 16px 16px}.tn-card-desc{font-size:.82rem;color:var(--ds-text-muted);line-height:1.5;margin:0 0 12px}.tn-card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.tn-card-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--ds-radius-full);font-size:.72rem;font-weight:700;border:1px solid}.tn-card-players,.tn-card-level{font-size:.75rem;color:var(--ds-text-muted);display:flex;align-items:center;gap:4px}.tn-card-prizes{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;padding:10px 12px;background:var(--ds-card-secondary);border-radius:var(--ds-radius-md);border:1px solid var(--ds-border)}.tn-card-prize{font-size:.78rem;color:var(--ds-text);font-weight:600}.tn-prize-1{color:var(--ds-gold)}.tn-prize-2{color:var(--ds-text-muted)}.tn-prize-3{color:var(--ds-text-light)}.tn-card-footer{display:flex;align-items:center;justify-content:space-between}.tn-card-fee{font-size:.82rem;font-weight:700;color:var(--ds-gold)}.tn-card-join{min-width:100px}.tn-empty{text-align:center;padding:60px 20px;color:var(--ds-text-muted)}.tn-empty span{font-size:3rem;display:block;margin-bottom:12px}.tn-card--active{border-color:var(--ds-primary)!important;box-shadow:0 0 0 2px #8b1e1e26,var(--ds-shadow-md)}.tn-card-active-badge{position:absolute;top:8px;right:10px;z-index:2;background:#0009;color:#fff;font-size:.68rem;font-weight:700;padding:4px 10px;border-radius:var(--ds-radius-full);letter-spacing:.5px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:tn-pulse 2s ease infinite}.tn-card-join--resume{background:var(--ds-green)!important;box-shadow:0 2px 8px #27ae604d}.tn-card-join--resume:hover{background:#1e9651!important}.tn-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:tn-fade-in .2s ease}@keyframes tn-fade-in{0%{opacity:0}to{opacity:1}}.tn-confirm-dialog{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);padding:28px 24px;max-width:380px;width:100%;text-align:center;box-shadow:0 20px 60px #0006;animation:tn-dialog-in .3s ease}@keyframes tn-dialog-in{0%{transform:scale(.9) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.tn-confirm-icon{color:var(--ds-gold);margin-bottom:8px}.tn-confirm-title{font-size:1.1rem;font-weight:700;font-family:var(--ds-font-serif);color:var(--ds-text);margin:0 0 10px}.tn-confirm-text{font-size:.85rem;color:var(--ds-text-muted);line-height:1.6;margin:0 0 8px}.tn-confirm-warning{font-size:.78rem;color:var(--ds-red-dot, #e74c3c);background:#e74c3c14;border:1px solid rgba(231,76,60,.2);border-radius:var(--ds-radius-md);padding:10px 14px;margin:0 0 20px;line-height:1.5}.tn-confirm-actions{display:flex;gap:10px;justify-content:center}.tn-confirm-cancel{flex:1;padding:10px 16px!important;font-size:.85rem!important}.tn-confirm-switch{flex:1;padding:10px 16px!important;font-size:.85rem!important;background:var(--ds-primary)!important}.tp-page{background:var(--ds-bg)}.tp-scroll{padding:0 var(--ds-page-px);position:relative;background:linear-gradient(180deg,transparent 0%,rgba(var(--ds-bg-rgb, 245,240,230),.15) 100%),url(/tournament/bg_scroll_texture.webp) top center / cover no-repeat;background-attachment:local}.tp-scroll:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--ds-bg);opacity:.65;pointer-events:none;z-index:0}.tp-scroll>*{position:relative;z-index:1}.tp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 20px;text-align:center;color:var(--ds-text-muted)}.tp-empty-icon{font-size:3.5rem;opacity:.6;margin-bottom:4px}.tp-empty p{font-size:.92rem;line-height:1.5;color:var(--ds-text);opacity:.7}.tp-info-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;color:#fff;position:relative;overflow:hidden}.tp-info-icon{font-size:1.5rem;position:relative;z-index:1}.tp-info-text{flex:1;display:flex;flex-direction:column;gap:2px;position:relative;z-index:1}.tp-info-format{font-size:.78rem;font-weight:700;opacity:.9}.tp-info-detail{font-size:.72rem;opacity:.7}.tp-result-btn{position:relative;z-index:1;background:#fff3!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important}.tp-tabs{display:flex;border-bottom:2px solid var(--ds-border)}.tp-tab{flex:1;padding:12px;border:none;background:none;font-family:var(--ds-font);font-size:.82rem;font-weight:700;color:var(--ds-text-muted);cursor:pointer;transition:all .2s;border-bottom:3px solid transparent}.tp-tab.active{color:var(--ds-primary);border-bottom-color:var(--ds-primary)}.tp-swiss-pairings{margin-top:16px}.tp-round-label{text-align:center;font-size:.85rem;font-weight:700;color:var(--ds-primary);margin-bottom:12px;letter-spacing:1px}.tp-pairings-table{width:100%}.tp-pair-header,.tp-pair-row{display:grid;grid-template-columns:36px 1fr 30px 1fr 70px;gap:4px;align-items:center;padding:8px}.tp-pair-header{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--ds-text-light);border-bottom:2px solid var(--ds-border)}.tp-pair-row{border-bottom:1px solid var(--ds-border);font-size:.82rem;transition:background .15s}.tp-pair-row:last-child{border-bottom:none}.tp-pair-highlight{background:var(--ds-primary-light)!important;border-radius:var(--ds-radius-md)}.tp-pair-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-pair-num{text-align:center;font-weight:700;color:var(--ds-text-light)}.tp-pair-vs{text-align:center;font-size:.7rem}.tp-pair-result{text-align:center;font-weight:700}.tp-pair-result.done{color:var(--ds-primary)}.tp-player-name{font-weight:700;color:var(--ds-primary)!important}.tp-play-btn{font-size:.68rem!important;padding:4px 8px!important}.tp-standings{margin-top:16px}.tp-standings-table{width:100%}.tp-standings-header,.tp-standings-row{display:grid;grid-template-columns:36px 1fr 50px 50px 50px 40px;gap:2px;align-items:center;padding:8px 6px}.tp-standings-header{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--ds-text-light);border-bottom:2px solid var(--ds-border)}.tp-standings-row{font-size:.8rem;border-bottom:1px solid var(--ds-border);transition:background .15s}.tp-player-row{background:var(--ds-primary-light);border-radius:var(--ds-radius-sm);font-weight:700}.tp-st-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-st-rank{text-align:center;font-size:.9rem}.tp-st-name{display:flex;align-items:center;gap:4px}.tp-st-avatar{font-size:.9rem}.tp-st-pts,.tp-st-bh,.tp-st-bh1,.tp-st-win{text-align:center;font-size:.75rem}.tp-you-badge{background:var(--ds-primary);color:#fff;font-size:.6rem;padding:1px 6px;border-radius:var(--ds-radius-full);font-weight:700}.tp-bracket{margin-top:16px}.tp-bracket-scroll{display:flex;gap:8px;overflow-x:auto;padding:8px 0 16px;-webkit-overflow-scrolling:touch}.tp-bracket-round{min-width:160px;flex-shrink:0;display:flex;flex-direction:column;gap:8px}.tp-bracket-round-label{text-align:center;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--ds-text-light);padding:6px 0;border-bottom:2px solid var(--ds-border);margin-bottom:4px}.tp-bracket-matches{display:flex;flex-direction:column;gap:8px;justify-content:space-around;flex:1}.tp-bracket-match{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-md);padding:8px;display:flex;flex-direction:column;gap:4px;position:relative;transition:all .2s}.tp-bracket-match.done{opacity:.85}.tp-bracket-highlight{border-color:var(--ds-primary)!important;box-shadow:0 0 0 2px #8b1e1e26}.tp-bracket-slot{display:flex;align-items:center;gap:6px;padding:4px 6px;border-radius:var(--ds-radius-sm);font-size:.78rem;transition:background .15s}.tp-bracket-slot.winner{background:var(--ds-green-light);font-weight:700}.tp-bracket-slot.is-player{color:var(--ds-primary);font-weight:700}.tp-bracket-seed{font-size:.85rem}.tp-bracket-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-char-img{width:28px;height:28px;border-radius:50%;object-fit:cover;border:2px solid var(--ds-card-border);flex-shrink:0}.tp-st-avatar.tp-char-img{width:24px;height:24px;border-width:1.5px}.tp-bracket-slot .tp-char-img{width:26px;height:26px}.tp-bracket-win-icon{color:var(--ds-green);font-weight:700}.tp-bracket-vs{text-align:center;font-size:.65rem;color:var(--ds-text-light);letter-spacing:1px}.tp-bracket-play{width:100%;margin-top:4px;font-size:.72rem!important}.tp-bracket-bye{text-align:center;font-size:.68rem;color:var(--ds-text-light);font-weight:700;letter-spacing:1px}.tp-double-bracket{margin-top:12px;display:flex;flex-direction:column;gap:20px}.tp-double-section{border:2px solid var(--ds-border);border-radius:var(--ds-radius-lg);overflow:hidden}.tp-double-section-label{padding:10px 14px;font-size:.85rem;font-weight:700;display:flex;align-items:center;gap:8px}.tp-winners-label{background:#27ae601a;color:var(--ds-green);border-bottom:2px solid rgba(39,174,96,.2)}.tp-losers-label{background:#c0392b1a;color:var(--ds-red-dot);border-bottom:2px solid rgba(192,57,43,.2)}.tp-gf-label{background:#c8960a1f;color:var(--ds-gold);border-bottom:2px solid rgba(200,150,10,.25)}.tp-grand-final-section{border-color:var(--ds-gold)!important}.tp-here-badge{font-size:.68rem;background:var(--ds-green);color:#fff;padding:2px 8px;border-radius:var(--ds-radius-full);animation:tn-pulse 2s ease infinite}.tp-here-losers{background:var(--ds-red-dot)}.tp-gf-match{border-color:var(--ds-gold)!important;box-shadow:0 0 12px #c8960a33}.tp-reset-label{text-align:center;padding:8px;font-size:.78rem;font-weight:700;color:var(--ds-gold)}.tp-champion-announce{text-align:center;padding:16px;font-size:1.1rem;font-weight:700;color:var(--ds-gold);animation:tr-glow 1.5s ease infinite}.tp-bottom-area{margin-top:20px}.tp-enter-btn{font-size:1rem!important;padding:16px!important}.tp-bottom-spacer{height:80px}.tp-eliminated-notice{text-align:center;padding:24px;color:var(--ds-text-muted)}.tp-eliminated-notice span{font-size:2.5rem;display:block;margin-bottom:8px}.tp-abandon-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.tp-abandon-modal{background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);padding:24px;max-width:360px;text-align:center}.tp-abandon-modal h3{margin:0 0 8px;font-size:1.1rem;color:var(--ds-text)}.tp-abandon-modal p{font-size:.85rem;color:var(--ds-text-muted);margin:0 0 16px}.tp-abandon-actions{display:flex;gap:8px;justify-content:center}.tr-page{background:var(--ds-bg)}.tr-scroll{padding:0 var(--ds-page-px)}.tr-empty,.tr-claimed{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 20px;text-align:center}.tr-claimed-icon{font-size:4rem;animation:tr-bounce .8s ease}@keyframes tr-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.tr-tournament-name{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;font-family:var(--ds-font-serif);font-size:1.1rem;font-weight:700;color:var(--ds-text)}.tr-tn-icon{font-size:1.5rem}.tr-podium{position:relative;padding:20px 0 0;overflow:hidden}.tr-podium-row{display:flex;align-items:flex-end;justify-content:center;gap:8px;min-height:220px}.tr-podium-item{display:flex;flex-direction:column;align-items:center;gap:4px;width:100px}.tr-podium-crown{font-size:1.8rem;animation:tr-crown 1s ease infinite alternate}@keyframes tr-crown{0%{transform:translateY(0)}to{transform:translateY(-4px)}}.tr-podium-avatar{width:50px;height:50px;border-radius:50%;background:var(--ds-card);border:3px solid var(--ds-border);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.tr-avatar-champion{width:64px;height:64px;border-color:var(--ds-gold);box-shadow:0 0 16px #c8960a66;font-size:2rem}.tr-podium-medal{font-size:1.2rem}.tr-podium-name{font-size:.75rem;font-weight:700;text-align:center;color:var(--ds-text);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tr-podium-you{background:var(--ds-primary);color:#fff;font-size:.6rem;padding:2px 8px;border-radius:var(--ds-radius-full);font-weight:700;animation:tn-pulse 1.5s ease infinite}.tr-podium-block{width:80px;border-radius:var(--ds-radius-sm) var(--ds-radius-sm) 0 0}.tr-block-1{height:100px;background:linear-gradient(180deg,#f0d060,#c8960a)}.tr-block-2{height:70px;background:linear-gradient(180deg,#d0d0d0,#aaa)}.tr-block-3{height:50px;background:linear-gradient(180deg,#d4a76a,#cd7f32)}.tr-your-result{display:flex;align-items:center;gap:16px;padding:20px;margin:20px 0;background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-md)}.tr-result-icon{font-size:2.5rem}.tr-result-text{flex:1}.tr-result-rank{font-size:1.2rem;font-weight:700;font-family:var(--ds-font-serif);color:var(--ds-text)}.tr-result-prize{font-size:.82rem;color:var(--ds-text-muted);margin-top:4px}.tr-section-label{font-size:.85rem;font-weight:700;color:var(--ds-text);margin-bottom:8px}.tr-full-standings{margin-top:20px}.tr-bottom{margin:24px 0}.tr-claim-btn{font-size:1rem!important;padding:16px!important}.tr-confetti-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:10}.tr-confetti-particle{position:absolute;width:8px;height:8px;background:var(--color, #f0d060);left:var(--x, 50%);top:-10px;border-radius:2px;animation:tr-confetti-fall 3s ease-out var(--delay, 0s) both}@keyframes tr-confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(300px) rotate(720deg);opacity:0}}@keyframes tr-glow{0%,to{text-shadow:0 0 4px rgba(200,150,10,.3)}50%{text-shadow:0 0 16px rgba(200,150,10,.6)}}.tr-tn-bg-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:.2;z-index:0;pointer-events:none;border-radius:var(--ds-radius-lg)}.tr-tournament-name .tr-tn-icon,.tr-tournament-name .tr-tn-text{position:relative;z-index:1}.tr-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.tr-prize-showcase{margin:20px 0;padding:20px;background:linear-gradient(135deg,#c8960a0f,#c8960a05);border:2px solid rgba(200,150,10,.2);border-radius:var(--ds-radius-lg)}.tr-prize-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:16px;margin-top:12px}.tr-prize-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:var(--ds-radius-md);transition:transform .2s,box-shadow .2s}.tr-prize-item:hover{transform:translateY(-3px);box-shadow:0 6px 20px #c8960a26}.tr-prize-img{width:80px;height:80px;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.2))}.tr-prize-label{font-size:.72rem;font-weight:700;color:var(--ds-gold);text-align:center;line-height:1.3}.vs-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#1a0a0a,#0a0505 70%,#000);animation:vs-overlay-in .3s ease-out}@keyframes vs-overlay-in{0%{opacity:0}to{opacity:1}}.vs-bg-flash{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 50%,rgba(200,150,10,.15) 0%,transparent 60%);animation:vs-flash 1.5s ease infinite;pointer-events:none}@keyframes vs-flash{0%,to{opacity:.3}50%{opacity:.8}}.vs-tournament-name{position:absolute;top:12%;font-family:var(--ds-font-serif);font-size:clamp(.9rem,3vw,1.4rem);font-weight:700;color:var(--ds-gold);text-transform:uppercase;letter-spacing:3px;text-shadow:0 0 20px rgba(200,150,10,.5);animation:vs-fade-in .6s .3s ease both;z-index:2}.vs-cards-row{display:flex;align-items:center;gap:clamp(16px,4vw,40px);z-index:2}.vs-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 20px;background:#140a0ab3;border:2px solid rgba(200,150,10,.3);border-radius:16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;overflow:hidden;min-width:clamp(120px,25vw,180px)}.vs-card-left{animation:vs-slide-left .6s .15s cubic-bezier(.16,1,.3,1) both}.vs-card-right{animation:vs-slide-right .6s .15s cubic-bezier(.16,1,.3,1) both}@keyframes vs-slide-left{0%{opacity:0;transform:translate(-120px) scale(.8)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes vs-slide-right{0%{opacity:0;transform:translate(120px) scale(.8)}to{opacity:1;transform:translate(0) scale(1)}}.vs-card-glow{position:absolute;top:-50%;right:-50%;bottom:-50%;left:-50%;border-radius:50%;pointer-events:none;filter:blur(40px);opacity:.3}.vs-glow-red{background:radial-gradient(circle,#c0392b 0%,transparent 70%)}.vs-glow-black{background:radial-gradient(circle,#2c3e50 0%,transparent 70%)}.vs-card-avatar{width:clamp(72px,15vw,100px);height:clamp(72px,15vw,100px);border-radius:50%;border:3px solid var(--ds-gold);overflow:hidden;display:flex;align-items:center;justify-content:center;background:#1e140a99;box-shadow:0 0 24px #c8960a4d;animation:vs-avatar-glow 1.5s ease infinite}@keyframes vs-avatar-glow{0%,to{box-shadow:0 0 16px #c8960a4d}50%{box-shadow:0 0 32px #c8960a99}}.vs-avatar-img{width:100%;height:100%;object-fit:cover}.vs-avatar-emoji{font-size:clamp(2.2rem,6vw,3rem)}.vs-card-info{display:flex;flex-direction:column;align-items:center;gap:4px;animation:vs-fade-in .5s .5s ease both}.vs-card-name{font-family:var(--ds-font-serif);font-size:clamp(.9rem,2.5vw,1.15rem);font-weight:700;color:#fff;text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.6)}.vs-card-title{font-size:clamp(.65rem,1.8vw,.78rem);color:var(--ds-gold);font-weight:600;letter-spacing:.5px;text-shadow:0 0 8px rgba(200,150,10,.3)}.vs-badge{position:relative;animation:vs-badge-pop .5s .5s cubic-bezier(.34,1.56,.64,1) both}@keyframes vs-badge-pop{0%{opacity:0;transform:scale(0) rotate(-20deg)}to{opacity:1;transform:scale(1) rotate(0)}}.vs-badge-text{display:block;font-family:var(--ds-font-serif);font-size:clamp(2rem,6vw,3.2rem);font-weight:900;color:#fff;text-shadow:0 0 12px rgba(200,150,10,.8),0 0 40px rgba(200,150,10,.4),0 2px 4px rgba(0,0,0,.5);letter-spacing:4px;animation:vs-badge-pulse 1s 1s ease infinite}@keyframes vs-badge-pulse{0%,to{text-shadow:0 0 12px rgba(200,150,10,.8),0 0 40px rgba(200,150,10,.4)}50%{text-shadow:0 0 24px rgba(200,150,10,1),0 0 60px rgba(200,150,10,.7)}}.vs-badge-sparks{position:absolute;top:-30px;right:-30px;bottom:-30px;left:-30px;background:radial-gradient(circle,rgba(200,150,10,.2) 0%,transparent 50%);animation:vs-sparks 1.2s ease infinite;pointer-events:none}@keyframes vs-sparks{0%,to{transform:scale(1);opacity:.3}50%{transform:scale(1.3);opacity:.6}}.vs-bottom-text{position:absolute;bottom:12%;font-size:clamp(.75rem,2vw,.9rem);color:#fff9;letter-spacing:2px;animation:vs-fade-in .5s .8s ease both,vs-bottom-blink 1.5s 1.3s ease infinite;z-index:2}@keyframes vs-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes vs-bottom-blink{0%,to{opacity:.6}50%{opacity:1}}@media(min-width:640px){.tn-scroll,.tp-scroll,.tr-scroll{padding:0 24px}.tn-list{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.tn-card-name{font-size:1rem}.tn-card-desc{font-size:.85rem}.tp-pair-header,.tp-pair-row{grid-template-columns:40px 1fr 40px 1fr 90px;gap:8px;padding:10px 12px}.tp-pair-row{font-size:.85rem}.tp-standings-header,.tp-standings-row{grid-template-columns:40px 1fr 60px 60px 60px 50px;gap:4px;padding:10px}.tp-standings-row{font-size:.85rem}.tp-bracket-round{min-width:200px}.tp-bracket-slot{font-size:.82rem;padding:6px 8px}.tr-podium-row{min-height:260px;gap:16px}.tr-podium-item{width:120px}.tr-podium-avatar{width:60px;height:60px;font-size:1.8rem}.tr-avatar-champion{width:76px;height:76px;font-size:2.2rem}.tr-podium-name{font-size:.82rem;max-width:120px}.tr-podium-block{width:100px}.tr-block-1{height:120px}.tr-block-2{height:85px}.tr-block-3{height:60px}.tr-prize-grid{grid-template-columns:repeat(3,1fr)}.tr-prize-img{width:100px;height:100px}.tr-your-result{padding:24px}.tr-result-rank{font-size:1.3rem}.vs-card{padding:28px 24px;min-width:180px}.vs-card-avatar{width:90px;height:90px}}@media(min-width:900px){.tn-scroll,.tp-scroll,.tr-scroll{padding:0 32px}.tn-filters{flex-direction:row;gap:24px}.tn-filter-row{flex:1}.tn-card-header{padding:20px}.tn-card-name{font-size:1.1rem}.tn-card-body{padding:16px 20px 20px}.tn-card-desc{font-size:.88rem}.tn-card-footer{padding-top:8px}.tp-info-bar{padding:16px 20px}.tp-info-format{font-size:.85rem}.tp-tab{padding:14px 16px;font-size:.88rem}.tp-pair-header,.tp-pair-row{grid-template-columns:44px 1fr 44px 1fr 100px;gap:10px;padding:12px 16px}.tp-standings-header,.tp-standings-row{grid-template-columns:44px 1fr 70px 70px 70px 60px;gap:6px;padding:12px 14px}.tp-bracket-scroll{gap:12px}.tp-bracket-round{min-width:220px}.tp-bracket-match{padding:10px 12px}.tr-podium-row{min-height:300px;gap:24px}.tr-podium-item{width:140px}.tr-podium-avatar{width:68px;height:68px}.tr-avatar-champion{width:88px;height:88px}.tr-podium-block{width:120px}.tr-block-1{height:140px}.tr-block-2{height:100px}.tr-block-3{height:70px}.vs-card{min-width:200px;padding:32px 28px}}@media(min-width:1024px){.tn-scroll,.tp-scroll,.tr-scroll{padding:0 40px}.tn-card-header{padding:22px 24px}.tn-card-icon{font-size:2.2rem}.tn-card-name{font-size:1.15rem}.tp-double-bracket{gap:24px}.tr-prize-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:20px}.tr-prize-img{width:120px;height:120px}.tr-prize-label{font-size:.78rem}.vs-card{min-width:220px;padding:36px 32px;gap:16px;border-radius:20px}.vs-card-avatar{width:100px;height:100px}.vs-badge-text{font-size:3.2rem}}@media(min-width:1024px){.tn-page .tn-scroll,.tn-page .ds-bottom-nav{display:none}}.tn-dt-wrapper{margin:0 auto;padding:20px 28px;display:flex;flex-direction:column;gap:16px}.tn-dt-top-bar{display:flex;align-items:center;justify-content:flex-start;gap:12px}.tn-dt-resume{flex:1;display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-card);border:2px solid var(--accent-green, #48a868);border-radius:var(--ds-radius-lg);cursor:pointer;font-size:.88rem;color:var(--text-body);transition:all .2s;box-shadow:0 0 12px #48a86826}.tn-dt-resume:hover{transform:translateY(-1px)}.tn-dt-resume strong{color:var(--text-h)}.tn-dt-xu{display:flex;align-items:center;gap:6px;padding:10px 18px;background:var(--bg-card);border:1px solid var(--border-gold);border-radius:var(--ds-radius-full);font-size:.88rem;font-weight:700;color:var(--border-gold);box-shadow:var(--shadow-card);width:fit-content}.tn-dt-filters{display:flex;flex-direction:column;gap:8px;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border-gold);border-radius:var(--ds-radius-lg);box-shadow:var(--shadow-card)}.tn-dt-filters>.tn-dt-xu{margin-bottom:2px}.tn-dt-filter-group{display:flex;align-items:center;flex-wrap:wrap;gap:6px}.tn-dt-filter-label{font-size:.72rem;font-weight:700;color:var(--text-muted);letter-spacing:.5px;min-width:70px}.tn-dt-chip{padding:6px 14px;border-radius:var(--ds-radius-full);border:1.5px solid var(--border-dim);background:transparent;font-family:var(--ds-font);font-size:.78rem;font-weight:600;color:var(--text-body);cursor:pointer;transition:all .18s}.tn-dt-chip:hover{border-color:var(--border-bright);color:var(--text-h)}.tn-dt-chip.active{background:var(--btn-cta-bg);border-color:var(--btn-cta-bg);color:var(--btn-cta-text)}.tn-dt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;grid-column:1 / -1}.tn-dt-card{background:var(--bg-card);border:1px solid var(--border-gold);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-card);position:relative}.tn-dt-card:hover{transform:translateY(-2px);box-shadow:var(--ds-shadow-md);border-color:var(--border-bright)}.tn-dt-card--active{border-color:var(--accent-green, #48a868);box-shadow:0 0 12px #48a86833}.tn-dt-card-header{display:flex;align-items:center;gap:10px;padding:14px 16px;position:relative;overflow:hidden}.tn-dt-card-bg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:.15}.tn-dt-card-icon{font-size:1.6rem;flex-shrink:0;position:relative;z-index:1}.tn-dt-card-name{font-size:.92rem;font-weight:700;color:#fff;margin:0;position:relative;z-index:1}.tn-dt-card-province{font-size:.72rem;color:#ffffffb3;display:flex;align-items:center;gap:4px;position:relative;z-index:1}.tn-dt-card-badge-active{position:absolute;top:8px;right:8px;font-size:.65rem;font-weight:700;background:#48a868e6;color:#fff;padding:3px 10px;border-radius:999px;z-index:1}.tn-dt-card-body{padding:14px 16px;display:flex;flex-direction:column;gap:10px}.tn-dt-card-desc{font-size:.78rem;color:var(--text-body);line-height:1.4;margin:0}.tn-dt-card-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:.72rem;color:var(--text-muted);align-items:center}.tn-dt-card-format{padding:3px 10px;border-radius:999px;border:1px solid;font-weight:600;font-size:.68rem}.tn-dt-card-prizes{display:flex;flex-wrap:wrap;gap:8px}.tn-dt-prize{display:flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600}.tn-dt-prize-1{color:gold}.tn-dt-prize-2{color:silver}.tn-dt-prize-3{color:#cd7f32}.tn-dt-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:8px;border-top:1px solid var(--border-dim)}.tn-dt-card-fee{display:flex;align-items:center;gap:4px;font-size:.78rem;font-weight:600;color:var(--border-gold)}.tn-dt-empty{text-align:center;padding:40px;color:var(--text-muted)}.tn-dt-empty p{margin:8px 0 0;font-size:.88rem}:root{--ps-blue-deep: #1a3a5c;--ps-gold: #d4af37;--ps-gold-light: #f0d060;--ps-purple: #7b2d8b;--ps-white-mist: #f0ece4;--ps-brown-wood: #2c1810;--ps-amber: #c17f3a;--ps-green-leaf: #2d5a1b;--ps-red-seal: #8b1a1a;--ps-parchment: #e8d5a3;--ps-ink: #1a1008}.ps-hub{padding-bottom:100px}.ps-hero{position:relative;padding:32px 20px 28px;background:linear-gradient(135deg,var(--ps-blue-deep) 0%,var(--ps-purple) 50%,var(--ps-blue-deep) 100%);overflow:hidden;border-bottom:3px solid var(--ps-gold)}.ps-hero-bg-img{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.12;pointer-events:none}.ps-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 80%,rgba(212,175,55,.15) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(123,45,139,.2) 0%,transparent 50%);pointer-events:none}.ps-hero-particles{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.ps-hero-particle{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--ps-gold);opacity:0;animation:ps-float 4s ease-in-out infinite}@keyframes ps-float{0%{opacity:0;transform:translateY(0) scale(.5)}30%{opacity:.8}to{opacity:0;transform:translateY(-80px) scale(0)}}.ps-hero-content{position:relative;z-index:1;text-align:center}.ps-hero-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid var(--ps-gold);box-shadow:0 0 30px #d4af3766,0 8px 24px #0006;margin-bottom:12px;animation:ps-avatar-glow 3s ease-in-out infinite alternate;display:block;margin-left:auto;margin-right:auto}@keyframes ps-avatar-glow{0%{box-shadow:0 0 20px #d4af374d,0 8px 24px #0006}to{box-shadow:0 0 40px #d4af3799,0 8px 24px #0006}}.ps-hero-title{font-family:var(--ds-font-serif);font-size:1.4rem;font-weight:800;color:var(--ps-gold-light);letter-spacing:3px;text-shadow:0 2px 8px rgba(0,0,0,.5);margin-bottom:4px}.ps-hero-subtitle{font-size:.78rem;color:#f0ece4b3;letter-spacing:1px}.ps-rank-badge{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:6px 16px;background:#d4af3726;border:1px solid rgba(212,175,55,.4);border-radius:20px;font-size:.82rem;color:var(--ps-gold-light);font-weight:700}.ps-rank-icon{font-size:1.1rem}.ps-progress-overview{display:flex;gap:12px;padding:12px 16px;justify-content:center}.ps-progress-stat{display:flex;flex-direction:column;align-items:center;padding:10px 16px;background:var(--bg-card2);border-radius:12px;border:1px solid var(--border-dim);min-width:80px}.ps-progress-val{font-size:1.2rem;font-weight:800;color:var(--ds-text)}.ps-progress-label{font-size:.68rem;color:var(--ds-text-muted);margin-top:2px}.ps-biKiep-bar{display:flex;gap:8px;padding:8px 16px;justify-content:center}.ps-bk-frag{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;border:2px solid var(--border-dim);background:var(--bg-card2);transition:all .3s}.ps-bk-frag.collected{border-color:var(--ps-gold);background:#d4af371f;box-shadow:0 0 12px #d4af3733;animation:ps-bk-glow 2s ease-in-out infinite alternate}.ps-bk-frag.locked{opacity:.3;filter:grayscale(1)}@keyframes ps-bk-glow{0%{box-shadow:0 0 8px #d4af3726}to{box-shadow:0 0 16px #d4af3759}}.ps-chapters{padding:8px 16px;display:flex;flex-direction:column;gap:12px}.ps-chapter-card{position:relative;padding:16px;border-radius:16px;border:2px solid var(--border-dim);background:var(--bg-card);cursor:pointer;transition:all .25s;overflow:hidden;text-align:left;width:100%;font-family:var(--ds-font)}.ps-chapter-card:hover{border-color:var(--ps-gold);transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.ps-chapter-card.locked{opacity:.5;cursor:not-allowed;filter:grayscale(.5)}.ps-chapter-card.locked:hover{transform:none;border-color:var(--border-dim);box-shadow:none}.ps-chapter-card.current{border-color:var(--ps-gold);box-shadow:0 0 0 2px #d4af3726,0 4px 16px #0000001f;padding:20px;min-height:160px}.ps-chapter-card.current .ps-ch-header{gap:16px;margin-bottom:12px}.ps-chapter-card.current .ps-ch-icon{width:56px;height:56px;font-size:2rem}.ps-chapter-card.current .ps-ch-title{font-size:1.2rem}.ps-chapter-card.current .ps-ch-subtitle{font-size:.82rem}.ps-chapter-card.current .ps-ch-character{margin-top:12px}.ps-chapter-card.current .ps-ch-char-avatar{width:36px;height:36px;font-size:1.5rem}.ps-ch-skip-btn{display:block;width:100%;margin-top:12px;padding:10px;border:1.5px dashed var(--ds-text-light);border-radius:10px;background:transparent;color:var(--ds-text-muted);font-size:.82rem;font-weight:600;cursor:pointer;font-family:var(--ds-font);transition:all .2s}.ps-ch-skip-btn:hover{border-color:var(--ps-gold);color:var(--ps-gold);background:#d4af370f}.ps-chapter-card.completed{border-color:var(--ds-green);background:#27ae600a}.ps-ch-bg{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.08;pointer-events:none;border-radius:14px}.ps-ch-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.ps-ch-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:#d4af371a;border:1px solid rgba(212,175,55,.2);flex-shrink:0}.ps-ch-info{flex:1}.ps-ch-number{font-size:.68rem;font-weight:700;color:var(--ds-text-light);letter-spacing:2px;text-transform:uppercase}.ps-ch-title{font-family:var(--ds-font-serif);font-size:1.05rem;font-weight:800;color:var(--ds-text)}.ps-ch-subtitle{font-size:.75rem;color:var(--ds-text-muted);font-style:italic;margin-top:2px}.ps-ch-character{display:flex;align-items:center;gap:8px;margin-top:8px}.ps-ch-char-avatar{font-size:1.2rem}.ps-ch-char-name{font-size:.78rem;font-weight:700;color:var(--ds-text-muted)}.ps-ch-char-loc{font-size:.7rem;color:var(--ds-text-light)}.ps-ch-progress-bar{height:4px;border-radius:2px;background:var(--border-dim);margin-top:10px;overflow:hidden}.ps-ch-progress-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--ps-gold),var(--ps-gold-light));transition:width .5s}.ps-ch-status{position:absolute;top:12px;right:12px;font-size:.72rem;font-weight:700;padding:3px 10px;border-radius:12px}.ps-ch-status.playing{background:#d4af3726;color:var(--ps-gold)}.ps-ch-status.completed{background:#27ae601f;color:var(--ds-green)}.ps-ch-status.locked{background:#00000014;color:var(--ds-text-light)}@media(min-width:768px){.ps-hero,.ps-progress-overview,.ps-biKiep-bar,.ps-chapters{max-width:800px;margin-left:auto;margin-right:auto}.ps-chapters{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.ps-chapter-card.current{grid-column:1 / -1}}.dlg-overlay{position:relative;display:flex;flex-direction:column;min-height:200px;cursor:pointer;-webkit-user-select:none;user-select:none}.dlg-character-area{display:flex;justify-content:center;padding:16px 0 8px}.dlg-avatar-wrap{position:relative;width:80px;height:80px}.dlg-avatar-emoji{display:flex;align-items:center;justify-content:center;width:80px;height:80px;font-size:2.8rem;background:#0003;border-radius:50%;border:3px solid var(--char-color, var(--ps-gold));box-shadow:0 0 20px #d4af3733}.dlg-deity-particles{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;border-radius:50%;background:radial-gradient(circle,rgba(212,175,55,.15) 0%,transparent 70%);animation:dlg-deity-pulse 3s ease-in-out infinite;pointer-events:none}@keyframes dlg-deity-pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.15);opacity:.8}}.dlg-box{margin:0 16px 8px;padding:16px;background:var(--bg-card);border:2px solid var(--border-dim);border-radius:16px;box-shadow:var(--ds-shadow-md);position:relative}.dlg-name{font-family:var(--ds-font-serif);font-size:.92rem;font-weight:800;margin-bottom:6px;display:flex;align-items:baseline;gap:8px}.dlg-title{font-size:.7rem;font-weight:600;opacity:.6;font-family:var(--ds-font)}.dlg-text{font-size:.88rem;color:var(--ds-text);line-height:1.7;min-height:48px;font-style:italic}.dlg-indicator{text-align:right;margin-top:8px}.dlg-continue{font-size:.72rem;color:var(--ps-gold);font-weight:700;animation:dlg-blink 1.5s ease-in-out infinite}@keyframes dlg-blink{0%,to{opacity:.5}50%{opacity:1}}.dlg-typing-dots span{font-size:1.2rem;color:var(--ds-text-muted);animation:dlg-dot-bounce 1.4s ease-in-out infinite}.dlg-typing-dots span:nth-child(2){animation-delay:.2s}.dlg-typing-dots span:nth-child(3){animation-delay:.4s}@keyframes dlg-dot-bounce{0%,80%,to{opacity:.3}40%{opacity:1}}.dlg-progress{display:flex;justify-content:center;gap:4px;margin-top:8px}.dlg-dot{width:6px;height:6px;border-radius:3px;background:var(--border-dim);transition:all .3s}.dlg-dot.active{background:var(--ps-gold);width:16px}.dlg-dot.done{background:var(--ds-green)}.cs-wrap{display:flex;flex-direction:column;align-items:center;position:relative}.cs-wrap.cs-animate{animation:cs-appear .6s ease-out}@keyframes cs-appear{0%{opacity:0;filter:blur(10px);transform:scale(.8)}50%{opacity:.7;filter:blur(3px);transform:scale(1.05)}to{opacity:1;filter:blur(0);transform:scale(1)}}.cs-glow{position:absolute;width:140px;height:140px;border-radius:50%;top:-10px;pointer-events:none}.cs-deity-fx{position:absolute;top:-30px;right:-30px;bottom:-30px;left:-30px;pointer-events:none}.cs-particle{position:absolute;border-radius:50%;width:var(--size);height:var(--size);left:50%;bottom:30%;opacity:0;animation:cs-particle-rise 3s ease-out infinite;animation-delay:var(--delay)}@keyframes cs-particle-rise{0%{opacity:0;transform:translate(0) scale(1)}20%{opacity:.9}to{opacity:0;transform:translate(var(--dx),var(--dy)) scale(0)}}.cs-avatar{width:90px;height:90px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid;box-shadow:0 4px 20px #0000004d;position:relative;z-index:1}.cs-emoji{font-size:2.6rem}.cs-name{font-family:var(--ds-font-serif);font-size:.82rem;font-weight:800;margin-top:8px;text-shadow:0 1px 4px rgba(0,0,0,.3)}.tut-engine{display:flex;gap:0;flex:1;min-height:0;overflow:hidden}.tut-progress-sidebar{display:flex;flex-direction:column;gap:6px;padding:8px 6px;background:var(--bg-card2);border-right:1px solid var(--border-dim);align-items:center;flex-shrink:0;width:52px;overflow-y:auto}.tut-main{flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden;min-width:0}.tut-step{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;border:2px solid var(--border-dim);background:var(--bg-card2);cursor:pointer;transition:all .3s;padding:0}.tut-step.active{border-color:var(--ps-gold);background:#d4af3726;box-shadow:0 0 12px #d4af3740;transform:scale(1.08)}.tut-step.done{border-color:var(--ds-green);background:#27ae601a;opacity:.7}.tut-step.done .tut-step-icon{filter:none}.tut-step-icon{font-size:1.1rem}.tut-lore-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}.tut-lore-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:100;width:calc(100% - 32px);max-width:400px;max-height:80%;overflow-y:auto;background:var(--bg-card);border:2px solid var(--ps-gold);border-radius:20px;padding:24px;box-shadow:0 16px 60px #00000080,0 0 40px #d4af371a;animation:tut-lore-pop .35s cubic-bezier(.34,1.56,.64,1)}@keyframes tut-lore-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.85)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.tut-lore-header{display:flex;align-items:center;gap:14px;margin-bottom:14px}.tut-lore-icon{font-size:2.4rem;flex-shrink:0}.tut-lore-name{font-family:var(--ds-font-serif);font-size:1.1rem;font-weight:800;color:var(--ds-text)}.tut-lore-char{font-family:var(--ds-font-serif);font-size:.9rem;color:var(--ps-gold)}.tut-lore-text{font-size:.85rem;color:var(--ds-text-muted);line-height:1.7;font-style:italic;margin-bottom:12px}.tut-lore-move{font-size:.82rem;color:var(--ds-text);padding:10px;background:#d4af370f;border-radius:8px;border:1px solid rgba(212,175,55,.15);margin-bottom:14px;line-height:1.6}.tut-btn{padding:10px 20px;border-radius:10px;border:1.5px solid var(--border-dim);background:var(--bg-card2);color:var(--ds-text);font-size:.85rem;font-weight:700;cursor:pointer;font-family:var(--ds-font);transition:all .2s}.tut-btn:hover{border-color:var(--ps-gold)}.tut-btn:disabled{opacity:.4;cursor:not-allowed}.tut-btn-primary{background:linear-gradient(135deg,var(--ps-blue-deep),var(--ps-purple));color:var(--ps-gold-light);border-color:var(--ps-gold)}.tut-btn-primary:hover{filter:brightness(1.1)}.tut-hint-popup{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#00000073;animation:tut-hint-fade-in .2s ease}@keyframes tut-hint-fade-in{0%{opacity:0}to{opacity:1}}.tut-hint-popup-card{position:relative;width:calc(100% - 40px);max-width:360px;background:var(--bg-card);border:2px solid var(--ps-gold);border-radius:16px;padding:20px;text-align:center;box-shadow:0 8px 40px #0006;animation:tut-lore-pop .3s cubic-bezier(.34,1.56,.64,1)}.tut-hint-close{position:absolute;top:8px;right:10px;width:28px;height:28px;border-radius:50%;border:1px solid var(--border-dim);background:var(--bg-card2);color:var(--ds-text-muted);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.tut-hint-close:hover{background:var(--ds-primary);color:#fff}.tut-hint-icon{font-size:2rem;display:block;margin-bottom:8px}.tut-hint-text{font-size:.85rem;color:var(--ps-gold);line-height:1.6;font-weight:600;margin-bottom:14px}.tut-hint-ok{width:100%}.tut-board-wrap{flex:1;display:flex;justify-content:center;align-items:center;padding:4px;overflow:hidden}.tut-canvas{display:block;cursor:pointer;border-radius:4px}.tut-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:8px 12px;border-top:1px solid var(--border-dim);background:var(--bg-card2);flex-shrink:0}.tut-move-count{font-size:.78rem;color:var(--ds-text-muted);font-weight:600;margin-right:auto}.tut-btn-ghost{padding:8px 14px;border-radius:10px;border:1.5px solid var(--border-dim);background:transparent;color:var(--ds-text-muted);font-size:.82rem;font-weight:600;cursor:pointer;font-family:var(--ds-font);transition:all .2s}.tut-btn-ghost:hover{border-color:var(--ps-gold);color:var(--ps-gold);background:#d4af370f}.bf-container{position:relative}.bf-scene-bg{padding:40px 20px;text-align:center;min-height:200px;display:flex;align-items:center;justify-content:center}.bf-boss-intro{text-align:center}.bf-boss-avatar{font-size:3.5rem;display:block;margin-bottom:12px;animation:cs-appear .8s ease-out}.bf-boss-name{font-family:var(--ds-font-serif);font-size:1.3rem;font-weight:800;color:var(--ps-gold-light);margin-bottom:4px}.bf-boss-title{font-size:.82rem;color:#fff9;font-style:italic}.bf-info-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--bg-card2);border-bottom:1px solid var(--border-dim)}.bf-opponent{display:flex;align-items:center;gap:8px}.bf-opp-avatar{font-size:1.2rem}.bf-opp-name{font-size:.82rem;font-weight:700;color:var(--ds-text)}.bf-opp-level{font-size:.7rem;font-weight:600;color:var(--ds-text-muted);padding:2px 6px;background:#0000000f;border-radius:4px}.bf-turn-indicator{font-size:.78rem;font-weight:700;color:var(--ps-gold)}.bf-board-wrap{display:flex;justify-content:center;padding:6px}.bf-canvas{display:block;cursor:pointer;border-radius:8px}.bf-comment{display:flex;align-items:flex-start;gap:10px;margin:6px 16px;padding:10px 14px;background:linear-gradient(135deg,#1a3a5c1a,#7b2d8b0f);border:1px solid rgba(212,175,55,.2);border-radius:12px;animation:bf-comment-in .3s ease-out}@keyframes bf-comment-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.bf-comment-avatar{font-size:1.3rem;flex-shrink:0}.bf-comment-bubble{flex:1}.bf-comment-name{font-size:.72rem;font-weight:700;color:var(--ps-gold);display:block;margin-bottom:2px}.bf-comment-text{font-size:.8rem;color:var(--ds-text);line-height:1.5;font-style:italic}.bf-actions{display:flex;align-items:center;justify-content:space-between;padding:8px 16px}.bf-move-count{font-size:.78rem;color:var(--ds-text-muted)}.bf-result-overlay{display:flex;align-items:center;justify-content:center;padding:40px 20px}.bf-result-card{text-align:center;padding:32px;border-radius:20px;animation:bf-result-pop .5s cubic-bezier(.34,1.56,.64,1)}@keyframes bf-result-pop{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.bf-win{background:linear-gradient(135deg,#27ae6026,#d4af371a);border:2px solid var(--ds-green)}.bf-lose{background:linear-gradient(135deg,#e74c3c1a,#8b1a1a1a);border:2px solid var(--ps-red-seal)}.bf-result-icon{font-size:3rem;display:block;margin-bottom:8px}.bf-result-text{font-family:var(--ds-font-serif);font-size:1.5rem;font-weight:800;letter-spacing:3px}.bf-win .bf-result-text{color:var(--ds-green)}.bf-lose .bf-result-text{color:#e74c3c}.bk-viewer{padding:8px 16px}.bk-tabs{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;margin-bottom:10px}.bk-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:10px;border:1.5px solid var(--border-dim);background:var(--bg-card2);color:var(--ds-text-muted);font-size:.78rem;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;font-family:var(--ds-font);transition:all .2s}.bk-tab.active{border-color:var(--ps-gold);background:#d4af371a;color:var(--ps-gold)}.bk-tab-icon{font-size:1rem}.bk-tab-name{font-size:.75rem}.bk-header{text-align:center;margin-bottom:12px}.bk-book-title{font-family:var(--ds-font-serif);font-size:1.1rem;font-weight:800;color:var(--ds-text)}.bk-book-subtitle{font-size:.75rem;color:var(--ds-text-muted);font-style:italic}.bk-scroll{position:relative;background:var(--bg-card);border:2px solid var(--ps-amber);border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0000001a}.bk-scroll-ornament{height:6px;background:linear-gradient(90deg,var(--ps-amber),var(--ps-gold),var(--ps-amber))}.bk-scroll-content{padding:20px}.bk-tech-number{font-size:.7rem;color:var(--ds-text-light);font-weight:600;letter-spacing:1px;margin-bottom:4px}.bk-tech-name{font-family:var(--ds-font-serif);font-size:1.2rem;font-weight:800;color:var(--ps-ink);margin-bottom:8px}[data-theme=dark] .bk-tech-name{color:var(--ps-gold-light)}.bk-tech-desc{font-size:.85rem;color:var(--ds-text-muted);line-height:1.6;margin-bottom:14px}.bk-show-board-btn{display:block;width:100%;padding:10px;border-radius:8px;border:1.5px dashed var(--ps-gold);background:#d4af370f;color:var(--ps-gold);font-size:.82rem;font-weight:700;cursor:pointer;font-family:var(--ds-font);transition:all .2s}.bk-show-board-btn:hover{background:#d4af371f}.bk-board-section{margin-top:8px}.bk-board-wrap{display:flex;justify-content:center;padding:4px}.bk-hint{display:flex;align-items:flex-start;gap:8px;margin-top:10px;padding:10px;background:#d4af3714;border-radius:8px;font-size:.8rem;color:var(--ps-gold);line-height:1.5}.bk-hint-icon{font-size:1rem;flex-shrink:0}.bk-nav{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px}.bk-nav-info{font-size:.75rem;color:var(--ds-text-muted);font-weight:600}.scp-page{display:flex;flex-direction:column;height:100dvh;overflow-y:auto}.scp-scene-badge{font-size:.72rem;font-weight:700;color:var(--ps-gold);background:#d4af3726;padding:4px 10px;border-radius:6px}.scp-scene-progress{display:flex;justify-content:center;gap:4px;padding:8px 16px}.scp-sp-dot{width:20px;height:4px;border-radius:2px;background:var(--border-dim);transition:all .3s}.scp-sp-dot.active{background:var(--ps-gold);width:30px}.scp-sp-dot.done{background:var(--ds-green)}.scp-content{flex:1;display:flex;flex-direction:column;padding:0;overflow:hidden}.scp-tutorial-scene{flex:1;display:flex;flex-direction:column;overflow:hidden}.scp-scene-title{font-family:var(--ds-font-serif);font-size:1.1rem;font-weight:800;color:var(--ds-text);text-align:center;padding:12px 16px 4px}.scp-scene-desc{font-size:.82rem;color:var(--ds-text-muted);text-align:center;padding:0 16px 8px;line-height:1.6}.scp-character-showcase{display:flex;justify-content:center;padding:16px 0 8px;min-height:120px}.scp-lesson-scene{padding:0 16px}.scp-lesson-list{display:flex;flex-direction:column;gap:10px;margin:8px 0}.scp-lesson-card{display:flex;align-items:flex-start;gap:12px;padding:14px;background:var(--bg-card);border:1.5px solid var(--border-dim);border-radius:12px}.scp-lesson-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#d4af371f;color:var(--ps-gold);font-size:.82rem;font-weight:800;flex-shrink:0}.scp-lesson-info{flex:1}.scp-lesson-name{font-size:.88rem;font-weight:700;color:var(--ds-text);margin-bottom:2px}.scp-lesson-desc{font-size:.78rem;color:var(--ds-text-muted);line-height:1.5}.scp-lesson-next{width:100%;margin-top:12px}.scp-reward-overlay,.scp-reward-scene{display:flex;align-items:center;justify-content:center;min-height:50vh;padding:20px}.scp-reward-card{text-align:center;position:relative;padding:32px 24px;background:var(--bg-card);border:2px solid var(--ps-gold);border-radius:20px;max-width:360px;animation:bf-result-pop .6s cubic-bezier(.34,1.56,.64,1)}.scp-reward-glow,.scp-inline-reward-glow{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;background:radial-gradient(circle,rgba(212,175,55,.12) 0%,transparent 70%);pointer-events:none;animation:ps-bk-glow 3s ease-in-out infinite alternate}.scp-reward-icon{font-size:3rem;margin-bottom:12px}.scp-reward-title{font-family:var(--ds-font-serif);font-size:1.2rem;font-weight:800;color:var(--ps-gold);margin-bottom:4px}.scp-reward-subtitle{font-size:.82rem;color:var(--ds-text-muted);margin-bottom:16px}.scp-bi-kiep-reward{background:#d4af3714;border:1px solid rgba(212,175,55,.2);border-radius:12px;padding:14px;margin-bottom:16px}.scp-bk-icon{font-size:2rem;margin-bottom:6px}.scp-bk-label{font-size:.82rem;font-weight:700;color:var(--ps-gold);margin-bottom:4px}.scp-bk-quote{font-size:.85rem;color:var(--ds-text);font-style:italic;line-height:1.5}.scp-reward-btn{width:100%}.scp-inline-reward{position:relative;text-align:center;padding:32px 24px;background:var(--bg-card);border:2px solid var(--ps-gold);border-radius:20px;max-width:360px;animation:bf-result-pop .6s cubic-bezier(.34,1.56,.64,1)}.scp-inline-reward-icon{font-size:3rem;margin-bottom:8px}.scp-inline-reward-title{font-family:var(--ds-font-serif);font-size:1.1rem;font-weight:800;color:var(--ps-gold);margin-bottom:8px}.scp-inline-reward-quote{font-size:.85rem;color:var(--ds-text);font-style:italic;line-height:1.6;margin-bottom:16px}@media(max-width:600px){.tut-progress-sidebar{width:42px;padding:6px 4px;gap:4px}.tut-step{width:32px;height:32px;border-radius:8px}.tut-step-icon{font-size:.9rem}.tut-actions{padding:6px 8px;gap:6px}.tut-btn{padding:8px 12px;font-size:.78rem}.tut-btn-ghost{padding:6px 10px;font-size:.76rem}.tut-move-count{font-size:.7rem}.tut-lore-card{width:calc(100% - 16px);max-width:340px;padding:16px}.tut-lore-icon{font-size:1.8rem}.tut-lore-name{font-size:.95rem}.tut-lore-text{font-size:.8rem}.tut-lore-move{font-size:.78rem;padding:8px}.tut-hint-popup-card{width:calc(100% - 24px);max-width:300px;padding:16px}.tut-hint-icon{font-size:1.6rem}.tut-hint-text{font-size:.8rem}}@media(min-width:1200px){.tut-progress-sidebar{width:58px;gap:8px}.tut-step{width:42px;height:42px}.tut-step-icon{font-size:1.2rem}}.dp-scroll{padding:0;padding-bottom:max(96px,env(safe-area-inset-bottom))}.dp-daily-hero{margin:12px 16px;padding:24px 20px;background:linear-gradient(145deg,#1a3a5c,#0d253f 40%,#2c1810);border-radius:18px;border:1.5px solid rgba(212,175,55,.25);position:relative;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s}.dp-daily-hero:hover{transform:translateY(-2px);box-shadow:0 8px 24px #d4af3726}.dp-daily-hero:before{content:"";position:absolute;top:-50%;right:-30%;width:200px;height:200px;background:radial-gradient(circle,rgba(212,175,55,.08) 0%,transparent 70%);pointer-events:none}.dp-hero-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;background:#d4af3726;border:1px solid rgba(212,175,55,.3);border-radius:20px;font-size:.72rem;font-weight:700;color:#d4af37;margin-bottom:12px;letter-spacing:.5px}.dp-hero-title{font-family:var(--ds-font-serif);font-size:1.3rem;font-weight:800;color:#fff;margin-bottom:4px}.dp-hero-desc{font-size:.82rem;color:#fff9;margin-bottom:16px;line-height:1.5}.dp-hero-bottom{display:flex;align-items:center;justify-content:space-between}.dp-countdown{display:flex;align-items:center;gap:6px;font-size:.78rem;color:#ffffff80}.dp-countdown-icon{font-size:1rem}.dp-hero-btn{padding:10px 22px;background:linear-gradient(135deg,#d4af37,#c17f3a);border:none;border-radius:10px;color:#1a1a2e;font-size:.85rem;font-weight:800;font-family:var(--ds-font);cursor:pointer;transition:all .2s;letter-spacing:.5px}.dp-hero-btn:hover{transform:scale(1.05);box-shadow:0 4px 16px #d4af374d}.dp-hero-solved{background:linear-gradient(145deg,#0d3f1a,#1a3a2c);border-color:#27ae604d}.dp-hero-solved .dp-hero-btn{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff}.dp-stats-grid{display:flex;gap:8px;margin:0 16px 12px}.dp-stat-card{flex:1;padding:14px 8px;background:var(--bg-card);border:1.5px solid var(--border-dim);border-radius:12px;text-align:center}.dp-stat-val{display:block;font-size:1.3rem;font-weight:800;color:var(--ds-text);font-family:var(--ds-font)}.dp-stat-label{display:block;font-size:.68rem;color:var(--ds-text-muted);margin-top:2px;font-weight:600}.dp-section-label{margin:12px 16px 6px;font-size:.78rem;font-weight:700;color:var(--ds-text-muted);text-transform:uppercase;letter-spacing:1px}.dp-stat-select-card{display:flex;flex-direction:column;padding:8px 4px}.dp-category-select{flex:1;width:100%;background:transparent;border:none;color:var(--ds-primary);font-family:var(--ds-font);font-size:.85rem;font-weight:800;text-align:center;text-align-last:center;outline:none;cursor:pointer;padding:0;margin:auto 0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.dp-puzzle-grid{display:flex;overflow-x:auto;gap:12px;padding:8px 16px 16px;max-width:100%;box-sizing:border-box;scroll-snap-type:x mandatory}.dp-puzzle-grid::-webkit-scrollbar{height:6px}.dp-puzzle-grid::-webkit-scrollbar-track{background:var(--bg-card2);border-radius:4px;margin:0 16px}.dp-puzzle-grid::-webkit-scrollbar-thumb{background:var(--ds-primary);border-radius:4px}.dp-puzzle-card{flex:0 0 150px;scroll-snap-align:start;background:var(--bg-card);border:1.5px solid var(--border-dim);border-radius:14px;padding:12px 14px;cursor:pointer;transition:border-color .2s,transform .15s;display:flex;flex-direction:column;gap:6px;text-align:left;font-family:var(--ds-font)}.dp-puzzle-card:hover{border-color:var(--ds-primary);transform:translateY(-1px)}.dp-puzzle-card.solved{border-color:var(--ds-green);background:#27ae600f}.dp-puzzle-head{display:flex;justify-content:space-between;align-items:center}.dp-puzzle-diff{font-size:.7rem}.dp-puzzle-solved-badge{font-size:.85rem}.dp-puzzle-title{font-size:.85rem;font-weight:700;color:var(--ds-text);font-family:var(--ds-font-serif);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dp-puzzle-desc{font-size:.7rem;color:var(--ds-text-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.dp-puzzle-meta{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:6px}.dp-puzzle-loc{font-size:.65rem;color:var(--ds-gold);font-weight:600}.dp-puzzle-plays{font-size:.65rem;color:var(--ds-text-muted)}.dp-cta-group{display:flex;gap:10px;margin:4px 16px 16px;box-sizing:border-box;max-width:100%}.dp-cta-btn{flex:1;margin:0;padding:12px 8px;font-size:.8rem;justify-content:center}.dp-cta-btn .dp-cta-icon{margin-right:4px}.dp-cta-kipho{background:#2c1810;color:#d4af37;border:1px solid rgba(212,175,55,.3)}.dp-cta-kipho:hover{background:#3a2418}.dp-puzzle-board-wrap{display:flex;justify-content:center;margin:6px 0}.dp-reward-tip{display:flex;align-items:center;gap:8px;margin:0 16px 12px;padding:10px 14px;background:#d4af3714;border:1px solid rgba(212,175,55,.15);border-radius:10px;font-size:.78rem;color:var(--ds-text-muted);line-height:1.5}.dp-reward-tip-icon{font-size:1.2rem;flex-shrink:0}.dp-reward-tip strong{color:#d4af37}.lp-story-hero{margin:12px 16px;padding:0;background:linear-gradient(160deg,#0d1a2e,#1a2a4a 30%,#2c1810 70%,#1a0e08);border-radius:20px;border:2px solid rgba(212,175,55,.3);cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;min-height:280px;display:flex;flex-direction:column}.lp-story-hero:hover{transform:translateY(-3px);box-shadow:0 8px 32px #d4af3733,0 0 60px #d4af3714;border-color:#d4af3780}.lp-story-hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 50%,rgba(212,175,55,.06) 0%,transparent 60%),radial-gradient(ellipse at 80% 30%,rgba(139,88,32,.08) 0%,transparent 50%);pointer-events:none}.lp-story-hero-bg:after{content:"";position:absolute;top:-40%;right:-20%;width:300px;height:300px;background:radial-gradient(circle,rgba(212,175,55,.04) 0%,transparent 70%);animation:lp-hero-glow 6s ease-in-out infinite alternate}@keyframes lp-hero-glow{0%{opacity:.3;transform:scale(1)}to{opacity:1;transform:scale(1.2)}}.lp-story-hero-content{display:flex;align-items:center;gap:20px;padding:28px 24px 16px;position:relative;z-index:1;flex:1}.lp-story-avatar{width:144px;height:144px;border-radius:50%;object-fit:cover;border:3px solid rgba(212,175,55,.5);box-shadow:0 0 24px #d4af3740,0 0 48px #d4af371a;flex-shrink:0;animation:lp-avatar-breathe 4s ease-in-out infinite alternate}@keyframes lp-avatar-breathe{0%{box-shadow:0 0 24px #d4af3740,0 0 48px #d4af371a}to{box-shadow:0 0 32px #d4af3766,0 0 64px #d4af3726}}.lp-story-hero-text{flex:1;min-width:0}.lp-story-chapter-badge{display:inline-block;padding:3px 12px;background:#d4af3726;border:1px solid rgba(212,175,55,.35);border-radius:20px;font-size:.65rem;font-weight:800;color:#d4af37;letter-spacing:1.5px;margin-bottom:8px}.lp-story-hero-title{font-family:var(--ds-font-serif);font-size:1.4rem;font-weight:900;color:#fff;margin:0 0 10px;text-shadow:0 2px 8px rgba(0,0,0,.5)}.lp-story-hero-desc{font-size:.85rem;color:#ffffffb3;line-height:1.65;margin:0;font-style:italic;font-family:var(--ds-font-serif)}.lp-glow-speak{animation:lp-speak-glow 2.5s ease-in-out infinite}@keyframes lp-speak-glow{0%{color:#fff9;text-shadow:none}50%{color:#f0d060;text-shadow:0 0 12px rgba(212,175,55,.5),0 0 24px rgba(212,175,55,.2)}to{color:#fff9;text-shadow:none}}.lp-story-hero-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 24px 20px;position:relative;z-index:1}.lp-story-hero-footer .lp-story-progress-row{flex:1}.lp-story-progress-row{display:flex;align-items:center;gap:8px}.lp-story-progress-bar{flex:1;height:4px;border-radius:2px;background:#ffffff1a;overflow:hidden}.lp-story-progress-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,#d4af37,#c17f3a);transition:width .5s}.lp-story-progress-pct{font-size:.72rem;font-weight:700;color:#d4af37;min-width:32px;text-align:right}.lp-story-hero-cta{font-size:.8rem;font-weight:700;color:#d4af37;white-space:nowrap;letter-spacing:.3px;transition:color .2s}.lp-story-hero:hover .lp-story-hero-cta{color:#f0d060}.dp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 24px;gap:6px}.dp-empty-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background:var(--ds-primary-light);color:var(--ds-text-muted);opacity:.5;margin-bottom:8px;animation:dp-empty-breathe 3s ease-in-out infinite alternate}@keyframes dp-empty-breathe{0%{opacity:.4;transform:scale(1)}to{opacity:.6;transform:scale(1.05)}}.dp-empty-title{font-size:1rem;font-weight:800;color:var(--ds-text-muted);letter-spacing:.3px}.dp-empty-sub{font-size:.82rem;color:var(--ds-text-light);line-height:1.6;max-width:280px}.dp-loading{text-align:center;padding:40px;color:var(--ds-text-muted);font-size:.85rem}.dp-hero-lore{font-size:.75rem;color:#ffffff73;font-style:italic;font-family:var(--ds-font-serif);line-height:1.5;margin-top:8px;padding-left:10px;border-left:2px solid rgba(212,175,55,.3)}@media(min-width:768px){.dp-daily-hero,.dp-reward-tip,.dp-stats-grid,.dp-puzzle-grid,.dp-cta-group,.dp-section-label,.dp-empty,.lp-story-hero{max-width:800px;margin-left:auto;margin-right:auto}}.mb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;animation:mb-fade-in .25s ease}@keyframes mb-fade-in{0%{opacity:0}to{opacity:1}}.mb-book{width:100%;max-width:440px;max-height:85vh;background:var(--ds-bg);border-top-left-radius:24px;border-top-right-radius:24px;border:1.5px solid var(--ds-card-border);border-bottom:none;display:flex;flex-direction:column;overflow:hidden;animation:mb-slide-up .35s cubic-bezier(.16,1,.3,1);box-shadow:0 -8px 40px #00000080,0 0 60px #d4af3714}@keyframes mb-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mb-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--ds-card-border);background:var(--ds-card)}.mb-title{display:flex;align-items:center;gap:8px;font-family:var(--ds-font-serif);font-size:1.1rem;font-weight:800;color:var(--ds-gold, #d4af37)}.mb-title-icon{font-size:1.4rem}.mb-close{width:32px;height:32px;border-radius:50%;border:1px solid var(--ds-border);background:var(--ds-card);color:var(--ds-text-muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.mb-close:hover{background:var(--ds-primary);color:#fff}.mb-tabs{display:flex;gap:4px;padding:8px 16px;border-bottom:1px solid var(--ds-card-border)}.mb-tab{flex:1;padding:8px 4px;text-align:center;border-radius:8px;border:none;background:transparent;color:var(--ds-text-muted);font-size:.75rem;font-weight:600;font-family:var(--ds-font);cursor:pointer;transition:all .2s;white-space:nowrap}.mb-tab:hover{background:var(--ds-card)}.mb-tab.active{background:var(--ds-primary);color:#fff;border:1px solid var(--ds-primary)}.mb-tab-icon{display:block;font-size:1.1rem;margin-bottom:2px}.mb-content{flex:1;overflow-y:auto;padding:12px 16px 24px;scrollbar-width:thin;scrollbar-color:rgba(212,175,55,.2) transparent}.mb-section{font-size:.72rem;font-weight:700;color:var(--ds-text-light);text-transform:uppercase;letter-spacing:1.5px;margin:16px 0 8px;padding-bottom:4px;border-bottom:1px solid var(--ds-card-border)}.mb-section:first-child{margin-top:4px}.mb-quest{display:flex;align-items:center;gap:12px;padding:12px 14px;margin-bottom:6px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:12px;transition:all .2s}.mb-quest.completed{background:#27ae600f;border-color:#27ae6026}.mb-quest-check{width:24px;height:24px;border-radius:6px;border:2px solid var(--ds-border);display:flex;align-items:center;justify-content:center;font-size:.75rem;flex-shrink:0;transition:all .3s}.mb-quest.completed .mb-quest-check{background:var(--ds-green);border-color:var(--ds-green);color:#fff}.mb-quest-icon{font-size:1.3rem;flex-shrink:0}.mb-quest-info{flex:1;min-width:0}.mb-quest-title{font-size:.82rem;font-weight:600;color:var(--ds-text);margin-bottom:2px}.mb-quest.completed .mb-quest-title{text-decoration:line-through;opacity:.6}.mb-quest-progress-bar{height:3px;border-radius:2px;background:var(--ds-border);overflow:hidden}.mb-quest-progress-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,#d4af37,#c17f3a);transition:width .5s}.mb-quest.completed .mb-quest-progress-fill{background:var(--ds-green)}.mb-quest-xp{flex-shrink:0;padding:3px 8px;border-radius:6px;background:var(--ds-card);color:var(--ds-gold, #d4af37);font-size:.7rem;font-weight:700}.mb-quest.completed .mb-quest-xp{background:#27ae601a;color:var(--ds-green)}.mb-xp-summary{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px;margin:8px 0;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:10px}.mb-xp-val{font-size:1.1rem;font-weight:800;color:var(--ds-gold, #d4af37)}.mb-xp-label{font-size:.72rem;color:var(--ds-text-muted)}.mb-roadmap{position:relative;padding-left:24px}.mb-roadmap:before{content:"";position:absolute;left:10px;top:12px;bottom:12px;width:2px;background:#d4af3726;border-radius:1px}.mb-road-step{position:relative;padding:12px 14px;margin-bottom:6px;background:var(--ds-card);border:1px solid var(--ds-card-border);border-radius:12px}.mb-road-step.completed{background:#27ae600f;border-color:#27ae6026}.mb-road-dot{position:absolute;left:-20px;top:16px;width:10px;height:10px;border-radius:50%;background:var(--ds-border);border:2px solid var(--ds-gold, rgba(212,175,55,.3))}.mb-road-step.completed .mb-road-dot{background:var(--ds-green);border-color:var(--ds-green)}.mb-road-header{display:flex;align-items:center;gap:8px;margin-bottom:2px}.mb-road-icon{font-size:1.1rem}.mb-road-title{font-size:.82rem;font-weight:600;color:var(--ds-text)}.mb-road-step.completed .mb-road-title{text-decoration:line-through;opacity:.6}.mb-road-desc{font-size:.72rem;color:var(--ds-text-muted);margin-left:28px}.mb-season-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#ffd7000a;border:1px solid rgba(255,215,0,.1);border-radius:12px;margin-bottom:10px}.mb-season-level{font-size:1.3rem;font-weight:800;color:#d4af37}.mb-season-level-label{font-size:.7rem;color:var(--ds-text-muted)}.mb-season-xp-bar{flex:1;margin:0 16px}.mb-season-xp-frame{height:8px;border-radius:4px;background:#0006;overflow:hidden}.mb-season-xp-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,#f59e0b,#fbbf24);transition:width .3s}.mb-season-xp-text{font-size:.65rem;color:var(--ds-text-muted);text-align:center;margin-top:2px}.mb-season-row{display:flex;align-items:stretch;margin-bottom:6px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:10px;overflow:hidden}.mb-season-row.unlocked{border-color:#d4af3726}.mb-season-lvl-box{width:44px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;color:var(--ds-text-muted);background:#0003;border-right:1px solid rgba(255,255,255,.06)}.mb-season-rewards{display:flex;flex:1}.mb-season-cell{flex:1;padding:10px;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.72rem}.mb-season-cell+.mb-season-cell{border-left:1px solid rgba(255,255,255,.06)}.mb-season-cell.premium{background:#ffd70008}.mb-season-cell-label{font-size:.6rem;color:var(--ds-text-muted)}.mb-season-cell-label.premium{color:#d4af37}.mb-season-cell-icon{font-size:1.2rem}.mb-season-cell-val{font-weight:700}.mb-claim-btn{padding:3px 12px;border-radius:6px;background:var(--ds-primary);color:#fff;border:none;font-size:.68rem;font-weight:700;cursor:pointer;font-family:var(--ds-font)}.mb-claimed-btn{padding:3px 12px;border-radius:6px;background:#ffffff1a;color:#fff6;border:none;font-size:.68rem}.mb-locked-btn{padding:3px 12px;border-radius:6px;background:#0000004d;color:#ffffff40;border:1px dashed rgba(255,255,255,.1);font-size:.68rem}.mb-upgrade-btn{display:block;width:100%;margin:10px 0;padding:12px;background:linear-gradient(45deg,gold,orange);color:#1a1a2e;border:none;border-radius:10px;font-weight:800;font-size:.88rem;cursor:pointer;font-family:var(--ds-font);transition:transform .2s}.mb-upgrade-btn:hover{transform:scale(1.02)}.mb-fab{position:fixed;bottom:76px;right:16px;z-index:9990;width:52px;height:52px;border-radius:50%;background:var(--ds-card);border:2px solid var(--ds-card-border);box-shadow:var(--ds-shadow-md);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;transition:all .2s}.mb-fab:hover{transform:scale(1.1);box-shadow:0 6px 24px #00000080,0 0 30px #d4af3726}.mb-fab:active{transform:scale(.95)}.mb-fab-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 5px;border-radius:10px;background:#e74c3c;color:#fff;font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid #1a1a2e}.mb-fab.has-new{animation:mb-fab-pulse 2s ease-in-out infinite}@keyframes mb-fab-pulse{0%,to{box-shadow:0 4px 16px #0006,0 0 20px #d4af371a}50%{box-shadow:0 4px 16px #0006,0 0 30px #d4af374d}}.pp-tabs{display:flex;gap:4px;padding:0 16px;margin-bottom:12px}.pp-tab{flex:1;padding:10px 4px;text-align:center;border-radius:10px;border:1.5px solid var(--border-dim);background:var(--bg-card2);color:var(--ds-text-muted);font-size:.78rem;font-weight:600;font-family:var(--ds-font);cursor:pointer;transition:all .2s}.pp-tab:hover{border-color:#d4af374d}.pp-tab.active{background:var(--ds-primary);border-color:var(--ds-primary);color:#fff}.pp-tab-icon{display:block;font-size:1.1rem;margin-bottom:2px}.pp-inv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:0 16px}.pp-inv-card{background:var(--bg-card);border:1.5px solid var(--border-dim);border-radius:14px;padding:14px;display:flex;flex-direction:column;align-items:center;gap:6px;transition:all .2s}.pp-inv-card.equipped{border-color:var(--ds-green);background:#27ae600f}.pp-inv-preview{width:56px;height:56px;border-radius:50%;border:3px solid rgba(0,0,0,.15);position:relative}.pp-inv-active-pip{position:absolute;bottom:-2px;right:-2px;background:var(--ds-green);color:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}.pp-inv-name{font-size:.82rem;font-weight:700;color:var(--ds-text);text-align:center}.pp-inv-desc{font-size:.68rem;color:var(--ds-text-muted);text-align:center}.pp-inv-btn{width:100%;padding:7px;border-radius:8px;border:none;font-size:.75rem;font-weight:700;cursor:pointer;font-family:var(--ds-font);margin-top:auto}.pp-inv-btn.equip{background:var(--ds-blue, #2980b9);color:#fff}.pp-inv-btn.equipped{background:var(--ds-green);color:#fff;opacity:.7;cursor:default}.pp-inv-btn.buy{background:var(--btn-cta-bg, #8B1E1E);color:#fff}.pp-inv-btn.buy:disabled{opacity:.5;cursor:not-allowed}.pp-inv-section-label{font-size:.72rem;font-weight:700;color:var(--ds-text-muted);text-transform:uppercase;letter-spacing:1px;padding:12px 16px 4px}.pp-inv-empty{text-align:center;padding:30px;color:var(--ds-text-muted);font-size:.85rem}.pp-xu-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#c8960a26;border:1px solid rgba(224,168,32,.3);border-radius:999px;font-size:.82rem;font-weight:700;color:var(--ds-gold, #c8960a);margin:0 16px 8px}.ach-summary{display:flex;align-items:center;justify-content:center;gap:0;margin:16px;background:var(--ds-card);border:1px solid var(--border-gold);border-radius:var(--ds-radius-lg);padding:16px;box-shadow:var(--ds-shadow-card)}.ach-summary-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.ach-summary-num{font-size:22px;font-weight:800;color:var(--ds-primary)}.ach-summary-label{font-size:11px;color:var(--ds-text-muted)}.ach-summary-divider{width:1px;height:32px;background:var(--border-dim)}.ach-tabs{display:flex;overflow-x:auto;gap:8px;padding:0 16px 8px;scrollbar-width:none}.ach-tabs::-webkit-scrollbar{display:none}.ach-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;border-radius:var(--ds-radius-md);border:1px solid var(--border-dim);background:var(--ds-card-secondary);cursor:pointer;white-space:nowrap;flex-shrink:0;font-size:11px;color:var(--ds-text-muted);font-family:var(--ds-font);transition:background var(--ds-transition),color var(--ds-transition),border-color var(--ds-transition)}.ach-tab:hover{border-color:var(--ds-card-border);background:var(--ds-card)}.ach-tab.active{background:var(--ds-primary);border-color:var(--ds-primary);color:var(--btn-cta-text)}.ach-tab-label{font-size:12px;font-weight:600}.ach-tab-count{font-size:10px;opacity:.75}.ach-list{padding:8px 16px 100px;display:flex;flex-direction:column;gap:10px}.ach-empty{text-align:center;color:var(--ds-text-muted);padding:40px 0;font-size:14px}.ach-card{display:flex;align-items:flex-start;gap:12px;padding:14px;border-radius:var(--ds-radius-lg);border:1px solid var(--border-dim);background:var(--ds-card-secondary);transition:border-color var(--ds-transition),opacity var(--ds-transition)}.ach-card--unlocked{background:var(--ds-card);border-color:var(--border-gold);box-shadow:var(--ds-shadow-card)}.ach-card--locked{opacity:.6}.ach-card-icon{font-size:28px;flex-shrink:0;width:36px;text-align:center}.ach-card-body{flex:1;min-width:0}.ach-card-name{font-size:15px;font-weight:700;color:var(--ds-text);margin-bottom:2px;font-family:var(--ds-font-serif)}.ach-card-desc{font-size:12px;color:var(--ds-text-muted);margin-bottom:6px}.ach-progress-track{height:4px;background:var(--border-dim);border-radius:var(--ds-radius-full);overflow:hidden;margin-bottom:3px}.ach-progress-fill{height:100%;background:var(--ds-primary);border-radius:var(--ds-radius-full);transition:width .4s ease}.ach-progress-label{font-size:10px;color:var(--ds-text-muted);margin-bottom:4px}.ach-reward-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.ach-reward-xu{font-size:12px;font-weight:600;color:var(--ds-gold);display:inline-flex;align-items:center;gap:3px}.ach-reward-title{font-size:12px;color:var(--ds-text-muted);font-style:italic}.ach-claim-btn{flex-shrink:0;padding:6px 14px;background:var(--ds-primary);color:var(--btn-cta-text);border:none;border-radius:var(--ds-radius-md);font-size:13px;font-weight:700;cursor:pointer;align-self:center;font-family:var(--ds-font);transition:background var(--ds-transition),transform .1s}.ach-claim-btn:hover{background:var(--ds-primary-hover)}.ach-claim-btn:active{transform:scale(.96)}.ach-claim-btn:disabled{opacity:.5;cursor:not-allowed}.ach-claimed{flex-shrink:0;font-size:18px;color:var(--ds-green);align-self:center}.ach-lock{flex-shrink:0;font-size:18px;align-self:center;opacity:.4}.ach-header-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--accent-red);color:#fff;border-radius:var(--ds-radius-full);font-size:10px;font-weight:700;padding:1px 6px;margin-left:6px;vertical-align:middle}.soc-tabs{display:flex;gap:6px;padding:8px 16px;overflow-x:auto;scrollbar-width:none}.soc-tabs::-webkit-scrollbar{display:none}.soc-tab{flex-shrink:0;padding:8px 14px;border-radius:var(--ds-radius-md);border:1px solid var(--border-dim);background:var(--ds-card-secondary);color:var(--ds-text-muted);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--ds-font);white-space:nowrap;position:relative;display:inline-flex;align-items:center;gap:4px;transition:background var(--ds-transition),color var(--ds-transition),border-color var(--ds-transition)}.soc-tab:hover{border-color:var(--ds-card-border);background:var(--ds-card)}.soc-tab.active{background:var(--ds-primary);border-color:var(--ds-primary);color:var(--btn-cta-text)}.soc-tab-badge{position:absolute;top:-6px;right:-6px;background:var(--accent-red);color:#fff;font-size:10px;font-weight:800;border-radius:50%;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;padding:0 3px}.soc-content{padding:8px 16px}.soc-section-title{font-size:14px;font-weight:800;color:var(--ds-text);margin:12px 0 8px;font-family:var(--ds-font-serif);display:flex;align-items:center;gap:4px}.soc-empty{text-align:center;padding:24px;color:var(--ds-text-muted);font-size:13px}.soc-list{display:flex;flex-direction:column;gap:8px}.soc-user{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--ds-card);border:1px solid var(--border-dim);border-radius:var(--ds-radius-lg);box-shadow:var(--ds-shadow-sm);transition:border-color var(--ds-transition),box-shadow var(--ds-transition)}.soc-user:hover{border-color:var(--ds-card-border);box-shadow:var(--ds-shadow-md)}.soc-avatar{width:40px;height:40px;border-radius:50%;background:var(--ds-card-secondary);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;overflow:hidden}.soc-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.soc-user-info{flex:1;min-width:0}.soc-user-name{font-size:14px;font-weight:700;color:var(--ds-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.soc-user-meta{font-size:11px;color:var(--ds-text-muted);display:flex;gap:8px;margin-top:2px;align-items:center}.soc-status--online{color:var(--ds-green);display:inline-flex;align-items:center;gap:2px}.soc-status--offline{color:var(--ds-text-muted);display:inline-flex;align-items:center;gap:2px}.soc-elo{color:var(--ds-gold);display:inline-flex;align-items:center;gap:2px}.soc-actions{display:flex;gap:6px}.soc-btn-accept{padding:6px 12px;border-radius:var(--ds-radius-md);background:var(--ds-green-light);border:1px solid var(--ds-green);color:var(--ds-green);font-size:14px;font-weight:800;cursor:pointer;transition:background var(--ds-transition)}.soc-btn-accept:hover{background:var(--ds-green);color:#fff}.soc-btn-decline{padding:6px 12px;border-radius:var(--ds-radius-md);background:transparent;border:1px solid var(--accent-red);color:var(--accent-red);font-size:14px;font-weight:800;cursor:pointer;transition:background var(--ds-transition)}.soc-btn-decline:hover{background:var(--accent-red);color:#fff}.soc-btn-remove{padding:6px 10px;border-radius:var(--ds-radius-md);background:transparent;border:1px solid var(--border-dim);color:var(--ds-text-muted);font-size:12px;cursor:pointer;transition:border-color var(--ds-transition),color var(--ds-transition)}.soc-btn-remove:hover{border-color:var(--accent-red);color:var(--accent-red)}.soc-btn-add{padding:6px 12px;border-radius:var(--ds-radius-md);background:var(--ds-primary);border:none;color:var(--btn-cta-text);font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background var(--ds-transition)}.soc-btn-add:hover{background:var(--ds-primary-hover)}.soc-pending-label{font-size:11px;color:var(--ds-gold);font-weight:600}.soc-search-row{display:flex;gap:8px;margin-bottom:12px}.soc-search-input{flex:1;padding:10px 14px;border-radius:var(--ds-radius-md);border:1px solid var(--border-dim);background:var(--bg-input);color:var(--ds-text);font-size:13px;font-family:var(--ds-font);outline:none;transition:border-color var(--ds-transition)}.soc-search-input:focus{border-color:var(--ds-primary)}.soc-search-btn{padding:10px 16px;border-radius:var(--ds-radius-md);background:var(--ds-primary);color:var(--btn-cta-text);border:none;font-size:13px;font-weight:700;cursor:pointer;transition:background var(--ds-transition)}.soc-search-btn:hover{background:var(--ds-primary-hover)}.soc-invite{text-align:center;padding:16px 0}.soc-invite-title{font-size:18px;font-weight:800;color:var(--ds-text);margin-bottom:8px;font-family:var(--ds-font-serif);display:flex;align-items:center;justify-content:center;gap:6px}.soc-invite-desc{font-size:13px;color:var(--ds-text-muted);margin-bottom:20px}.soc-share-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;max-width:320px;margin:0 auto 20px}.soc-share-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:var(--ds-radius-lg);border:none;color:#fff;font-size:13px;font-weight:700;cursor:pointer;justify-content:center;transition:opacity var(--ds-transition),transform .1s}.soc-share-btn:hover{opacity:.9}.soc-share-btn:active{transform:scale(.97)}.soc-share-btn--facebook{background:#1877f2}.soc-share-btn--zalo{background:#0068ff}.soc-share-btn--telegram{background:#08c}.soc-share-btn--copy{background:var(--ds-card-secondary);color:var(--ds-text);border:1px solid var(--border-dim)}.soc-share-logo{font-size:16px;font-weight:800}.soc-ref-box{padding:12px;background:var(--ds-card);border:1px solid var(--border-dim);border-radius:var(--ds-radius-md);max-width:400px;margin:0 auto}.soc-ref-label{font-size:11px;color:var(--ds-text-muted);margin-bottom:4px}.soc-ref-link{font-size:12px;color:var(--ds-gold);word-break:break-all;font-family:var(--ds-font-mono)}.soc-login-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;height:100%;color:var(--ds-text-muted)}.soc-login-icon{font-size:32px;margin-bottom:8px}.soc-login-btn{margin-top:16px;padding:10px 24px;border-radius:var(--ds-radius-md);background:var(--ds-primary);color:var(--btn-cta-text);border:none;font-size:14px;font-weight:700;cursor:pointer;transition:background var(--ds-transition)}.soc-login-btn:hover{background:var(--ds-primary-hover)}.pzp-scroll{padding:0;padding-bottom:max(96px,env(safe-area-inset-bottom))}.pzp-title{font-size:14px}.pzp-error-card{text-align:center;padding:40px 24px;background:var(--ds-card);border-radius:18px;border:1.5px solid var(--ds-card-border);max-width:360px;box-shadow:var(--ds-shadow-md)}.pzp-error-icon{font-size:2.5rem;margin-bottom:12px}.pzp-error-title{font-size:1.1rem;font-weight:700;color:var(--ds-text);margin-bottom:8px}.pzp-error-desc{font-size:.85rem;color:var(--ds-text-muted);margin-bottom:20px;line-height:1.5}.pzp-error-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.pzp-timer{font-size:14px;font-weight:700;color:var(--ds-gold);font-family:var(--ds-font-mono);padding:4px 10px;background:var(--ds-card-secondary);border:1px solid var(--border-dim);border-radius:var(--ds-radius-sm)}.pzp-lore{margin:6px 16px;padding:12px 14px;background:var(--ds-card);border:1px solid var(--border-gold);border-radius:var(--ds-radius-lg);font-size:12px;color:var(--ds-text-muted);line-height:1.6;font-style:italic;box-shadow:var(--ds-shadow-sm)}.pzp-board-wrap{display:flex;justify-content:center;padding:8px}.pzp-board-area{width:100%;aspect-ratio:1;position:relative}.pzp-status{padding:8px 16px;text-align:center}.pzp-status--success{padding:12px;border-radius:var(--ds-radius-md);background:var(--ds-green-light);border:1px solid var(--ds-green);color:var(--ds-green);font-size:15px;font-weight:700}.pzp-status--fail{padding:12px;border-radius:var(--ds-radius-md);background:#c0392b1a;border:1px solid var(--accent-red);color:var(--accent-red);font-size:14px;font-weight:600}.pzp-status--info{font-size:13px;color:var(--ds-text-muted);line-height:1.5}.pzp-hints{margin:4px 16px;padding:10px;background:var(--ds-card);border-radius:var(--ds-radius-md);border:1px solid var(--ds-gold)}.pzp-hint{font-size:12px;color:var(--ds-gold);padding:4px 0}.pzp-actions{display:flex;gap:8px;padding:8px 16px;justify-content:center;flex-wrap:wrap}.pzp-action-btn{padding:10px 16px;border-radius:var(--ds-radius-md);background:var(--ds-card-secondary);border:1px solid var(--border-dim);color:var(--ds-text);font-size:13px;font-weight:700;cursor:pointer;font-family:var(--ds-font);transition:background var(--ds-transition),border-color var(--ds-transition),transform .1s}.pzp-action-btn:hover{background:var(--ds-card);border-color:var(--ds-card-border)}.pzp-action-btn:active{transform:scale(.97)}.pzp-action-btn:focus-visible{outline:2px solid var(--ds-primary);outline-offset:2px}.pzp-action-btn--hint{background:transparent;border-color:var(--ds-gold);color:var(--ds-gold)}.pzp-action-btn--hint:hover{background:var(--ds-card)}.pzp-action-btn--back{background:transparent;border-color:var(--ds-primary);color:var(--ds-primary)}.pzp-action-btn--back:hover{background:var(--ds-primary-light)}@media(min-width:768px){.pzp-board-wrap{padding:16px}.pzp-board-area{width:100%;max-width:440px}.pzp-lore,.pzp-status,.pzp-hints,.pzp-actions,.pzp-replay-bar{max-width:500px;margin-left:auto;margin-right:auto}}.pzp-success-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#0000;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);transition:background .4s,backdrop-filter .4s;pointer-events:none}.pzp-success-overlay.show{background:#0009;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:all}.pzp-confetti-particle{position:absolute;width:8px;height:8px;border-radius:2px;animation:pzp-confetti-fall 2s ease-out forwards;opacity:0}@keyframes pzp-confetti-fall{0%{transform:translateY(0) rotate(0) scale(1);opacity:1}to{transform:translateY(120vh) rotate(720deg) scale(.3);opacity:0}}@keyframes pzp-bounce{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}.pzp-replay-bar{display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 16px;margin:4px 16px;background:#d4af3714;border:1px solid rgba(212,175,55,.2);border-radius:10px;font-size:.82rem;color:#d4af37;font-weight:600;animation:pzp-replay-pulse 1.5s ease-in-out infinite}@keyframes pzp-replay-pulse{0%,to{opacity:.8}50%{opacity:1}}.pzp-replay-bar button{padding:6px 14px;border-radius:8px;border:1px solid rgba(212,175,55,.3);background:#d4af3726;color:#d4af37;font-size:.78rem;font-weight:700;cursor:pointer;font-family:var(--ds-font)}.mini-board-canvas{border:1px solid var(--border-dim);background:#f5e6c8}.pzp-skeleton{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px}.pzp-skeleton-bar{height:16px;border-radius:8px;background:linear-gradient(90deg,var(--bg-card2) 25%,var(--bg-card) 50%,var(--bg-card2) 75%);background-size:200% 100%;animation:pzp-shimmer 1.5s ease-in-out infinite}.pzp-skeleton-bar--title{width:200px}.pzp-skeleton-bar--subtitle{width:260px}.pzp-skeleton-bar--btn{width:80px;height:36px;border-radius:10px}.pzp-skeleton-bar--btn-wide{width:100px}.pzp-skeleton-actions{display:flex;gap:8px}.pzp-skeleton-board{width:280px;height:310px;border-radius:12px;background:linear-gradient(90deg,var(--bg-card2) 25%,var(--bg-card) 50%,var(--bg-card2) 75%);background-size:200% 100%;animation:pzp-shimmer 1.5s ease-in-out infinite}@keyframes pzp-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.pzl-scroll{padding:0;padding-bottom:max(96px,env(safe-area-inset-bottom))}.pzl-stats-bar{display:flex;gap:12px;padding:8px 16px;justify-content:center}.pzl-stat{display:flex;flex-direction:column;align-items:center;padding:8px 16px;background:var(--bg-card2);border-radius:10px;min-width:70px}.pzl-stat-val{font-size:18px;font-weight:800;color:var(--ds-text)}.pzl-stat-label{font-size:10px;color:var(--ds-text-muted);margin-top:2px}.pzl-search-row{display:flex;gap:8px;padding:8px 16px}.pzl-search-input{flex:1;padding:10px 14px;border-radius:10px;border:1px solid var(--border-dim);background:var(--bg-card2);color:var(--ds-text);font-size:13px;font-family:var(--ds-font);outline:none;transition:border-color .2s}.pzl-search-input:focus{border-color:var(--ds-primary);box-shadow:0 0 0 3px #8b1e1e14}.pzl-search-btn{padding:10px 16px;border-radius:10px;background:var(--ds-primary);color:#fff;border:none;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--ds-font);transition:background .18s,transform .1s}.pzl-search-btn:hover{background:var(--ds-primary-hover)}.pzl-search-btn:active{transform:scale(.97)}.pzl-cat-row{display:flex;gap:6px;padding:4px 16px;overflow-x:auto;scrollbar-width:none}.pzl-cat-row::-webkit-scrollbar{display:none}.pzl-cat-tab.active{background:var(--ds-primary);border-color:var(--ds-primary);color:#fff}.pzl-loc-row{display:flex;gap:6px;padding:4px 16px;overflow-x:auto;scrollbar-width:none}.pzl-loc-row::-webkit-scrollbar{display:none}.pzl-loc-btn.active{background:#c8960a33;border-color:var(--ds-gold);color:var(--ds-gold)}.pzl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));gap:12px;padding:12px 16px}.pzl-card-header{display:flex;justify-content:space-between;align-items:center}.pzl-card-diff{font-size:11px}.pzl-solved-badge{font-size:14px}.pzl-card-board-wrap{display:flex;justify-content:center;margin:6px 0}.pzl-card-title{font-size:15px;font-weight:800;color:var(--ds-text);font-family:var(--ds-font-serif)}.pzl-card-desc{font-size:12px;color:var(--ds-text-muted);line-height:1.5}.pzl-card-meta{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:6px}.pzl-card-loc{font-size:11px;color:var(--ds-gold);font-weight:600}.pzl-card-plays{font-size:10px;color:var(--ds-text-muted)}.pzl-loading-msg{text-align:center;padding:40px;color:var(--ds-text-muted);font-size:14px}.pzl-pagination{display:flex;justify-content:center;align-items:center;gap:16px;padding:16px}.pzl-page-btn{padding:8px 16px;border-radius:8px;background:var(--bg-card2);border:1px solid var(--border-dim);color:var(--ds-text);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--ds-font);transition:background .18s,border-color .18s,transform .1s}.pzl-page-btn:hover:not(:disabled){background:var(--bg-card);border-color:var(--ds-card-border)}.pzl-page-btn:active:not(:disabled){transform:scale(.97)}.pzl-page-btn:disabled{opacity:.4;cursor:not-allowed}.pzl-page-info{font-size:13px;color:var(--ds-text-muted)}.pzl-stat-val--green{color:var(--ds-green)}.pzl-stat-val--gold{color:var(--ds-gold);display:flex;align-items:center;gap:4px}.pzl-cat-icon{margin-right:4px}@media(min-width:768px){.pzl-stats-bar,.pzl-search-row,.pzl-cat-row,.pzl-loc-row,.pzl-grid,.pzl-pagination,.pzl-loading-msg{max-width:800px;margin-left:auto;margin-right:auto}.pzl-cat-row,.pzl-loc-row{justify-content:center}}.kp-scroll{padding:0;padding-bottom:max(96px,env(safe-area-inset-bottom))}.kp-section-label{margin:12px 16px 0}.kp-cta-btn{margin:16px 16px 0;background:#c8960a!important}.kpd-empty-state{text-align:center;padding:40px;color:var(--ds-text-muted)}.kp-hero{margin:12px 16px;padding:28px 24px;background:linear-gradient(145deg,#2c1810,#1a0f08 40%,#3a1a10);border-radius:18px;border:1.5px solid rgba(212,175,55,.25);position:relative;overflow:hidden;text-align:center}.kp-hero:before{content:"";position:absolute;top:-30%;left:-30%;width:200%;height:200%;background:radial-gradient(ellipse at 30% 20%,rgba(212,175,55,.06) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(194,48,48,.04) 0%,transparent 50%);pointer-events:none}.kp-hero-icon{display:flex;justify-content:center;margin-bottom:12px;position:relative;z-index:1}.kp-hero-title{font-family:var(--ds-font-serif);font-size:1.5rem;font-weight:800;color:#d4af37;margin-bottom:4px;letter-spacing:2px;position:relative;z-index:1}.kp-hero-sub{font-size:.82rem;color:#ffffffb3;line-height:1.5;position:relative;z-index:1}.kp-filter{display:flex;gap:8px;padding:0 16px;margin:12px 0 0;overflow-x:auto;scrollbar-width:none}.kp-filter::-webkit-scrollbar{display:none}.kp-filter-btn{flex-shrink:0;padding:7px 14px;border-radius:20px;border:1px solid var(--border-dim);background:var(--ds-card);color:var(--ds-text-muted);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s}.kp-filter-btn.active{background:var(--ds-gold);color:#1a0f08;border-color:var(--ds-gold)}.kp-filter-btn:hover:not(.active){border-color:var(--ds-gold);color:var(--ds-gold)}.kp-books{display:grid;grid-template-rows:repeat(3,1fr);grid-auto-flow:column;grid-auto-columns:240px;gap:12px;padding:4px 16px 16px;margin-top:12px;overflow-x:auto;scroll-snap-type:x mandatory}.kp-books::-webkit-scrollbar{height:6px}.kp-books::-webkit-scrollbar-track{background:#0000001a;border-radius:10px;margin:0 16px}.kp-books::-webkit-scrollbar-thumb{background:#d4af3766;border-radius:10px}.kp-book-card{width:100%;scroll-snap-align:start;display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--ds-card);border:1px solid var(--border-dim);border-radius:14px;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;text-align:left}.kp-book-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001f;border-color:var(--ds-gold)}.kp-book-card:active{transform:translateY(0)}.kp-book-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--ds-card-secondary);border:1px solid var(--border-dim)}.kp-book-info{flex:1;min-width:0}.kp-book-name{font-family:var(--ds-font-serif);font-size:.95rem;font-weight:700;color:var(--text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kp-book-name-cn{font-size:.72rem;color:var(--ds-gold);opacity:.7;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kp-book-desc{font-size:.72rem;color:var(--text-secondary);line-height:1.4;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.kp-book-meta{display:flex;align-items:center;gap:8px;font-size:.68rem;color:var(--text-tertiary)}.kp-book-tag{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;background:var(--ds-card-secondary);border:1px solid var(--border-dim);border-radius:8px;font-size:.65rem;font-weight:600;color:var(--ds-gold)}@media(min-width:768px){.kp-books,.kp-hero,.kp-filter,.kp-section-label,.kp-cta-btn,.kpd-empty-state{max-width:800px;margin-left:auto;margin-right:auto}.kp-filter{justify-content:center}}@media(max-width:360px){.kpd-banner-icon{width:48px;height:48px;border-radius:10px}.kpd-banner-name{font-size:16px}}.kpd-detail-page{overflow:hidden!important}.kpd-page-layout{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;position:relative}.kpd-header-actions{display:flex;gap:6px;align-items:center;margin-left:auto}.kpd-toggle-btn{width:36px;height:36px;border-radius:8px;border:1.5px solid rgba(212,175,55,.4);background:#d4af3714;color:#d4af37;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.kpd-toggle-btn:hover{background:#d4af3733;border-color:#d4af37}.kpd-overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:900;animation:kpd-fadeIn .2s ease}.kpd-sidebar{overflow-y:auto;scrollbar-width:thin;background:var(--ds-bg, #0f1a14);padding:12px}.kpd-drawer-close,.kpd-panel-close{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:50%;border:1.5px solid rgba(212,175,55,.4);background:#0000004d;color:#d4af37;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .2s}.kpd-drawer-close:hover,.kpd-panel-close:hover{background:#d4af3740}.kpd-banner{display:flex;gap:10px;align-items:center;padding:10px 12px;background:linear-gradient(135deg,#2c1810,#1a0f08);border-radius:10px;border:1.5px solid rgba(212,175,55,.3);margin-bottom:8px}.kpd-banner-icon{width:40px;height:40px;border-radius:8px;background:linear-gradient(135deg,#d4af3740,#8b582026);display:flex;align-items:center;justify-content:center;color:var(--ds-gold);flex-shrink:0}.kpd-banner-name{font-family:var(--ds-font-serif);font-size:14px;font-weight:800;color:var(--ds-gold)}.kpd-banner-cn{font-size:10px;color:#d4af37;font-weight:600;margin-top:1px}.kpd-banner-author{font-size:10px;color:#b8a080;margin-top:1px}.kpd-sidebar-label{font-family:var(--ds-font-serif);font-size:.68rem;font-weight:700;color:#d4af37;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;padding:2px 6px;border-bottom:1px solid rgba(212,175,55,.2)}.kpd-sidebar-ch.active{background:#d4af372e;color:var(--ds-gold);font-weight:700;border-color:#d4af3766}.kpd-sidebar-games{margin-bottom:6px}.kpd-sidebar-game-list{display:flex;flex-direction:column;gap:2px;max-height:calc(100vh - 340px);overflow-y:auto;scrollbar-width:thin}.kpd-sidebar-game{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:10px;border:1px solid transparent;background:transparent;cursor:pointer;transition:all .15s;text-align:left;font-family:var(--ds-font);width:100%}.kpd-sidebar-game:hover{background:#d4af370f;border-color:#d4af3726}.kpd-sidebar-game.active{background:#d4af371f;border-color:var(--ds-gold)}.kpd-sidebar-game canvas{border-radius:4px;flex-shrink:0}.kpd-sidebar-game-info{flex:1;min-width:0}.kpd-sidebar-game-title{font-size:.7rem;font-weight:700;color:var(--ds-text);line-height:1.25;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.kpd-sidebar-game.active .kpd-sidebar-game-title{color:var(--ds-gold)}.kpd-sidebar-game-meta{display:flex;align-items:center;gap:6px;margin-top:2px;font-size:.62rem}.kpd-sidebar-game-cat{padding:1px 5px;border-radius:4px;background:#d4af371f;color:var(--ds-gold);font-weight:700}.kpd-sidebar-back{margin-top:10px;background:#c8960a!important;font-size:.78rem!important}.kpd-main{flex:1;min-height:0;overflow-y:auto;padding:8px;padding-bottom:max(96px,env(safe-area-inset-bottom));scrollbar-width:thin;box-sizing:border-box;display:flex;flex-direction:column;align-items:center}.kpd-empty{text-align:center;padding:40px 20px;color:var(--ds-text-muted);font-size:14px}.kpd-board-hero{display:flex;flex-direction:column;align-items:center;width:100%;animation:kpd-fadeIn .3s ease}@keyframes kpd-fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.kpd-inline-header{margin-bottom:10px;text-align:center;width:100%;max-width:480px}.kpd-inline-title{font-family:var(--ds-font-serif);font-size:1.05rem;font-weight:800;color:var(--ds-text);margin-bottom:2px}.kpd-inline-meta{display:flex;align-items:center;justify-content:center;gap:10px}.kpd-inline-cat{display:inline-block;font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:4px;background:#c2303033;color:#e07050;border:1px solid rgba(194,48,48,.3)}.kpd-inline-diff{font-size:.7rem}.kpd-inline-board{display:flex;justify-content:center;align-items:center;border-radius:4px;overflow:hidden;margin:0 auto;border:3px solid #d4af37;box-shadow:0 0 0 1px #0000004d,0 4px 16px #00000040}.kpd-inline-board canvas{max-width:100%!important;height:auto!important}.kpd-inline-controls{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:10px;width:100%}.kpd-ctrl-btn{padding:8px 16px;border-radius:6px;font-size:.78rem;font-weight:700;font-family:var(--ds-font);border:2px solid #d4af37;background:#0d73771f;color:#d4af37;cursor:pointer;transition:background .2s,color .2s,transform .15s,box-shadow .2s}.kpd-ctrl-btn:hover{background:#d4af37;color:#1a0f08;transform:translateY(-2px);box-shadow:0 3px 10px #d4af374d}.kpd-ctrl-btn:active{transform:scale(.97)}.kpd-ctrl-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.kpd-ctrl-primary{background:#d4af37!important;border-color:#d4af37!important;color:#1a0f08!important}.kpd-ctrl-primary:hover{background:#e8c840!important;border-color:#e8c840!important}.kpd-commentary-panel{position:relative}.kpd-commentary-desc{font-size:.75rem;color:var(--ds-text);line-height:1.5;padding:8px 12px;background:var(--ds-card-secondary);border-radius:8px;border-left:3px solid #c23030;margin-bottom:10px}.kpd-commentary-list{display:flex;flex-direction:column;gap:4px;max-height:360px;overflow-y:auto;scrollbar-width:thin}.kpd-commentary-label{font-family:var(--ds-font-serif);font-size:.82rem;font-weight:700;color:var(--ds-text);margin-bottom:6px}.kpd-commentary-move{display:flex;align-items:flex-start;gap:10px;padding:8px 12px;border-radius:10px;border:1px solid transparent;background:transparent;text-align:left;cursor:pointer;transition:all .2s;font-family:var(--ds-font);width:100%}.kpd-commentary-move:hover{background:#d4af370f;border-color:#d4af3726}.kpd-commentary-move.active{background:#d4af371f;border-color:var(--ds-gold);box-shadow:0 0 0 1px #d4af3726}.kpd-commentary-move.played:not(.active){opacity:.6}.kpd-move-num{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:#d4af3726;color:var(--ds-gold);font-size:.68rem;font-weight:800;display:flex;align-items:center;justify-content:center}.kpd-commentary-move.active .kpd-move-num{background:var(--ds-gold);color:#1a0f08}.kpd-move-body{flex:1;min-width:0}.kpd-move-wxf{display:inline-block;font-family:JetBrains Mono,Consolas,monospace;font-size:.72rem;font-weight:700;color:var(--ds-gold);background:#d4af371a;padding:1px 6px;border-radius:4px;margin-right:6px}.kpd-move-text{font-size:.72rem;color:var(--ds-text-muted);line-height:1.4}.kpd-commentary-move.active .kpd-move-text{color:var(--ds-text)}@media(max-width:899px){.kpd-header-actions{display:flex}.kpd-inline-board{max-width:calc(100vw - 36px);width:100%}.kpd-sidebar{position:fixed;top:0;left:0;bottom:0;width:85vw;max-width:340px;z-index:1000;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);border-right:2px solid rgba(212,175,55,.3);padding:48px 12px 12px;box-shadow:none}.kpd-sidebar.kpd-sidebar-open{transform:translate(0);box-shadow:4px 0 24px #0006}.kpd-sidebar .kpd-drawer-close{display:flex}.kpd-sidebar-game-list{max-height:calc(100vh - 320px)}.kpd-commentary-panel{position:fixed;bottom:0;left:0;right:0;max-height:75vh;z-index:1000;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);background:var(--ds-card, #1a2a1e);border-top:3px solid #d4af37;border-radius:18px 18px 0 0;padding:44px 14px 20px;overflow-y:auto;box-shadow:none}.kpd-commentary-panel.kpd-commentary-open{transform:translateY(0);box-shadow:0 -4px 24px #0006}.kpd-commentary-panel .kpd-panel-close{display:flex}.kpd-commentary-list{max-height:50vh}.kpd-main{padding:6px}.kpd-inline-header{margin-bottom:6px}.kpd-inline-title{font-size:.9rem}.kpd-ctrl-btn{padding:6px 12px;font-size:.72rem}}@media(min-width:900px){.kpd-header-actions{display:none}.kpd-drawer-close,.kpd-panel-close,.kpd-overlay-backdrop{display:none!important}.kpd-page-layout{display:grid;grid-template-columns:280px 1fr 320px;height:100%;overflow:hidden}.kpd-page-layout:not(:has(.kpd-commentary-panel)){grid-template-columns:280px 1fr}.kpd-sidebar{overflow-y:auto;scrollbar-width:thin;height:100%;border-right:2px solid rgba(212,175,55,.25);padding:12px;background:#0000001f;transform:none!important;position:relative!important}.kpd-sidebar-game-list{max-height:none;overflow-y:auto;scrollbar-width:thin}.kpd-main{overflow-y:auto;scrollbar-width:thin;height:100%;padding:16px 24px;display:flex;flex-direction:column;align-items:center}.kpd-board-hero{display:flex;flex-direction:column;align-items:center;width:100%;max-width:720px}.kpd-inline-board{width:100%;max-width:680px;aspect-ratio:1 / 1}.kpd-inline-controls{max-width:680px}.kpd-commentary-panel{position:relative!important;transform:none!important;background:#0000000f!important;border:none!important;border-radius:0!important;padding:16px 14px!important;box-shadow:none!important;max-height:none!important;overflow-y:auto;scrollbar-width:thin;height:100%;border-left:2px solid rgba(212,175,55,.25)!important}.kpd-commentary-list{max-height:none;overflow-y:visible}}.cfm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:cfmFadeIn .18s ease}.cfm-dialog{width:min(380px,calc(100vw - 48px));background:var(--ds-card);border:2px solid var(--ds-card-border);border-radius:var(--ds-radius-xl);box-shadow:var(--ds-shadow-lg),0 0 40px #0000004d;padding:28px 24px 20px;animation:cfmPop .2s ease}.cfm-title{margin:0 0 8px;font-family:var(--ds-font);font-size:1.05rem;font-weight:800;color:var(--ds-text);text-align:center;letter-spacing:.3px}.cfm-message{margin:0 0 20px;font-size:.88rem;color:var(--ds-text-muted);text-align:center;line-height:1.5}.cfm-actions{display:flex;gap:10px;justify-content:center}.cfm-btn{flex:1;padding:11px 18px;border-radius:var(--ds-radius-md);font-family:var(--ds-font);font-weight:700;font-size:.88rem;letter-spacing:.3px;cursor:pointer;transition:background .18s,transform .1s;border:none}.cfm-btn:active{transform:scale(.97)}.cfm-btn-cancel{background:transparent;color:var(--ds-text-muted);border:2px solid var(--ds-border)}.cfm-btn-cancel:hover{background:#0000000a}.cfm-btn-confirm{background:var(--ds-primary);color:#fff;box-shadow:0 2px 8px #8b1e1e4d}.cfm-btn-confirm:hover{background:var(--ds-primary-hover)}.cfm--danger .cfm-title{color:var(--ds-red-dot)}.cfm-btn-confirm.cfm--danger{background:var(--ds-red-dot);box-shadow:0 2px 8px #c0392b59}.cfm-btn-confirm.cfm--danger:hover{background:#a93226}.cfm--warning .cfm-title{color:#e67e22}.cfm-btn-confirm.cfm--warning{background:#e67e22;box-shadow:0 2px 8px #e67e2259}.cfm-btn-confirm.cfm--warning:hover{background:#d35400}[data-theme=dark] .cfm-btn-cancel{border-color:var(--border-dim)}[data-theme=dark] .cfm-btn-cancel:hover{background:#ffffff0d}[data-theme=premium] .cfm-btn-confirm{background:var(--btn-cta-bg)}@keyframes cfmFadeIn{0%{opacity:0}to{opacity:1}}@keyframes cfmPop{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.skel{background:var(--ds-card-secondary, #eee);border-radius:var(--ds-radius-sm);position:relative;overflow:hidden}.skel:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.25) 50%,transparent 100%);animation:skelShimmer 1.5s ease-in-out infinite}[data-theme=dark] .skel{background:#ffffff0f}[data-theme=dark] .skel:after{background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.08) 50%,transparent 100%)}[data-theme=premium] .skel{background:#7ecfb014}[data-theme=premium] .skel:after{background:linear-gradient(90deg,transparent 0%,rgba(126,207,176,.1) 50%,transparent 100%)}.skel-text{height:14px;border-radius:4px}.skel-circle{border-radius:50%;flex-shrink:0}.skel-rect{border-radius:var(--ds-radius-md)}.skel-card{border-radius:var(--ds-radius-lg);overflow:hidden;border:2px solid var(--ds-card-border)}.skel-group{display:flex;flex-direction:column;gap:8px}.skel-row{display:flex;align-items:center;gap:12px;padding:8px 0}@keyframes skelShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.es-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px;text-align:center;gap:8px}.es-icon{font-size:2rem;opacity:.4;margin-bottom:4px}.es-title{font-size:.92rem;font-weight:700;color:var(--ds-text-muted);letter-spacing:.3px}.es-message{font-size:.82rem;color:var(--ds-text-light);margin:0;max-width:280px;line-height:1.5}.es-action{margin-top:8px}
