@import"https://fonts.googleapis.com/css2?family=Anton&family=Baloo+2:wght@700;800&family=Bangers&family=Bebas+Neue&family=Fredoka:wght@400;500;600;700&family=Montserrat:wght@400;500;600;700;800&family=Nunito:wght@400;500;600;700;800&family=Orbitron:wght@400;600;700;800&family=Poppins:wght@400;500;600;700;800&family=Press+Start+2P&display=swap";:root{--primary-50: #e6f3ff;--primary-100: #b3d9ff;--primary-200: #80bfff;--primary-300: #4da6ff;--primary-400: #1a8cff;--primary-500: #0073e6;--primary-600: #005cb3;--primary-700: #004580;--accent-50: #ffe6e6;--accent-100: #ffb3b3;--accent-200: #ff8080;--accent-300: #ff4d4d;--accent-400: #ff1a1a;--accent-500: #e60000;--accent-600: #b30000;--accent-700: #800000;--success-500: #00c853;--warning-500: #ffab00;--white: #ffffff;--black: #1a1a1a;--gray-50: #fafafa;--gray-100: #f5f5f5;--gray-200: #e5e5e5;--gray-300: #d4d4d4;--gray-400: #a3a3a3;--gray-500: #737373;--gray-600: #525252;--gray-700: #404040;--gray-800: #262626;--landing-nav-height: 72px;--landing-logo-height: 64px}.landing-section{padding:clamp(48px,8vw,88px) 0}.landing-section.gray{background:var(--gray-50)}.landing-section.primary{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-700) 100%);color:#fff}.landing-section-badge{display:inline-flex;align-items:center;gap:6px;background:var(--primary-50);color:var(--primary-600);padding:7px 18px;border-radius:50px;font-weight:700;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}.landing-section-title{font-family:Fredoka,sans-serif;font-size:clamp(1.75rem,5vw,2.75rem);font-weight:700;color:var(--black);margin-bottom:14px;line-height:1.2}.landing-section-title span{color:var(--primary-500)}.landing-section-subtitle{font-size:clamp(.95rem,2.5vw,1.15rem);color:var(--gray-600);max-width:560px;margin:0 auto 44px;line-height:1.6}.landing-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 32px;font-family:Nunito,sans-serif;font-size:1.1rem;font-weight:700;border:none;border-radius:16px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.landing-btn-primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;box-shadow:0 6px 0 var(--primary-700),0 10px 20px #0073e64d}.landing-btn-primary:hover{transform:translateY(-3px);box-shadow:0 9px 0 var(--primary-700),0 15px 30px #0073e666}.landing-btn-accent{background:linear-gradient(135deg,var(--accent-500),var(--accent-600));color:#fff;box-shadow:0 6px 0 var(--accent-700),0 10px 20px #e600004d}.landing-btn-accent:hover{transform:translateY(-3px);box-shadow:0 9px 0 var(--accent-700),0 15px 30px #e6000066}.landing-btn-white{background:#fff;color:var(--primary-600);box-shadow:0 6px 0 var(--gray-300),0 10px 20px #0000001a}.landing-btn-white:hover{transform:translateY(-3px);box-shadow:0 9px 0 var(--gray-300),0 15px 30px #00000026}.landing-card{background:#fff;border-radius:24px;padding:40px 32px;text-align:center;border:2px solid var(--gray-200);transition:all .3s ease;position:relative;overflow:hidden}.landing-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-500),var(--accent-500));transform:scaleX(0);transition:transform .3s ease}.landing-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px -10px #0003;border-color:var(--primary-200)}.landing-card:hover:before{transform:scaleX(1)}.landing-card-icon{width:80px;height:80px;margin:0 auto 24px;background:var(--primary-50);border-radius:24px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;transition:all .3s ease}.landing-card:hover .landing-card-icon{transform:scale(1.1) rotate(5deg);background:var(--primary-100)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-float{animation:float 3s ease-in-out infinite}.animate-bounce{animation:bounce 2s ease-in-out infinite}.animate-wiggle{animation:wiggle 2s ease-in-out infinite}.animate-slideInUp{animation:slideInUp .6s ease}.landing-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}.landing-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}.landing-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}@media(max-width:968px){.landing-grid-2,.landing-grid-3,.landing-grid-4{grid-template-columns:1fr}.landing-section{padding:60px 0}}@media(max-width:768px){:root{--landing-nav-height: 64px;--landing-logo-height: 56px}}@media(max-width:480px){:root{--landing-nav-height: 60px;--landing-logo-height: 52px}}.landing-nav-logo{height:var(--landing-logo-height);width:auto;display:block;-o-object-fit:contain;object-fit:contain}.floating-element{background:#fff;border-radius:20px;padding:16px 20px;box-shadow:0 10px 25px -5px #0000001a;display:flex;align-items:center;gap:12px;font-weight:700;color:var(--black);position:absolute}.floating-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.floating-icon.blue{background:var(--primary-100)}.floating-icon.gold{background:#fff3cd}.floating-icon.green{background:#d4edda}:root{--section-pad: clamp(48px, 8vw, 88px);--side-pad: clamp(16px, 5vw, 40px)}.landing-root{overflow-x:hidden}.landing-section-container{max-width:1200px;margin:0 auto;padding:0 var(--side-pad)}.landing-hero-section{padding-top:calc(var(--landing-nav-height, 64px) + 32px);padding-bottom:60px;position:relative;overflow:hidden}.landing-hero-grid{display:flex;flex-direction:column;align-items:center;text-align:center;gap:32px}.landing-hero-text{width:100%}.landing-hero-visual{position:relative;display:flex;justify-content:center;align-items:center;order:-1}.landing-hero-mascot{width:200px;max-width:100%;height:auto;animation:float 3s ease-in-out infinite}.landing-hero-floating{display:none}.landing-hero-title{font-family:Fredoka,sans-serif;font-size:clamp(2rem,7vw,3.5rem);font-weight:700;line-height:1.1;margin-bottom:16px}.landing-hero-ctas{display:flex;flex-direction:column;gap:12px;width:100%;max-width:360px;margin:0 auto 36px}.landing-hero-ctas .landing-btn{width:100%;min-height:56px;font-size:1.05rem;justify-content:center}.landing-hero-stats{display:flex;justify-content:center;gap:clamp(20px,6vw,56px);padding:20px 24px;background:#ffffff1f;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:20px;border:1px solid rgba(255,255,255,.2);width:100%;max-width:440px;margin:0 auto;flex-wrap:nowrap}.landing-stat-num{font-family:Fredoka,sans-serif;font-size:clamp(1.5rem,5vw,2.2rem);font-weight:700;line-height:1;text-align:center}.landing-stat-lbl{font-size:.82rem;opacity:.75;margin-top:3px;text-align:center}.landing-cta-title{font-family:Fredoka,sans-serif;font-size:clamp(1.8rem,5.5vw,3rem);font-weight:700;color:#fff;margin-bottom:16px;line-height:1.15}.landing-cta-btns{display:flex;flex-direction:column;gap:12px;align-items:center;margin-bottom:20px}.landing-cta-btns .landing-btn{width:100%;max-width:300px;min-height:56px;font-size:1.05rem}.landing-games-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.landing-btn-ghost{background:#ffffff26;color:#fff;border:2px solid rgba(255,255,255,.4);box-shadow:none}.landing-btn-ghost:hover{background:#ffffff40;transform:translateY(-2px)}.landing-mobile-drawer{position:fixed;top:var(--landing-nav-height, 64px);left:0;right:0;background:#002e55f7;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:999;padding:24px var(--side-pad) 32px;display:flex;flex-direction:column;gap:4px;transform:translateY(-110%);opacity:0;transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .35s;pointer-events:none}.landing-mobile-drawer.open{transform:translateY(0);opacity:1;pointer-events:all}.landing-mob-link{color:#ffffffe6;font-weight:700;font-size:1.05rem;padding:14px 16px;border-radius:12px;background:none;border:none;cursor:pointer;text-align:left;width:100%;min-height:48px;transition:background .2s;font-family:inherit}.landing-mob-link:hover,.landing-mob-link:focus-visible{background:#ffffff1a}.landing-mob-cta{margin-top:12px;display:flex;flex-direction:column;gap:10px}.landing-mob-cta .landing-btn{width:100%;min-height:54px;font-size:1.05rem}.landing-mob-lang{margin-top:8px;display:flex;align-items:center;gap:10px;padding:12px 16px;color:#ffffffb3;font-size:.9rem}.landing-mob-lang-select{flex:1;padding:8px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.3);background:#00000040;color:#fff;font-weight:600;font-size:.9rem;cursor:pointer;font-family:inherit}.landing-navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--landing-nav-height, 64px);background:transparent;box-shadow:none;border-bottom:1px solid transparent;backdrop-filter:none;-webkit-backdrop-filter:none;transition:background .3s ease,box-shadow .3s ease,border-color .3s ease,backdrop-filter .3s ease}.landing-navbar.scrolled{background:#ffffffad;border-bottom-color:#0f172a1f;box-shadow:0 6px 24px #0f172a14;backdrop-filter:saturate(155%) blur(14px);-webkit-backdrop-filter:saturate(155%) blur(14px)}html[data-theme=dark] .landing-navbar.scrolled{background:#081228a3;border-bottom-color:#94a3b83d;box-shadow:0 8px 28px #0000006b;backdrop-filter:saturate(145%) blur(14px);-webkit-backdrop-filter:saturate(145%) blur(14px)}.landing-nav-btn{background:transparent;border:none;color:#ffffffeb;font-weight:700;font-size:.95rem;cursor:pointer;padding:6px 2px;transition:color .2s;font-family:inherit;white-space:nowrap}.landing-nav-btn:hover{color:#fff}.landing-navbar.scrolled .landing-nav-btn{color:#374151}.landing-navbar.scrolled .landing-nav-btn:hover{color:var(--primary-500, #0073e6)}html[data-theme=dark] .landing-navbar.scrolled .landing-nav-btn{color:#ffffffe6}html[data-theme=dark] .landing-navbar.scrolled .landing-nav-btn:hover{color:#fff}.landing-nav-lang{padding:7px 10px;border-radius:10px;border:1.5px solid rgba(255,255,255,.35);background:#0003;color:#fff;font-weight:700;font-size:.85rem;cursor:pointer;font-family:inherit;transition:border-color .3s,background .3s,color .3s}.landing-navbar.scrolled .landing-nav-lang{border-color:#0f172a24;background:#ffffff94;color:#1f2937}html[data-theme=dark] .landing-navbar.scrolled .landing-nav-lang{border-color:#94a3b83d;background:#0f172a85;color:#f8fafcf2}.landing-nav-links{display:none;align-items:center;gap:28px}.landing-nav-right{display:none;align-items:center;gap:12px}.landing-ham-btn{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:10px;border-radius:8px;transition:background .2s}.landing-ham-btn:hover{background:#ffffff1a}.landing-ham-btn span{display:block;width:24px;height:3px;border-radius:2px;background:#fff;transition:transform .3s,opacity .3s,background .3s}.landing-navbar.scrolled .landing-ham-btn span{background:#374151}html[data-theme=dark] .landing-navbar.scrolled .landing-ham-btn span{background:#ffffffe6}.landing-ham-btn.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}.landing-ham-btn.open span:nth-child(2){opacity:0;transform:scaleX(0)}.landing-ham-btn.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}@media(min-width:480px){.landing-hero-ctas{flex-direction:row;max-width:none;margin:0 0 36px}.landing-hero-ctas .landing-btn{width:auto}.landing-cta-btns{flex-direction:row;justify-content:center}.landing-cta-btns .landing-btn{width:auto;max-width:none}}@media(min-width:768px){.landing-nav-links,.landing-nav-right{display:flex}.landing-ham-btn{display:none}.landing-hero-section{padding-top:calc(var(--landing-nav-height, 72px) + 88px);padding-bottom:80px}.landing-hero-grid{flex-direction:row;text-align:left;align-items:center;gap:56px}.landing-hero-text{flex:1;min-width:0;order:0}.landing-hero-visual{order:1;flex-shrink:0}.landing-hero-mascot{width:280px}.landing-hero-floating{display:flex}.landing-hero-ctas{margin:0 0 36px}.landing-hero-stats{margin:0;max-width:none;width:auto}}@media(min-width:900px){.landing-games-grid{grid-template-columns:repeat(4,1fr);gap:20px}.landing-grid-3{grid-template-columns:repeat(3,1fr)}.landing-hero-mascot{width:320px}}@media(min-width:1024px){.landing-hero-mascot{width:370px}.landing-grid-4{grid-template-columns:repeat(4,1fr)}}@media(max-width:899px){.landing-grid-2,.landing-grid-3{grid-template-columns:1fr;gap:20px}.landing-grid-4{grid-template-columns:repeat(2,1fr);gap:16px}}@media(max-width:480px){.landing-grid-4{grid-template-columns:1fr}}.cookie-banner{position:fixed;left:50%;bottom:20px;transform:translate(-50%);width:min(1100px,96vw);background:var(--bg-card);border:2px solid var(--border-color);border-radius:18px;box-shadow:var(--shadow-lg);padding:18px 20px;z-index:1200;display:flex;flex-direction:column;gap:14px}.cookie-banner-content{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap}.cookie-banner-title{font-family:var(--font-display);font-weight:700;font-size:1.1rem;margin-bottom:6px}.cookie-banner-text{color:var(--text-secondary);max-width:540px;margin:0}.cookie-banner-actions{display:flex;gap:10px;flex-wrap:wrap}.cookie-banner-settings{border-top:1px dashed var(--border-color);padding-top:14px;display:flex;flex-direction:column;gap:12px}.cookie-setting{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.cookie-setting-title{font-weight:700}.cookie-setting-text{color:var(--text-secondary);font-size:.9rem}.cookie-toggle{display:inline-flex;align-items:center;gap:8px;font-weight:600}.cookie-toggle input{width:18px;height:18px}.cookie-banner-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.cookie-banner-link{color:var(--primary-600);font-weight:600;text-decoration:none}.cookie-banner-link:hover{text-decoration:underline}@media(max-width:768px){.cookie-banner{bottom:12px;padding:16px}.cookie-banner-actions,.cookie-banner-footer,.cookie-banner-actions .btn,.cookie-banner-footer .btn{width:100%}}.student-access-page,.student-shell{font-family:var(--font-sans);color:var(--text-primary)}.student-access-page{min-height:100dvh;background:var(--bg-primary);padding:24px 20px 40px;position:relative;overflow:hidden}.student-access-page:before{content:"";position:fixed;inset:-10%;background:radial-gradient(circle at 10% 10%,rgba(0,115,230,.16),transparent 55%),radial-gradient(circle at 85% 20%,rgba(230,0,0,.08),transparent 60%),radial-gradient(circle at 20% 80%,rgba(0,115,230,.1),transparent 55%),radial-gradient(circle at 80% 90%,rgba(255,197,53,.08),transparent 60%);opacity:.8;pointer-events:none;z-index:-1}.student-access-hero{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-700) 100%);border-radius:var(--radius-xl);padding:22px 24px;color:#fff;box-shadow:var(--shadow-lg);margin-bottom:24px;display:flex;align-items:center;justify-content:space-between;gap:16px;position:relative;overflow:hidden}.student-access-hero.small{padding:18px 20px}.student-access-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top,rgba(255,255,255,.22),transparent 65%);opacity:.7}.student-access-hero-content{position:relative;z-index:1;display:grid;gap:6px}.student-access-brand{display:inline-flex;align-items:center;gap:10px;margin-bottom:2px}.student-access-brand img{width:150px;height:auto;-o-object-fit:contain;object-fit:contain;background:transparent;padding:0}.student-access-brand-title{font-family:var(--font-display);font-size:1rem;font-weight:700}.student-access-brand-sub{font-size:.75rem;font-weight:700;opacity:.8}.student-access-hero h1{margin:0 0 4px;font-family:var(--font-display);font-size:1.7rem}.student-access-hero p{margin:0;opacity:.85;font-weight:600}.student-access-mode{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:800;background:#fff3;padding:4px 10px;border-radius:999px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.student-access-school{display:inline-block;margin-top:8px;font-size:.78rem;opacity:.8}.student-access-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px}.student-access-card{border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:18px;background:var(--bg-card);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:12px;font-size:1rem;font-weight:800;color:var(--text-primary);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.student-access-card:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:var(--shadow-sm)}.student-access-card.alt{background:var(--bg-secondary)}.student-access-card.student{flex-direction:column;gap:8px;align-items:center}.student-access-card .icon{font-size:1.6rem}.student-access-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.student-access-input{background:var(--bg-card);border-radius:var(--radius-lg);padding:16px;border:2px solid var(--border-color);box-shadow:var(--shadow-sm)}.student-access-input label{font-weight:800;display:block;margin-bottom:8px;color:var(--text-primary)}.student-access-input-row{display:flex;gap:10px}.student-access-input-row input{flex:1;padding:12px 14px;border-radius:var(--radius-md);border:2px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-weight:700}.student-access-input-row button{flex-shrink:0}.student-access-error,.student-access-loading{margin-top:16px;font-weight:700;color:var(--accent-500)}.student-access-loading{color:var(--text-secondary)}.student-access-hint{margin-top:10px;font-weight:700;font-size:.85rem;color:var(--text-secondary)}.student-access-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}.student-avatar{width:72px;height:72px;border-radius:50%;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;font-weight:800;overflow:hidden}.student-avatar.large{width:92px;height:92px}.student-avatar img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.student-name{font-weight:800}.student-pin-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:22px;border:2px solid var(--border-color);box-shadow:var(--shadow-md)}.student-pin-profile{display:flex;align-items:center;gap:16px;margin-bottom:16px}.student-pin-name{font-weight:800;font-size:1.2rem}.student-pin-sub{font-size:.85rem;color:var(--text-secondary)}.student-pinpad{display:grid;gap:16px}.pin-display{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.pin-display span{background:var(--bg-secondary);border-radius:var(--radius-md);padding:14px 0;text-align:center;font-weight:800;font-size:1.2rem;color:var(--text-secondary)}.pin-display span.filled{color:var(--text-primary)}.pin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.pin-key{border:none;border-radius:var(--radius-md);padding:14px 0;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;font-weight:800;font-size:1.1rem;cursor:pointer;box-shadow:0 4px 0 var(--primary-700)}.pin-key.ghost{background:var(--bg-secondary);color:var(--text-primary);box-shadow:none}.student-qr-modal{position:fixed;inset:0;background:#0f172a80;display:grid;place-items:center;z-index:999}.student-qr-card{background:var(--bg-card);border-radius:var(--radius-lg);width:min(480px,92vw);padding:16px;border:2px solid var(--border-color);box-shadow:var(--shadow-xl)}.student-qr-card header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.student-qr-card h2{margin:0;font-family:var(--font-display)}.qr-close{border:none;background:transparent;font-size:1.6rem;cursor:pointer}.student-qr-video{background:#0f172a;border-radius:var(--radius-md);overflow:hidden;aspect-ratio:4 / 3}.student-qr-video video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.student-qr-hint,.student-qr-error{margin-top:12px;font-weight:700}.student-qr-error{color:var(--accent-500)}.student-qr-actions{display:flex;justify-content:flex-end;margin-top:12px}.student-qr-card .btn{font-weight:800;border-radius:12px;padding:10px 16px;cursor:pointer}.student-qr-card .btn-outline{border:2px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary)}.student-shell{min-height:100dvh;background:var(--bg-primary);position:relative;overflow:hidden}.student-shell:before{content:"";position:fixed;inset:-10%;background:radial-gradient(circle at 15% 10%,rgba(0,115,230,.12),transparent 55%),radial-gradient(circle at 85% 20%,rgba(230,0,0,.08),transparent 60%),radial-gradient(circle at 25% 85%,rgba(0,115,230,.08),transparent 55%);opacity:.8;pointer-events:none;z-index:-1}.student-navbar.app-navbar{position:fixed;top:0;background:transparent;border-bottom:1px solid transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;--landing-nav-height: 72px}html[data-theme=dark] .student-navbar.app-navbar{background:transparent;border-bottom:1px solid transparent;box-shadow:none}.student-navbar.app-navbar.at-top,html[data-theme=dark] .student-navbar.app-navbar.at-top{background:transparent;border-bottom:1px solid transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.student-navbar.app-navbar.is-scrolled{background:#ffffffb8;border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}html[data-theme=dark] .student-navbar.app-navbar.is-scrolled{background:#0c1220c7;border-bottom:1px solid rgba(255,255,255,.08)}.student-navbar.app-navbar.app-navbar-budychess.at-top{background:transparent;border-bottom:1px solid transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.student-navbar.app-navbar.app-navbar-budychess.is-scrolled{background:#1a2a3ce0;border-bottom:1px solid rgba(176,199,228,.22);box-shadow:0 2px 16px #00000047;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.student-navbar .app-navbar-inner{padding:0 20px;gap:14px}.student-navbar-logo{height:64px;transform:none}.student-navbar-logo.is-chess{height:72px;width:auto;display:block;-o-object-fit:contain;object-fit:contain}.student-navbar-brand{display:flex;align-items:center;flex-shrink:0}.student-navbar.app-navbar-budychess .student-navbar-brand{align-self:flex-start}.student-chess-brand{display:inline-flex;align-items:center;gap:0}.student-navbar-center{display:flex;align-items:center;flex:1;min-width:0}.student-navbar-menu{gap:8px}.student-navbar-menu .app-navbar-link{border:0;background:transparent;cursor:pointer}.student-navbar-budychess-controls{min-width:0;width:100%;overflow-x:auto;scrollbar-width:thin}.student-navbar-budychess-controls .app-navbar-budychess-tabs{flex-wrap:nowrap}.student-navbar.app-navbar-budychess .student-navbar-center{justify-content:flex-end}.student-navbar.app-navbar-budychess .student-navbar-budychess-controls{width:auto;max-width:100%;margin-left:auto;justify-content:flex-end}.student-shell-topbar{padding:16px 20px;background:var(--bg-card);border-bottom:2px solid var(--border-color);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;gap:16px}.student-shell-brand{display:flex;align-items:center;gap:12px}.student-shell-logo{width:120px;height:auto;border-radius:12px;background:transparent;padding:0;-o-object-fit:contain;object-fit:contain}.student-shell-title{font-family:var(--font-display);font-size:1rem;font-weight:700}.student-shell-sub{font-size:.78rem;color:var(--text-secondary)}.student-shell-actions{display:inline-flex;align-items:center;gap:12px}.student-shell-content{padding:calc(var(--landing-nav-height, 72px) + 24px) 20px 40px}.student-shell-content--chess{padding:var(--landing-nav-height, 72px) 0 0}@media(max-width:1100px){.student-access-mode{display:none}}@media(max-width:900px){.student-navbar .app-navbar-inner{gap:10px}.student-navbar-brand{display:none}.student-navbar.app-navbar-budychess .student-navbar-brand{display:flex}.student-navbar-center{overflow-x:auto}.student-navbar-menu{width:100%}}.student-home{display:grid;gap:24px}.student-profile-hero{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-700) 100%);border-radius:var(--radius-xl);padding:24px;color:#fff;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}.student-profile-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top,rgba(255,255,255,.24),transparent 65%);opacity:.7}.student-profile-hero-inner{position:relative;z-index:1;display:grid;gap:16px}.student-profile-header{display:flex;align-items:center;gap:18px;flex-wrap:wrap}.student-profile-avatar{width:96px;height:96px;border-radius:50%;background:#ffffff2e;border:3px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.student-profile-avatar img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.student-profile-kicker{text-transform:uppercase;font-weight:800;letter-spacing:.4px;font-size:.75rem;opacity:.8}.student-profile-name{margin:0 0 4px;font-family:var(--font-display);font-size:1.8rem}.student-profile-level{font-size:.9rem;font-weight:700;opacity:.9}.student-profile-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.student-profile-badge{padding:6px 12px;border-radius:999px;background:#ffffff2e;font-size:.75rem;font-weight:800;letter-spacing:.2px}.student-profile-actions{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.student-profile-hint{font-size:.8rem;font-weight:700;color:#ffffffd9}.student-profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.student-profile-stat{background:var(--bg-card);border-radius:var(--radius-lg);padding:16px;border:2px solid var(--border-color);box-shadow:var(--shadow-sm);display:grid;gap:6px}.student-profile-stat-value{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text-primary)}.student-profile-stat-label{font-size:.8rem;font-weight:700;color:var(--text-secondary)}.student-profile-section-title{font-family:var(--font-display);font-size:1rem;font-weight:700;margin:4px 0 8px}.student-profile-settings{display:grid;gap:10px}.student-setting-item{background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:12px 14px;display:flex;align-items:center;gap:12px;text-align:left;cursor:pointer;box-shadow:var(--shadow-sm)}.student-setting-item:active{transform:translateY(1px)}.student-setting-icon{width:40px;height:40px;border-radius:12px;background:var(--bg-secondary);display:inline-flex;align-items:center;justify-content:center;color:var(--primary-600)}.student-setting-label{font-weight:800;color:var(--text-primary)}.student-setting-sub{font-size:.78rem;color:var(--text-secondary);font-weight:600}.student-setting-action{margin-left:auto;font-weight:800;color:var(--text-secondary)}.student-setting-item.danger{border-color:#e600004d}.student-setting-item.danger .student-setting-label,.student-setting-item.danger .student-setting-action{color:var(--accent-500)}@media(max-width:640px){.student-access-brand img{width:120px}.student-shell-logo{width:100px}.student-access-hero,.student-pin-profile{flex-direction:column;align-items:flex-start}.student-shell-topbar{flex-direction:column;align-items:flex-start;gap:12px}.student-shell-actions{width:100%;justify-content:space-between}.student-profile-header{flex-direction:column;align-items:flex-start}}.bb-login-page{min-height:100vh;padding:calc(var(--landing-nav-height, 64px) + 24px) 16px 48px;display:flex;align-items:flex-start;justify-content:center}.bb-login-card{width:min(520px,100%)}.bb-login-student-hint{border:1px solid var(--border-color);border-radius:14px;padding:12px;background:var(--bg-secondary);display:grid;gap:8px;font-size:.8rem}.bb-login-hint-title{font-weight:800}.bb-login-student-hint p{margin:0;color:var(--text-secondary)}.bb-password-input-wrap{position:relative}.bb-password-input-wrap .input{padding-right:44px}.bb-password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:0;background:transparent;color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;padding:4px;border-radius:8px;cursor:pointer}.bb-password-toggle:hover{color:var(--text-primary)}.bb-password-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.legal-content{max-width:900px;text-align:left}.legal-card{padding:0}.legal-card h2{font-family:var(--font-display);margin:20px 0 8px;font-size:1.25rem}.legal-card h3{margin:12px 0 6px;font-size:1rem}.legal-card p{color:var(--text-secondary);line-height:1.6}.legal-muted{color:var(--text-secondary);font-size:.85rem;margin-bottom:12px}.legal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:12px}.legal-consent{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:12px;padding:12px 16px;border-radius:14px;background:var(--bg-secondary)}@media(max-width:768px){.legal-consent{flex-direction:column;align-items:flex-start}.legal-consent .btn{width:100%}}.chess-active-match-banner{position:fixed;top:calc(var(--landing-nav-height, 54px) + 12px);right:14px;z-index:1050;isolation:isolate;display:flex;align-items:center;gap:12px;width:min(430px,calc(100vw - 28px));padding:14px 13px 14px 16px;border-radius:14px;border:1px solid rgba(132,189,255,.52);background:linear-gradient(165deg,#13385cf7,#0e2945f7);box-shadow:0 14px 30px #040a127a,0 0 0 1px #649fec33 inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.chess-active-match-banner:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:14px 0 0 14px;background:#7eb7ff;opacity:.95}.chess-active-match-banner.is-my-turn{border-color:#68e29aa3;box-shadow:0 14px 30px #040a127a,0 0 0 1px #66d8914d inset}.chess-active-match-banner.is-my-turn:before{background:#68e29a}.chess-active-match-banner.is-opponent-turn{border-color:#84bdff85}.chess-active-match-banner.is-ended{border-color:#ffa4629e;box-shadow:0 14px 30px #040a127a,0 0 0 1px #ffa46247 inset}.chess-active-match-banner.is-ended:before{background:#ffb36d}.chess-active-match-body{min-width:0;display:flex;flex:1;flex-direction:column;gap:4px}.chess-active-match-kicker{color:#e3f0ff!important;font-size:.84rem;font-weight:800;letter-spacing:.03em;text-transform:uppercase;line-height:1.2;text-shadow:0 1px 0 rgba(4,11,19,.45)}.chess-active-match-title{color:#fff!important;font-size:1.12rem;font-weight:800;line-height:1.2;text-shadow:0 1px 0 rgba(4,11,19,.45)}.chess-active-match-clock{margin-top:3px;display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;padding:4px 10px;border-radius:999px;border:1px solid rgba(134,186,255,.35);background:#050e1a47;color:#fff!important;font-size:.86rem;font-weight:700;line-height:1.2}.chess-active-match-close{margin-top:2px;display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;padding:4px 10px;border-radius:999px;border:1px solid rgba(132,189,255,.28);background:#050e1a38;color:#eaf4ff!important;font-size:.84rem;font-weight:700;line-height:1.2}.chess-active-match-close.is-warning{color:#ffd98a}.chess-active-match-close.is-danger{color:#ff9ca5}.chess-active-match-open{flex-shrink:0;min-height:38px;border-radius:11px;padding:0 14px;font-size:.8rem;font-weight:800;white-space:nowrap;box-shadow:0 4px #07366d8c}.chess-active-match-dismiss{flex-shrink:0;width:38px;height:38px;border:1px solid rgba(255,202,160,.48);border-radius:11px;background:#10263dcc;color:#fff4e7;font-size:1.3rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .18s ease,border-color .18s ease,transform .18s ease}.chess-active-match-dismiss:hover{background:#1a3957e6;border-color:#ffcaa0c7;transform:translateY(-1px)}.chess-active-match-dismiss:focus-visible{outline:2px solid rgba(255,202,160,.9);outline-offset:2px}@media(max-width:900px){.chess-active-match-banner{width:calc(100vw - 24px);right:12px;top:calc(var(--landing-nav-height, 54px) + 10px)}}.dashboard-cards{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.dashboard-card{position:relative;background:var(--bg-card);border-radius:20px;border:2px solid var(--border-color);padding:22px;display:flex;gap:16px;align-items:flex-start;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;text-align:left}.dashboard-card:before{content:"";position:absolute;top:0;left:0;height:4px;width:100%;background:linear-gradient(90deg,var(--primary-500),var(--accent-500));transform:scaleX(0);transform-origin:left;transition:transform .25s ease}.dashboard-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--primary-200)}.dashboard-card:hover:before{transform:scaleX(1)}.dashboard-card-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.dashboard-card-icon.primary{background:var(--primary-100);color:var(--primary-600)}.dashboard-card-icon.accent{background:var(--accent-100);color:var(--accent-600)}.dashboard-card-icon.gold{background:#fff3cd;color:#8a6500}.dashboard-card-title{font-family:var(--font-display);font-weight:600;margin-bottom:6px}.dashboard-card-text{color:var(--text-secondary);font-size:.95rem}.groups-page{width:100%}.groups-hero-btn{background:#fff;color:var(--primary-700);box-shadow:0 4px #00000029;border-radius:12px;font-family:var(--font-display);white-space:nowrap}.groups-hero-btn:hover{transform:translateY(-2px);box-shadow:0 6px #00000029}.groups-hero-btn:active{transform:translateY(2px);box-shadow:0 2px #00000029}.groups-main-container{width:100%;padding:24px 8px 56px;display:flex;flex-direction:column;gap:24px}.groups-stats-summary{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.mini-stat{background:var(--bg-card);border-radius:14px;border:2px solid var(--border-color);padding:16px 18px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.mini-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-200)}.mini-stat-icon{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;font-family:var(--font-display);font-size:.95rem;font-weight:700}.mini-stat-icon.blue{background:var(--primary-50);color:var(--primary-600)}.mini-stat-icon.green{background:#e6fff0;color:#078b35}.mini-stat-icon.amber{background:#fff8e6;color:#8a6500}.mini-stat-icon.red{background:var(--accent-50);color:var(--accent-600)}.mini-stat-label{color:var(--text-secondary);font-size:.82rem;font-weight:700}.mini-stat-value{font-family:var(--font-display);font-size:1.45rem;font-weight:700}.groups-filters-bar{background:var(--bg-card);border:2px solid var(--border-color);border-radius:16px;padding:14px 20px;box-shadow:var(--shadow-lg);display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}.groups-filters-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.groups-tab-btn{border:2px solid transparent;background:transparent;color:var(--text-secondary);border-radius:10px;font-weight:700;padding:9px 16px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:all .2s ease}.groups-tab-btn:hover{background:var(--bg-secondary)}.groups-tab-btn.active{background:var(--primary-50);color:var(--primary-600);border-color:var(--primary-200)}.tab-count{background:var(--primary-500);color:#fff;border-radius:999px;padding:2px 8px;font-size:.72rem;font-weight:800}.tab-count.muted{background:var(--gray-400)}.groups-filters-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.groups-search-box{display:flex;align-items:center;gap:8px;border:2px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);padding:7px 12px}.groups-search-box:focus-within{border-color:var(--primary-400)}.groups-search-icon{color:var(--text-secondary);font-family:var(--font-display);font-size:.84rem}.groups-search-box input{border:none;background:transparent;color:var(--text-primary);outline:none;min-width:180px}.groups-filter-select{border:2px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);padding:9px 12px;font-weight:700}.groups-view-toggle{display:inline-flex;border:2px solid var(--border-color);border-radius:10px;overflow:hidden}.groups-view-toggle button{border:none;padding:8px 12px;background:transparent;color:var(--text-secondary);font-family:var(--font-display);cursor:pointer}.groups-view-toggle button.active{background:var(--primary-50);color:var(--primary-600)}.groups-alert{margin-bottom:4px}.groups-grid{display:grid;gap:22px}.groups-grid.view-grid{grid-template-columns:repeat(auto-fill,minmax(325px,1fr))}.groups-grid.view-list{grid-template-columns:1fr}.group-card{background:var(--bg-card);border:2px solid var(--border-color);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.group-card:hover{transform:translateY(-6px);box-shadow:0 16px 36px #0073e629;border-color:var(--primary-300)}.group-card-banner{height:138px;position:relative;overflow:hidden}.group-card-banner-pattern{position:absolute;inset:0;opacity:.1;background-image:radial-gradient(circle at 22% 42%,#fff 2px,transparent 2px),radial-gradient(circle at 72% 32%,#fff 1.5px,transparent 1.5px),radial-gradient(circle at 50% 82%,#fff 1.2px,transparent 1.2px)}.theme-badge{position:absolute;top:12px;left:12px;z-index:2;background:#ffffffed;color:#0f172a;border-radius:999px;padding:5px 12px;display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:700}.theme-badge-dot{width:8px;height:8px;border-radius:50%}.status-badge{position:absolute;top:12px;right:12px;z-index:2;border-radius:999px;padding:4px 11px;font-size:.71rem;font-weight:800;text-transform:uppercase;letter-spacing:.02em}.status-badge.active{background:#00b846eb;color:#fff}.status-badge.archived{background:#666666eb;color:#fff}.group-card-mascot{position:absolute;right:16px;bottom:-20px;width:52px;height:52px;border-radius:50%;border:3px solid var(--border-color);background:var(--bg-card);box-shadow:0 6px 14px #00000029;display:grid;place-items:center;font-family:var(--font-display);font-weight:700}.group-card-body{padding:22px 18px 14px}.group-card-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.group-card-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700}.group-card-tags-inline{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}.group-type-tag{display:inline-flex;align-items:center;gap:5px;border-radius:8px;padding:4px 9px;font-size:.7rem;font-weight:800;text-transform:uppercase}.group-type-tag.clase{background:var(--primary-50);color:var(--primary-600)}.group-type-tag.pack{background:#fff4e6;color:#c66a00}.group-type-tag.club{background:#f3e8ff;color:#7e22ce}.group-type-tag.visibility.private{background:#eef2ff;color:#3730a3}.group-type-tag.visibility.centre{background:#e0f2fe;color:#0c4a6e}.group-type-tag.visibility.public{background:#dcfce7;color:#166534}.type-icon{width:14px;height:14px;border-radius:50%;display:inline-grid;place-items:center;border:1px solid currentColor;font-size:.62rem}.group-card-centre{margin-top:8px;color:var(--text-secondary);font-size:.88rem}.group-card-course-tags{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px}.course-tag{border:1.5px solid var(--border-color);background:var(--bg-secondary);border-radius:8px;padding:4px 9px;font-size:.74rem;font-weight:700;color:var(--text-secondary)}.group-card-stats{margin-top:14px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.group-stat{background:var(--bg-secondary);border-radius:12px;text-align:center;padding:9px 6px}.group-stat-value{font-family:var(--font-display);font-size:1.15rem;color:var(--primary-600)}.group-stat-label{font-size:.66rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);font-weight:800}.group-xp-row{margin-top:14px;display:flex;align-items:center;gap:8px}.group-xp-label{font-size:.76rem;font-weight:800;color:var(--text-secondary)}.group-xp-bar{flex:1;height:10px;border-radius:999px;border:1.5px solid var(--border-color);background:var(--bg-secondary);overflow:hidden}.group-xp-fill{height:100%;background:linear-gradient(90deg,var(--xp-gold),#ff9800);border-radius:999px}.group-xp-amount{font-size:.74rem;font-weight:800;color:#a16207}.group-card-avatars{margin-top:12px;display:flex;align-items:center}.mini-avatar{width:30px;height:30px;border-radius:50%;border:2px solid var(--bg-card);margin-left:-8px;display:grid;place-items:center;color:#fff;font-size:.65rem;font-weight:800}.mini-avatar:first-child{margin-left:0}.mini-avatar.more{background:var(--gray-300);color:var(--gray-700)}.group-card-footer{border-top:2px solid var(--border-color);padding:12px 18px 16px;display:flex;justify-content:space-between;align-items:center;gap:10px}.group-card-footer-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-card{border-radius:10px;font-size:.82rem;font-weight:700;padding:8px 14px;border:2px solid transparent;cursor:pointer}.btn-card-primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;box-shadow:0 3px 0 var(--primary-700)}.btn-card-outline{background:transparent;border-color:var(--border-color);color:var(--text-secondary)}.group-card-menu-wrap{position:relative}.card-menu-btn{width:34px;height:34px;border-radius:9px;border:2px solid var(--border-color);background:transparent;color:var(--text-secondary);cursor:pointer}.card-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:170px;border:2px solid var(--border-color);border-radius:12px;background:var(--bg-card);box-shadow:var(--shadow-lg);padding:6px;opacity:0;pointer-events:none;transform:translateY(-5px);transition:all .2s ease;z-index:20}.card-dropdown.open{opacity:1;pointer-events:auto;transform:translateY(0)}.card-dropdown-item{width:100%;text-align:left;border:none;background:transparent;color:var(--text-primary);font-weight:700;border-radius:8px;padding:9px 10px;cursor:pointer}.card-dropdown-item:hover{background:var(--primary-50);color:var(--primary-600)}.card-dropdown-item.danger{color:var(--accent-500)}.card-dropdown-divider{height:1px;background:var(--border-color);margin:5px 0}.group-card-add{border:3px dashed var(--primary-200);border-radius:20px;min-height:360px;background:var(--bg-card);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:all .2s ease}.group-card-add:hover{border-color:var(--primary-400);background:var(--primary-50);transform:translateY(-4px)}.add-icon{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;background:var(--primary-100);color:var(--primary-700);font-size:1.9rem;font-weight:700}.add-label{font-family:var(--font-display);color:var(--primary-600);font-size:1.1rem}.add-sublabel{color:var(--text-secondary);font-size:.85rem}.groups-empty{max-width:520px;margin:0 auto}.empty-state{grid-column:1 / -1;text-align:center;border:2px dashed var(--border-color);border-radius:16px;padding:52px 24px;background:var(--bg-card)}.empty-state-icon{width:74px;height:74px;margin:0 auto 14px;border-radius:50%;display:grid;place-items:center;background:var(--primary-100);color:var(--primary-700);font-family:var(--font-display);font-size:1.25rem}.empty-state-title{font-family:var(--font-display);font-size:1.25rem}.empty-state-text{margin:8px 0 16px;color:var(--text-secondary)}.groups-modal{width:min(760px,100%)}.groups-form{display:flex;flex-direction:column;gap:12px}.groups-centre-search-row{display:flex;gap:8px;flex-wrap:wrap}.groups-visibility-hint{margin-top:8px;display:block}.groups-form-actions{margin:0 -20px -20px}.selected-centre{margin-top:8px;display:flex;justify-content:space-between;align-items:center;gap:12px;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);padding:9px 12px}.centre-results{margin-top:8px;display:flex;flex-direction:column;gap:6px}.centre-option{width:100%;text-align:left;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-card);padding:8px 10px;cursor:pointer}.centre-option:hover{border-color:var(--primary-300);background:var(--primary-50)}.grades-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.grade-option{display:flex;align-items:center;gap:8px;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-card);padding:8px 10px;font-weight:700}.join-code-box{background:var(--bg-secondary);border-radius:14px;padding:12px 14px;display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:14px}.join-code-label{font-size:.82rem;color:var(--text-secondary);font-weight:700}.join-code-value{font-family:var(--font-display);font-size:1.18rem}.join-requests-list{display:flex;flex-direction:column;gap:10px}.join-request-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-card);padding:10px 12px}.join-request-alias{font-weight:800}.join-request-actions{display:flex;gap:8px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}@media(max-width:768px){.groups-main-container{padding:22px 0 48px}.groups-stats-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.groups-filters-right{width:100%}.groups-search-box{flex:1}.groups-search-box input{min-width:120px;width:100%}.groups-grid.view-grid{grid-template-columns:1fr}.group-card-footer{flex-direction:column;align-items:stretch}.group-card-footer-actions{width:100%}.join-request-item{flex-direction:column;align-items:flex-start}.join-request-actions{width:100%}}.prov-card{border-radius:12px;border:1.5px solid var(--color-border, #e5e7eb);background:var(--color-surface, #ffffff);overflow:hidden;margin-bottom:8px}.prov-card--active{border-color:#86efac;background:#f0fdf4}.prov-card--inactive{border-color:#fde68a;background:#fefce8}.prov-card--finished{border-color:var(--color-border, #e5e7eb);background:var(--color-surface-subtle, #f9fafb);opacity:.85}.prov-summary{display:flex;align-items:center;gap:10px;padding:10px 12px 10px 16px;position:relative}.prov-summary-accent{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:12px 0 0}.prov-summary-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.prov-summary-head{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.prov-summary-name{font-size:.84rem;font-weight:700;color:var(--color-text, #111827);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.prov-summary-meta{display:flex;align-items:center;gap:5px;flex-wrap:wrap}.prov-summary-pack{font-size:.75rem;color:var(--color-text-muted, #6b7280)}.prov-summary-sep{font-size:.75rem;color:var(--color-text-soft, #9ca3af)}.prov-summary-time{font-size:.72rem;color:var(--color-text-soft, #9ca3af)}.prov-panel{padding:8px 12px 8px 16px;border-top:1px solid var(--color-border, #e5e7eb);display:flex;flex-direction:column;gap:6px}.prov-panel-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-soft, #9ca3af)}.prov-progress-phase{display:flex;align-items:center;gap:6px}.prov-progress-phase-label{font-size:.72rem;color:var(--color-text-soft, #9ca3af);text-transform:uppercase;letter-spacing:.04em}.prov-progress-phase-value{font-size:.78rem;font-weight:600;color:var(--color-text, #111827)}.prov-progress-row{display:flex;align-items:center;gap:6px}.prov-progress-track{flex:1;height:6px;background:var(--color-border, #e5e7eb);border-radius:3px;overflow:hidden}.prov-progress-fill{height:100%;background:#16a34a;border-radius:3px;transition:width .4s ease}.prov-progress-fraction{font-size:.72rem;font-weight:600;color:var(--color-text, #111827);white-space:nowrap}.prov-progress-pct{font-size:.68rem;color:var(--color-text-soft, #9ca3af);white-space:nowrap}.prov-progress-empty{font-size:.72rem;color:var(--color-text-soft, #9ca3af);margin:0}.prov-events-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:5px}.prov-event-item{display:flex;align-items:flex-start;gap:7px}.prov-event-icon{flex-shrink:0;font-size:.82rem;line-height:1.4;width:18px;text-align:center}.prov-event-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.prov-event-label{font-size:.75rem;font-weight:600;color:var(--color-text, #111827)}.prov-event-desc{font-size:.7rem;color:var(--color-text-muted, #6b7280);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.prov-event-time{flex-shrink:0;font-size:.68rem;color:var(--color-text-soft, #9ca3af);white-space:nowrap}.prov-participants-counters{display:flex;gap:12px}.prov-participants-stat{display:flex;flex-direction:column;align-items:center;gap:1px;min-width:44px}.prov-participants-stat-value{font-size:1rem;font-weight:700;color:var(--color-text, #111827);line-height:1.2}.prov-participants-stat-label{font-size:.65rem;color:var(--color-text-soft, #9ca3af);text-transform:uppercase;letter-spacing:.04em}.prov-participants-stat--active .prov-participants-stat-value{color:#16a34a}.prov-participants-stat--done .prov-participants-stat-value{color:#2563eb}.prov-participants-roles{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:5px}.prov-participants-role{display:flex;align-items:center;gap:3px;padding:2px 7px 2px 5px;border-radius:20px;background:var(--color-surface-subtle, #f3f4f6);font-size:.7rem}.prov-participants-role-icon{font-size:.78rem}.prov-participants-role-name{color:var(--color-text-muted, #6b7280)}.prov-participants-role-count{font-weight:700;color:var(--color-text, #111827)}.prov-actions{display:flex;align-items:center;gap:6px;padding:8px 12px 10px 16px;border-top:1px solid var(--color-border, #e5e7eb);flex-wrap:wrap}.prov-action{padding:6px 13px;border-radius:8px;border:none;font-size:.75rem;font-weight:700;cursor:pointer;transition:opacity .15s ease,transform .1s ease;white-space:nowrap}.prov-action:hover{opacity:.88;transform:translateY(-1px)}.prov-action:active{transform:translateY(0)}.prov-action--primary{background:#16a34a;color:#fff}.prov-action--secondary{background:var(--color-primary, #0073e6);color:#fff}.prov-action--ghost{background:transparent;color:var(--color-text-muted, #6b7280);border:1.5px solid var(--color-border, #e5e7eb)}.prov-actions--bar{flex-direction:column;gap:4px}.prov-actionbar-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.prov-actionbar-feedback{display:flex;flex-wrap:wrap;gap:6px;min-height:0}.prov-action-feedback{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:20px}.prov-action-feedback--ok{background:#dcfce7;color:#15803d}.prov-action-feedback--error{background:#fee2e2;color:#dc2626}.prov-action--danger{background:transparent;color:#dc2626;border:1.5px solid #fca5a5}.prov-action--danger:hover{background:#fee2e2}.prov-action--active{background:var(--color-primary, #0073e6);color:#fff;border-color:transparent}.prov-phase-picker{display:flex;align-items:center;gap:5px}.prov-phase-picker-label{font-size:.7rem;color:var(--color-text-soft, #9ca3af);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.prov-phase-select{font-size:.75rem;font-weight:600;padding:4px 8px;border-radius:6px;border:1.5px solid var(--color-border, #e5e7eb);background:var(--color-surface, #ffffff);color:var(--color-text, #111827);cursor:pointer}.prov-phase-select:disabled{opacity:.5;cursor:default}.prov-phase-busy{font-size:.7rem;color:var(--color-text-soft, #9ca3af)}.prov-inline-form{padding:10px 12px 10px 16px;border-top:1px solid var(--color-border, #e5e7eb);display:flex;flex-direction:column;gap:8px}.prov-inline-form-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-soft, #9ca3af)}.prov-inline-form-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.prov-inline-label{font-size:.72rem;color:var(--color-text-muted, #6b7280);white-space:nowrap}.prov-inline-sep{font-size:.72rem;color:var(--color-text-soft, #9ca3af)}.prov-inline-input{font-size:.78rem;padding:4px 8px;border-radius:6px;border:1.5px solid var(--color-border, #e5e7eb);background:var(--color-surface, #ffffff);color:var(--color-text, #111827)}.prov-inline-input:focus{outline:none;border-color:var(--color-primary, #0073e6)}.prov-inline-input--short{width:64px;text-align:center}.prov-inline-input--wide{flex:1;min-width:120px}.prov-inline-textarea{font-size:.78rem;padding:6px 8px;border-radius:6px;border:1.5px solid var(--color-border, #e5e7eb);background:var(--color-surface, #ffffff);color:var(--color-text, #111827);resize:vertical;width:100%;box-sizing:border-box;font-family:inherit}.prov-inline-textarea:focus{outline:none;border-color:var(--color-primary, #0073e6)}.prov-inline-error{font-size:.72rem;color:#dc2626;margin:0}.prov-inline-form-actions{display:flex;gap:6px;flex-wrap:wrap}.prov-dialog-overlay{position:absolute;inset:0;background:#00000073;border-radius:12px;display:flex;align-items:center;justify-content:center;z-index:10}.prov-dialog{background:var(--color-surface, #ffffff);border-radius:10px;padding:18px 20px;max-width:300px;width:90%;display:flex;flex-direction:column;gap:10px;box-shadow:0 8px 24px #0000002e}.prov-dialog-header{display:flex;align-items:center;gap:8px}.prov-dialog-icon{font-size:1.1rem}.prov-dialog-title{font-size:.88rem;font-weight:700;color:var(--color-text, #111827);margin:0}.prov-dialog-body{display:flex;flex-direction:column;gap:4px}.prov-dialog-msg{font-size:.78rem;color:var(--color-text, #111827);margin:0}.prov-dialog-warn{font-size:.72rem;color:var(--color-text-muted, #6b7280);margin:0}.prov-dialog-error{font-size:.72rem;color:#dc2626;margin:0}.prov-dialog-actions{display:flex;gap:6px;flex-wrap:wrap}.pr-part-panel{padding:8px 12px 8px 16px;border-top:1px solid var(--color-border, #e5e7eb);display:flex;flex-direction:column;gap:6px}.pr-part-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.pr-part-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-soft, #9ca3af)}.pr-part-legend{display:flex;gap:8px}.pr-part-legend-item{font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:1px 5px;border-radius:3px}.pr-part-legend-item--total{background:var(--color-surface-subtle, #f3f4f6);color:var(--color-text-muted, #6b7280)}.pr-part-legend-item--active{background:#dcfce7;color:#15803d}.pr-part-legend-item--done{background:#dbeafe;color:#1d4ed8}.pr-part-rows{display:flex;flex-direction:column;gap:5px}.pr-part-row{display:grid;grid-template-columns:56px 1fr auto auto;align-items:center;gap:6px}.pr-part-row-label{font-size:.72rem;color:var(--color-text-muted, #6b7280);font-weight:600;white-space:nowrap}.pr-part-row-counters{display:flex;gap:4px}.pr-part-counter{font-size:.7rem;font-weight:700;min-width:20px;text-align:center}.pr-part-counter--total{color:var(--color-text-muted, #6b7280)}.pr-part-counter--active{color:#16a34a}.pr-part-counter--done{color:#2563eb}.pr-part-bar{height:5px;background:var(--color-border, #e5e7eb);border-radius:3px;overflow:hidden;min-width:48px;flex:1}.pr-part-bar-fill{height:100%;background:#16a34a;border-radius:3px;transition:width .4s ease}.pr-part-percent{font-size:.65rem;color:var(--color-text-soft, #9ca3af);min-width:28px;text-align:right}.pr-hl-panel{padding:8px 12px 8px 16px;border-top:1px solid var(--color-border, #e5e7eb);display:flex;flex-direction:column;gap:8px}.pr-hl-section{display:flex;flex-direction:column;gap:4px}.pr-hl-section-title{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-soft, #9ca3af)}.pr-hl-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.pr-hl-entry{display:flex;align-items:center;gap:8px}.pr-hl-entry-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.pr-hl-entry-label{font-size:.73rem;font-weight:600;color:var(--color-text, #111827);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pr-hl-entry-note{font-size:.66rem;color:var(--color-text-muted, #6b7280);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pr-hl-entry-right{display:flex;align-items:center;gap:5px;flex-shrink:0}.pr-hl-bar{width:56px;height:5px;background:var(--color-border, #e5e7eb);border-radius:3px;overflow:hidden}.pr-hl-bar-fill{height:100%;background:#16a34a;border-radius:3px;transition:width .3s ease}.pr-hl-percent{font-size:.65rem;font-weight:700;color:var(--color-text-muted, #6b7280);min-width:26px;text-align:right}.pr-hl-changes-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.pr-hl-change{display:flex;align-items:flex-start;gap:6px}.pr-hl-change-scope{flex-shrink:0;width:16px;height:16px;border-radius:4px;font-size:.6rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin-top:1px}.pr-hl-change-scope--student{background:#dbeafe;color:#1d4ed8}.pr-hl-change-scope--team{background:#fef9c3;color:#a16207}.pr-hl-change-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.pr-hl-change-label{font-size:.7rem;font-weight:600;color:var(--color-text, #111827)}.pr-hl-change-msg{font-size:.66rem;color:var(--color-text-muted, #6b7280);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pr-hl-change-time{flex-shrink:0;font-size:.63rem;color:var(--color-text-soft, #9ca3af);white-space:nowrap}.pr-pds-sheet{border-top:2px solid var(--color-primary, #0073e6);background:var(--color-surface-subtle, #f9fafb);padding:10px 12px 12px 16px;display:flex;flex-direction:column;gap:7px}.pr-hl-entry--clickable,.pr-hl-change--clickable{cursor:pointer}.pr-hl-entry--clickable:hover,.pr-hl-change--clickable:hover{background:var(--color-surface-subtle, #f9fafb);border-radius:5px}.pr-hl-entry-cta{font-size:.82rem;color:var(--color-text-soft, #9ca3af);margin-left:2px}.pr-pds-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.pr-pds-header-title{font-size:.78rem;font-weight:700;color:var(--color-text, #111827);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pr-pds-close{flex-shrink:0;background:none;border:none;cursor:pointer;padding:2px;color:var(--color-text-soft, #9ca3af);display:flex;align-items:center;border-radius:4px}.pr-pds-close:hover{color:var(--color-text, #111827);background:var(--color-border, #e5e7eb)}.pr-pds-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.pr-pds-scope-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:4px}.pr-pds-scope-badge--student{background:#dbeafe;color:#1d4ed8}.pr-pds-scope-badge--team{background:#fef9c3;color:#a16207}.pr-pds-badge{font-size:.65rem;font-weight:600;padding:2px 6px;border-radius:4px}.pr-pds-badge--active{background:#dcfce7;color:#15803d}.pr-pds-badge--done{background:#dbeafe;color:#1d4ed8}.pr-pds-badge--idle{background:var(--color-surface-subtle, #f3f4f6);color:var(--color-text-muted, #6b7280)}.pr-pds-tracked{font-size:.78rem}.pr-pds-progress{display:flex;align-items:center;gap:8px}.pr-pds-progress-bar{flex:1;height:6px;background:var(--color-border, #e5e7eb);border-radius:3px;overflow:hidden}.pr-pds-progress-fill{height:100%;background:#16a34a;border-radius:3px;transition:width .4s ease}.pr-pds-progress-label{font-size:.7rem;font-weight:600;color:var(--color-text-muted, #6b7280);white-space:nowrap;flex-shrink:0}.pr-pds-last-change{display:flex;align-items:center;gap:6px}.pr-pds-last-change-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-soft, #9ca3af)}.pr-pds-last-change-time{font-size:.7rem;font-weight:600;color:var(--color-text-muted, #6b7280)}.pr-pds-changes{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}.pr-pds-change-item{display:flex;align-items:baseline;justify-content:space-between;gap:6px}.pr-pds-change-msg{font-size:.7rem;color:var(--color-text-muted, #6b7280);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pr-pds-change-time{font-size:.63rem;color:var(--color-text-soft, #9ca3af);flex-shrink:0}.pr-pds-actions{display:flex;gap:6px;flex-wrap:wrap}.pr-pds-form{display:flex;flex-direction:column;gap:6px}.pr-pds-loading{display:flex;flex-direction:column;gap:5px}.pr-pds-skeleton{height:10px;border-radius:4px;background:var(--color-border, #e5e7eb);animation:pr-shimmer 1.2s infinite ease-in-out}.pr-pds-skeleton--short{width:60%}@keyframes pr-shimmer{0%,to{opacity:1}50%{opacity:.5}}.pr-pds-error{font-size:.72rem;color:#dc2626;margin:0}.pr-pds-success{font-size:.72rem;color:#15803d;font-weight:600;margin:0}.pr-pds-no-data{font-size:.72rem;color:var(--color-text-soft, #9ca3af);margin:0}@media(prefers-color-scheme:dark){.prov-card{background:#1f2937;border-color:#374151}.prov-card--active{background:#052e16;border-color:#166534}.prov-card--inactive{background:#1c1407;border-color:#854d0e}.prov-card--finished{background:#111827}.prov-summary-name{color:#f9fafb}.prov-summary-pack,.prov-summary-sep{color:#9ca3af}.prov-summary-time{color:#6b7280}.prov-panel{border-top-color:#374151}.prov-panel-title{color:#6b7280}.prov-progress-phase-value,.prov-progress-fraction{color:#f9fafb}.prov-progress-track{background:#374151}.prov-progress-pct,.prov-progress-empty{color:#6b7280}.prov-event-label{color:#f3f4f6}.prov-event-desc{color:#9ca3af}.prov-event-time{color:#6b7280}.prov-participants-stat-value{color:#f9fafb}.prov-participants-stat-label{color:#6b7280}.prov-participants-stat--active .prov-participants-stat-value{color:#4ade80}.prov-participants-stat--done .prov-participants-stat-value{color:#60a5fa}.prov-participants-role{background:#374151}.prov-participants-role-name{color:#9ca3af}.prov-participants-role-count{color:#f9fafb}.prov-actions{border-top-color:#374151}.prov-action--ghost{color:#9ca3af;border-color:#374151}.prov-action--danger{color:#f87171;border-color:#7f1d1d}.prov-action--danger:hover{background:#1f0808}.prov-phase-select,.prov-inline-input,.prov-inline-textarea{background:#1f2937;border-color:#374151;color:#f9fafb}.prov-inline-form{border-top-color:#374151}.prov-dialog{background:#1f2937}.prov-dialog-title,.prov-dialog-msg{color:#f9fafb}.prov-action-feedback--ok{background:#166534;color:#86efac}.prov-action-feedback--error{background:#7f1d1d;color:#fca5a5}.pr-part-panel,.pr-hl-panel{border-top-color:#374151}.pr-part-title,.pr-part-percent,.pr-hl-section-title,.pr-hl-percent,.pr-hl-change-time{color:#6b7280}.pr-part-legend-item--total{background:#374151;color:#9ca3af}.pr-part-legend-item--active{background:#14532d;color:#86efac}.pr-part-legend-item--done{background:#1e3a5f;color:#93c5fd}.pr-part-row-label,.pr-part-counter--total{color:#9ca3af}.pr-part-counter--active{color:#4ade80}.pr-part-counter--done{color:#60a5fa}.pr-part-bar,.pr-hl-bar{background:#374151}.pr-hl-entry-label,.pr-hl-change-label{color:#f3f4f6}.pr-hl-entry-note,.pr-hl-change-msg,.pr-hl-percent{color:#9ca3af}.pr-hl-change-scope--student{background:#1e3a5f;color:#93c5fd}.pr-hl-change-scope--team{background:#422006;color:#fcd34d}.pr-pds-sheet{background:#111827;border-top-color:#3b82f6}.pr-hl-entry--clickable:hover,.pr-hl-change--clickable:hover{background:#1f2937}.pr-pds-header-title,.pr-pds-progress-label,.pr-pds-last-change-time,.pr-pds-change-msg{color:#d1d5db}.pr-pds-close{color:#6b7280}.pr-pds-close:hover{color:#f9fafb;background:#374151}.pr-pds-scope-badge--student{background:#1e3a5f;color:#93c5fd}.pr-pds-scope-badge--team{background:#422006;color:#fcd34d}.pr-pds-badge--active{background:#14532d;color:#86efac}.pr-pds-badge--done{background:#1e3a5f;color:#93c5fd}.pr-pds-badge--idle{background:#374151;color:#9ca3af}.pr-pds-progress-bar,.pr-pds-skeleton{background:#374151}.pr-pds-error{color:#f87171}.pr-pds-success{color:#4ade80}.pr-pds-no-data,.pr-pds-last-change-label,.pr-pds-change-time{color:#6b7280}}.ggp-panel{border:1.5px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-card);color:var(--text-primary);overflow:hidden;box-shadow:var(--shadow-sm)}.ggp-pack-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 14px;background:linear-gradient(135deg,var(--primary-500),var(--primary-700));border-bottom:none}.ggp-pack-name{font-size:.82rem;font-weight:800;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.01em}.ggp-run-badge{flex-shrink:0;font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:999px;background:#ffffff38;color:#fff;border:1px solid rgba(255,255,255,.35)}.ggp-lock-notice{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;background:#e6a80014;border-bottom:1px solid rgba(230,168,0,.22);font-size:.75rem;font-weight:600;color:var(--text-secondary);line-height:1.4}.ggp-lock-icon{font-size:.85rem;flex-shrink:0;margin-top:1px}.ggp-section{padding:10px 14px 12px;display:flex;flex-direction:column;gap:2px;border-bottom:1px solid var(--border-color)}.ggp-section:last-of-type{border-bottom:none}.ggp-section-title{font-size:.65rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:6px;opacity:.7}.ggp-config-row{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:32px;padding:4px 0}.ggp-config-label{font-size:.78rem;font-weight:700;color:var(--text-primary);flex-shrink:0}.ggp-config-value{font-size:.76rem;font-weight:600;color:var(--text-secondary);text-align:right}.ggp-select{padding:7px 10px;border-radius:10px;border:1.5px solid var(--border-color);background:var(--bg-secondary);font-family:var(--font-sans);font-size:.78rem;font-weight:600;color:var(--text-primary);outline:none;cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease;max-width:190px}.ggp-select:focus{border-color:var(--primary-400);box-shadow:0 0 0 2px #1a8cff26}.ggp-select:disabled{opacity:.5;cursor:not-allowed}.ggp-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer;min-width:0;padding:4px 0;min-height:32px}.ggp-toggle-row--disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.ggp-toggle-label{font-size:.78rem;font-weight:700;color:var(--text-primary);flex:1 1 auto;min-width:0}.ggp-toggle-row input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:44px;height:26px;border-radius:13px;border:1.5px solid var(--border-color);background:var(--bg-secondary);cursor:pointer;position:relative;flex-shrink:0;transition:all .25s ease}.ggp-toggle-row input[type=checkbox]:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:var(--bg-card);box-shadow:0 1px 4px #00000026;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.ggp-toggle-row input[type=checkbox]:checked{background:var(--primary-500);border-color:var(--primary-500)}.ggp-toggle-row input[type=checkbox]:checked:after{transform:translate(18px);background:#fff}.ggp-toggle-row input[type=checkbox]:active:after{width:24px}.ggp-toggle-row input[type=checkbox]:checked:active:after{transform:translate(14px)}.ggp-toggle-row input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.ggp-actions{padding:10px 14px;border-top:1px solid var(--border-color);background:var(--bg-secondary);display:flex;gap:8px}.ggp-btn-reset{border:1.5px solid var(--border-color);border-radius:999px;background:var(--bg-card);color:var(--text-secondary);font-size:.72rem;font-weight:700;padding:6px 14px;cursor:pointer;transition:border-color .18s ease,color .18s ease,background .18s ease}.ggp-btn-reset:hover:not(:disabled){border-color:var(--primary-400);color:var(--primary-600);background:var(--primary-50)}.ggp-btn-reset:disabled{opacity:.5;cursor:not-allowed}.ggp-panel--empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:28px 16px;text-align:center}.ggp-empty-icon{font-size:1.6rem;margin-bottom:4px;opacity:.6}.ggp-empty-text{font-size:.85rem;font-weight:700;color:var(--text-secondary)}.ggp-empty-sub{font-size:.72rem;font-weight:600;color:var(--text-secondary);opacity:.7;max-width:220px;line-height:1.4}.ggp-panel--loading{padding:14px 16px;display:flex;flex-direction:column;gap:10px}.ggp-skeleton{height:14px;border-radius:8px;background:var(--bg-secondary);animation:ggp-shimmer 1.4s ease-in-out infinite}.ggp-skeleton--short{width:55%}@keyframes ggp-shimmer{0%,to{opacity:.6}50%{opacity:1}}.ggp-error,.ggp-no-data,.ggp-save-error{margin:0;padding:10px 14px;font-size:.75rem;font-weight:600}.ggp-error,.ggp-save-error{background:#e2505014;border-top:1px solid rgba(226,80,80,.22);color:#b02121}.ggp-no-data{color:var(--text-secondary);opacity:.75}.ggp-session-cta{display:flex;flex-direction:column;gap:0}.ggp-session-btn{width:100%;border:none;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.82rem;font-weight:800;padding:12px 16px;cursor:pointer;text-align:center;letter-spacing:.01em;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}.ggp-session-btn:active{transform:translateY(1px)}.ggp-session-btn--start{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;box-shadow:0 3px 0 var(--primary-700)}.ggp-session-btn--start:hover{transform:translateY(-1px);box-shadow:0 5px 0 var(--primary-700)}.ggp-session-btn--start:active{transform:translateY(1px);box-shadow:0 2px 0 var(--primary-700)}.ggp-session-btn--continue{background:var(--bg-card);color:var(--text-primary);border:1.5px solid var(--border-color);box-shadow:var(--shadow-sm)}.ggp-session-btn--continue:hover{border-color:var(--primary-400);color:var(--primary-600);background:var(--primary-50)}.ggp-tools-section{display:flex;flex-direction:column;gap:8px}.ggp-tools-title{font-size:.65rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);opacity:.6;padding:0 2px}html[data-theme=dark] .ggp-panel{background:var(--bg-card);border-color:var(--border-color)}html[data-theme=dark] .ggp-lock-notice{background:#e6a80012;border-bottom-color:#e6a8002e}html[data-theme=dark] .ggp-select{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-primary)}html[data-theme=dark] .ggp-toggle-row input[type=checkbox]{background:var(--bg-secondary);border-color:var(--border-color)}html[data-theme=dark] .ggp-toggle-row input[type=checkbox]:after{background:var(--bg-card)}html[data-theme=dark] .ggp-actions{background:var(--bg-secondary)}html[data-theme=dark] .ggp-btn-reset{background:var(--bg-card);border-color:var(--border-color);color:var(--text-secondary)}html[data-theme=dark] .ggp-btn-reset:hover:not(:disabled){background:#0073e61f;border-color:var(--primary-400);color:var(--primary-300)}html[data-theme=dark] .ggp-skeleton{background:var(--bg-secondary)}html[data-theme=dark] .ggp-error,html[data-theme=dark] .ggp-save-error{background:#e250501a;border-top-color:#e2505040;color:#f87171}html[data-theme=dark] .ggp-session-btn--continue{background:var(--bg-card);border-color:var(--border-color);color:var(--text-primary)}html[data-theme=dark] .ggp-session-btn--continue:hover{background:#0073e61a;border-color:var(--primary-400);color:var(--primary-300)}.group-detail-page{width:100%;overflow-x:clip}.group-detail-hero{background:var(--group-hero-gradient);padding:calc(28px + var(--landing-nav-height, 64px)) 24px 28px}.group-detail-hero-inner{max-width:760px}.group-detail-hero-pattern{position:absolute;inset:0;opacity:.16;pointer-events:none}.group-detail-hero-pattern span{position:absolute;font-size:.68rem;font-weight:800;color:#fff;letter-spacing:.09em;text-transform:uppercase}.group-detail-hero-pattern span:nth-child(1){top:16px;right:18%}.group-detail-hero-pattern span:nth-child(2){top:52px;right:9%}.group-detail-hero-pattern span:nth-child(3){top:94px;right:22%}.group-detail-chip-row{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.group-detail-chip{border-radius:999px;background:#ffffff38;border:1px solid rgba(255,255,255,.28);color:#fff;font-size:.72rem;font-weight:800;padding:5px 11px}.group-detail-hero-characters{position:absolute;right:24px;bottom:8px;z-index:2;display:flex;align-items:flex-end;gap:8px}.group-detail-hero-character{width:92px;height:92px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 6px 10px rgba(0,0,0,.22))}.group-detail-hero-character.secondary{width:72px;height:72px;opacity:.92}.group-detail-hero-stats-wrap{position:relative;z-index:1;width:100%;display:flex;justify-content:center;margin-top:14px}.group-detail-hero-stats{width:min(1160px,100%)}.group-detail-main{width:100%;max-width:none;margin:0 auto;padding:24px clamp(14px,2vw,28px) 120px;display:flex;flex-direction:column;gap:14px}.group-detail-control-bar{border:2px solid var(--border-color);border-radius:16px;background:var(--bg-card);box-shadow:var(--shadow-sm);padding:10px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.group-control-item{display:flex;flex-direction:column;gap:4px;font-size:.72rem;font-weight:800;color:var(--text-secondary)}.group-control-item select{border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);font-size:.82rem;font-weight:700;padding:7px 9px;outline:none}.group-control-summary strong{display:inline-flex;align-items:center;min-height:34px;border:1px solid var(--border-color);border-radius:10px;padding:7px 10px;background:var(--bg-secondary);color:var(--text-primary);font-size:.82rem}.group-control-open-settings-wrap{justify-content:flex-end}.group-control-open-settings{border:1px solid var(--primary-300);border-radius:10px;background:var(--primary-50);color:var(--primary-700);font-size:.82rem;font-weight:800;padding:8px 10px;cursor:pointer}.grid-size-control div{display:flex;gap:4px}.grid-size-control button{border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);width:34px;height:32px;font-weight:800;cursor:pointer}.grid-size-control button.active{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700)}.group-detail-stats{display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr))}.group-detail-stat-card{border:2px solid var(--border-color);border-radius:16px;background:var(--bg-card);padding:14px;text-align:center}.group-detail-stat-card .value{font-family:var(--font-display);font-size:1.3rem;font-weight:700}.group-detail-stat-card .label{margin-top:2px;color:var(--text-secondary);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.group-detail-hero-stats .group-detail-stat-card{background:linear-gradient(180deg,#071634d1,#081b3ec7);border-color:#7daaec61;box-shadow:inset 0 1px #ffffff14,0 10px 18px #040a1857;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.group-detail-hero-stats .group-detail-stat-card .value{color:#f7fbff}.group-detail-hero-stats .group-detail-stat-card .label{color:#e9f2ffd1}.group-detail-local-tools{border:2px solid var(--border-color);border-radius:16px;background:var(--bg-card);box-shadow:var(--shadow-sm);padding:10px;display:flex;gap:8px;overflow-x:auto}.group-detail-local-tools button{border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);font-size:.76rem;font-weight:800;padding:8px 12px;cursor:pointer;white-space:nowrap}.group-detail-local-tools button:disabled{opacity:.55;cursor:not-allowed}.group-detail-local-tools button.active{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700)}.group-detail-tabs{border:2px solid var(--border-color);border-radius:16px;background:var(--bg-card);box-shadow:var(--shadow-sm);padding:8px;display:flex;gap:8px;overflow-x:auto}.group-detail-tabs button{border:none;border-radius:10px;background:transparent;color:var(--text-secondary);font-size:.78rem;font-weight:800;padding:9px 12px;cursor:pointer;white-space:nowrap}.group-detail-tab-count{margin-left:6px;min-width:20px;height:20px;border-radius:999px;border:1px solid color-mix(in srgb,var(--border-color) 65%,var(--primary-500) 35%);background:var(--bg-secondary);color:var(--text-secondary);font-size:.68rem;font-weight:800;display:inline-flex;align-items:center;justify-content:center;line-height:1;vertical-align:middle}.group-detail-tabs button.active{background:var(--text-primary);color:var(--bg-card)}.group-detail-tabs button.active .group-detail-tab-count{background:#ffffff24;border-color:#ffffff59;color:var(--bg-card)}.group-detail-tabs button:disabled{opacity:.45;cursor:not-allowed}.group-detail-panel{border:2px solid var(--border-color);border-radius:18px;background:var(--bg-card);box-shadow:var(--shadow-sm);padding:16px}.group-detail-panel.students-layout{border:none;border-radius:0;background:transparent;box-shadow:none;padding:0}.group-detail-students-grid{display:flex;flex-wrap:wrap;justify-content:center;align-content:center;align-items:flex-start;gap:14px;padding-top:22px;min-height:clamp(300px,44vh,620px)}.group-roster-error,.group-roster-empty{flex:1 0 100%;display:flex;justify-content:center;text-align:center}.group-roster-error{margin:4px 0 8px}.group-detail-students-grid.grid-compact .group-student-card{width:92px}.group-detail-students-grid.grid-normal .group-student-card{width:116px}.group-detail-students-grid.grid-wide .group-student-card{width:138px}.group-detail-students-grid.grid-xl .group-student-card{width:160px}.group-student-card{border:2px solid var(--border-color);border-radius:16px;background:var(--bg-card);padding:48px 8px 10px;text-align:center;cursor:pointer;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease;position:relative;overflow:visible;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:154px}.group-student-card:hover{transform:translateY(-2px)}.group-student-card .attendance-indicator{position:absolute;top:8px;left:8px;width:22px;height:22px;border-radius:999px;display:grid;place-items:center;z-index:6;pointer-events:none}.group-student-card .attendance-indicator.absent{background:#ef4444;color:#fff;border:1px solid #dc2626;box-shadow:0 2px 8px #dc26264d}.group-student-card.add-student{border-style:dashed;background:var(--bg-secondary);color:var(--text-secondary);justify-content:center}.group-student-card.add-student:hover{border-color:var(--primary-300);box-shadow:0 0 0 3px #3b82f61f}.group-student-card.add-student .add-student-circle{width:46px;height:46px;border-radius:50%;background:var(--primary-50);border:2px solid var(--primary-200);color:var(--primary-600);font-size:1.6rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.group-student-card.add-student .add-student-label{font-size:.7rem;font-weight:800;color:var(--text-secondary)}.group-student-card.selected{border-color:var(--primary-500);box-shadow:0 0 0 3px #0073e61f}.group-student-card.highlight,.group-student-card.winner{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b38}.group-student-card.selected.winner,.group-student-card.selected.highlight{border-color:var(--primary-500);box-shadow:0 0 0 3px #0073e629}.group-student-card.shuffling .avatar img{animation:shuffle-blink .18s linear infinite}@keyframes shuffle-blink{0%{opacity:1}50%{opacity:.55}to{opacity:1}}.group-student-card .avatar{width:80px;height:80px;margin:0;border-radius:50%;overflow:visible;background:transparent;border:none;position:absolute;top:-30px;left:50%;transform:translate(-50%)}.group-student-card.gender-highlight{border-color:color-mix(in srgb,var(--gender-color) 45%,var(--border-color) 55%);box-shadow:0 6px 16px #0f172a1f;background:linear-gradient(180deg,color-mix(in srgb,var(--gender-color) 8%,var(--bg-card) 92%),color-mix(in srgb,var(--gender-color) 12%,var(--bg-card) 88%) 45%,color-mix(in srgb,var(--gender-color) 16%,var(--bg-card) 84%))}.group-student-card.gender-highlight.selected{border-color:var(--primary-500);box-shadow:0 0 0 3px #0073e629}.group-student-card.gender-highlight.winner,.group-student-card.gender-highlight.highlight{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b38}.group-student-card.gender-highlight.selected.winner,.group-student-card.gender-highlight.selected.highlight{border-color:var(--primary-500);box-shadow:0 0 0 3px #0073e629}.group-student-card.absent{opacity:.7;border-style:dashed;border-color:color-mix(in srgb,var(--border-color) 75%,#64748b 25%);box-shadow:none}.group-student-card.absent.selected{border-style:solid;border-color:#ef4444;box-shadow:0 0 0 3px #ef444438}.group-student-card.gender-highlight.absent.selected{border-color:#ef4444;box-shadow:0 0 0 3px #ef444438}.group-student-card.absent:hover{transform:none}.group-student-card.absent .avatar img{filter:grayscale(.26) saturate(.68) opacity(.9)}.group-student-card.absent .online-dot{display:none}.group-student-card.absent .name,.group-student-card.absent .points,.group-student-card.absent .streak{color:var(--text-secondary);text-shadow:none}.group-student-card .avatar img{width:96px;height:96px;border-radius:0;-o-object-fit:contain;object-fit:contain;position:absolute;left:50%;bottom:-4px;transform:translate(-50%);filter:drop-shadow(0 6px 10px rgba(0,0,0,.22))}.group-student-card .online-dot{position:absolute;right:-1px;bottom:2px;width:12px;height:12px;border-radius:50%;background:#16a34a;border:2px solid var(--bg-card);z-index:3}.group-student-card .avatar-medals{position:absolute;inset:0;pointer-events:none}.group-student-card .student-medal{position:absolute;width:20px;height:20px;border-radius:999px;display:grid;place-items:center;font-size:.66rem;border:1px solid rgba(255,255,255,.55);box-shadow:0 2px 7px #0000003d}.group-student-card .student-medal:nth-child(1){left:-6px;top:-4px}.group-student-card .student-medal:nth-child(2){right:-6px;top:-4px}.group-student-card .student-medal.gold{background:linear-gradient(135deg,#ffe69a,#f7b801)}.group-student-card .student-medal.red{background:linear-gradient(135deg,#ffb8b8,#ef4444)}.group-student-card .student-medal.blue{background:linear-gradient(135deg,#b8d7ff,#3b82f6)}.group-student-card .student-medal.purple{background:linear-gradient(135deg,#e7d2ff,#8b5cf6)}.group-student-card .name{font-size:.77rem;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:6px;margin-bottom:2px}.group-student-card .points{font-family:var(--font-display);font-size:.95rem;font-weight:800;color:#f7b21d;line-height:1.1;text-shadow:0 1px 1px rgba(0,0,0,.25)}.group-student-card .name.gender,.group-student-card .points.gender{color:var(--gender-color);text-shadow:none}.group-student-card .xp-bar{width:76%;margin:6px auto 0;height:5px;border-radius:999px;overflow:hidden;background:var(--border-color)}.group-student-card .xp-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#f8bf2a,#f28f24)}.group-student-card .streak{margin-top:5px;color:var(--text-secondary);font-size:.65rem;font-weight:700}.group-student-card .student-detail{margin-top:6px;display:inline-flex;align-items:center;border-radius:999px;background:var(--primary-50);border:1px solid var(--primary-200);color:var(--primary-700);font-size:.6rem;font-weight:800;padding:2px 8px}.group-achievements-panel{margin-top:14px;border:2px solid var(--border-color);border-radius:16px;background:var(--bg-card);box-shadow:var(--shadow-sm);padding:12px 12px 10px}.group-achievements-panel header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.group-achievements-panel h3{margin:0;font-size:.92rem;font-family:var(--font-display);font-weight:700}.group-achievements-panel small{color:var(--text-secondary);font-size:.75rem;font-weight:700}.group-achievements-track{display:flex;align-items:stretch;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:thin}.group-achievement-item{min-width:82px;border-radius:12px;border:1px solid var(--border-color);background:var(--bg-secondary);padding:8px 8px 7px;text-align:center;display:grid;gap:4px;justify-items:center;color:var(--text-primary)}.group-achievement-item .icon{width:34px;height:34px;border-radius:999px;display:grid;place-items:center;font-size:1rem}.group-achievement-item .label{font-size:.68rem;font-weight:800;line-height:1.1;color:inherit}.group-achievement-item.unlocked{border-color:var(--primary-200);background:var(--primary-50);color:var(--primary-700)}.group-achievement-item.unlocked .icon{background:linear-gradient(135deg,#ffe9a8,#f7bf1a);box-shadow:0 2px 8px #f7bf1a47}.group-achievement-item.locked{opacity:.58}.group-achievement-item.locked .icon{background:var(--border-color);filter:grayscale(1)}html[data-theme=dark] .group-achievements-panel{background:#0e1628f5;border-color:#78aaf099;box-shadow:0 16px 34px #0000008c}html[data-theme=dark] .group-achievements-panel h3{color:#f3f7ff}html[data-theme=dark] .group-achievements-panel small{color:#c6d7f2}html[data-theme=dark] .group-achievement-item{background:#16243cd1;border-color:#96bef099;color:#f6f9ff}html[data-theme=dark] .group-achievement-item .icon{background:#8caadc66}html[data-theme=dark] .group-achievement-item.unlocked{background:#286ed28c;border-color:#aad2ffcc;color:#fff}html[data-theme=dark] .group-achievement-item.unlocked .icon{box-shadow:0 2px 12px #f7bf1a5c}html[data-theme=dark] .group-achievement-item.locked{background:#121c30b3;border-color:#6e8ab680;opacity:1;color:#c9d7ee}html[data-theme=dark] .group-achievement-item.locked .icon{background:#6e86aa57;filter:grayscale(.25)}.group-achievements-footer{position:fixed;left:clamp(14px,2vw,28px);right:clamp(14px,2vw,28px);bottom:10px;margin-top:0;z-index:78;transition:opacity .2s ease,transform .2s ease}.group-achievements-footer.with-dock{opacity:0;transform:translateY(8px);pointer-events:none}.point-fly{position:absolute;left:50%;top:6px;transform:translate(-50%);font-family:var(--font-display);font-size:.88rem;font-weight:700;animation:point-fly .9s ease forwards;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.25)}.point-fly.plus{color:#16a34a}.point-fly.minus{color:#dc2626}@keyframes point-fly{0%{opacity:1;transform:translate(-50%) scale(1)}to{opacity:0;transform:translate(-50%,-38px) scale(1.2)}}.group-detail-list{display:flex;flex-direction:column;gap:8px}.rank-row{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-color);padding-bottom:8px}.rank-row:last-child{border-bottom:none;padding-bottom:0}.rank-row .position{width:28px;height:28px;border-radius:8px;background:var(--bg-secondary);display:grid;place-items:center;font-family:var(--font-display);font-size:.82rem}.rank-row .position.top{background:linear-gradient(135deg,gold,#d4a017);color:#3a2800}.rank-row img{width:34px;height:34px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid var(--border-color)}.rank-row .name{flex:1;font-size:.84rem;font-weight:800}.rank-row .score{font-family:var(--font-display);color:#a06e00}.group-detail-missions{display:flex;flex-direction:column;gap:10px}.group-detail-missions article{border:1px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);padding:11px 12px}.group-detail-missions header{display:flex;justify-content:space-between;gap:8px;font-size:.8rem;font-weight:800;margin-bottom:7px}.group-detail-missions .bar{height:8px;border-radius:999px;overflow:hidden;background:var(--border-color)}.group-detail-missions .bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary-500),#4da6ff)}.group-detail-missions small{display:block;margin-top:6px;color:var(--text-secondary);font-size:.72rem;font-weight:700}.group-detail-activity{display:flex;flex-direction:column;gap:8px}.group-detail-activity-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color);margin-bottom:2px}.group-detail-activity-meta{display:inline-flex;align-items:baseline;gap:8px}.group-detail-activity-meta strong{font-size:.85rem;font-weight:900}.group-detail-activity-meta small{color:var(--text-secondary);font-size:.72rem;font-weight:700}.group-detail-activity-undo{border:1px solid var(--border-color);border-radius:999px;background:var(--bg-secondary);color:var(--text-primary);display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:800;padding:6px 11px;cursor:pointer}.group-detail-activity-undo:hover{border-color:var(--primary-500);color:var(--primary-700)}.group-detail-activity-undo:disabled{opacity:.5;cursor:not-allowed}.group-detail-activity .empty-message{margin:0;color:var(--text-secondary);font-size:.82rem}.group-detail-activity article{border:1px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);padding:9px 10px;display:flex;gap:10px;align-items:center}.group-detail-activity .icon{width:30px;height:30px;border-radius:9px;background:var(--primary-50);color:var(--primary-700);font-weight:900;display:grid;place-items:center}.group-detail-activity article.activity-plus .icon{background:#dcfce7;color:#166534}.group-detail-activity article.activity-minus .icon{background:#fee2e2;color:#991b1b}.group-detail-activity .content p{margin:0;font-size:.8rem;font-weight:700}.group-detail-activity .content{flex:1;min-width:0}.group-detail-activity .content small{color:var(--text-secondary);font-size:.7rem}.group-activity-item-undo{border:1px solid var(--border-color);border-radius:999px;background:var(--bg-card);color:var(--text-primary);width:30px;height:30px;padding:0;display:grid;place-items:center;cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease}.group-activity-item-undo:hover:not(:disabled){border-color:var(--primary-500);color:var(--primary-700)}.group-activity-item-undo:disabled{opacity:.55;cursor:not-allowed}.group-detail-tools-grid{display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.group-detail-tools-grid button{border:1px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);color:var(--text-primary);font-size:.78rem;font-weight:800;padding:11px 10px;cursor:pointer}.group-detail-tools-grid button:disabled{opacity:.5;cursor:not-allowed}.group-points-dock{position:fixed;left:16px;right:16px;bottom:14px;z-index:80;border:2px solid var(--border-color);border-radius:16px;background:var(--bg-card);box-shadow:0 16px 34px #0003;padding:10px}.group-points-dock-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px;flex-wrap:wrap}.group-points-dock-head strong{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:.88rem;font-weight:800}.group-points-dock-count{min-width:30px;height:30px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.82rem;color:var(--primary-700);background:linear-gradient(180deg,#eef6ff,#dcecff);border:1px solid rgba(0,115,230,.26)}.group-points-dock-tools{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.group-points-kind-toggle{display:inline-grid;grid-template-columns:1fr 1fr;gap:3px;padding:3px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-secondary)}.group-points-kind-toggle button{min-width:90px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.68rem;font-weight:800;padding:6px 10px;cursor:pointer;transition:all .2s ease}.group-points-dock-head button{border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.7rem;font-weight:800;padding:6px 10px;cursor:pointer}.group-points-kind-toggle button.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 3px #0000001f}.group-points-dock-head button.active{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700)}.group-points-dock-head button:disabled{opacity:.45;cursor:not-allowed}.group-points-dock-head button.ghost{background:var(--bg-card)}.group-points-error{margin:6px 0 10px;font-size:.85rem}.group-points-actions{display:flex;gap:6px;flex-wrap:wrap}.group-points-actions>button,.group-points-actions .score-action{border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.78rem;font-weight:800;padding:8px 12px;cursor:pointer}.group-points-actions>button.plus,.group-points-actions .score-action.positive{background:linear-gradient(180deg,#f4fbf7,#eaf8f0);border-color:#16a34a3d;color:#14532d}.group-points-actions>button.minus,.group-points-actions .score-action.negative{background:linear-gradient(180deg,#fff5f5,#ffeceb);border-color:#dc262638;color:#7f1d1d}.group-points-actions .score-action.plus{background:linear-gradient(180deg,#f7f9fd,#edf2f8);border-color:#0073e638;color:var(--text-primary)}.group-points-actions .score-action.icon-only{width:44px;min-width:44px;height:44px;padding:0;border-radius:12px;display:inline-flex;align-items:center;justify-content:center}.group-points-actions .score-action{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;-moz-column-gap:8px;column-gap:8px;row-gap:2px;align-items:center;min-width:140px;text-align:left}.group-points-actions .score-action .icon{grid-row:1 / span 2;width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-size:.9rem;background:#ffffffb3}.group-points-actions .score-action .icon img{width:20px;height:20px;-o-object-fit:contain;object-fit:contain}.group-points-actions .score-action.positive .icon{background:#16a34a29}.group-points-actions .score-action.negative .icon{background:#dc262624}.group-points-actions .score-action.plus .icon{background:#0073e61f;color:var(--primary-600);font-weight:900}.group-points-actions .score-action .label{font-size:.74rem;font-weight:800}.group-points-actions .score-action .range{font-size:.65rem;font-weight:700;opacity:.8}.custom-points{display:inline-flex;align-items:center;gap:6px;margin-left:auto}.custom-points input{width:64px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-weight:700;text-align:center;padding:7px 8px}.custom-points button{border:1px solid var(--border-color);border-radius:8px;background:var(--primary-50);color:var(--primary-700);font-size:.78rem;font-weight:800;padding:8px 10px;cursor:pointer}@keyframes groupSettingsSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.group-settings-backdrop{position:fixed;inset:var(--landing-nav-height, 64px) 0 0;border:none;background:#07102159;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:120;cursor:default;animation:fadeIn .2s ease}.group-settings-panel{position:fixed;top:var(--landing-nav-height, 64px);right:0;bottom:0;width:min(380px,96vw);border-left:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);z-index:130;transform:translate(102%);opacity:0;pointer-events:none;transition:transform .24s ease,opacity .24s ease;box-shadow:-8px 0 32px #0f172a29;display:grid;grid-template-rows:auto 1fr auto;overflow:clip}.group-settings-panel.open{transform:translate(0);opacity:1;pointer-events:auto;animation:groupSettingsSlideIn .3s cubic-bezier(.16,1,.3,1)}.group-settings-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border-color);background:var(--bg-card);flex-shrink:0}.group-settings-panel-head{display:flex;align-items:center;gap:12px;min-width:0}.group-settings-panel-icon{width:36px;height:36px;border-radius:10px;background:var(--primary-50);color:var(--primary-600);display:flex;align-items:center;justify-content:center;font-size:1rem;flex:0 0 auto}.group-settings-panel-meta{min-width:0;display:flex;flex-direction:column;gap:2px}.group-settings-panel-header h3{margin:0;font-family:var(--font-display);font-size:1.05rem;font-weight:700;min-width:0;overflow-wrap:anywhere}.group-settings-panel-subtitle{font-size:.66rem;font-weight:600;color:var(--text-secondary)}.group-settings-panel-close{border:1.5px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);color:var(--text-secondary);font-size:1rem;cursor:pointer;width:34px;height:34px;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease}.group-settings-panel-close:hover{border-color:#dc26264d;background:#dc262614;color:#dc2626}.group-settings-panel-close:active{transform:scale(.94)}.group-settings-panel-scroll{min-height:0;padding:16px 16px 32px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.group-settings-panel-scroll>*+*{margin-top:12px}.group-settings-panel-scroll::-webkit-scrollbar{width:4px}.group-settings-panel-scroll::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.group-settings-panel-scroll::-webkit-scrollbar-track{background:transparent}.group-settings-block{border:1.5px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-card);color:var(--text-primary);overflow:hidden;min-width:0;box-shadow:var(--shadow-sm);transition:border-color .2s ease,box-shadow .2s ease}.group-settings-block.open{border-color:#0073e626;box-shadow:var(--shadow-md)}.group-settings-block-head{width:100%;border:none;background:var(--bg-card);color:var(--text-primary);text-align:left;padding:14px 16px;font-size:.88rem;font-weight:700;display:flex;align-items:center;justify-content:space-between;cursor:pointer;min-width:0;gap:8px;transition:background .15s ease;border-bottom:none;border-radius:0;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.group-settings-block-head:hover{background:var(--bg-secondary)}.group-settings-block-head:active{background:var(--primary-50)}.group-settings-block.open .group-settings-block-head{background:var(--bg-secondary)}.group-settings-block-left{display:inline-flex;align-items:center;gap:10px;min-width:0}.group-settings-block-label{display:inline-flex;align-items:center;gap:10px;min-width:0;font-family:var(--font-display);font-size:.85rem;font-weight:700}.group-settings-block-icon{width:32px;height:32px;border-radius:8px;background:var(--primary-50);color:var(--primary-600);display:inline-flex;align-items:center;justify-content:center;font-size:.9rem;flex:0 0 auto}.group-settings-block-icon.pack{background:#d4a0172e;color:#a07c10}.group-settings-block-icon.scoring{background:#16a34a24;color:#15803d}.group-settings-block-icon.game{background:#7c3aed24;color:#7c3aed}.group-settings-block-icon.danger{background:#dc262624;color:#dc2626}.group-settings-block-icon.danger+.group-settings-block-label{color:#dc2626}.group-settings-block-badge{font-size:.58rem;font-weight:800;padding:2px 8px;border-radius:999px;background:var(--primary-50);color:var(--primary-600);white-space:nowrap}.group-settings-block-chevron{width:24px;height:24px;border-radius:6px;background:var(--bg-secondary);color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;transition:transform .25s ease;flex:0 0 auto}.group-settings-block.open .group-settings-block-chevron{transform:rotate(180deg)}.group-settings-block-body{background:var(--bg-card);min-width:0;max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.16,1,.3,1)}.group-settings-block.open .group-settings-block-body{max-height:3000px}.group-settings-block-body-inner{padding:8px 16px 18px;display:flex;flex-direction:column;gap:14px}.group-settings-row{display:flex;flex-direction:column;gap:8px;min-width:0}.group-settings-row>strong{display:inline-flex;align-items:center;gap:6px}.group-settings-row strong{font-size:.78rem;font-weight:800;overflow-wrap:anywhere;font-family:var(--font-display)}.group-settings-set-group{display:flex;flex-direction:column;gap:8px}.group-settings-set-label{font-family:var(--font-display);font-weight:700;font-size:.78rem;color:var(--text-primary);display:inline-flex;align-items:center;gap:6px}.group-settings-set-hint{font-size:.64rem;color:var(--text-secondary);font-weight:600}.group-settings-divider{height:1px;background:var(--border-color)}.group-settings-pill-row{display:flex;flex-wrap:wrap;gap:4px;min-width:0;background:var(--bg-secondary);padding:4px;border-radius:999px;border:1px solid var(--border-color);min-height:40px;align-items:center}.group-settings-info-banner{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-secondary);font-size:.7rem;font-weight:600;color:var(--text-secondary);line-height:1.4}.group-settings-info-banner-error{border-color:#e2505059;background:#e250501f;color:#b02121;margin:10px 0 0}.group-settings-danger-list{display:flex;flex-direction:column;gap:8px}.group-settings-danger-action{padding:10px 14px;border-radius:999px;font-family:var(--font-display);font-weight:700;font-size:.76rem;border:1.5px solid rgba(220,38,38,.25);background:transparent;color:#dc2626;text-align:left;cursor:pointer;transition:all .15s ease}.group-settings-danger-action:hover{background:#dc2626;color:#fff;border-color:#dc2626}.group-settings-danger-action:active{transform:scale(.97)}.group-settings-danger-action:disabled{opacity:.55;cursor:not-allowed;transform:none;background:transparent;color:#dc2626;border-color:#dc262633}.group-settings-pill-row button{border:none;border-radius:999px;background:transparent;color:var(--text-secondary);padding:6px 14px;font-size:.72rem;font-weight:800;cursor:pointer;max-width:100%;white-space:normal;overflow-wrap:anywhere;transition:all .2s ease;flex:1 1 auto;text-align:center}.group-settings-pill-row button.active{background:var(--bg-card);color:var(--primary-600);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.group-settings-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:14px;font-size:.8rem;font-weight:700;min-width:0;padding:6px 0}.group-settings-toggle-info{display:flex;flex-direction:column;gap:2px;min-width:0}.group-settings-toggle-name{font-weight:700;font-size:.8rem}.group-settings-toggle-desc{font-size:.62rem;color:var(--text-secondary);font-weight:600}.group-settings-toggle-row span{min-width:0;flex:1 1 auto;overflow-wrap:anywhere}.group-settings-toggle-row input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:44px;height:26px;border-radius:13px;background:var(--border-color);border:none;cursor:pointer;flex:0 0 auto;position:relative;transition:all .25s ease}.group-settings-toggle-row input[type=checkbox]:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:var(--bg-card);box-shadow:0 1px 4px #00000026;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.group-settings-toggle-row input[type=checkbox]:checked{background:var(--primary-500)}.group-settings-toggle-row input[type=checkbox]:checked:after{transform:translate(18px)}.group-settings-toggle-row input[type=checkbox]:active:after{width:24px}.group-settings-toggle-row input[type=checkbox]:checked:active:after{transform:translate(14px)}.group-settings-gender-colors{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px}.group-settings-gender-colors.disabled{opacity:.75}.group-settings-gender-color{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;border:1px solid var(--border-color);background:var(--bg-secondary)}.group-settings-gender-label{font-size:.72rem;font-weight:700;color:var(--text-secondary)}.group-settings-gender-swatch{width:16px;height:16px;border-radius:999px;border:2px solid var(--bg-card);box-shadow:0 1px 3px #00000026}.group-settings-gender-color input[type=color]{width:32px;height:24px;border:none;background:transparent;padding:0;cursor:pointer}.group-settings-gender-color input[type=color]::-webkit-color-swatch-wrapper{padding:0}.group-settings-gender-color input[type=color]::-webkit-color-swatch{border:1px solid var(--border-color);border-radius:8px}.group-settings-gender-color input[type=color]::-moz-color-swatch{border:1px solid var(--border-color);border-radius:8px}.group-settings-row input[type=range],.group-settings-range-wrap input[type=range]{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;border-radius:3px;background:var(--bg-secondary);border:1px solid var(--border-color);cursor:pointer;margin:4px 0 2px}.group-settings-range-wrap{position:relative}.group-settings-range-value{margin-left:auto;font-family:var(--font-display);font-weight:700;font-size:.7rem;color:var(--primary-600);background:var(--primary-50);padding:2px 10px;border-radius:999px}.group-settings-row input[type=range]::-webkit-slider-thumb,.group-settings-range-wrap input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--bg-card);border:3px solid var(--primary-500);box-shadow:0 2px 8px #0073e640;cursor:pointer;-webkit-transition:transform .15s ease;transition:transform .15s ease}.group-settings-row input[type=range]::-webkit-slider-thumb:hover,.group-settings-range-wrap input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 2px 12px #0073e659}.group-settings-row input[type=range]::-webkit-slider-thumb:active,.group-settings-range-wrap input[type=range]::-webkit-slider-thumb:active{transform:scale(.95)}.group-settings-row input[type=range]::-moz-range-thumb,.group-settings-range-wrap input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--bg-card);border:3px solid var(--primary-500);box-shadow:0 2px 8px #0073e640;cursor:pointer}.group-settings-range-inputs{display:grid;grid-template-columns:1fr 1fr;gap:8px;min-width:0}.group-settings-range-inputs input{border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);font-size:.86rem;font-weight:700;padding:8px 10px;text-align:center;width:100%;min-width:0}.group-settings-range-inputs input:focus{outline:none;border-color:var(--primary-300);box-shadow:0 0 0 2px #0073e61a}.group-settings-pack-grid{display:grid;gap:10px}.group-settings-pack-card{border:2px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card);padding:0;display:flex;flex-direction:column;color:inherit;cursor:pointer;transition:border-color .2s ease,transform .15s ease,box-shadow .2s ease;text-align:left;box-shadow:var(--shadow-sm);overflow:hidden}.group-settings-pack-card:hover{border-color:var(--primary-400);box-shadow:var(--shadow-md)}.group-settings-pack-card:active{transform:scale(.98)}.group-settings-pack-card:disabled{opacity:.6;cursor:not-allowed;transform:none}.group-settings-pack-card.active{border-color:var(--primary-500);box-shadow:0 0 0 3px #0073e61f}.group-settings-pack-swatch{width:100%;height:56px;display:flex;align-items:center;justify-content:center;gap:6px;overflow:hidden;position:relative;border-radius:0}.group-settings-pack-swatch img{width:32px;height:32px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 3px 6px rgba(0,0,0,.25));position:relative;z-index:2}.group-settings-pack-info{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0;padding:10px 12px}.group-settings-pack-info>span:first-child{display:flex;flex-direction:column;gap:1px;min-width:0}.group-settings-pack-info strong{font-size:.78rem;font-weight:800;color:var(--text-primary);display:block}.group-settings-pack-info small{font-size:.6rem;color:var(--text-secondary);text-transform:capitalize;display:block}.group-settings-pack-status{font-size:.6rem;font-weight:800;color:var(--primary-600);text-transform:uppercase;padding:3px 8px;border-radius:999px;background:var(--primary-50);flex-shrink:0}.group-settings-pack-check{width:22px;height:22px;border-radius:50%;border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:.55rem;color:transparent;transition:all .2s ease;flex-shrink:0}.group-settings-pack-card.active .group-settings-pack-check{background:var(--primary-500);border-color:var(--primary-500);color:#fff}.group-settings-pack-manage{border:1.5px solid var(--border-color);border-radius:999px;background:var(--bg-secondary);color:var(--text-secondary);padding:8px 14px;font-size:.72rem;font-weight:800;cursor:pointer;text-align:center}.group-settings-pack-manage:hover{border-color:var(--primary-400);color:var(--primary-600);background:var(--primary-50)}.group-settings-pill-round-group{display:flex;gap:6px}.group-settings-pill-round{width:38px;height:38px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:.75rem;border:2px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.group-settings-pill-round.active{border-color:var(--primary-500);background:var(--primary-50);color:var(--primary-600);box-shadow:0 0 0 3px #0073e61a}.group-settings-pill-round:hover:not(.active){border-color:var(--text-secondary)}.group-settings-stepper{display:flex;align-items:center;border:1.5px solid var(--border-color);border-radius:10px;overflow:hidden;background:var(--bg-card)}.group-settings-stepper-btn{width:36px;height:36px;border:none;cursor:pointer;font-size:.9rem;font-weight:800;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--text-secondary);transition:all .15s ease}.group-settings-stepper-btn:hover{background:var(--primary-50);color:var(--primary-600)}.group-settings-stepper-value{flex:1;text-align:center;font-family:var(--font-display);font-weight:700;font-size:.85rem;min-width:40px}.group-settings-select{width:100%;padding:10px 14px;border-radius:10px;border:1.5px solid var(--border-color);background:var(--bg-secondary);font-family:var(--font-sans);font-size:.82rem;font-weight:600;color:var(--text-primary);outline:none}.group-settings-color-dots{display:flex;gap:6px;flex-wrap:wrap}.group-settings-color-dot{width:28px;height:28px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:all .15s ease;position:relative}.group-settings-color-dot:hover{transform:scale(1.12)}.group-settings-color-dot.active{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-card),0 0 0 4px var(--text-primary)}.group-settings-color-dot.active:after{content:"✓";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.55rem;font-weight:800;text-shadow:0 1px 2px rgba(0,0,0,.4)}.group-settings-footer{padding:14px 16px;border-top:1px solid var(--border-color);background:var(--bg-card);display:flex;gap:8px;flex-shrink:0}.group-settings-footer-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:999px;border:none;font-family:var(--font-display);font-weight:700;font-size:.82rem;cursor:pointer;transition:all .15s ease;flex:1}.group-settings-footer-btn:active{transform:scale(.96)}.group-settings-footer-btn.primary{background:var(--primary-500);color:#fff}.group-settings-footer-btn.primary:hover{background:var(--primary-600)}.group-settings-footer-btn.ghost{background:var(--bg-secondary);color:var(--text-secondary);border:1.5px solid var(--border-color)}.group-settings-footer-btn.ghost:hover{border-color:var(--text-secondary)}.group-score-actions{display:flex;flex-direction:column;gap:10px;margin-top:8px}.group-score-action-row{border:1px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);padding:10px;display:grid;gap:8px}.group-score-action-head{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap}.group-score-action-icon-preview{width:36px;height:36px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-card);display:grid;place-items:center;flex:0 0 auto}.group-score-action-icon-preview img{width:22px;height:22px;-o-object-fit:contain;object-fit:contain}.group-score-action-row input[type=text]{border:1px solid var(--border-color);border-radius:8px;padding:8px 10px;font-weight:700;background:var(--bg-card);color:var(--text-primary);min-width:0}.group-score-action-icon{width:52px;text-align:center;flex:0 0 auto;font-size:1.05rem}.group-score-action-label{flex:1 1 auto}.group-score-action-fields{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:6px}.group-score-action-fields input{width:100%;border:1px solid var(--border-color);border-radius:8px;padding:6px 8px;text-align:center;font-weight:700;background:var(--bg-card);color:var(--text-primary)}.group-score-action-fields span{font-size:.75rem;font-weight:700;color:var(--text-secondary)}.group-score-action-row select{border:1px solid var(--border-color);border-radius:8px;padding:6px 8px;font-weight:700;background:var(--bg-card);color:var(--text-primary);width:100%}.group-score-action-value{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.group-score-action-value input{width:100%;border:1px solid var(--border-color);border-radius:8px;padding:6px 8px;text-align:center;font-weight:700;background:var(--bg-card);color:var(--text-primary)}.group-score-action-value span{font-size:.72rem;font-weight:700;color:var(--text-secondary)}.group-score-action-remove{border:1px solid rgba(220,38,38,.25);border-radius:8px;background:#dc262614;color:#dc2626;font-weight:800;font-size:.72rem;padding:6px 10px;cursor:pointer}.group-score-action-range{font-size:.7rem;font-weight:700;color:var(--text-secondary)}.group-score-action-tools{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.group-score-action-add{border:1px dashed var(--primary-300);border-radius:10px;padding:8px 12px;background:var(--primary-50);color:var(--primary-600);font-weight:800;cursor:pointer}.group-score-action-add.icon-only{width:38px;min-width:38px;height:38px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;line-height:1}.group-score-action-library-btn{border:1px solid var(--border-color);border-radius:10px;padding:8px 12px;background:var(--bg-card);color:var(--text-secondary);font-weight:800;cursor:pointer}.group-score-library{margin-top:10px;border:1px dashed var(--border-color);border-radius:12px;padding:10px;display:grid;gap:8px;background:var(--bg-card)}.group-score-library-empty{font-size:.75rem;color:var(--text-secondary);margin:0}.group-score-library-filters{display:inline-flex;gap:6px;flex-wrap:wrap}.group-score-library-filters button{border:1px solid var(--border-color);border-radius:999px;padding:6px 10px;background:var(--bg-card);color:var(--text-secondary);font-size:.68rem;font-weight:800;cursor:pointer}.group-score-library-filters button.active{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700)}.group-score-library-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--border-color);border-radius:10px;padding:8px 10px;background:var(--bg-secondary)}.group-score-library-main{display:flex;align-items:center;gap:10px}.group-score-library-main strong{display:block;font-size:.8rem}.group-score-library-main span{display:block;font-size:.7rem;color:var(--text-secondary)}.group-score-library-main .scope{display:block;margin-top:2px;font-size:.65rem;color:var(--primary-600);font-weight:700}.group-score-library-icon{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;background:#ffffffb3}.group-score-library-icon img{width:18px;height:18px;-o-object-fit:contain;object-fit:contain}.group-score-library-item button{border:1px solid var(--primary-300);border-radius:10px;padding:6px 10px;background:var(--primary-50);color:var(--primary-600);font-weight:800;cursor:pointer}.group-score-editor{width:min(720px,92vw);background:var(--bg-card);border-radius:18px;border:1px solid var(--border-color);box-shadow:0 24px 60px #0f172a40;padding:18px 20px;display:grid;gap:14px}.group-score-editor header{display:flex;align-items:center;justify-content:space-between;gap:12px}.group-score-editor header h3{margin:0;font-size:1.05rem}.group-score-editor header p{margin:4px 0 0;font-size:.78rem;color:var(--text-secondary)}.group-score-editor header button{border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);padding:6px 10px;font-weight:700;cursor:pointer}.group-score-editor-kinds{display:flex;gap:8px}.group-score-editor-kinds button{flex:1 1 0;border:1px solid var(--border-color);border-radius:10px;padding:8px 10px;background:var(--bg-secondary);font-weight:800;cursor:pointer}.group-score-editor-kinds button.active{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700)}.group-score-editor-field{display:grid;gap:6px;font-weight:700;font-size:.82rem}.group-score-editor-field input{border:1px solid var(--border-color);border-radius:10px;padding:8px 10px;background:var(--bg-card);font-weight:700}.group-score-editor-field select{border:1px solid var(--border-color);border-radius:10px;padding:8px 10px;background:var(--bg-card);color:var(--text-primary);font-weight:700}.group-score-editor-icons{display:grid;grid-template-columns:repeat(auto-fit,minmax(62px,1fr));gap:8px}.group-score-editor-icons button{border:1px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);width:100%;aspect-ratio:1 / 1;padding:8px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.group-score-editor-icons button.active{border-color:var(--primary-300);background:var(--primary-50)}.group-score-editor-icons img{width:34px;height:34px;-o-object-fit:contain;object-fit:contain}.group-score-editor-empty{font-size:.75rem;color:var(--text-secondary);padding:8px 0}.group-score-editor-value{display:grid;gap:8px}.group-score-editor-value-head{display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:800;font-size:.8rem}.group-score-editor-value-head input{width:96px;border:1px solid var(--border-color);border-radius:10px;padding:6px 8px;text-align:center;font-weight:700}.group-score-editor-range{display:flex;justify-content:space-between;font-size:.72rem;color:var(--text-secondary);font-weight:700}.group-score-editor-checkbox{display:flex;align-items:center;gap:8px;font-size:.78rem;font-weight:700}.group-score-editor-actions{display:flex;justify-content:flex-end;gap:8px}.group-score-editor-actions button{border:1px solid var(--border-color);border-radius:10px;padding:8px 12px;font-weight:800;background:var(--bg-secondary);cursor:pointer}.group-score-editor-actions button:last-child{background:var(--primary-600);border-color:var(--primary-600);color:#fff}.group-settings-action{border:1px solid var(--primary-300);border-radius:10px;background:var(--primary-50);color:var(--primary-600);font-size:.82rem;font-weight:800;padding:8px 10px;cursor:pointer;max-width:100%;overflow-wrap:anywhere}.group-timer-modal{position:fixed;inset:0;z-index:120;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px}.group-timer-panel{width:min(420px,100%);border:2px solid var(--border-color);border-radius:16px;background:var(--bg-card);box-shadow:0 24px 50px #00000052;padding:14px;transition:transform .12s ease;will-change:transform;max-width:calc(100vw - 24px)}.group-timer-panel header{display:flex;justify-content:space-between;align-items:center;gap:10px}.group-timer-panel.dragging{transition:none}.group-timer-drag-handle{flex:1 1 auto;min-width:0;display:flex;align-items:baseline;gap:8px;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none}.group-timer-panel.dragging .group-timer-drag-handle{cursor:grabbing}.group-timer-panel header h3{margin:0;font-family:var(--font-display);font-size:1.15rem}.group-timer-drag-handle small{color:var(--text-secondary);font-size:.72rem;font-weight:700}.group-timer-head-actions{display:flex;align-items:center;gap:6px}.group-timer-panel header button{border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.78rem;font-weight:700;padding:6px 10px;cursor:pointer}.group-timer-value{margin:16px 0;text-align:center;font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--primary-600)}.group-timer-presets{display:flex;gap:8px;justify-content:center;margin-bottom:14px}.group-timer-presets button{border:1px solid var(--border-color);border-radius:999px;background:var(--bg-secondary);color:var(--text-primary);font-size:.8rem;font-weight:800;padding:8px 12px;cursor:pointer}.group-timer-presets button.active{background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700)}.group-timer-actions{display:flex;gap:8px;justify-content:center}.group-timer-actions button{border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);font-size:.84rem;font-weight:800;padding:9px 14px;cursor:pointer}.group-score-modal,.group-student-modal{position:fixed;inset:0;z-index:12000;background:#060a188c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;padding:16px}.group-confirm-modal{z-index:52010}.group-student-drawer-backdrop{position:fixed;inset:0;background:#060a1885;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:none;z-index:49000;cursor:default}.group-student-drawer{position:fixed;inset:0;width:100vw;background:var(--bg-card);border:none;box-shadow:none;z-index:50000;padding:calc(12px + env(safe-area-inset-top,0px)) 14px calc(16px + env(safe-area-inset-bottom,0px));overflow-y:auto}.group-student-drawer.student-editor{padding:0;overflow:hidden;background:var(--bg-secondary)}.student-editor-close{position:absolute;top:calc(12px + env(safe-area-inset-top,0px));right:12px;z-index:60;cursor:pointer}.student-editor-layout{display:grid;grid-template-columns:min(360px,32vw) 1fr;grid-template-rows:1fr auto;height:100vh;background:var(--bg-secondary)}.student-preview{width:min(360px,32vw);flex-shrink:0;border-right:1px solid var(--border-color);background:var(--bg-card);position:sticky;top:0;height:100%;min-height:0;overflow-y:auto;padding-bottom:16px}.student-preview-banner{height:120px;position:relative;overflow:hidden}.student-preview-deco{position:absolute;right:16px;top:8px;font-size:1.6rem;opacity:.18}.student-preview-deco+.student-preview-deco{inset:auto auto 10px 14px;font-size:1.2rem}.student-preview-avatar{width:96px;height:96px;margin:-44px auto 8px;position:relative;display:grid;place-items:center;justify-content:center}.student-preview-avatar img{width:114px;height:114px;-o-object-fit:contain;object-fit:contain;position:absolute;bottom:-6px;left:50%;transform:translate(-50%)}.student-preview-info{text-align:center;padding:0 16px;margin-bottom:10px}.student-preview-name{font-family:var(--font-display);font-weight:700;font-size:1rem}.student-preview-alias span{display:inline-flex;margin-top:4px;font-size:.7rem;color:var(--text-secondary);padding:2px 8px;border-radius:999px;background:var(--bg-secondary);font-weight:700}.student-preview-xp{padding:0 18px;margin-bottom:12px}.student-preview-xp-head{display:flex;justify-content:space-between;font-size:.65rem;font-weight:800;color:var(--text-secondary);margin-bottom:4px}.student-preview-xp-bar{width:100%;height:8px;background:var(--bg-secondary);border-radius:999px;overflow:hidden;border:1px solid var(--border-color)}.student-preview-xp-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#f59e0b,#fbbf24)}.student-preview-points{text-align:center;font-family:var(--font-display);font-weight:700;color:#f59e0b;display:flex;align-items:baseline;justify-content:center;gap:6px;margin-bottom:8px}.student-preview-points.negative{color:#dc2626}.student-preview-points strong{font-size:1.2rem}.student-preview-meta{display:flex;justify-content:center;gap:8px;font-size:.66rem;font-weight:700;color:var(--text-secondary);padding:0 12px;flex-wrap:wrap}.student-preview-roles{padding:14px 16px 0}.student-preview-roles-title{font-family:var(--font-display);font-size:.7rem;font-weight:700;margin-bottom:6px;color:var(--text-secondary)}.student-preview-roles-row{display:flex;flex-wrap:wrap;gap:6px}.student-preview-role-chip{padding:4px 8px;border-radius:999px;background:var(--bg-secondary);border:1px solid var(--border-color);font-size:.62rem;font-weight:700;color:var(--text-secondary)}.student-preview-role-empty{font-size:.65rem;color:var(--text-secondary)}.student-preview-streak{display:flex;justify-content:center;gap:4px;padding:12px 16px 0}.student-preview-day{width:24px;height:24px;border-radius:8px;border:1px solid var(--border-color);display:grid;place-items:center;font-size:.6rem;font-weight:800;color:var(--text-secondary);background:var(--bg-secondary)}.student-preview-day.done{background:var(--success-500);color:#fff;border-color:#00e63d80}.student-editor-main{flex:1;min-width:0;min-height:0;display:grid;grid-template-rows:auto 1fr auto;height:100%;overflow:hidden;padding:0 32px;background:var(--bg-secondary)}.student-editor-tabs{display:flex;justify-content:center;gap:10px;padding:14px 0 10px;background:var(--bg-secondary);z-index:2;border-bottom:1px solid var(--border-color)}.student-editor-tabs button{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);width:38px;height:38px;border-radius:999px;display:grid;place-items:center;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .15s ease}.student-editor-tabs button.active{color:var(--primary-600);background:var(--primary-50);border-color:var(--primary-200);transform:translateY(-1px)}.student-editor-tabs button:hover{color:var(--primary-600);border-color:var(--primary-200);background:var(--bg-card)}.student-editor-scroll{overflow-y:auto;min-height:0;padding:16px 0 24px;display:grid;gap:12px}.student-editor-panel{padding:18px;max-width:none;animation:fadeUp .25s ease;border:1px solid var(--border-color);border-radius:16px;background:var(--bg-card);box-shadow:var(--shadow-sm)}.student-editor-savebar{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 32px 16px;border-top:1px solid var(--border-color);background:var(--bg-card);font-weight:800;z-index:2;box-shadow:0 -6px 16px #00000014}.student-editor-savebar span{color:var(--text-secondary);font-size:.78rem}.student-editor-savebar button{border:none;border-radius:999px;padding:9px 18px;background:var(--primary-500);color:#fff;font-weight:800;cursor:pointer}.student-editor-savebar button:disabled{opacity:.55;cursor:not-allowed}.student-editor-savebar.saved button{background:var(--bg-secondary);color:var(--text-secondary)}.student-points-controls{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.pt-btn{padding:8px 16px;border-radius:999px;font-weight:800;font-size:.78rem;border:none;cursor:pointer}.pt-btn.plus{background:var(--success-500);color:#fff}.pt-btn.minus{background:var(--accent-500);color:#fff}.student-points-custom{display:grid;grid-template-columns:90px 1fr auto;gap:8px;margin-bottom:8px}.student-points-custom input{border:1px solid var(--border-color);border-radius:10px;padding:8px 10px;font-weight:700;background:var(--bg-secondary)}.student-points-custom button{border:none;border-radius:999px;padding:8px 14px;background:var(--primary-500);color:#fff;font-weight:800;cursor:pointer}@media(max-width:960px){.student-editor-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr auto;height:100vh}.student-preview{width:100%;height:auto;position:relative;border-right:none;border-bottom:1px solid var(--border-color)}.student-editor-main{height:auto;padding:0 16px}.student-editor-scroll{padding:12px 0 20px}.student-editor-savebar{padding:12px 16px 16px}}.group-student-drawer-content{width:100%;max-width:100%;margin:0 auto;display:flex;flex-direction:column;gap:14px}.group-student-drawer-content>header{position:sticky;top:0;z-index:2;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:6px 0 10px;background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}[data-theme=dark] .group-student-drawer-content>header{background:#121826e6}.group-student-drawer-content>header h3{margin:0;font-family:var(--font-display);font-size:clamp(1.18rem,1.3vw,1.42rem)}.group-student-drawer-content>header p{margin:4px 0 0;color:var(--text-secondary);font-size:.82rem;font-weight:700}.group-student-drawer-content>header button{border:none;border-radius:999px;background:var(--bg-secondary);color:var(--text-secondary);font-size:.8rem;font-weight:800;padding:7px 12px;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .15s ease,color .15s ease}.group-student-close{width:36px;height:36px;padding:0;border-radius:999px;display:grid;place-items:center;background:var(--bg-secondary);border:none;color:var(--text-secondary);box-shadow:none}.group-student-close:hover{background:var(--accent-100);color:var(--accent-500)}.group-score-panel,.group-student-panel{width:min(520px,100%);border:2px solid var(--border-color);border-radius:18px;background:var(--bg-card);box-shadow:0 26px 50px #00000059;padding:18px;max-height:85vh;overflow:auto}.group-confirm-panel{width:min(460px,100%)}.group-confirm-highlight{margin-top:8px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px}.group-confirm-highlight span{font-size:.82rem;font-weight:800}.group-confirm-highlight strong{font-family:var(--font-display);font-size:1rem}.group-confirm-highlight strong.plus{color:#16a34a}.group-confirm-highlight strong.minus{color:#dc2626}.group-confirm-field{margin-top:12px;display:grid;gap:6px}.group-confirm-field span{font-size:.74rem;font-weight:800;color:var(--text-secondary)}.group-confirm-field input{border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);color:var(--text-primary);font-size:.84rem;font-weight:700;padding:8px 10px}.group-confirm-actions .danger{background:#dc2626;border-color:#b91c1c;color:#fff}.group-confirm-actions .danger:hover{background:#ef4444;border-color:#dc2626}.add-student-panel{width:min(680px,100%)}.add-student-options{margin-top:14px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.add-student-options button{border:1px solid var(--border-color);border-radius:14px;background:var(--bg-secondary);padding:12px;text-align:left;cursor:pointer;display:grid;gap:4px;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.add-student-options button:hover{transform:translateY(-1px)}.add-student-options button.active{border-color:var(--primary-400);box-shadow:0 0 0 3px #3b82f626;background:var(--primary-50)}.add-student-options .title{font-weight:800;font-size:.86rem}.add-student-options .desc{color:var(--text-secondary);font-size:.72rem;font-weight:700}.add-student-section{margin-top:16px;display:grid;gap:12px}.join-code-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;border:1px solid var(--border-color);border-radius:14px;background:var(--bg-secondary);padding:12px}.join-code-label{font-size:.72rem;font-weight:800;color:var(--text-secondary)}.join-code-value{font-family:var(--font-display);font-size:1.2rem;font-weight:700;letter-spacing:.08em}.join-code-expiry{font-size:.7rem;color:var(--text-secondary);font-weight:700}.join-code-actions{display:flex;gap:8px}.join-code-actions button{border:1px solid var(--border-color);border-radius:10px;background:var(--bg-card);color:var(--text-primary);font-size:.75rem;font-weight:800;padding:7px 12px;cursor:pointer}.join-code-toggle{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:.82rem;font-weight:700}.join-code-toggle input[type=checkbox]{width:44px;height:24px;accent-color:var(--primary-500);cursor:pointer}.join-qr-box{border:1px dashed var(--border-color);border-radius:14px;background:var(--bg-secondary);padding:14px;display:grid;place-items:center;min-height:170px}.join-qr-box img{width:160px;height:160px;-o-object-fit:contain;object-fit:contain}.join-qr-placeholder{font-size:.74rem;font-weight:700;color:var(--text-secondary);text-align:center}.join-requests-section{border:1px solid var(--border-color);border-radius:14px;background:var(--bg-secondary);padding:12px;display:grid;gap:10px}.join-requests-title{font-weight:800;font-size:.84rem}.join-requests-list{display:grid;gap:8px}.join-request-item{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--border-color);border-radius:12px;padding:10px;background:var(--bg-card)}.join-request-alias{font-weight:800;font-size:.82rem}.join-request-actions{display:flex;gap:6px}.join-request-actions button{border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.72rem;font-weight:800;padding:6px 10px;cursor:pointer}.student-search-bar{display:flex;gap:8px}.student-search-bar input{flex:1;border:1px solid var(--border-color);border-radius:10px;padding:8px 10px;font-weight:700;background:var(--bg-secondary)}.student-search-bar button{border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);font-size:.78rem;font-weight:800;padding:8px 12px;cursor:pointer}.student-search-results{display:grid;gap:8px}.student-search-item{border:1px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);padding:10px;display:flex;align-items:center;justify-content:space-between;gap:10px}.student-search-name{font-weight:800;font-size:.82rem}.student-search-item button{border:1px solid var(--border-color);border-radius:8px;background:var(--bg-card);font-size:.72rem;font-weight:800;padding:6px 10px;cursor:pointer}.student-create-form{display:grid;gap:10px}.student-create-form label{display:grid;gap:6px;font-size:.76rem;font-weight:800;color:var(--text-secondary)}.student-create-form input{border:1px solid var(--border-color);border-radius:10px;padding:8px 10px;font-weight:700;background:var(--bg-secondary)}.input-inline{display:flex;gap:8px}.input-inline button{border:1px solid var(--border-color);border-radius:10px;padding:8px 12px;background:var(--bg-card);font-size:.72rem;font-weight:800;cursor:pointer}.student-create-actions{display:flex;justify-content:flex-end}.student-create-actions button{border:1px solid var(--primary-400);border-radius:999px;padding:9px 16px;background:var(--primary-500);color:#fff;font-weight:800;font-size:.8rem;cursor:pointer}.group-score-panel header,.group-student-panel header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.group-score-panel header h3,.group-student-panel header h3{margin:0;font-family:var(--font-display);font-size:1.1rem}.group-score-panel header p,.group-student-panel header p{margin:4px 0 0;color:var(--text-secondary);font-size:.78rem;font-weight:700}.group-score-panel header button,.group-student-panel header button{border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.78rem;font-weight:800;padding:6px 10px;cursor:pointer}.group-modal-close-btn{width:34px;height:34px;padding:0!important;border-radius:999px!important;display:grid;place-items:center;border:1px solid var(--border-color)!important;background:var(--bg-secondary)!important;color:var(--text-secondary)!important;transition:background .15s ease,color .15s ease,border-color .15s ease,transform .15s ease}.group-modal-close-btn:hover{background:var(--accent-100)!important;color:var(--accent-500)!important;border-color:var(--accent-200)!important}.group-modal-close-btn:disabled{opacity:.6;cursor:not-allowed}.group-score-header{display:flex;align-items:center;gap:10px}.group-score-icon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:1.2rem;background:var(--bg-secondary)}.group-score-icon img{width:24px;height:24px;-o-object-fit:contain;object-fit:contain}.group-score-icon.positive{background:#16a34a29;color:#166534}.group-score-icon.negative{background:#dc262629;color:#991b1b}.group-score-value{margin:14px 0 8px;font-family:var(--font-display);font-size:2.2rem;font-weight:700;text-align:center}.group-score-value.positive{color:#16a34a}.group-score-value.negative{color:#dc2626}.group-score-slider{width:100%;accent-color:var(--primary-500)}.group-score-range{display:flex;justify-content:space-between;font-size:.72rem;font-weight:700;color:var(--text-secondary);margin-top:6px}.group-score-modal-actions{display:flex;justify-content:center;gap:8px;margin-top:14px}.group-score-modal-actions button{border:1px solid var(--border-color);border-radius:999px;background:var(--bg-secondary);color:var(--text-primary);font-size:.82rem;font-weight:800;padding:8px 16px;cursor:pointer}.group-score-modal-actions button:last-child{background:var(--primary-500);border-color:var(--primary-600);color:#fff}.group-student-profile{display:flex;flex-direction:column;gap:14px;align-items:center;margin:16px 0}.group-student-layout{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:24px}.group-student-side{position:sticky;top:96px;align-self:start}.group-student-highlight{margin-top:12px;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);padding:10px 12px;font-size:.78rem;font-weight:800;text-align:center;color:var(--text-secondary)}.group-student-content{display:flex;flex-direction:column;gap:12px}.group-student-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;width:100%}.group-student-tabs button{border:none;border-radius:999px;background:var(--bg-secondary);color:var(--text-secondary);font-size:.78rem;font-weight:800;padding:0;cursor:pointer;transition:transform .15s ease,border-color .15s ease,color .15s ease,background .15s ease;display:grid;place-items:center;width:36px;height:36px;box-shadow:none}.group-student-tabs button.active{color:var(--primary-600);background:var(--primary-50)}.group-student-tabs button:hover{color:var(--primary-600);background:var(--bg-card)}.group-student-tabs button:active{transform:scale(.97)}@media(max-width:900px){.group-student-layout{grid-template-columns:1fr}.group-student-side{position:static}}.group-student-avatar-large{width:110px;height:110px;border-radius:50%;background:var(--bg-secondary);border:2px solid var(--border-color);position:relative;display:grid;place-items:center;overflow:visible}.group-student-avatar-large img{width:130px;height:130px;-o-object-fit:contain;object-fit:contain;position:absolute;bottom:-6px;left:50%;transform:translate(-50%)}.group-student-avatar-large .online-dot{position:absolute;right:2px;bottom:6px;width:14px;height:14px;border-radius:999px;background:#16a34a;border:2px solid var(--bg-card)}.group-student-meta{text-align:center;display:grid;gap:6px}.group-student-points{font-family:var(--font-display);font-size:1.35rem;font-weight:700;color:#f7b21d}.group-student-streak{font-size:.8rem;font-weight:700;color:var(--text-secondary)}.group-student-xp .bar{width:min(240px,70vw);height:6px;border-radius:999px;background:var(--border-color);overflow:hidden;margin:0 auto 6px}.group-student-xp .bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#f8bf2a,#f28f24)}.group-student-xp small{font-size:.7rem;font-weight:700;color:var(--text-secondary)}.group-student-section h4{margin:0 0 8px;font-family:var(--font-display);font-size:.9rem}.student-edit-grid{display:grid;gap:10px}.student-edit-grid label{display:grid;gap:6px;font-size:.74rem;font-weight:800;color:var(--text-secondary)}.student-edit-grid input,.student-edit-grid select{border:1px solid var(--border-color);border-radius:10px;padding:8px 10px;font-weight:700;background:var(--bg-secondary);color:var(--text-primary)}.student-chess-summary{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-bottom:10px}.student-chess-metric{border:1px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);padding:10px;display:grid;gap:4px}.student-chess-metric span{font-size:.7rem;font-weight:700;color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase}.student-chess-metric strong{font-size:1rem;font-weight:900}.student-chess-match-list{display:grid;gap:8px}.student-chess-match{border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);padding:8px 10px;display:flex;justify-content:space-between;gap:8px;align-items:center}.student-chess-match-main{display:grid;gap:2px}.student-chess-match-main strong{font-size:.82rem;font-weight:800}.student-chess-match-main span{font-size:.74rem;color:var(--text-secondary)}.student-chess-match-meta{display:grid;gap:4px;justify-items:end}.student-chess-result{display:inline-flex;align-items:center;justify-content:center;min-width:46px;padding:3px 8px;border-radius:999px;font-size:.72rem;font-weight:800}.student-chess-result.win{color:#166534;background:#16a34a2e}.student-chess-result.loss{color:#991b1b;background:#ef44442e}.student-chess-result.draw{color:#334155;background:#94a3b833}.student-chess-match-meta small{font-size:.68rem;color:var(--text-secondary)}.student-credentials-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.student-credential-card{border:1px solid var(--border-color);border-radius:14px;padding:12px;background:var(--bg-secondary);display:grid;gap:8px;font-size:.78rem}.student-credential-title{font-weight:800;font-size:.82rem}.student-credential-actions{display:flex;flex-wrap:wrap;gap:8px}.student-credential-actions button{border:1px solid var(--primary-400);border-radius:999px;padding:6px 12px;background:var(--primary-500);color:#fff;font-weight:800;font-size:.75rem;cursor:pointer}.student-credential-actions button.secondary{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-color)}.student-credential-actions button:disabled{opacity:.55;cursor:not-allowed}.student-credential-value{font-weight:800;font-size:.85rem}.student-credential-open{border:1px solid var(--primary-400);border-radius:999px;padding:7px 12px;background:var(--primary-500);color:#fff;font-weight:800;font-size:.74rem;cursor:pointer}.student-credential-open:disabled{opacity:.55;cursor:not-allowed}.student-credential-hint{font-size:.72rem;color:var(--text-secondary)}.student-credential-error{font-size:.72rem;color:#ef4444;font-weight:700}.student-credential-qr{border:1px dashed var(--border-color);border-radius:12px;background:var(--bg-card);padding:8px;display:flex;align-items:center;justify-content:center;min-height:120px}.student-credential-qr img{width:120px;height:120px;-o-object-fit:contain;object-fit:contain}.student-credential-placeholder{font-size:.72rem;color:var(--text-secondary);text-align:center}.student-credential-code{font-size:.7rem;color:var(--text-secondary);word-break:break-all}.student-profile-actions{display:flex;justify-content:flex-end}.student-profile-actions button{border:1px solid var(--primary-400);border-radius:999px;padding:9px 16px;background:var(--primary-500);color:#fff;font-weight:800;font-size:.8rem;cursor:pointer}.student-points-list{display:grid;gap:8px}.student-point-row{border:1px solid var(--border-color);border-radius:12px;background:var(--bg-secondary);padding:8px 10px;display:flex;gap:10px;align-items:center}.student-point-icon{width:30px;height:30px;border-radius:9px;background:var(--bg-card);border:1px solid var(--border-color);display:grid;place-items:center;overflow:hidden}.student-point-icon img{width:18px;height:18px;-o-object-fit:contain;object-fit:contain}.student-point-icon .score-icon-fallback{width:100%;height:100%;display:inline-flex;align-items:center;justify-content:center}.student-point-icon .score-icon-fallback .fallback-mark{display:none;width:18px;height:18px;border-radius:4px;align-items:center;justify-content:center;font-size:.7rem;font-weight:900}.student-point-icon .score-icon-fallback.positive .fallback-mark{background:#16a34a2e;color:#15803d}.student-point-icon .score-icon-fallback.negative .fallback-mark{background:#dc26262e;color:#b91c1c}.student-point-icon .history-fallback{width:18px;height:18px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:900}.student-point-icon .history-fallback.positive{background:#16a34a2e;color:#15803d}.student-point-icon .history-fallback.negative{background:#dc26262e;color:#b91c1c}.student-point-row .amount{min-width:48px;text-align:center;font-weight:800;font-size:.9rem}.student-point-row .amount.plus{color:#16a34a}.student-point-row .amount.minus{color:#dc2626}.student-point-row .meta{display:grid;gap:2px}.student-point-row .reason{font-weight:700;font-size:.82rem}.student-point-row .category{font-size:.68rem;color:var(--text-secondary)}.student-point-row small{color:var(--text-secondary);font-size:.7rem}.student-point-delete{margin-left:auto;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-card);color:var(--text-secondary);font-size:.72rem;font-weight:800;padding:6px 10px;cursor:pointer}.student-point-delete:disabled{opacity:.5;cursor:not-allowed}.group-student-avatar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:14px;padding:4px;justify-content:center;justify-items:center}.student-gradient-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.student-gradient-swatch{width:58px;height:38px;border-radius:12px;border:3px solid transparent;cursor:pointer;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.student-gradient-swatch:hover{transform:scale(1.05)}.student-gradient-swatch.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-card),0 0 0 4px var(--text-primary)}.student-gradient-reset{margin-top:12px;border:1px solid var(--border-color);border-radius:999px;padding:8px 14px;background:var(--bg-secondary);font-weight:800;font-size:.74rem;color:var(--text-secondary);cursor:pointer}.student-gradient-reset:hover{border-color:var(--primary-400);color:var(--primary-600)}.avatar-option{border:2px solid transparent;border-radius:16px;background:var(--bg-secondary);padding:10px;cursor:pointer;display:grid;place-items:center;position:relative;transition:transform .15s ease,border-color .15s ease,opacity .15s ease}.avatar-option.special{border-color:#f59e0b73}.avatar-option-badge{position:absolute;top:6px;left:6px;width:18px;height:18px;border-radius:50%;display:grid;place-items:center;font-size:.65rem;font-weight:900;color:#7c2d12;background:linear-gradient(135deg,#fef3c7,#f59e0b);box-shadow:0 2px 6px #f59e0b66}.avatar-option img{width:74px;height:74px;-o-object-fit:contain;object-fit:contain}.avatar-option.selected{border-color:var(--primary-500);box-shadow:0 0 0 2px #0073e626}.avatar-option.current{border-color:var(--accent-500);box-shadow:0 0 0 2px #e6000026}.avatar-option.disabled{opacity:.35;cursor:not-allowed}.group-shuffle-overlay{position:fixed;inset:0;z-index:20000;background:#050816eb;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:grid;place-items:center;padding:16px}body.group-shuffle-active .app-navbar{opacity:.05;filter:blur(10px);pointer-events:none}body.group-shuffle-active .app-navbar *{pointer-events:none}body.group-shuffle-active{overflow:hidden}body.group-student-active .app-navbar{opacity:0;visibility:hidden;pointer-events:none;display:none}body.group-student-active .app-navbar *{pointer-events:none}body.group-student-active .app-compact-menu,body.group-student-active .app-compact-menu-backdrop{display:none}body.group-student-active{overflow:hidden}.group-shuffle-stage{width:min(460px,100%);border:none;background:transparent;box-shadow:none;padding:0;color:#f2f7ff;text-align:center;position:relative}.group-shuffle-stage.multi{width:min(720px,94vw)}.group-shuffle-stage.cycling .group-shuffle-avatar{animation:shuffle-pulse .18s linear infinite}.group-shuffle-stage.cycling .group-shuffle-avatar img{animation:shuffle-avatar-cycle .22s linear infinite}.group-shuffle-stage.final .group-shuffle-avatar{animation:shuffle-winner .5s ease}@keyframes shuffle-pulse{0%{transform:scale(1) rotate(-1deg)}50%{transform:scale(1.04) rotate(1deg)}to{transform:scale(1) rotate(-1deg)}}@keyframes shuffle-winner{0%{transform:scale(.88);opacity:.4}to{transform:scale(1);opacity:1}}@keyframes shuffle-avatar-cycle{0%{transform:scale(.95) rotate(-1deg)}50%{transform:scale(1.04) rotate(1deg)}to{transform:scale(.95) rotate(-1deg)}}.group-shuffle-avatar{width:clamp(180px,50vw,280px);height:clamp(180px,50vw,280px);margin:0 auto 14px;border-radius:0;overflow:visible;background:transparent;border:none;box-shadow:none;display:flex;align-items:center;justify-content:center}.group-shuffle-grid{display:flex;flex-direction:column;gap:18px;align-items:center;justify-content:center;margin:0 auto;width:100%}.group-shuffle-grid.cols-1{max-width:280px}.group-shuffle-grid.cols-2{max-width:520px}.group-shuffle-grid.cols-3{max-width:720px}.group-shuffle-row{display:flex;align-items:center;justify-content:center;gap:18px;width:100%}.group-shuffle-slot{display:flex;flex-direction:column;align-items:center;flex:0 1 clamp(140px,22vw,200px)}.group-shuffle-grid.cols-1 .group-shuffle-slot{flex-basis:clamp(160px,48vw,240px)}.group-shuffle-grid.cols-2 .group-shuffle-slot{flex-basis:clamp(150px,32vw,220px)}.group-shuffle-grid.cols-3 .group-shuffle-slot{flex-basis:clamp(130px,22vw,190px)}.group-shuffle-stage.multi .group-shuffle-avatar{width:clamp(130px,24vw,190px);height:clamp(130px,24vw,190px);margin-bottom:10px}.group-shuffle-stage.multi .group-shuffle-name{font-size:clamp(.95rem,3vw,1.2rem)}.group-shuffle-avatar img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;transition:transform .12s ease,opacity .12s ease,filter .18s ease;filter:drop-shadow(0 10px 18px rgba(0,0,0,.35))}.group-shuffle-name{font-family:var(--font-display);font-size:clamp(1.15rem,4.5vw,1.8rem);font-weight:700;letter-spacing:.01em}.group-score-spotlight-overlay{position:fixed;inset:0;z-index:20010;background:#050816db;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;padding:16px;animation:spotlight-fade-in .12s ease-out}.group-score-spotlight-card{width:min(420px,94vw);border-radius:0;background:transparent;border:none;box-shadow:none;padding:12px 8px;text-align:center;color:#f3f8ff;display:flex;flex-direction:column;align-items:center;gap:12px;animation:spotlight-pop-in .18s ease-out}.group-score-spotlight-avatar{width:clamp(170px,40vw,240px);height:clamp(170px,40vw,240px);display:flex;align-items:center;justify-content:center}.group-score-spotlight-avatar img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 10px 22px rgba(0,0,0,.35))}.group-score-spotlight-name{margin:0;font-family:var(--font-display);font-size:clamp(1.4rem,4vw,1.95rem);line-height:1.1;letter-spacing:.01em}.group-score-spotlight-action{width:auto;border-radius:999px;background:#081126b8;border:none;padding:8px 14px;display:flex;align-items:center;justify-content:center;gap:10px}.group-score-spotlight-action-icon{width:48px;height:48px;border-radius:999px;display:grid;place-items:center;background:transparent;border:none}.group-score-spotlight-action-icon img{width:44px;height:44px;-o-object-fit:contain;object-fit:contain}.group-score-spotlight-action-icon .score-icon-fallback{position:relative;display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center}.group-score-spotlight-action-icon .score-icon-fallback .fallback-mark{position:absolute;inset:0;display:none;align-items:center;justify-content:center;font-size:1.05rem;font-weight:900;border-radius:12px;color:#fff}.group-score-spotlight-action-icon .score-icon-fallback.positive .fallback-mark{background:#16a34a}.group-score-spotlight-action-icon .score-icon-fallback.negative .fallback-mark{background:#dc2626}.group-score-spotlight-action-meta{min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:2px}.group-score-spotlight-action-meta .label{font-size:.95rem;font-weight:700;color:#e6efff;line-height:1.2}.group-score-spotlight-action-meta strong{font-size:1.7rem;font-weight:900;line-height:1}.group-score-spotlight-action-meta strong.positive{color:#4ade80}.group-score-spotlight-action-meta strong.negative{color:#f87171}.group-confetti-layer{position:fixed;inset:0;pointer-events:none;z-index:22010;overflow:hidden}@keyframes spotlight-fade-in{0%{opacity:0}to{opacity:1}}@keyframes spotlight-pop-in{0%{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.group-confetti-piece{position:absolute;left:var(--left);top:-10px;width:var(--size);height:var(--size);background:var(--color);animation:confetti-fall var(--duration) ease-out var(--delay) forwards}.group-confetti-piece.round{border-radius:50%}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0) rotate(0)}to{opacity:0;transform:translateY(100vh) rotate(640deg)}}.group-detail-hero-skeleton{margin-left:0;margin-right:0}.group-loading-wrap{margin-top:12px;display:inline-flex;align-items:center;gap:10px;padding:6px 12px;border-radius:999px;background:#ffffff40;border:1px solid rgba(255,255,255,.4)}.group-loading-spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;animation:groupSpinner .9s linear infinite}.group-loading-text{font-size:.78rem;font-weight:700;color:#ffffffe6}@keyframes groupSpinner{to{transform:rotate(360deg)}}@media(max-width:940px){.group-detail-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.group-detail-control-bar{grid-template-columns:1fr}.group-control-open-settings-wrap{justify-content:stretch}.group-detail-main{padding:20px 12px 130px}.group-detail-hero{padding:calc(24px + var(--landing-nav-height, 64px)) 16px 24px}.group-detail-hero-character{width:74px;height:74px}.group-detail-hero-character.secondary{width:58px;height:58px}}@media(max-width:640px){.group-detail-hero-characters{display:none}.group-detail-activity-head{flex-wrap:wrap}.group-detail-activity-undo{width:100%;justify-content:center}.group-detail-tabs button,.group-detail-local-tools button{font-size:.74rem}.group-settings-panel{width:100%;max-width:100%}.group-timer-modal{padding:10px}.group-timer-drag-handle small{display:none}.group-points-dock,.group-achievements-footer{left:10px;right:10px;bottom:10px}.custom-points{margin-left:0}.group-points-dock-tools{width:100%;justify-content:space-between}.group-points-kind-toggle{flex:1 1 auto;min-width:200px}.group-points-kind-toggle button{min-width:0}}.group-timer-popout{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px;background:var(--timer-gradient)}.group-timer-popout-card{width:min(440px,100%);border:2px solid rgba(255,255,255,.25);border-radius:18px;background:#051024c2;box-shadow:0 20px 40px #0000004d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#f2f7ff;padding:16px}.group-timer-popout-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.group-timer-popout-head h1{margin:0;font-family:var(--font-display);font-size:1.2rem}.group-timer-popout-head p{margin:2px 0 0;color:#f2f7ffc7;font-size:.82rem;font-weight:700}.group-timer-popout-head button{border:1px solid rgba(255,255,255,.28);border-radius:9px;background:#ffffff1a;color:#f2f7ff;font-size:.78rem;font-weight:700;padding:7px 10px;cursor:pointer}.group-timer-popout-value{margin:18px 0;text-align:center;font-family:var(--font-game, var(--font-display));font-size:clamp(2rem,16vw,3.2rem);font-weight:700;color:#ffe38e}.group-timer-popout-presets{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.group-timer-popout-presets button{border:1px solid rgba(255,255,255,.24);border-radius:999px;background:#ffffff1a;color:#f2f7ff;font-size:.82rem;font-weight:800;padding:8px 10px;cursor:pointer}.group-timer-popout-presets button.active{background:#57a9ff59;border-color:#add8ffcc}.group-timer-popout-actions{margin-top:14px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.group-timer-popout-actions button{border:1px solid rgba(255,255,255,.24);border-radius:10px;background:#ffffff1f;color:#f2f7ff;font-size:.9rem;font-weight:800;padding:10px 12px;cursor:pointer}.minigames-page{--bg-card: #283a4f;--bg-secondary: #213246;--bg-primary: #1e2f42;--text-primary: #eef5ff;--text-secondary: #c7d7ea;--border-color: rgba(176, 199, 228, .3)}.minigames-page.page-shell:before{background:linear-gradient(155deg,#4d6077,#42566f 48%,#3e536d)}.minigames-page.page-shell:after{background:radial-gradient(circle at 10% 14%,rgba(130,162,198,.22),transparent 58%),radial-gradient(circle at 86% 18%,rgba(54,84,118,.3),transparent 62%),radial-gradient(circle at 30% 90%,rgba(81,109,140,.22),transparent 60%);opacity:.9}.minigames-page .page-hero{background:linear-gradient(135deg,#2a3e56,#22354b)}.minigames-page .page-hero:before{opacity:.45}.minigames-page .page-hero:after{background:#ffffff1a}.minigames-page .card,.minigames-page .page-empty{border-color:var(--border-color);background:linear-gradient(180deg,#2d4158,#26384d);color:var(--text-primary)}.minigames-page .dashboard-card-text,.minigames-page .text-muted{color:var(--text-secondary)}.minigames-page .card:hover{box-shadow:0 14px 28px #08122261}.budychess-end-modal{display:flex;flex-direction:column;align-items:center;gap:12px;padding:6px 0 4px;text-align:center}.budychess-end-modal-icon{font-size:3rem;line-height:1}.budychess-end-modal-subtitle{font-size:.92rem;color:#3f5066;font-weight:600;margin:0;max-width:34ch}.budychess-end-elo-summary{width:100%;max-width:360px;padding:0;display:grid;gap:10px}.budychess-end-elo-title{font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#3f5c7d;text-align:left}.budychess-end-elo-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.budychess-end-elo-row{display:grid;gap:3px;justify-items:start;font-size:.82rem;color:#4d637d;padding:9px 10px;border:1px solid rgba(96,126,160,.26);border-radius:10px;background:#f6fafff5}.budychess-end-elo-row strong{font-size:.96rem;font-weight:800}.budychess-end-elo-row small{font-size:.72rem;color:#6a819d;font-weight:700}.budychess-end-elo-pending{border:1px solid rgba(96,126,160,.24);border-radius:10px;background:#f6fafff5;color:#48607c;font-size:.82rem;font-weight:700;padding:10px 12px;text-align:center}.budychess-end-elo-row strong.is-positive{color:#34d399}.budychess-end-elo-row strong.is-negative{color:#f87171}.budychess-end-elo-row strong.is-neutral{color:#2f4561}@media(max-width:640px){.budychess-end-elo-grid{grid-template-columns:1fr}.budychess-end-player-row{flex-direction:column;align-items:flex-start;gap:6px}.budychess-end-player-elo{justify-items:start;text-align:left;min-width:0}}.budychess-end-modal-actions{display:flex;gap:8px;justify-content:center;align-items:center}.budychess-end-modal-actions .btn{display:inline-flex;align-items:center;gap:6px}.budychess-end-winner{display:flex;align-items:center;gap:10px;padding:8px 12px;border:1px solid rgba(176,199,228,.28);border-radius:12px;background:#111e2e6b}.budychess-end-winner-avatar{width:52px;height:52px;border-radius:0;overflow:visible;border:0;display:inline-flex;align-items:center;justify-content:center;font-size:1rem;font-weight:800;color:#eaf2ff;background:transparent}.budychess-end-winner-avatar img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.budychess-end-winner-meta{display:grid;gap:2px;text-align:left}.budychess-end-winner-meta strong{font-size:.86rem;color:#f3f8ff}.budychess-end-winner-meta span{font-size:.78rem;font-weight:700;color:#c6d6ea}.budychess-end-players{width:100%;max-width:540px;display:grid;gap:8px}.budychess-end-player-row{border:1px solid rgba(120,148,182,.44);border-radius:12px;background:#edf3fb;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:10px}.budychess-end-player-left{display:flex;align-items:center;gap:10px;min-width:0}.budychess-end-player-meta{display:grid;gap:1px;min-width:0;text-align:left}.budychess-end-player-meta strong{font-size:.85rem;color:#1f334b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.budychess-end-player-meta span{font-size:.75rem;font-weight:700;color:#4f6988}.budychess-end-player-elo{display:grid;gap:1px;justify-items:end;text-align:right;min-width:180px}.budychess-end-player-elo small{font-size:.72rem;color:#355271;font-weight:800}.budychess-end-player-elo strong{font-size:.8rem;font-weight:800}.budychess-end-player-elo strong.is-positive{color:#198a64}.budychess-end-player-elo strong.is-negative{color:#c84f4f}.budychess-end-player-elo strong.is-neutral{color:#2f4763}.bc-promotion-modal{display:flex;flex-direction:column;gap:10px}.bc-promotion-help{margin:0;font-size:.86rem;color:var(--text-secondary, #c7d7ea)}.bc-promotion-grid{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.bc-promotion-option{border:1px solid rgba(176,199,228,.32);border-radius:12px;background:#172435d9;color:#eaf2ff;padding:12px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:800;font-size:1rem}.bc-promotion-option:hover{border-color:#83bfffa6}.bc-promotion-piece{width:42px;height:42px;flex:0 0 auto;background-position:center;background-size:contain;background-repeat:no-repeat;filter:drop-shadow(0 3px 6px rgba(0,0,0,.36))}.bc-draw-offer-modal{display:grid;gap:10px}.bc-draw-offer-modal p{margin:0}.bc-draw-offer-modal-help{font-size:.86rem;color:var(--text-secondary, #c7d7ea)}.bc-draw-offer-modal-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}.budychess-page{--bg-card: #2b3e53;--bg-secondary: #223448;--bg-primary: #1f3247;--text-primary: #eef5ff;--text-secondary: #c7d7ea;--border-color: rgba(176, 199, 228, .32);--budychess-surface-1: #233549;--budychess-surface-2: #2a3d53;--budychess-surface-3: #324861;--budychess-surface-soft: rgba(17, 30, 46, .46);--budychess-border: rgba(182, 205, 236, .24);margin-top:-14px;height:auto;min-height:calc(100dvh - var(--landing-nav-height, 54px) - 6px)}.budychess-page.page-shell:before{background:linear-gradient(155deg,#4d6077,#42566f 48%,#3e536d)}.budychess-page.page-shell:after{background:radial-gradient(circle at 10% 14%,rgba(130,162,198,.22),transparent 58%),radial-gradient(circle at 86% 18%,rgba(54,84,118,.3),transparent 62%),radial-gradient(circle at 30% 90%,rgba(81,109,140,.22),transparent 60%);opacity:.9}.budychess-page-content{width:100%;max-width:none;margin:0;padding:0;text-align:left;height:auto;overflow:visible}.budychess-page .page-content.budychess-page-content{width:100%!important;max-width:100%!important;margin:0!important;padding:0!important;overflow-x:clip}.budychess-alert{margin-bottom:10px}.budychess-floating-message{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:1000;padding:12px 48px 12px 16px;border-radius:10px;font-size:.85rem;font-weight:600;max-width:500px;width:min(500px,calc(100vw - 28px));text-align:left;animation:slideDown .3s ease-out;box-shadow:0 8px 24px #0000004d;border:1px solid;display:flex;align-items:center;gap:10px}.budychess-floating-message-text{flex:1}.budychess-floating-message-close{position:absolute;top:8px;right:10px;width:24px;height:24px;border:0;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:1rem;line-height:1;cursor:pointer;color:#fff;background:#0f172a38;transition:background .15s ease}.budychess-floating-message-close:hover{background:#0f172a57}.budychess-floating-message-close:focus-visible{outline:2px solid rgba(255,255,255,.9);outline-offset:1px}.budychess-floating-message.is-success{background:linear-gradient(135deg,#4ade80e6,#22c55ee6);color:#fff;border-color:#86f0accc}.budychess-floating-message.is-error{background:linear-gradient(135deg,#f87171e6,#ef4444e6);color:#fff;border-color:#fca2a2cc}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.budychess-shell{border-radius:0;border:none;background:transparent;box-shadow:none;overflow:hidden;min-height:calc(100dvh - var(--landing-nav-height, 54px) - 6px);height:auto;display:flex;flex-direction:column}.budychess-header{padding:6px 10px;border-bottom:1px solid var(--border-color);display:grid;gap:10px;grid-template-columns:minmax(200px,1fr) minmax(200px,300px);align-items:center;background:linear-gradient(180deg,#2f445cf2,#26384deb)}.budychess-header-title{display:flex;align-items:center;gap:12px;min-width:0}.budychess-header,.budychess-tabs,.budychess-card{color:#e9f1fb}.budychess-page .dashboard-card-title{color:#f3f8ff}.budychess-page .dashboard-card-text,.budychess-page .text-muted,.budychess-page .budychess-player-chip span,.budychess-page .budychess-rank,.budychess-page .budychess-summary-item span,.budychess-page .budychess-history-meta,.budychess-page .budychess-san-row span{color:#c6d6ea}.budychess-header-logo{width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#62b3ff,#6f5cff);box-shadow:0 6px 18px #1f4ca147;overflow:hidden}.budychess-header-logo img{width:85%;height:85%;-o-object-fit:contain;object-fit:contain}.budychess-header-copy h1{margin:0;font-size:1.1rem;font-weight:900;letter-spacing:.01em;line-height:1.1}.budychess-header-copy p{margin:1px 0 0;font-size:.74rem;color:var(--text-secondary);font-weight:700}.budychess-header-group{display:grid;gap:4px}.budychess-header-group label{font-size:.72rem;font-weight:800;color:var(--text-secondary)}.budychess-header-group .input{min-height:36px}.budychess-header-group-meta{font-size:.72rem;color:var(--text-secondary);font-weight:700}.budychess-header-clock{display:grid;gap:4px}.budychess-header-clock label{font-size:.72rem;font-weight:800;color:var(--text-secondary)}.budychess-header-clock-controls{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:flex-end}.budychess-icon-btn{width:38px;min-width:38px;height:34px;padding:0!important;font-size:1rem;line-height:1;display:inline-flex!important;align-items:center;justify-content:center;border-radius:12px;color:#dcecff!important;border-color:#78adf1a6!important;background:#111f3094!important;cursor:pointer}.budychess-icon-btn svg{width:18px;height:18px;stroke-width:2.25}.budychess-icon-btn:hover:not(:disabled){background:#3467a46b!important;border-color:#86baffe0!important}.budychess-icon-btn.is-highlighted{border-color:#facc15e6;color:#ffe08a;background:#a8760938}.budychess-header-clock-display{display:inline-flex;gap:6px}.budychess-clock-chip{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;min-width:86px;border:1px solid var(--border-color);border-radius:999px;background:#0d18276b;color:#dcecff;font-size:.76rem;font-weight:800}.budychess-clock-chip.is-active{border-color:#78adf1d6;background:#4372ad66;color:#fff}.budychess-header-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end}.budychess-content-layout{display:grid;grid-template-columns:220px minmax(0,1fr);min-height:0;flex:1;overflow:visible}.budychess-content-layout.no-sidenav{grid-template-columns:minmax(0,1fr)}.budychess-content-layout.is-sidenav-collapsed{grid-template-columns:74px minmax(0,1fr)}.budychess-sidenav{border-right:1px solid rgba(182,205,236,.14);background:transparent;padding:10px;display:grid;align-content:start;gap:8px;overflow:visible}.budychess-sidenav-collapse-btn{width:100%;min-height:34px;border:1px solid var(--border-color);border-radius:10px;background:#0d18276b;color:#dcecff;display:inline-flex;align-items:center;justify-content:center;padding:0;cursor:pointer}.budychess-sidenav-collapse-btn svg{width:16px;height:16px}.budychess-sidenav-section{font-size:.7rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#9ab3cf;margin-top:4px}.budychess-sidenav-btn{display:inline-flex;align-items:center;gap:8px;width:100%;border:1px solid var(--border-color);background:#0d18276b;color:#dcecff;border-radius:10px;padding:8px 10px;font-size:.82rem;font-weight:700;text-align:left;transition:all .18s ease;cursor:pointer}.budychess-sidenav-btn:hover{border-color:#78adf1a8;color:#fff}.budychess-sidenav-btn.is-active{border-color:#78adf1d1;background:#4372ad6b;color:#fff}.budychess-sidenav-icon{width:18px;display:inline-flex;justify-content:center}.budychess-sidenav-btn-label{white-space:nowrap}.budychess-content-layout.is-sidenav-collapsed .budychess-sidenav{align-content:start}.budychess-content-layout.is-sidenav-collapsed .budychess-sidenav-section,.budychess-content-layout.is-sidenav-collapsed .budychess-sidenav-btn-label{display:none}.budychess-content-layout.is-sidenav-collapsed .budychess-sidenav-btn{justify-content:center;padding:9px 0}.budychess-main{min-width:0;min-height:0;display:flex;flex:1}.budychess-tabs{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border-color);background:linear-gradient(180deg,#2b3e54f0,#233447e6)}.budychess-tab{border:1px solid var(--border-color);background:var(--budychess-surface-soft);color:#dbe8f8;border-radius:999px;padding:8px 14px;font-size:.83rem;font-weight:800;cursor:pointer;transition:all .18s ease}.budychess-tab:hover{border-color:#78adf1a8;color:#fff}.budychess-tab.is-active{border-color:#78adf1d1;background:#4372ad6b;color:#fff}.budychess-page .input{background:#0d182780;border-color:var(--border-color);color:#edf4ff}.budychess-page .input:focus{border-color:#78adf1bf;box-shadow:0 0 0 3px #387bd247}.budychess-page .btn.btn-outline{background:#0d18276b;border-color:#78adf1b3;color:#dcecff}.budychess-page .btn.btn-outline:hover{background:#387bd259;color:#fff}.budychess-nav-tabs{display:flex;align-items:center;gap:6px;padding:8px 12px;border-bottom:1px solid var(--border-color);background:#162435e0;overflow-x:auto;flex-shrink:0}.budychess-nav-tab{border:1px solid var(--border-color);background:#0d18276b;color:#dbe8f8;border-radius:999px;padding:7px 14px;font-size:.82rem;font-weight:800;cursor:pointer;white-space:nowrap;transition:all .18s ease;flex-shrink:0}.budychess-nav-tab:hover{border-color:#78adf1a8;color:#fff}.budychess-nav-tab.is-active{border-color:#78adf1d1;background:#4372ad6b;color:#fff}.budychess-color-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.budychess-color-btn{border:2px solid var(--border-color);border-radius:12px;background:#0d18276b;padding:12px 6px 8px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:all .18s ease}.budychess-color-btn:hover:not(:disabled){border-color:#78adf1b3;background:#2848746b}.budychess-color-btn.is-active{border-color:#78adf1eb;background:#4372ad75}.budychess-color-btn:disabled{opacity:.5}.budychess-color-piece{width:44px;height:44px;background-repeat:no-repeat;background-position:center;background-size:contain;display:block;flex-shrink:0}.budychess-color-random{width:44px;height:44px;border-radius:50%;background:linear-gradient(to right,#ede8cf 50%,#5a7a42 50%);display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:900;color:#0000008c;border:2px solid rgba(182,205,236,.25);flex-shrink:0}.budychess-color-btn-label{font-size:.68rem;font-weight:800;color:#b0c4db;text-align:center;line-height:1}.budychess-color-btn.is-active .budychess-color-btn-label{color:#fff}.budychess-tab-panel{padding:8px;flex:1;min-height:0;display:flex;overflow:visible}.budychess-card{border-radius:14px;border:1px solid var(--budychess-border);background:linear-gradient(180deg,var(--budychess-surface-2),var(--budychess-surface-1));box-shadow:0 10px 24px #0511204d}.budychess-card:hover{transform:none;box-shadow:0 10px 24px #0511204d}.budychess-card .card-header{padding:13px 14px;display:flex;justify-content:space-between;align-items:center;gap:10px}.budychess-card .card-body{padding:14px}.budychess-learning-list,.budychess-scenarios,.budychess-form,.budychess-ranking-body,.budychess-history-body,.budychess-san-history,.budychess-play-controls{display:grid;gap:10px}.budychess-clock-panel{border:1px solid var(--border-color);border-radius:10px;background:#101f3170;padding:10px;display:grid;gap:8px}.budychess-mode-picker{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.budychess-mode-btn{border:1px solid var(--border-color);border-radius:10px;background:#0d18276b;color:#dcecff;padding:6px;min-height:52px;font-size:.78rem;font-weight:800;transition:all .16s ease;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.budychess-mode-btn:hover{border-color:#78adf1bd;color:#fff}.budychess-mode-btn.is-active{border-color:#78adf1d6;background:#4372ad66;color:#fff}.budychess-mode-btn svg{width:20px;height:20px}.budychess-mode-btn-mascot{width:30px;height:30px;-o-object-fit:contain;object-fit:contain;display:block}.budychess-mode-btn-local{display:inline-flex;align-items:center;gap:4px;font-weight:900}.budychess-mode-btn-local span{font-size:.95rem;line-height:1;color:#dcecff}.budychess-preset-btn.is-active{border-color:#78adf1d6;background:#4372ad66;color:#fff}.budychess-mode-panel{border:1px solid var(--border-color);border-radius:12px;background:#0d18274d;padding:10px;display:grid;gap:10px}.budychess-accordion-toggle{width:100%;border:1px solid var(--border-color);border-radius:10px;background:#0a142294;color:#e6f1ff;padding:8px 10px;display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;font-size:.79rem;font-weight:800;cursor:pointer}.budychess-accordion-toggle svg{width:14px;height:14px}.budychess-accordion-title{text-align:left}.budychess-accordion-meta{font-size:.72rem;color:#b7cae3}.budychess-accordion-body{display:grid;gap:10px;border:1px solid rgba(147,176,210,.26);border-radius:10px;padding:10px;background:#09121e61}.budychess-switch-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;font-size:.8rem;color:var(--text-secondary);font-weight:700}.budychess-switch{width:42px;height:24px;border-radius:999px;border:1px solid var(--border-color);background:#0d182780;position:relative;padding:0;display:inline-flex;align-items:center}.budychess-switch-thumb{width:18px;height:18px;border-radius:999px;background:#dcecff;position:absolute;left:2px;transition:transform .16s ease}.budychess-switch.is-on{background:#2b8ae885;border-color:#86baffe0}.budychess-switch.is-on .budychess-switch-thumb{transform:translate(18px)}.budychess-switch:disabled{opacity:.45}.budychess-mode-row{display:grid;gap:6px}.budychess-inline-section{margin-top:2px;border-top:1px solid rgba(182,205,236,.18);padding-top:10px;display:grid;gap:10px}.budychess-inline-title{margin:0;font-size:.82rem;font-weight:800;color:#dcecff}.budychess-choice-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.budychess-choice-btn{border:1px solid var(--border-color);border-radius:10px;background:#0d18276b;color:#dcecff;min-height:58px;padding:8px 6px;display:grid;justify-items:center;align-content:center;gap:2px;transition:all .16s ease;cursor:pointer}.budychess-choice-btn:hover:not(:disabled){border-color:#78adf1bd;color:#fff}.budychess-choice-btn.is-active{border-color:#78adf1e6;background:#4372ad75;color:#fff}.budychess-choice-btn:disabled{opacity:.5}.budychess-choice-icon{font-size:1.08rem;line-height:1}.budychess-choice-label{font-size:.72rem;font-weight:800;line-height:1.1}.budychess-mode-note{font-size:.78rem;color:var(--text-secondary);font-weight:700}.budychess-elo-slider-wrap{display:grid;gap:6px}.budychess-elo-slider{width:100%;accent-color:#78adf1}.budychess-elo-slider-value{font-size:.76rem;color:#dcecff;font-weight:800}.budychess-difficulty-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.budychess-difficulty-btn{border:1px solid var(--border-color);border-radius:10px;background:#0d18276b;padding:8px 4px;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;color:var(--text-secondary);transition:border-color .15s,background .15s,color .15s;text-align:center;line-height:1.2}.budychess-difficulty-btn:hover:not(:disabled){border-color:#78adf1bd;color:#fff}.budychess-difficulty-btn.is-active{border-color:#78adf1e6;background:#4372ad73;color:#fff}.budychess-difficulty-btn.is-server{border-style:dashed}.budychess-difficulty-btn:disabled{opacity:.45;cursor:default}.budychess-difficulty-label{font-size:.78rem;font-weight:800}.budychess-difficulty-elo{font-size:.68rem;font-weight:700;color:#78adf1}.budychess-difficulty-btn.is-active .budychess-difficulty-elo{color:#b8d8ff}.budychess-difficulty-desc{font-size:.62rem;font-weight:600;opacity:.78}.budychess-preview{border:1px solid var(--border-color);border-radius:12px;background:#09121e73;padding:12px 10px 10px;display:flex;flex-direction:column;gap:10px}.budychess-preview-matchup{display:flex;align-items:center;justify-content:space-between;gap:8px}.budychess-preview-side{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}.budychess-preview-avatar{width:40px;height:40px;border-radius:50%;border:1px solid var(--border-color);background:#0d182799;overflow:hidden;display:flex;align-items:center;justify-content:center}.budychess-preview-avatar-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.budychess-preview-avatar-initial,.budychess-preview-avatar-q{font-size:1rem;font-weight:800;color:#78adf1;line-height:1}.budychess-preview-piece{font-size:1.15rem;line-height:1;color:#dcecff}.budychess-preview-name{font-size:.7rem;font-weight:700;color:var(--text-secondary);text-align:center;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budychess-preview-vs{font-size:.72rem;font-weight:900;color:var(--text-secondary);letter-spacing:.05em;flex-shrink:0}.budychess-preview-tags{display:flex;flex-wrap:wrap;gap:5px;justify-content:center}.budychess-preview-tag{font-size:.65rem;font-weight:700;color:#78adf1;background:#4372ad38;border:1px solid rgba(120,173,241,.35);border-radius:999px;padding:2px 8px;line-height:1.4}.budychess-mode-check{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-secondary);font-weight:700}.budychess-learn-grid{width:100%;display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.budychess-learning-item{border:1px solid var(--border-color);border-radius:12px;padding:10px 12px;background:#101f3170}.budychess-learning-item strong{display:block;font-size:.9rem}.budychess-learning-item p{margin:4px 0 0;font-size:.8rem;color:var(--text-secondary)}.budychess-scenario{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;border:1px solid var(--border-color);border-radius:12px;padding:10px 12px;background:#101f3170}.budychess-scenario strong{font-size:.9rem}.budychess-scenario p{margin:2px 0;font-size:.79rem;color:var(--text-secondary)}.budychess-scenario span{font-size:.76rem;color:var(--text-secondary)}.budychess-play-layout{width:100%;display:grid;gap:6px;grid-template-columns:clamp(200px,16vw,280px) minmax(0,1fr) clamp(200px,15vw,260px);height:auto;min-height:0;overflow-x:hidden;overflow-y:visible;align-items:start}.budychess-play-left,.budychess-play-right{display:grid;gap:12px;align-content:start;min-height:0;overflow:visible;padding-right:2px}.budychess-play-center{min-width:0;min-height:0;display:flex}.budychess-mini-list{display:grid;gap:8px}.budychess-player-chip{display:grid;grid-template-columns:42px 1fr auto;align-items:center;gap:8px;border:1px solid var(--border-color);border-radius:10px;padding:8px 10px;background:#101f3170}.budychess-player-chip span{font-size:.74rem;font-weight:800;color:var(--text-secondary)}.budychess-player-chip strong{font-size:.84rem}.budychess-player-chip em{font-style:normal;font-size:.8rem;font-weight:800;color:var(--primary-600)}.budychess-board-card .card-body{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:8px;flex:1;min-height:0}.budychess-board-body{display:grid;gap:2px;grid-template-rows:auto auto 1fr auto;position:relative}.budychess-board-meta-line{min-height:14px;font-size:.75rem;font-weight:700;color:#c6d6ea;text-align:center}.budychess-board-card .card-header{align-items:flex-start;gap:12px}.budychess-board-header-main{display:grid;gap:2px}.budychess-board-header-controls{margin-left:auto;display:grid;gap:6px;justify-items:end}.budychess-board-header-controls #budychess-clock-preset{min-width:136px}.budychess-board-card{width:100%;min-height:0;display:flex;flex-direction:column;overflow:visible}.budychess-board-stage{display:flex;align-items:stretch;justify-content:center;gap:10px;width:100%}.budychess-board-side-controls{display:grid;grid-auto-rows:min-content;gap:8px;align-content:center;padding-top:0}.budychess-board-shell{--coord-col: 22px;--coord-gap: 6px;--captured-col: 30px;--captured-piece-size: 18px;--board-edge: 2px;--board-max-size: clamp(300px, calc(100dvh - var(--landing-nav-height, 54px) - 310px), 70dvh);--board-shell-side-padding: calc( var(--captured-col) + var(--coord-col) + var(--coord-gap) + var(--coord-gap) );width:min(100%,calc(var(--board-max-size) + var(--board-shell-side-padding) + var(--board-shell-side-padding)));margin:0 auto;display:grid;gap:4px}.bc-online-chat-side{width:230px;flex:0 0 230px;border:1px solid rgba(176,199,228,.24);border-radius:12px;background:#09121e9e;padding:10px;display:grid;grid-template-rows:auto minmax(0,1fr);gap:8px;min-height:240px;height:auto;align-self:stretch;overflow:hidden;transition:width .18s ease,flex-basis .18s ease,min-height .18s ease,padding .18s ease,border-color .18s ease,background-color .18s ease}.bc-online-chat-side.is-disabled{opacity:.62;border-style:dashed}.bc-online-chat-side.is-collapsed{width:64px;min-width:64px;flex-basis:64px;min-height:64px;align-self:flex-start;padding:8px 6px}.bc-online-chat-header{display:flex;align-items:center}.bc-online-chat-header svg{width:15px;height:15px}.bc-online-chat-toggle{width:100%;border:1px solid rgba(176,199,228,.28);border-radius:10px;background:#101f318a;color:#dcecff;display:inline-flex;align-items:center;justify-content:space-between;gap:6px;font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.03em;padding:7px 8px;transition:border-color .16s ease,background-color .16s ease,color .16s ease}.bc-online-chat-toggle:hover{border-color:#78adf194;background:#1b344fa8}.bc-online-chat-toggle-chevron{width:14px;height:14px;opacity:.85}.bc-online-chat-side.is-collapsed .bc-online-chat-toggle{justify-content:center;padding:8px 6px}.bc-online-chat-side.is-collapsed .bc-online-chat-toggle-chevron{width:13px;height:13px}.bc-online-chat-unread{min-width:20px;height:20px;border-radius:999px;background:#1d8bf1;color:#f7fbff;font-size:.62rem;font-weight:800;line-height:1;display:inline-flex;align-items:center;justify-content:center;padding:0 6px;transition:transform .16s ease,opacity .16s ease}.bc-online-chat-content{display:grid;grid-template-rows:minmax(0,1fr) auto auto;gap:8px;min-height:0;max-height:2000px;opacity:1;transform:translateY(0);overflow:hidden;transition:max-height .22s ease,opacity .18s ease,transform .22s ease}.bc-online-chat-content.is-hidden{max-height:0;opacity:0;transform:translateY(-8px);pointer-events:none}.bc-online-chat-log{border:1px solid rgba(176,199,228,.2);border-radius:10px;background:#0f1b2ab8;padding:8px;display:grid;gap:6px;align-content:start;overflow-y:auto;min-height:0;max-height:none;height:100%}.bc-online-chat-item{display:grid;gap:2px;padding:6px 8px;border-radius:8px;background:#2c4c7057;color:#e6f1ff;font-size:.72rem;text-align:left}.bc-online-chat-item.is-self{background:#38bdf83d}.bc-online-chat-author{font-size:.65rem;font-weight:800;text-transform:uppercase;color:#9dc5f8}.bc-online-chat-empty{font-size:.72rem;color:#9db3cd;text-align:center;padding:8px 4px;margin:auto 0}.bc-online-chat-quick-grid{display:grid;gap:6px}.bc-online-chat-disabled-note{font-size:.68rem;color:#9db3cd;text-align:center;padding:2px 4px 0}.budychess-board-player{display:flex;align-items:center;gap:10px;width:100%;border:1px solid var(--border-color);border-radius:12px;padding:10px 12px;background:#101f3170;position:relative;overflow:visible}.budychess-board-player.is-active{border-color:#78adf1d6;box-shadow:inset 0 0 0 1px #78adf14d}.budychess-board-player-turn{font-size:.65rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#78adf1;line-height:1}.budychess-board-player-avatar{width:60px;height:60px;border-radius:0;overflow:visible;border:0;background:transparent;display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:900;color:#fff;flex:0 0 auto;line-height:1;position:relative;margin-block:-8px;z-index:2}.budychess-board-player-avatar img{width:84px;height:84px;max-width:none;position:absolute;left:50%;top:50%;transform:translate(-50%,-55%);-o-object-fit:contain;object-fit:contain;display:block;filter:drop-shadow(0 7px 14px rgba(3,8,14,.45));pointer-events:none}.budychess-board-player-left{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.budychess-board-player-meta{display:grid;gap:0px;min-width:0}.budychess-board-player-meta.is-recommend-mode{display:flex;align-items:center;gap:10px;flex-wrap:nowrap;min-width:0}.budychess-board-player-name{font-size:.82rem;font-weight:800;color:#f3f8ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.budychess-board-player-rating{font-size:.72rem;color:#c6d6ea;font-weight:700}.bc-online-recommend-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:2px}.bc-online-recommend-only-empty{display:inline-flex;align-items:center;min-width:0}.budychess-board-player.is-pre-match-online{padding-top:8px;padding-bottom:8px}.budychess-board-player.is-pre-match-online .budychess-board-player-avatar{width:52px;height:52px;font-size:1.12rem;margin-block:-5px}.budychess-board-player.is-pre-match-online .budychess-board-player-avatar img{width:72px;height:72px}.budychess-board-player-meta.is-recommend-mode .bc-online-recommend-row{margin-top:0;gap:8px;flex-wrap:nowrap;min-width:0}.bc-online-recommend-text{font-size:.66rem;font-weight:700;color:#f6c15a;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.budychess-board-player-meta.is-recommend-mode .bc-online-recommend-row .btn{white-space:nowrap}.budychess-board-player-clock{margin-left:auto;min-width:60px;text-align:right;font-size:1rem;font-weight:900;color:#dcecff;flex:0 0 auto}.budychess-board-player-turn-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:1;max-width:40%;display:block;text-align:center;font-size:.76rem;font-weight:800;color:#d6e6fb;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.budychess-board-player.is-active .budychess-board-player-clock{color:#ffe49a}.budychess-board-player-clock.is-expired{color:#ff8f8f}.budychess-board-row{display:grid;grid-template-columns:var(--captured-col) var(--coord-col) 1fr var(--coord-col) var(--captured-col);gap:var(--coord-gap);align-items:stretch}.budychess-captured-column{border:1px solid rgba(176,199,228,.24);border-radius:10px;background:#09121e8f;padding:5px 2px;display:flex;align-items:flex-start;justify-content:center;min-width:0;overflow:hidden}.budychess-captured-stack{width:100%;display:grid;align-content:start;justify-items:center;gap:1px}.budychess-captured-piece{width:var(--captured-piece-size);height:var(--captured-piece-size);background-repeat:no-repeat;background-position:center;background-size:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.32));opacity:.96}.budychess-captured-empty{font-size:.7rem;color:#c6d6eac2;font-weight:700;line-height:1;margin-top:2px}.budychess-board-ranks{display:grid;grid-template-rows:repeat(8,minmax(0,1fr));font-size:.72rem;font-weight:800;color:var(--text-secondary);line-height:1;height:100%}.budychess-board-ranks span{display:flex;align-items:center;justify-content:center}.budychess-board{width:100%;height:auto;max-width:100%;max-height:100%;aspect-ratio:1 / 1;display:grid;grid-template-columns:repeat(8,minmax(0,1fr));grid-template-rows:repeat(8,minmax(0,1fr));border-radius:16px;box-shadow:inset 0 0 0 var(--board-edge) color-mix(in srgb,var(--border-color) 72%,#000000 28%);overflow:hidden}.budychess-square{border:none;padding:0;margin:0;min-width:0;min-height:0;position:relative;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.budychess-square:disabled{cursor:default}.budychess-square.is-light{background:#f3f0df}.budychess-square.is-dark{background:#799954}.budychess-square.is-selected{box-shadow:inset 0 0 0 4px #3b82f6b8}.budychess-square.is-last-move:after{content:"";position:absolute;inset:0;background:#f59e0b47}.budychess-square.is-hint-from{box-shadow:inset 0 0 0 3px #facc15d1}.budychess-square.is-hint-to{box-shadow:inset 0 0 0 3px #38bdf8d1}.budychess-square.is-candidate:before{content:"";position:absolute;width:32%;aspect-ratio:1 / 1;border-radius:999px;background:#14172033;z-index:0}.budychess-dot{width:24%;aspect-ratio:1 / 1;border-radius:999px;background:#13171f3d}.budychess-piece{width:84%;height:84%;position:relative;z-index:1;display:block;background-repeat:no-repeat;background-position:center;background-size:contain;filter:drop-shadow(0 2px 3px rgba(0,0,0,.28))}.budychess-piece.piece-w{filter:drop-shadow(0 2px 3px rgba(0,0,0,.36))}.budychess-piece.piece-b{filter:drop-shadow(0 2px 3px rgba(0,0,0,.34))}.budychess-piece.piece-rotate-local-black{transform:rotate(180deg)}.budychess-board-files{width:100%;padding-left:var(--board-shell-side-padding);padding-right:var(--board-shell-side-padding)}.budychess-board-files-grid{width:100%;display:grid;grid-template-columns:repeat(8,minmax(0,1fr));font-size:.74rem;font-weight:800;color:var(--text-secondary);line-height:1}.budychess-board-files-grid span{display:flex;align-items:center;justify-content:center}.budychess-status-line{border:1px solid var(--border-color);border-radius:10px;padding:10px;background:#101f3170;font-size:.84rem;font-weight:800}.budychess-san-history{max-height:210px;overflow:auto;align-content:start}.budychess-san-row{display:grid;grid-template-columns:36px 1fr 1fr;gap:8px;border:1px solid var(--border-color);border-radius:9px;padding:7px 9px;background:#101f3170;align-items:center}.budychess-san-row span{color:var(--text-secondary);font-size:.75rem;font-weight:700}.budychess-dashboard-grid{width:100%;display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.budychess-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.budychess-summary-item{border:1px solid var(--border-color);border-radius:11px;padding:10px;background:#101f3170;display:grid;gap:2px}.budychess-summary-item span{font-size:.75rem;font-weight:700;color:var(--text-secondary)}.budychess-summary-item strong{font-size:1.02rem}.budychess-player-row{display:grid;grid-template-columns:44px 1fr auto;gap:8px;align-items:center;padding:8px 10px;border:1px solid var(--border-color);border-radius:11px;background:#101f3170}.budychess-rank{font-size:.76rem;font-weight:800;color:var(--text-secondary)}.budychess-player-name{font-size:.9rem;font-weight:700}.budychess-player-rating{font-size:.9rem;font-weight:800;color:var(--primary-600)}.budychess-history-body{max-height:360px;overflow:auto}.budychess-history-item{border:1px solid var(--border-color);border-radius:11px;padding:8px 10px;display:grid;gap:4px;background:#101f3170}.budychess-page .card,.budychess-page .card:hover,.budychess-page .budychess-player-chip,.budychess-page .budychess-player-row,.budychess-page .budychess-history-item,.budychess-page .budychess-san-row,.budychess-page .budychess-learning-item,.budychess-page .budychess-scenario{transform:none!important;translate:none!important;transition:none!important}.budychess-history-main{display:flex;align-items:center;gap:6px;font-size:.85rem}.budychess-history-meta{display:flex;justify-content:space-between;font-size:.74rem;color:var(--text-secondary)}.budychess-history-delta{display:flex;justify-content:flex-end;gap:10px;font-size:.78rem;font-weight:800;flex-wrap:wrap}.budychess-history-delta .is-up{color:var(--success-600)}.budychess-history-delta .is-down{color:var(--danger-600)}.budychess-history-delta .is-even{color:var(--text-secondary)}.budychess-activity-card{grid-column:span 2}@media(max-width:1320px){.budychess-header{grid-template-columns:1fr;align-items:start}.budychess-header-actions{justify-content:flex-start}.budychess-content-layout{grid-template-columns:200px minmax(0,1fr)}.budychess-play-layout{grid-template-columns:minmax(240px,.8fr) minmax(0,1.5fr);overflow-x:hidden;overflow-y:visible}.budychess-play-center{grid-column:2 / 3}.budychess-play-left,.budychess-play-right{grid-template-columns:1fr;overflow:visible;padding-right:0}.budychess-play-right{grid-column:1 / 2;grid-row:2 / 3}.budychess-dashboard-grid{grid-template-columns:1fr}.budychess-activity-card{grid-column:auto}.budychess-board-player-meta.is-recommend-mode{flex-wrap:wrap;align-items:flex-start;row-gap:2px}.budychess-board-player-meta.is-recommend-mode .bc-online-recommend-row{width:100%}}@media(max-width:980px){.budychess-shell{height:auto;min-height:calc(100vh - 96px)}.budychess-tab-panel{overflow:visible}.budychess-content-layout,.budychess-content-layout.is-sidenav-collapsed{grid-template-columns:1fr}.budychess-sidenav{border-right:none;border-bottom:1px solid rgba(182,205,236,.14);background:transparent;grid-auto-flow:column;grid-auto-columns:max-content;align-items:center;overflow-x:auto;overflow-y:hidden;padding:8px;gap:6px}.budychess-sidenav-collapse-btn,.budychess-sidenav-section{display:none}.budychess-play-layout{grid-template-columns:1fr;height:auto;overflow:visible}.budychess-board-card .card-header{flex-direction:column;align-items:stretch}.budychess-board-header-controls{margin-left:0;justify-items:stretch}.budychess-header-clock-controls{justify-content:flex-start}.budychess-board-stage{flex-direction:column;align-items:stretch;gap:8px}.budychess-board-player-avatar{width:54px;height:54px;font-size:1.25rem;margin-block:-4px}.budychess-board-player-avatar img{width:74px;height:74px}.budychess-board-player.is-pre-match-online .budychess-board-player-avatar{width:46px;height:46px;margin-block:-2px}.budychess-board-player.is-pre-match-online .budychess-board-player-avatar img{width:62px;height:62px}.budychess-board-side-controls{display:flex;flex-wrap:wrap;justify-content:center;padding-top:0}.budychess-play-center{grid-column:auto}.budychess-play-right{grid-column:auto;grid-row:auto}.budychess-board{width:100%;height:auto;max-width:100%}.budychess-board-shell{--coord-col: 18px;--coord-gap: 4px;--captured-col: 24px;--captured-piece-size: 14px;width:100%}.budychess-board-files{padding-left:var(--board-shell-side-padding);padding-right:var(--board-shell-side-padding)}.bc-online-overlay-stack{inset:auto 10px 96px;width:auto}.bc-online-overlay-stack.has-side-chat{right:10px;width:auto}.bc-online-chat-side{width:100%;flex-basis:auto;min-height:180px}.bc-online-chat-side.is-collapsed{width:100%;min-width:0;flex-basis:auto;padding:8px}.bc-online-chat-quick-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.bc-online-quick-btn{width:auto}}@media(max-width:900px){.budychess-page-content{width:100%;padding:4px 0 14px}.budychess-page .page-content.budychess-page-content{width:100%!important;max-width:100%!important;margin:0!important;padding:0!important}.budychess-shell{border-radius:0;min-height:calc(100vh - 92px)}.budychess-mode-picker,.budychess-learn-grid,.budychess-summary,.budychess-scenario{grid-template-columns:1fr}}.bc-learning-mvp-shell{width:100%;display:grid;gap:10px;margin-bottom:10px}.bc-learning-mvp-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;border:1px solid rgba(176,199,228,.22);border-radius:14px;background:linear-gradient(180deg,#122133d1,#0f1a29c2);padding:12px 14px}.bc-learning-mvp-header h2{margin:0;font-size:1rem}.bc-learning-mvp-header p{margin:4px 0 0;font-size:.8rem;color:#c6d6ea;max-width:70ch}.bc-learning-mvp-grid{display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}.bc-learning-mvp-card{border:1px solid rgba(176,199,228,.22);border-radius:14px;background:#0c1827b8;padding:12px;display:grid;gap:10px;align-content:start}.bc-learning-mvp-card h3{margin:0;font-size:.92rem;color:#f1f7ff}.bc-learning-block-map{display:grid;gap:8px}.bc-learning-block-item{border:1px solid rgba(176,199,228,.18);border-radius:12px;background:#142436d1;padding:10px;color:#eaf2ff;text-align:left;display:grid;gap:6px}.bc-learning-block-item:hover{border-color:#7eb8f6a3}.bc-learning-block-item-top{display:grid;gap:2px}.bc-learning-block-step{font-size:.66rem;text-transform:uppercase;letter-spacing:.05em;color:#9dc5f8;font-weight:800}.bc-learning-block-item p{margin:0;font-size:.75rem;color:#c6d6ea}.bc-learning-progress-fill{height:100%;display:block;background:linear-gradient(90deg,#61b0ff,#79dd95);border-radius:999px}.bc-learning-category-row{display:flex;flex-wrap:wrap;gap:6px}.bc-learning-category-btn{border:1px solid rgba(176,199,228,.25);border-radius:999px;background:#142436c7;color:#d9e8fb;font-size:.72rem;font-weight:700;padding:6px 10px}.bc-learning-category-btn.is-active{border-color:#7eb8f6b8;background:#294c72db;color:#fff}.bc-learning-exercise-list{display:grid;gap:7px;max-height:280px;overflow:auto;padding-right:2px}.bc-learning-exercise-item{border:1px solid rgba(176,199,228,.2);border-radius:10px;background:#111f30d6;color:#eaf2ff;text-align:left;padding:10px;display:grid;gap:5px}.bc-learning-exercise-item.is-active{border-color:#7eb8f6cc}.bc-learning-exercise-item.is-done{border-color:#7ad894b3}.bc-learning-exercise-item p{margin:0;font-size:.74rem;color:#c6d6ea}.bc-learning-exercise-item small{font-size:.68rem;color:#9ec4ef;font-weight:700}.bc-learning-exercise-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.bc-learning-diff{font-size:.62rem;text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:2px 7px;background:#b0c7e433}.bc-learning-diff.is-easy{color:#8dffb8}.bc-learning-diff.is-medium{color:#ffe397}.bc-learning-diff.is-hard{color:#ffb4b4}.bc-learning-selected{border:1px dashed rgba(176,199,228,.32);border-radius:11px;background:#0d1724c7;padding:10px;display:grid;gap:8px}.bc-learning-selected h4,.bc-learning-selected p{margin:0}.bc-learning-selected p{font-size:.78rem;color:#c6d6ea}.bc-learning-hints{display:flex;flex-wrap:wrap;gap:6px}.bc-learning-hint-pill{font-size:.68rem;border-radius:999px;padding:3px 8px;background:#f1c15a26;color:#ffd888}.bc-learning-actions{display:flex;flex-wrap:wrap;gap:6px}.bc-learning-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.bc-learning-stats div{border:1px solid rgba(176,199,228,.18);border-radius:10px;background:#142436b3;padding:8px;display:grid;gap:2px}.bc-learning-stats span{font-size:.66rem;color:#9ec4ef;text-transform:uppercase;font-weight:700;letter-spacing:.05em}.bc-learning-stats strong{font-size:1rem;color:#f3f8ff}.bc-learning-badge-row{display:flex;flex-wrap:wrap;gap:6px}.bc-learning-badge{border-radius:999px;padding:4px 8px;font-size:.68rem;background:#7159ff2e;color:#d7ccff}.bc-learning-badge-empty{font-size:.74rem;color:#9eb5d2}.bc-learning-feedback{border-radius:10px;padding:9px;display:grid;gap:4px;border:1px solid rgba(176,199,228,.22);background:#101f318c}.bc-learning-feedback p,.bc-learning-feedback small{margin:0}.bc-learning-feedback.is-correct{border-color:#5cd0868c;background:#10382873}.bc-learning-feedback.is-wrong{border-color:#e87c7c8c;background:#4718186b}.bc-learning-empty{border:1px dashed rgba(176,199,228,.24);border-radius:10px;padding:10px;color:#aac2dd;font-size:.78rem}.bc-learning-live{border:1px solid rgba(96,149,214,.4);border-radius:11px;background:#172f4a80;padding:8px 10px;display:flex;gap:8px;justify-content:space-between;align-items:flex-start}.bc-learning-live.is-resolved{border-color:#7ad8948c;background:#143b2c61}.bc-learning-live-copy{display:grid;gap:2px}.bc-learning-live-copy strong{font-size:.78rem}.bc-learning-live-copy span,.bc-learning-live-copy small{font-size:.7rem;color:#c6d6ea}.bc-learning-live-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}@media(max-width:1180px){.bc-learning-mvp-grid{grid-template-columns:1fr}}.bc-learn-layout{display:grid;grid-template-columns:220px 1fr;width:100%;min-height:560px;overflow:hidden;border:1px solid var(--border-color);border-radius:14px;background:var(--card-bg, #0f1117)}.bc-learn-sidebar{border-right:1px solid var(--border-color);overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:3px}.bc-learn-sidebar-section{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);padding:10px 8px 4px}.bc-lesson-btn{display:flex;align-items:center;gap:8px;width:100%;padding:9px 10px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--text-secondary);font-size:.82rem;font-weight:600;text-align:left;cursor:pointer;transition:background .15s,color .15s}.bc-lesson-btn:hover{background:#ffffff0d;color:var(--text-primary)}.bc-lesson-btn.is-active{background:#d4a8431a;color:#f0c96a;border-color:#d4a84359}.bc-lesson-icon{font-size:14px;width:18px;text-align:center;flex-shrink:0}.bc-lesson-status{margin-left:auto;font-size:11px}.bc-learn-content{overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.bc-learn-hero{background:linear-gradient(135deg,#d4a84312,#5b8ee60a);border:1px solid rgba(212,168,67,.3);border-radius:12px;padding:22px}.bc-learn-hero-tag{display:inline-flex;align-items:center;gap:6px;background:#d4a8431a;border:1px solid rgba(212,168,67,.3);color:#d4a843;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:3px 10px;border-radius:99px;margin-bottom:10px}.bc-learn-hero h2{font-size:1.4rem;font-weight:700;margin-bottom:6px}.bc-learn-hero p{font-size:.87rem;color:var(--text-secondary);line-height:1.6;max-width:580px}.bc-lesson-block{background:var(--card-bg, #161b25);border:1px solid var(--border-color);border-radius:12px;padding:18px}.bc-lesson-block h3{font-size:1rem;font-weight:700;margin-bottom:10px}.bc-lesson-block p{font-size:.85rem;color:var(--text-secondary);line-height:1.65;margin-bottom:10px}.bc-lesson-block p:last-child{margin-bottom:0}.bc-lesson-block strong{color:var(--text-primary)}.bc-lesson-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.bc-lesson-tag{background:#ffffff0d;border:1px solid var(--border-color);border-radius:6px;padding:4px 10px;font-size:.74rem;font-weight:600;color:var(--text-secondary)}.bc-lesson-tag-gold{border-color:#d4a84359;color:#d4a843;background:#d4a84312}.bc-learn-pieces-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.bc-piece-card{background:var(--card-bg, #161b25);border:1px solid var(--border-color);border-radius:12px;padding:14px 12px;text-align:center;cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s;position:relative;overflow:hidden}.bc-piece-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#d4a843,transparent);transform:scaleX(0);transition:transform .2s}.bc-piece-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #00000059;border-color:#d4a84359}.bc-piece-card:hover:before,.bc-piece-card.is-active:before{transform:scaleX(1)}.bc-piece-card.is-active{border-color:#d4a843;background:#d4a8430f}.bc-piece-value{position:absolute;top:7px;right:8px;background:#d4a843;color:#1a1000;font-size:.62rem;font-weight:700;padding:2px 6px;border-radius:99px}.bc-piece-img{width:52px;height:52px;margin:0 auto 8px;display:block;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}.bc-piece-card h4{font-size:.82rem;font-weight:700;margin-bottom:2px}.bc-piece-card small{font-size:.69rem;color:var(--text-secondary);line-height:1.3}.bc-piece-detail{display:flex;align-items:flex-start;gap:18px;background:var(--card-bg, #161b25);border:1px solid var(--border-color);border-radius:12px;padding:18px}.bc-piece-detail-img{width:64px;height:64px;flex-shrink:0;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}.bc-piece-detail h3{font-size:1rem;font-weight:700;margin-bottom:6px}.bc-piece-detail-value{color:#d4a843;font-size:.78rem;font-weight:600}.bc-piece-detail p{font-size:.84rem;color:var(--text-secondary);line-height:1.65;margin-bottom:10px}.bc-tactic-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.bc-tactic-card{background:var(--card-bg, #161b25);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .18s,box-shadow .18s}.bc-tactic-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000059}.bc-tactic-thumb{height:76px;display:flex;align-items:center;justify-content:center;font-size:2.2rem}.bc-tactic-body{padding:12px}.bc-tactic-body h4{font-size:.83rem;font-weight:700;margin-bottom:3px}.bc-tactic-body small{font-size:.72rem;color:var(--text-secondary)}.bc-opening-list{display:flex;flex-direction:column;gap:6px}.bc-opening-item{background:#ffffff08;border:1px solid var(--border-color);border-radius:8px;padding:10px 14px;display:flex;align-items:center;gap:10px;cursor:default;transition:border-color .15s,background .15s}.bc-opening-item:hover{border-color:#d4a8434d;background:#d4a8430a}.bc-opening-name{font-size:.85rem;font-weight:700;margin-bottom:2px}.bc-opening-moves{font-size:.73rem;color:var(--text-secondary);font-family:monospace;flex:1}.bc-opening-cat{font-size:.69rem;padding:2px 8px;border-radius:99px;font-weight:700;flex-shrink:0}.bc-cat-e4{background:#e05a5a26;color:#e06060}.bc-cat-d4{background:#5b8ee626;color:#5b8ee6}.bc-lesson-nav{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.bc-piece-tutor{display:flex;gap:20px;align-items:flex-start;background:var(--card-bg, #0d1018);border:1px solid rgba(212,168,67,.2);border-radius:14px;padding:18px;flex-wrap:wrap}.bc-tutor-budy{display:flex;gap:12px;align-items:flex-start;flex:1;min-width:240px}.bc-tutor-avatar{width:58px;height:58px;border-radius:12px;-o-object-fit:cover;object-fit:cover;flex-shrink:0;border:2px solid rgba(212,168,67,.4);box-shadow:0 0 12px #d4a84326}.bc-tutor-bubble{background:#d4a84312;border:1px solid rgba(212,168,67,.22);border-radius:3px 12px 12px;padding:11px 14px;font-size:.84rem;color:var(--text-secondary);line-height:1.65;flex:1;position:relative}.bc-tutor-bubble:before{content:"";position:absolute;left:-7px;top:14px;border:5px solid transparent;border-right-color:#d4a84338;border-left:none}.bc-tutor-bubble-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:7px}.bc-tutor-bubble-name{font-size:.69rem;font-weight:700;color:#d4a843;text-transform:uppercase;letter-spacing:.07em}.bc-tutor-speak-btn{display:flex;align-items:center;gap:5px;background:#d4a8431a;border:1px solid rgba(212,168,67,.28);border-radius:7px;padding:3px 9px;font-size:.78rem;cursor:pointer;color:var(--text-secondary);transition:background .15s,color .15s;flex-shrink:0}.bc-tutor-speak-btn:hover{background:#d4a84333;color:#d4a843}.bc-tutor-speak-btn.is-speaking{background:#d4a8432e;border-color:#d4a84380;color:#d4a843}.bc-tutor-wave{display:inline-flex;align-items:flex-end;gap:2px;height:14px}.bc-tutor-wave span{display:block;width:3px;border-radius:2px;background:#d4a843;animation:bc-wave-bar .9s ease-in-out infinite}.bc-tutor-wave span:nth-child(1){animation-delay:0s;animation-duration:.75s}.bc-tutor-wave span:nth-child(2){animation-delay:.15s;animation-duration:.85s}.bc-tutor-wave span:nth-child(3){animation-delay:.3s;animation-duration:.65s}.bc-tutor-wave span:nth-child(4){animation-delay:.1s;animation-duration:.95s}@keyframes bc-wave-bar{0%,to{height:3px;opacity:.5}50%{height:13px;opacity:1}}.bc-tutor-avatar.is-speaking{border-color:#d4a843;animation:bc-avatar-ring 1.1s ease-in-out infinite}@keyframes bc-avatar-ring{0%,to{box-shadow:0 0 #d4a84399}60%{box-shadow:0 0 0 9px #d4a84300}}.bc-tutor-board-wrap{flex-shrink:0;display:flex;flex-direction:column;gap:8px;align-items:flex-start}.bc-tutor-board-inner{display:flex;gap:4px;align-items:flex-start}.bc-tutor-ranks{display:flex;flex-direction:column;padding-top:0}.bc-tutor-ranks span{height:32px;display:flex;align-items:center;justify-content:center;width:14px;font-size:.59rem;color:var(--text-secondary);font-weight:600}.bc-tutor-board{display:grid;grid-template-columns:repeat(8,32px);grid-template-rows:repeat(8,32px);border:2px solid rgba(212,168,67,.45);border-radius:5px;overflow:hidden;box-shadow:0 6px 20px #00000080}.bc-tutor-sq{width:32px;height:32px;display:flex;align-items:center;justify-content:center;position:relative}.bc-tutor-light{background:#f0d9b5}.bc-tutor-dark{background:#b58863}.bc-tutor-piece-sq.bc-tutor-light{background:#d9c87a}.bc-tutor-piece-sq.bc-tutor-dark{background:#c49c30}.bc-tutor-piece-img{width:26px;height:26px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 1px 3px rgba(0,0,0,.55));position:relative;z-index:1;animation:bc-tutor-pulse 2.4s ease-in-out infinite}@keyframes bc-tutor-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.bc-tutor-dot{width:10px;height:10px;border-radius:50%;background:#00000047;animation:bc-tutor-dot-in .22s ease}.bc-tutor-light .bc-tutor-dot{background:#0003}@keyframes bc-tutor-dot-in{0%{opacity:0;transform:scale(.2)}to{opacity:1;transform:scale(1)}}.bc-tutor-cap{width:26px;height:26px;border-radius:50%;border:3px solid rgba(210,80,40,.65);animation:bc-tutor-dot-in .22s ease}.bc-tutor-files{display:flex;margin-top:3px;margin-left:0}.bc-tutor-files span{width:32px;text-align:center;font-size:.59rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase}.bc-tutor-legend{display:flex;align-items:center;gap:12px;font-size:.73rem;color:var(--text-secondary);margin:0;flex-wrap:wrap}.bc-tutor-legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:#00000059;vertical-align:middle;margin-right:4px}.bc-tutor-legend-cap{display:inline-block;width:12px;height:12px;border-radius:50%;border:2px solid rgba(210,80,40,.7);vertical-align:middle;margin-right:4px;margin-left:4px}@media(max-width:700px){.bc-learn-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}.bc-learn-sidebar{border-right:none;border-bottom:1px solid var(--border-color);flex-direction:row;flex-wrap:wrap;gap:4px;padding:8px;overflow-x:auto}.bc-learn-sidebar-section{width:100%;padding:4px 4px 2px}.bc-piece-tutor{flex-direction:column}.bc-tutor-board-wrap{align-self:center}}.bc-replay-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:8px 10px;margin-top:8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px}.bc-replay-bar button{background:#ffffff14;border:1px solid rgba(255,255,255,.14);color:inherit;border-radius:8px;padding:4px 10px;cursor:pointer;font-size:14px;font-weight:700;line-height:1;transition:background .15s}.bc-replay-bar button:not(:disabled):hover{background:#ffffff26}.bc-replay-bar button:disabled{opacity:.3;cursor:default}.bc-replay-counter{flex:1;text-align:center;font-size:12px;font-weight:600;opacity:.7}.bc-replay-exit{background:#ef44441f!important;border-color:#ef444440!important;color:#f87171!important}.bc-replay-exit:hover{background:#ef444438!important}.budychess-san-row.is-replay-active{background:#ffc83224;border-radius:6px}.budychess-square.is-best-from{box-shadow:0 0 0 2px #facc15 inset}.budychess-square.is-best-to{background:#facc154d}.bc-analysis-comment{font-size:12px;font-style:italic;opacity:.8;margin-left:6px;white-space:nowrap}.bc-best-arrow{position:absolute;top:2px;right:2px;font-size:14px;color:#facc15;pointer-events:none}.bc-best-target-indicator{position:absolute;inset:0;background:#facc154d;pointer-events:none}.bc-history-tab{padding:4px 0}.bc-history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.bc-history-title{font-size:16px;font-weight:700;margin:0}.bc-history-count{font-size:12px;opacity:.5}.bc-history-empty{text-align:center;padding:40px 20px;opacity:.55}.bc-history-empty span{font-size:40px;display:block;margin-bottom:10px}.bc-history-list{display:flex;flex-direction:column;gap:7px}.bc-history-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-left:4px solid transparent;transition:background .15s}.bc-history-item:hover{background:#ffffff12}.bc-history-win{border-left-color:#22c55e}.bc-history-loss{border-left-color:#ef4444}.bc-history-draw{border-left-color:#f59e0b}.bc-history-result-icon{font-size:20px;min-width:26px;text-align:center}.bc-history-info{flex:1;min-width:0}.bc-history-opponent{font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bc-history-meta{font-size:11px;opacity:.6;margin-top:2px}.bc-history-diff{font-size:9px;font-weight:700;padding:1px 5px;border-radius:999px;margin-left:5px;text-transform:capitalize}.bc-diff-fácil,.bc-diff-easy{background:#22c55e2e;color:#4ade80}.bc-diff-normal{background:#f59e0b2e;color:#fbbf24}.bc-diff-difícil,.bc-diff-hard{background:#ef44442e;color:#f87171}.bc-history-actions{display:flex;gap:6px;flex-shrink:0;align-items:center}.bc-history-delete{opacity:.5}.bc-history-delete:hover{opacity:1}.budychess-board-row.has-eval-bar{grid-template-columns:20px var(--captured-col) var(--coord-col) 1fr var(--coord-col) var(--captured-col)}.budychess-eval-bar{display:flex;flex-direction:column-reverse;border-radius:6px;overflow:hidden;height:100%;position:relative;cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none}.budychess-eval-bar.is-flipped{flex-direction:column}.budychess-eval-white{background:#f0ede8;transition:height .35s cubic-bezier(.4,0,.2,1);position:relative;min-height:4px;flex-shrink:0}.budychess-eval-black{flex:1;background:#1e1e1e;position:relative}.budychess-eval-label{position:absolute;font-size:8px;font-weight:800;line-height:1;padding:2px 3px;pointer-events:none;white-space:nowrap;left:50%;transform:translate(-50%)}.budychess-eval-label.is-white-label{bottom:3px;color:#2a2a2a}.budychess-eval-label.is-black-label{top:3px;color:#d0d0d0}button,[role=button],.bc-lesson-btn,.bc-piece-card,.bc-tactic-card,.budychess-tab-button,.budychess-play-mode-btn,.budychess-color-choice-btn,.budychess-difficulty-preset-btn,.budychess-ai-hints-toggle,.budychess-clock-preset-btn,.budychess-play-button,.budychess-online-search-btn,.budychess-local-device-btn,.budychess-hint-btn,.budychess-resign-btn,.budychess-draw-btn,.budychess-clock-toggle-btn,.budychess-board-action-btn,.budychess-rotate-board-toggle,.budychess-close-message,.budychess-floating-message-close,.budychess-undo-btn,.budychess-reset-btn,.budychess-fullscreen-btn{cursor:pointer}[role=button]{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.bc-online-overlay-stack{position:absolute;top:110px;right:12px;width:min(340px,36%);display:grid;gap:8px;z-index:11;pointer-events:none}.bc-online-overlay-stack.has-side-chat{right:252px;width:min(460px,calc(100% - 272px))}.bc-online-overlay-stack.has-side-chat.is-side-chat-collapsed{right:84px;width:min(520px,calc(100% - 104px))}@media(max-width:1200px){.bc-online-overlay-stack.has-side-chat.is-side-chat-collapsed{right:10px;width:auto}}.bc-online-overlay-stack>*{pointer-events:auto}.bc-online-message .app-message-text{font-size:.82rem}.bc-invite-ready-float{position:fixed;right:272px;bottom:18px;z-index:1006;width:min(420px,calc(100vw - 32px));padding:12px 12px 10px;border-radius:14px;border:1px solid rgba(122,179,255,.52);background:linear-gradient(160deg,#112842f5,#0e1d2ff5);box-shadow:0 14px 30px #030a1280,0 0 0 1px #4075ba3d inset;color:#edf5ff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:bc-toast-in .2s ease}.bc-invite-ready-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:9px}.bc-invite-ready-title{font-size:.86rem;font-weight:800;letter-spacing:.03em;text-transform:uppercase;color:#d9ebff}.bc-invite-ready-timer{font-size:.78rem;font-weight:700;color:#ffcf6f;white-space:nowrap}.bc-invite-ready-code-row{display:flex;align-items:center;gap:10px}.bc-invite-ready-code{flex:1;display:inline-flex;align-items:center;min-height:40px;padding:0 11px;border-radius:10px;border:1px solid rgba(116,171,245,.42);background:#0a1828b8;color:#a9ceff;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;font-size:1.08rem;font-weight:800;letter-spacing:.12em}.bc-invite-ready-copy{border:1px solid rgba(107,170,255,.9);border-radius:10px;background:linear-gradient(135deg,#2f7de8,#2362be);color:#f7fbff;font-size:.84rem;font-weight:800;letter-spacing:.01em;min-height:40px;padding:0 14px;cursor:pointer;transition:transform .16s ease,filter .16s ease}.bc-invite-ready-copy:hover{filter:brightness(1.08);transform:translateY(-1px)}.bc-invite-ready-copy:active{transform:translateY(0)}.bc-invite-ready-delete{width:40px;min-width:40px;min-height:40px;border:1px solid rgba(240,124,124,.9);border-radius:10px;background:linear-gradient(135deg,#8f2830,#6f1d24);color:#ffdce0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .16s ease,filter .16s ease}.bc-invite-ready-delete:hover{filter:brightness(1.08);transform:translateY(-1px)}.bc-invite-ready-delete:active{transform:translateY(0)}.bc-invite-ready-help{margin:8px 1px 0;font-size:.78rem;color:#c6dcf8}@media(max-width:1200px){.bc-invite-ready-float{right:12px;bottom:12px}}@media(max-width:820px){.bc-invite-ready-float{width:calc(100vw - 24px)}.bc-invite-ready-code{font-size:.96rem}.bc-invite-ready-copy{padding:0 11px}}.bc-challenge-code-inline{font-family:ui-monospace,monospace;letter-spacing:.08em;color:#a7c5ff;margin-left:4px}.bc-online-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.2);border-top-color:#818cf8;border-radius:50%;animation:bc-spin .8s linear infinite;flex-shrink:0}@keyframes bc-spin{to{transform:rotate(360deg)}}.bc-online-quick-btn{border:1px solid rgba(147,176,210,.28);border-radius:10px;background:#101f3185;color:#dcecff;font-size:.76rem;font-weight:700;padding:8px 10px;text-align:left;transition:background .16s ease,border-color .16s ease}.bc-online-quick-btn:hover{background:#3467a452;border-color:#78adf1ad}.bc-online-quick-btn:disabled{opacity:.45;cursor:default}.bc-preset-toast{display:flex;align-items:center;gap:6px;padding:7px 12px;margin:0;background:#22c55e1a;border:1px solid rgba(34,197,94,.25);border-radius:10px;font-size:13px;font-weight:600;animation:bc-toast-in .25s ease}@keyframes bc-toast-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.bc-classmates-list{display:flex;flex-direction:column;gap:5px;margin-top:10px}.bc-classmates-title{font-size:11px;font-weight:700;opacity:.55;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;display:block}.bc-classmate-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);transition:all .2s ease}.bc-classmate-item.is-busy{border-color:#f59e0b5c;background:#f59e0b1a}.bc-classmate-item:hover{background:#ffffff14;border-color:#ffffff1f}.bc-classmate-avatar-wrap{position:relative;width:30px;height:30px;flex-shrink:0}.bc-classmate-avatar{width:100%;height:100%;border-radius:0;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;background:#ffffff12;color:#f3f8ff;font-size:12px;font-weight:800;text-transform:uppercase}.bc-classmate-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.bc-classmate-status-dot{position:absolute;right:-2px;bottom:-2px;width:9px;height:9px;border-radius:50%;border:2px solid rgba(16,31,49,.96)}.bc-classmate-status-dot.is-online{background:#22c55e;animation:bc-pulse 2s ease-in-out infinite}.bc-classmate-status-dot.is-busy{background:#f59e0b;box-shadow:0 0 0 2px #f59e0b33;animation:none}@keyframes bc-pulse{0%,to{opacity:1}50%{opacity:.7}}.bc-classmate-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.bc-classmate-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bc-classmate-rating{font-size:11px;opacity:.7;white-space:nowrap}.bc-incoming-challenge{display:flex;flex-direction:column;gap:8px;padding:12px 14px;background:#6366f11f;border:1px solid rgba(99,102,241,.35);border-radius:12px;margin-top:8px}.bc-incoming-challenge-header{display:flex;align-items:center;justify-content:space-between;font-size:14px;gap:8px;flex-wrap:wrap}.bc-incoming-badge{font-size:11px;padding:2px 8px;border-radius:20px;background:#6366f133;color:#a5b4fc;white-space:nowrap}.bc-incoming-challenge-actions{display:flex;gap:8px}.bc-opponent-disconnected{padding:8px 14px;border-radius:10px;font-size:13px;background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#fca5a5;margin:0}.bc-classmates-panel{margin-top:12px;padding:10px 12px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px}.bc-classmates-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.bc-classmates-panel-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#ffffff73}.bc-classmates-count{font-size:11px;padding:1px 7px;border-radius:20px;background:#22c55e26;color:#86efac;font-weight:600}.bc-classmate-info{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.bc-classmate-role{font-size:10px;color:#ffffff59;text-transform:uppercase;letter-spacing:.04em}.bc-classmate-role.is-busy{color:#fed7aaf2}.bc-classmate-challenge-btn{font-size:.68rem;line-height:1;padding:5px 9px;min-height:24px}.bc-classmates-empty{font-size:12px;color:#ffffff4d;text-align:center;padding:6px 0;margin:0}.bc-opening-coach-banner{border:1px solid rgba(126,184,246,.45);border-radius:12px;background:#172942b8;display:grid;gap:6px;padding:10px 12px;margin:0 0 10px}.bc-opening-coach-banner.is-complete{border-color:#79dd958c;background:#1a38259e}.bc-opening-coach-banner-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.bc-opening-coach-banner-head strong{color:#e9f4ff;font-size:.9rem}.bc-opening-coach-banner-head span{color:#b8d8fb;font-size:.76rem}.bc-opening-coach-banner p{margin:0;color:#d6e7fb;font-size:.8rem}.bc-opening-coach-banner small{color:#c6dcf5;font-size:.75rem}.bc-opening-coach-metrics{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.bc-opening-coach-metrics span{border:1px solid rgba(176,199,228,.3);border-radius:999px;padding:2px 8px;color:#e6f2ff;font-size:.72rem;background:#0e1a2a99}.bc-opening-coach-warnings{display:flex;flex-wrap:wrap;gap:6px}.bc-opening-coach-warnings span{border:1px solid rgba(244,194,79,.42);border-radius:999px;padding:2px 8px;color:#ffe4a1;font-size:.72rem;background:#402c0b94}.bc-opening-coach-principle{border-radius:9px;padding:6px 8px;font-size:.75rem;color:#e5f3ff;border:1px solid rgba(145,188,234,.35);background:#182e4a73}.bc-opening-coach-principle.is-broken{border-color:#f4c24f6b;background:#402c0b7a;color:#ffe5ab}.bc-opening-coach-principle.is-fulfilled{border-color:#79dd956b;background:#1a38257a;color:#d7f2df}.bc-opening-coach-plan,.bc-opening-coach-error,.bc-opening-coach-next{border:1px solid rgba(176,199,228,.22);border-radius:9px;background:#0d182785;color:#d6e8fd;font-size:.74rem;padding:6px 8px;display:grid;gap:3px}.bc-opening-coach-error{border-color:#f4c24f57;color:#ffe7b2}.bc-opening-coach-next small{color:#b9d6f8;font-size:.7rem}.budychess-play-layout.is-learning-embed{grid-template-columns:1fr;gap:0}.budychess-play-layout.is-learning-embed .budychess-play-left,.budychess-play-layout.is-learning-embed .budychess-play-right{display:none}.budychess-play-layout.is-learning-embed .budychess-play-center{grid-column:1 / -1}.budychess-page.is-learning-embed .budychess-tab-panel{padding:0}.budychess-page.is-learning-embed .budychess-board-card{border-radius:0}.budychess-page.is-learning-embed .budychess-board-shell{--coord-col: 24px;--coord-gap: 6px;--captured-col: 36px;--captured-piece-size: 22px;--board-max-size: min(86dvh, 1040px);width:min(100%,calc(var(--board-max-size) + var(--board-shell-side-padding) + var(--board-shell-side-padding)))}@media(max-width:900px){.budychess-page.is-learning-embed .budychess-board-shell{--coord-col: 18px;--coord-gap: 4px;--captured-col: 24px;--captured-piece-size: 14px;--board-max-size: min(88dvw, 92dvh);width:100%}}.bc-learning-course-layout{width:100%;display:grid;grid-template-columns:280px minmax(0,1fr) 280px;gap:10px}.bc-learning-course-sidebar,.bc-learning-course-progress,.bc-learning-lesson-hero,.bc-learning-lesson-content{padding:12px}.bc-learning-course-sidebar{display:grid;align-content:start;gap:10px;max-height:calc(100dvh - 132px);overflow:auto}.bc-learning-course-sidebar header h2,.bc-learning-course-progress h2,.bc-learning-lesson-content h2{margin:0;font-size:.96rem;color:#f1f7ff}.bc-learning-course-sidebar header p,.bc-learning-course-progress small,.bc-learning-lesson-content p,.bc-learning-lesson-hero p{margin:4px 0 0;color:#c6d6ea;font-size:.8rem}.bc-learning-section-list{display:grid;gap:9px}.bc-learning-section-group{display:grid;gap:6px}.bc-learning-section-group h3{margin:0;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:#9dc5f8}.bc-learning-section-group small{color:#c6d6ea;font-size:.71rem}.bc-learning-lesson-list{display:grid;gap:5px}.bc-learning-course-recommended{border:1px solid rgba(121,221,149,.35);border-radius:10px;background:#1a38256b;display:grid;gap:5px;padding:8px 9px}.bc-learning-course-recommended strong{color:#b8f2ce;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em}.bc-learning-course-recommended span{color:#ecf8f0;font-size:.8rem}.bc-learning-lesson-item{width:100%;text-align:left;border:1px solid rgba(176,199,228,.2);border-radius:10px;background:#142436c7;color:#dcecff;padding:8px 9px;display:grid;gap:3px}.bc-learning-lesson-item:hover{border-color:#7eb8f6a3}.bc-learning-lesson-item.is-active{border-color:#7eb8f6d6;background:#31537cdb}.bc-learning-lesson-item-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.bc-learning-lesson-item-head strong{font-size:.82rem}.bc-learning-lesson-item-head small,.bc-learning-lesson-item span{color:#c6d6ea;font-size:.72rem}.bc-learning-course-main{display:grid;gap:10px}.bc-learning-lesson-hero{display:grid;gap:8px}.bc-learning-lesson-path{font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;color:#9dc5f8;font-weight:800}.bc-learning-lesson-hero h1{margin:0;font-size:clamp(1.25rem,2.2vw,1.8rem);color:#f3f8ff}.bc-learning-focus-points{display:flex;flex-wrap:wrap;gap:6px}.bc-learning-focus-points span{border:1px solid rgba(176,199,228,.25);border-radius:999px;background:#142436b8;color:#d9e8fb;font-size:.72rem;padding:3px 8px}.bc-learning-lesson-actions{display:flex;align-items:center;gap:8px}.bc-learning-lesson-content{display:grid;gap:10px}.bc-learning-curation-block{border:1px solid rgba(166,196,229,.24);border-radius:12px;background:#0e1c2d9e;display:grid;gap:8px;padding:10px}.bc-learning-curation-block header{display:flex;align-items:center;justify-content:space-between;gap:8px}.bc-learning-curation-block header strong{color:#edf5ff;font-size:.82rem}.bc-learning-curation-block header span{border:1px solid rgba(145,188,234,.32);border-radius:999px;padding:2px 8px;color:#c7e1ff;font-size:.68rem;letter-spacing:.04em;text-transform:uppercase}.bc-learning-curation-block p{margin:0;color:#d3e4f7;font-size:.79rem}.bc-learning-curation-seq{margin:0;padding-left:18px;display:grid;gap:3px;color:#d9e8fb;font-size:.76rem}.bc-learning-curation-drill{border:1px solid rgba(121,221,149,.3);border-radius:9px;background:#1a382557;padding:7px 8px;color:#dff5e7;font-size:.74rem}.bc-learning-curation-guides{display:flex;flex-wrap:wrap;gap:6px}.bc-learning-curation-guides span{border:1px solid rgba(176,199,228,.22);border-radius:999px;background:#111f319e;color:#c8dbf2;font-size:.68rem;padding:3px 7px}.bc-learning-lesson-content header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.bc-learning-example-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.bc-learning-example-card{border:1px solid rgba(176,199,228,.24);border-radius:10px;background:#142436bd;padding:8px;text-align:left;display:grid;gap:6px;color:#d9e8fb}.bc-learning-example-card:hover{border-color:#7eb8f69e}.bc-learning-example-card.is-active{border-color:#7eb8f6d6;background:#31537cd1}.bc-learning-example-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.bc-learning-example-title-row strong{color:#f1f7ff;font-size:.82rem}.bc-learning-example-chip{border:1px solid rgba(176,199,228,.28);border-radius:999px;font-size:.66rem;letter-spacing:.03em;text-transform:uppercase;padding:1px 7px;color:#c6d9f2}.bc-learning-example-move{color:#9dc5f8;font-size:.7rem}.bc-learning-difficulty{border-radius:999px;padding:1px 7px;font-size:.68rem;text-transform:uppercase;letter-spacing:.03em;font-weight:700}.bc-learning-difficulty.is-easy{color:#0c4325;background:#59dd95eb}.bc-learning-difficulty.is-medium{color:#4a3407;background:#f7c761f0}.bc-learning-difficulty.is-hard{color:#4d1010;background:#f57b7bed}.bc-learning-practice-panel{border:1px solid rgba(176,199,228,.22);border-radius:12px;background:#14243699;padding:10px;display:grid;gap:8px}.bc-learning-practice-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.bc-learning-practice-head strong{color:#f1f7ff}.bc-learning-practice-head small{color:#9dc5f8}.bc-learning-hints-row{display:flex;flex-wrap:wrap;gap:6px}.bc-learning-hints-row span{border:1px solid rgba(176,199,228,.26);border-radius:999px;background:#0d1827b8;color:#dcecff;font-size:.72rem;padding:3px 8px}.bc-learning-practice-actions{display:flex;align-items:center;gap:8px}.bc-learning-opening-lab{border:1px solid rgba(99,168,255,.3);border-radius:12px;background:#18304e6b;display:grid;gap:8px;padding:10px}.bc-learning-opening-lab-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.bc-learning-opening-lab-head strong{color:#ebf4ff;font-size:.83rem}.bc-learning-opening-lab-head small{color:#9ec7ff;font-size:.74rem}.bc-learning-opening-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.bc-learning-opening-controls small{color:#c8ddf7;font-size:.73rem}.bc-learning-opening-plan{border:1px solid rgba(176,199,228,.24);border-radius:9px;background:#0d182780;padding:8px;display:grid;gap:5px}.bc-learning-opening-plan strong{color:#ebf4ff;font-size:.78rem}.bc-learning-opening-plan ul{margin:0;padding-left:16px;display:grid;gap:2px;color:#d0e3f9;font-size:.74rem}.bc-learning-opening-errors{display:flex;flex-wrap:wrap;gap:6px}.bc-learning-opening-errors span{border:1px solid rgba(244,194,79,.35);border-radius:999px;background:#402c0b70;color:#ffe5ac;font-size:.69rem;padding:3px 8px}.bc-learning-linked-list{display:grid;gap:6px}.bc-learning-linked-item{border:1px solid rgba(176,199,228,.2);border-radius:9px;background:#0d18278f;color:#dcecff;padding:7px 9px;display:flex;align-items:center;justify-content:space-between;gap:8px;text-align:left}.bc-learning-linked-item:hover{border-color:#7eb8f6a3}.bc-learning-linked-item.is-active{border-color:#7eb8f6d6}.bc-learning-linked-item.is-done{border-color:#79dd95a3}.bc-learning-linked-item strong{font-size:.8rem}.bc-learning-linked-item span{font-size:.72rem;color:#c6d6ea}.bc-learning-course-progress{display:grid;align-content:start;gap:9px}.bc-learning-course-progress header{display:grid;gap:6px}.bc-learning-progress-track{width:100%;height:7px;border-radius:999px;background:#ffffff1c;overflow:hidden}.bc-learning-progress-track span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#61b0ff,#79dd95)}.bc-learning-kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.bc-learning-kpi-grid div{border:1px solid rgba(176,199,228,.2);border-radius:9px;background:#142436b3;padding:7px 8px;display:grid;gap:2px}.bc-learning-kpi-grid span{font-size:.7rem;color:#c7d7ea}.bc-learning-kpi-grid strong{font-size:.9rem;color:#eef5ff}.bc-learning-badges{display:flex;flex-wrap:wrap;gap:5px}.bc-learning-badges span{border:1px solid rgba(176,199,228,.24);border-radius:999px;color:#eef5ff;font-size:.7rem;padding:2px 7px}.bc-learning-reinforcement-box{border:1px solid rgba(244,194,79,.34);border-radius:10px;background:#3a2a0a47;padding:8px;display:grid;gap:5px}.bc-learning-reinforcement-box strong{color:#ffe8a6;font-size:.78rem}.bc-learning-reinforcement-box p{margin:0;color:#f3f8ff;font-size:.8rem}.bc-learning-reinforcement-box small{color:#d9c78a}.bc-learning-progress-actions{display:flex;justify-content:flex-end}.bc-learning-empty{color:#c6d6ea;border:1px dashed rgba(176,199,228,.3);border-radius:10px;padding:10px}@media(max-width:1260px){.bc-learning-course-layout{grid-template-columns:250px minmax(0,1fr)}.bc-learning-course-progress{grid-column:1 / -1;grid-template-columns:repeat(2,minmax(0,1fr))}.bc-learning-course-progress header,.bc-learning-reinforcement-box,.bc-learning-progress-actions{grid-column:1 / -1}}@media(max-width:980px){.bc-learning-course-layout{grid-template-columns:1fr}.bc-learning-course-sidebar{max-height:none}.bc-learning-example-grid,.bc-learning-course-progress{grid-template-columns:1fr}}.bc-hero-eyebrow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.bc-hero-section-chip{background:#0d94882e;color:#2dd4bf;border:1px solid rgba(13,148,136,.35);border-radius:6px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:2px 8px}.bc-hero-step-label{color:#64748b;font-size:.72rem;font-weight:600}.bc-hero-title{margin:0;font-family:Fredoka,Fredoka One,sans-serif;font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700;color:#f1f5f9;line-height:1.2}.bc-hero-objective{display:flex;align-items:flex-start;gap:8px;background:#0ea5e91a;border:1px solid rgba(14,165,233,.22);border-radius:10px;padding:10px 12px;font-size:.85rem;color:#bae6fd;line-height:1.5}.bc-hero-objective-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}.bc-hero-keypoints{margin:0;padding:0;list-style:none;display:grid;gap:6px}.bc-hero-keypoints li{display:flex;gap:8px;align-items:flex-start;font-size:.84rem;color:#cbd5e1;line-height:1.5}.bc-hero-keypoints li:before{content:"▸";color:#0d9488;flex-shrink:0;font-size:.78rem;margin-top:2px}.bc-hero-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding-top:4px}.bc-hero-cta{background:linear-gradient(135deg,#0d9488,#0ea5e9);color:#fff;border:none;border-radius:10px;padding:11px 22px;font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .15s;white-space:nowrap}.bc-hero-cta:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.bc-hero-cta:disabled{opacity:.45;cursor:not-allowed}.bc-hero-btn-next{background:#ffffff0d;border:1px solid rgba(176,199,228,.22);border-radius:10px;color:#94a3b8;padding:11px 18px;font-size:.88rem;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s}.bc-hero-btn-next:hover:not(:disabled){border-color:#b0c7e480;color:#e2e8f0}.bc-hero-btn-next:disabled{opacity:.35;cursor:not-allowed}.bc-curation-block{border:1px solid rgba(166,196,229,.2);border-radius:12px;background:#0e1c2d8c;padding:14px;display:grid;gap:12px}.bc-curation-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.bc-curation-head strong{color:#e2e8f0;font-size:.85rem;line-height:1.5}.bc-level-chip{flex-shrink:0;background:#0d94882e;color:#2dd4bf;border:1px solid rgba(13,148,136,.3);border-radius:999px;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px}.bc-curation-seq{margin:0;padding:0;list-style:none;display:grid;gap:6px;counter-reset:none}.bc-curation-seq li{display:flex;gap:10px;align-items:flex-start;font-size:.82rem;color:#cbd5e1;line-height:1.5}.bc-curation-seq-num{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#0d948840;color:#2dd4bf;font-size:.68rem;font-weight:800;flex-shrink:0;margin-top:1px}.bc-minireto-card{background:linear-gradient(135deg,#0d948824,#0ea5e91a);border:1px solid rgba(14,165,233,.28);border-radius:12px;padding:14px 16px;display:grid;gap:8px}.bc-minireto-header{display:flex;align-items:center;gap:7px}.bc-minireto-icon{font-size:1.1rem}.bc-minireto-header strong{font-family:Fredoka,Fredoka One,sans-serif;font-size:1rem;font-weight:700;color:#2dd4bf}.bc-minireto-text{margin:0;font-size:.85rem;color:#bae6fd;line-height:1.6}.bc-minireto-btn{align-self:start;background:linear-gradient(135deg,#0d9488,#0ea5e9);color:#fff;border:none;border-radius:8px;padding:9px 18px;font-size:.88rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .15s;width:-moz-fit-content;width:fit-content}.bc-minireto-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.bc-minireto-btn:disabled{opacity:.4;cursor:not-allowed}.bc-fmb{display:grid;grid-template-columns:repeat(8,1fr);border:2px solid #4a3020;border-radius:4px;overflow:hidden;box-shadow:0 4px 16px #00000073;flex-shrink:0}.bc-fmb-cell{display:flex;align-items:center;justify-content:center;line-height:1;-webkit-user-select:none;-moz-user-select:none;user-select:none}.bc-fmb-cell--l{background:#f0d9b5}.bc-fmb-cell--d{background:#b58863}.bc-fmb-cell--from{background:#f5c518bf!important;outline:2px inset rgba(245,158,11,.6)}.bc-fmb-cell--to{background:#10b98199!important;outline:2px inset rgba(16,185,129,.5)}.bc-fmb-w{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.6)}.bc-fmb-b{color:#1a1a1a;text-shadow:0 1px 2px rgba(255,255,255,.3)}.bc-examples-section{border:1px solid rgba(99,168,255,.22);border-radius:14px;background:#101f317a;padding:12px;display:grid;gap:10px}.bc-examples-head{display:grid;gap:4px}.bc-examples-head h3{margin:0;font-size:.94rem;color:#e2e8f0}.bc-examples-head p{margin:0;color:#94a3b8;font-size:.79rem}.bc-examples-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.bc-example-card{border:1px solid rgba(176,199,228,.22);border-radius:12px;background:#142436b3;padding:12px;display:flex;gap:14px;align-items:flex-start;transition:border-color .15s}.bc-example-card:hover{border-color:#7eb8f680}.bc-example-board-wrap{display:flex;flex-direction:column;align-items:center;gap:5px;flex-shrink:0}.bc-example-index{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:#7dd3fc}.bc-example-move-chip{background:#0d948833;border:1px solid rgba(13,148,136,.35);color:#2dd4bf;border-radius:5px;font-size:.64rem;font-weight:700;font-family:monospace;padding:2px 6px;letter-spacing:.05em}.bc-example-info{display:grid;gap:5px;min-width:0}.bc-example-title{font-size:.84rem;font-weight:700;color:#f1f5f9;line-height:1.3}.bc-example-desc{margin:0;font-size:.76rem;color:#94a3b8;line-height:1.5}.bc-example-focus{margin:0;font-size:.74rem;color:#bae6fd}.bc-example-focus code{border:1px solid rgba(56,189,248,.35);border-radius:6px;background:#082f4973;color:#7dd3fc;padding:1px 6px;font-size:.72rem}.bc-example-practice-btn{justify-self:start}.bc-opening-lab{border:1px solid rgba(99,168,255,.28);border-radius:14px;background:#18304e66;padding:16px;display:grid;gap:14px}.bc-opening-lab-header{display:flex;align-items:center;gap:10px}.bc-opening-lab-icon{font-size:1.4rem}.bc-opening-lab-title{display:block;font-family:Fredoka,Fredoka One,sans-serif;font-size:1rem;font-weight:700;color:#e2e8f0}.bc-opening-lab-sub{font-size:.76rem;color:#64748b}.bc-opening-summary{margin:0;font-size:.84rem;color:#94a3b8;line-height:1.6}.bc-opening-principles{display:grid;gap:5px}.bc-opening-principle{display:flex;gap:8px;align-items:flex-start;font-size:.82rem;color:#bae6fd;line-height:1.5}.bc-opening-principle-dot{color:#0ea5e9;flex-shrink:0;font-size:.7rem;margin-top:3px}.bc-opening-plan{display:grid;gap:8px}.bc-opening-plan-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#475569}.bc-opening-plan-steps{list-style:none;margin:0;padding:0;display:grid;gap:4px}.bc-opening-plan-step{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:8px;font-size:.82rem;color:#64748b;background:#ffffff08;border:1px solid transparent;transition:color .15s}.bc-opening-plan-step--current{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b40;font-weight:700}.bc-opening-step-num{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#ffffff12;font-size:.68rem;font-weight:800;flex-shrink:0;color:#94a3b8}.bc-opening-plan-step--current .bc-opening-step-num{background:#f59e0b40;color:#f59e0b}.bc-opening-errors{display:grid;gap:7px}.bc-opening-errors-label{font-size:.72rem;font-weight:700;color:#f59e0b;letter-spacing:.02em}.bc-opening-errors-chips{display:flex;flex-wrap:wrap;gap:6px}.bc-opening-error-chip{background:#f59e0b1a;border:1px solid rgba(245,158,11,.28);border-radius:999px;color:#fcd34d;font-size:.72rem;padding:3px 10px}.bc-opening-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.bc-opening-side-toggle{display:flex;gap:4px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:3px}.bc-side-btn{padding:6px 12px;border-radius:7px;border:none;background:transparent;color:#64748b;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.bc-side-btn--active{background:#0ea5e933;color:#38bdf8}.bc-opening-side-fixed{font-size:.8rem;color:#64748b;font-weight:600}.bc-opening-cta{background:linear-gradient(135deg,#0d9488,#0ea5e9);color:#fff;border:none;border-radius:10px;padding:9px 18px;font-size:.9rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .15s}.bc-opening-cta:hover{opacity:.9;transform:translateY(-1px)}.bc-learning-lesson-item-head strong{font-size:.88rem;font-weight:700}.bc-learning-course-sidebar header h2{font-family:Fredoka,Fredoka One,sans-serif;font-size:1.05rem;font-weight:700}.bc-learning-lesson-hero{gap:14px}.bc-learning-kpi-grid strong{font-size:1.1rem}.bc-learning-kpi-grid span{font-size:.74rem}.bc-learning-lesson-content h2{font-family:Fredoka,Fredoka One,sans-serif;font-size:1rem;font-weight:700}@media(max-width:900px){.bc-examples-grid{grid-template-columns:1fr}.bc-example-card{flex-direction:column;align-items:center}}.bc-guided-practice-wrap{border:1px solid rgba(59,130,246,.28);border-radius:14px;background:#0f1e30b8;padding:12px;display:grid;gap:10px}.bc-guided-practice-wrap-head{display:grid;gap:4px}.bc-guided-practice-wrap-head h3{margin:0;color:#e2e8f0;font-size:.95rem}.bc-guided-practice-wrap-head p{margin:0;color:#9fb5cf;font-size:.8rem}.bc-guided-practice-picker{display:flex;flex-wrap:wrap;gap:6px}.bc-guided-practice-pill{border:1px solid rgba(148,163,184,.35);border-radius:999px;background:#082f4952;color:#bae6fd;padding:4px 10px;font-size:.72rem;font-weight:700;cursor:pointer}.bc-guided-practice-pill.is-active{border-color:#38bdf899;background:#0e74907a;color:#ecfeff}.bc-guided-practice{border:1px solid rgba(148,163,184,.24);border-radius:12px;background:#0206176b;padding:12px;display:grid;gap:10px}.bc-guided-practice-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.bc-guided-practice-title-wrap{display:grid;gap:4px}.bc-guided-practice-title-wrap h3{margin:0;color:#f1f5f9;font-size:.92rem}.bc-guided-practice-title-wrap p{margin:0;color:#9fb5cf;font-size:.78rem}.bc-guided-practice-meta{display:grid;gap:4px;justify-items:end}.bc-guided-practice-meta span{border:1px solid rgba(148,163,184,.28);border-radius:999px;padding:2px 8px;font-size:.68rem;color:#cbd5e1;background:#0f172a8f}.bc-guided-practice-info{display:flex;align-items:flex-start;gap:6px;border:1px solid rgba(56,189,248,.24);border-radius:8px;background:#082f4947;padding:8px 10px;font-size:.78rem;color:#cfe9ff}.bc-guided-practice-stage{display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:10px;align-items:start}.bc-guided-board-shell{border:1px solid rgba(148,163,184,.28);border-radius:12px;background:#02061780;padding:8px;display:grid;gap:4px}.bc-guided-board-files{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:0;margin:0 22px}.bc-guided-board-files span{display:flex;justify-content:center;font-size:.7rem;font-weight:700;color:#94a3b8}.bc-guided-board-wrap{display:grid;grid-template-columns:22px minmax(0,1fr) 22px;gap:4px;align-items:stretch}.bc-guided-board-ranks{display:grid;grid-template-rows:repeat(8,minmax(0,1fr))}.bc-guided-board-ranks span{display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#94a3b8}.bc-guided-board{width:100%;aspect-ratio:1 / 1;display:grid;grid-template-columns:repeat(8,minmax(0,1fr));border-radius:10px;overflow:hidden}.bc-guided-square{border:none;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;position:relative;cursor:pointer}.bc-guided-square.is-light{background:#f3f0df}.bc-guided-square.is-dark{background:#799954}.bc-guided-square.is-selected{box-shadow:inset 0 0 0 3px #38bdf8b8}.bc-guided-square.is-candidate:before{content:"";width:28%;aspect-ratio:1 / 1;border-radius:999px;background:#02061752}.bc-guided-piece{width:84%;height:84%;background-repeat:no-repeat;background-position:center;background-size:contain;filter:drop-shadow(0 2px 3px rgba(0,0,0,.3))}.bc-guided-dot{width:22%;aspect-ratio:1 / 1;border-radius:999px;background:#0206174d}.bc-guided-practice-side{border:1px solid rgba(148,163,184,.22);border-radius:10px;background:#0f172a94;padding:8px;display:grid;gap:8px}.bc-guided-feedback{margin:0;font-size:.78rem;color:#dbeafe}.bc-guided-hint{margin:0;font-size:.75rem;color:#fde68a}.bc-guided-actions{display:flex;flex-wrap:wrap;gap:6px}@media(max-width:900px){.bc-guided-practice-stage{grid-template-columns:1fr}}.cem-picker{margin-top:8px;border:1px solid var(--cem-border);background:#ffffff0a;border-radius:var(--cem-rs);padding:8px}.cem-picker-tabs{display:flex;gap:6px;flex-wrap:wrap}.cem-picker-tab{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;border:1px solid var(--cem-border);background:#ffffff0d;color:var(--cem-text-dim);font-size:11px;font-weight:700;cursor:pointer}.cem-picker-tab.is-active{border-color:#ffffff59;color:#fff;background:#ffffff1f}.cem-picker-tab:disabled{opacity:.4;cursor:not-allowed}.cem-picker-tab-count{min-width:18px;padding:1px 5px;border-radius:999px;background:#ffffff1f;color:inherit;font-size:10px;line-height:1.2;text-align:center}.cem-picker-source-hint{margin-top:8px;padding:8px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#0000002e}.cem-picker-source-title{display:block;color:var(--cem-text);font-size:12px;font-weight:700}.cem-picker-source-copy{margin:4px 0 0;color:var(--cem-text-dim);font-size:11px;line-height:1.35}.cem-picker-upload{margin-top:8px}.cem-picker-upload-btn{width:100%;padding:10px 12px;border-radius:10px;border:1px dashed rgba(255,255,255,.25);background:#ffffff0a;color:var(--cem-text);font-size:12px;font-weight:700;cursor:pointer}.cem-picker-upload-btn:hover{border-color:#ffffff80;background:#ffffff14}.cem-picker-toolbar{display:flex;gap:8px;margin-top:8px}.cem-picker-search{flex:1;min-width:0;padding:6px 8px;border-radius:var(--cem-rs);border:1px solid var(--cem-border);background:#00000059;color:var(--cem-text);font-size:12px}.cem-picker-select{padding:6px 8px;border-radius:var(--cem-rs);border:1px solid var(--cem-border);background:#00000073;color:var(--cem-text);font-size:12px}.cem-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:8px;margin-top:8px;max-height:190px;overflow:auto;padding-right:4px}.cem-picker-tile{border:1px solid transparent;background:#00000040;border-radius:8px;padding:6px;color:var(--cem-text);font-size:10px;cursor:pointer;text-align:left}.cem-picker-tile:hover{border-color:#ffffff40}.cem-picker-tile.is-selected{border-color:var(--cem-select);box-shadow:0 0 0 1px #38bdf84d}.cem-picker-thumb{width:100%;height:64px;border-radius:6px;overflow:hidden;background:#ffffff0f;display:flex;align-items:center;justify-content:center}.cem-picker-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.cem-picker-label{display:block;margin-top:6px;color:var(--cem-text-dim);font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cem-picker-empty{grid-column:1 / -1;padding:10px;border:1px dashed rgba(255,255,255,.2);border-radius:8px;color:var(--cem-text-dim);font-size:11px;text-align:center}.cbr-root{position:absolute;inset:0;pointer-events:none}.cbr-block{line-height:1}.cbr-effect-overlay{position:absolute;inset:0;pointer-events:none;z-index:1}.cbr-block--rect,.cbr-block--circle{min-width:0;min-height:0}.cbr-img-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.cbr-img-inner img{width:auto;height:auto;max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center}.cbr-icon-tint{width:100%;height:100%;display:block}.cbr-img-ph{font-size:22px;opacity:.3}.cbr-slot-ph{width:100%;height:100%;padding:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-align:center;color:#ffffffe0}.cbr-slot-ph.is-circle{border-radius:9999px}.cbr-slot-ph-name{font-size:10px;font-weight:800;letter-spacing:.02em}.cbr-slot-ph-purpose,.cbr-slot-ph-sources{font-size:8px;line-height:1.25;color:#ffffffa3}.cbr-divider-line{display:block;width:100%;height:2px;background:currentColor;border-radius:2px;opacity:.7}.cbr-stat-inner{display:flex;align-items:center;gap:4px;padding:0 4px;overflow:visible}.cbr-stat-label{font-size:inherit;font-weight:inherit;display:inline-block}.cbr-stat-value{font-size:120%;font-weight:900;display:inline-block}.cbr-text-inner{display:block;position:relative;min-width:0}.cvs-card{width:100%;height:100%;border-radius:calc(14px * var(--cvs-ui-scale, 1));position:relative;overflow:hidden;flex-shrink:0;display:flex;flex-direction:column;box-shadow:0 0 0 1px #ffffff14,0 18px 52px #000000b3,0 0 40px #7c6fff26}.cvs-card-visual-layer,.cvs-card-semantic-layer{position:absolute;inset:0}.cvs-card-visual-layer{z-index:2}.cvs-card-semantic-layer{z-index:4;pointer-events:none}.cvs-card-glare{position:absolute;inset:0;background:radial-gradient(circle at var(--card-glare-x, 50%) var(--card-glare-y, 50%),rgba(255,255,255,.34),rgba(255,255,255,.09) 28%,transparent 58%);mix-blend-mode:screen;opacity:.42;pointer-events:none;z-index:1}.cvs-card-holo{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.06) 0%,transparent 50%,rgba(255,255,255,.03) 100%);pointer-events:none;z-index:1}.cvs-card-toprow{display:flex;justify-content:space-between;align-items:center;padding:calc(7px * var(--cvs-ui-scale, 1)) calc(8px * var(--cvs-ui-scale, 1)) 0;z-index:12;position:relative}.cvs-card-rarity-badge{font-size:calc(8px * var(--cvs-ui-scale, 1));font-weight:900;letter-spacing:calc(.8px * var(--cvs-ui-scale, 1));text-transform:uppercase;padding:calc(2px * var(--cvs-ui-scale, 1)) calc(5px * var(--cvs-ui-scale, 1));border-radius:calc(4px * var(--cvs-ui-scale, 1));background:#0006;color:#fff}[data-rarity=RARE] .cvs-card-rarity-badge,.cvs-card[data-rarity=RARE] .cvs-card-rarity-badge{color:#60a5fa}[data-rarity=EPIC] .cvs-card-rarity-badge,.cvs-card[data-rarity=EPIC] .cvs-card-rarity-badge{color:#c084fc}[data-rarity=LEGENDARY] .cvs-card-rarity-badge,.cvs-card[data-rarity=LEGENDARY] .cvs-card-rarity-badge{color:#fbbf24}.cvs-card-cost{width:calc(22px * var(--cvs-ui-scale, 1));height:calc(22px * var(--cvs-ui-scale, 1));border-radius:50%;background:#0000008c;border:calc(1.5px * var(--cvs-ui-scale, 1)) solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:calc(11px * var(--cvs-ui-scale, 1));font-weight:900;color:#fff;z-index:13;position:relative}.cvs-card-art-zone{position:absolute;inset:0;overflow:hidden}.cvs-card-art-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.cvs-card-back-ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:calc(8px * var(--cvs-ui-scale, 1));color:#ffffff40;z-index:10}.cvs-card-back-ph span:first-child{font-size:calc(36px * var(--cvs-ui-scale, 1))}.cvs-card-back-ph span:last-child{font-size:calc(11px * var(--cvs-ui-scale, 1));letter-spacing:calc(2px * var(--cvs-ui-scale, 1));text-transform:uppercase}.cvr-root{position:relative;overflow:hidden;flex-shrink:0}.cvr-scaler{position:absolute;top:0;left:0;overflow:visible}.cvr-overlay-layer{position:absolute;inset:0;z-index:40;pointer-events:auto;overflow:visible}.cem-overlay{--cem-bg: #06061a;--cem-surface: rgba(255,255,255,.04);--cem-surface2: rgba(255,255,255,.08);--cem-surface3: rgba(255,255,255,.14);--cem-border: rgba(255,255,255,.09);--cem-border2: rgba(255,255,255,.2);--cem-gold: #f5c842;--cem-cyan: #00d4ff;--cem-pink: #ff4d8d;--cem-text: #e2d8c4;--cem-text-dim: #7a7060;--cem-text-hi: #ffffff;--cem-accent: #7c6fff;--cem-select: #38bdf8;--cem-r: 10px;--cem-rs: 6px;--cem-sb-w: 264px;--cem-pp-w: 264px;--cem-topbar-h: 64px;--cem-bottom-h: 48px;--cem-card-w: 252px;--cem-card-h: 352px;--cem-overlay-bg: rgba(0,0,0,.75);--cem-topbar-bg: rgba(0,0,0,.45);--cem-panel-bg: rgba(0,0,0,.25);--cem-bottom-bg: rgba(0,0,0,.35);--cem-canvas-bg: radial-gradient(ellipse at center, rgba(124,111,255,.06) 0%, transparent 70%), repeating-linear-gradient(0deg, transparent, transparent 29px, rgba(255,255,255,.025) 30px), repeating-linear-gradient(90deg, transparent, transparent 29px, rgba(255,255,255,.025) 30px), #08081e;--cem-input-bg: rgba(19,24,42,.95);--cem-input-text: #eef2ff;--cem-select-option-bg: #0f162d;--cem-chip-text: rgba(255,255,255,.78);--cem-chip-active-border: rgba(255,255,255,.55);--cem-close-bg: rgba(255,50,50,.14);--cem-close-border: rgba(255,80,80,.5);--cem-close-text: #ff8b8b;--cem-color-scheme: dark}.cem-overlay[data-editor-theme=light]{--cem-bg: #edf2fb;--cem-surface: rgba(15,23,42,.04);--cem-surface2: rgba(15,23,42,.08);--cem-surface3: rgba(15,23,42,.14);--cem-border: rgba(15,23,42,.08);--cem-border2: rgba(15,23,42,.16);--cem-text: #1f2937;--cem-text-dim: #64748b;--cem-text-hi: #0f172a;--cem-accent: #6d28d9;--cem-select: #0ea5e9;--cem-overlay-bg: rgba(148,163,184,.24);--cem-topbar-bg: rgba(255,255,255,.88);--cem-panel-bg: rgba(255,255,255,.68);--cem-bottom-bg: rgba(255,255,255,.84);--cem-canvas-bg: radial-gradient(ellipse at center, rgba(109,40,217,.06) 0%, transparent 70%), repeating-linear-gradient(0deg, transparent, transparent 29px, rgba(15,23,42,.035) 30px), repeating-linear-gradient(90deg, transparent, transparent 29px, rgba(15,23,42,.035) 30px), #e8edf7;--cem-input-bg: rgba(255,255,255,.98);--cem-input-text: #0f172a;--cem-select-option-bg: #ffffff;--cem-chip-text: rgba(15,23,42,.82);--cem-chip-active-border: rgba(15,23,42,.26);--cem-close-bg: rgba(220,38,38,.08);--cem-close-border: rgba(220,38,38,.28);--cem-close-text: #dc2626;--cem-color-scheme: light}.cem-overlay{position:fixed;inset:0;z-index:2147483000;display:flex;align-items:stretch;background:var(--cem-overlay-bg);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);overflow:hidden}.cem-modal{flex:1;display:flex;flex-direction:column;background:var(--cem-bg);overflow:hidden;color-scheme:var(--cem-color-scheme);position:relative}.cem-modal:before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");pointer-events:none;z-index:0}.cem-overlay>*{position:relative;z-index:1}.cem-topbar{height:var(--cem-topbar-h);min-height:var(--cem-topbar-h);display:flex;align-items:center;gap:8px;padding:0 12px;background:var(--cem-topbar-bg);border-bottom:1px solid var(--cem-border);flex-shrink:0;position:relative;z-index:10;overflow:visible}.cem-topbar-brand{display:flex;align-items:center;gap:10px;margin-right:8px;flex:1;min-width:0}.cem-topbar-logo{width:60px;height:60px;border-radius:0;background:transparent;border:none;display:flex;align-items:center;justify-content:center;overflow:visible;margin-top:0;flex-shrink:0}.cem-topbar-logo img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;-o-object-position:center center;object-position:center center;display:block}.cem-topbar-name-wrap{display:flex;flex-direction:column;gap:1px}.cem-topbar-name{font-size:14px;font-weight:700;color:var(--cem-text);letter-spacing:.3px}.cem-topbar-tools{display:flex;align-items:center;gap:4px;flex-shrink:0}.cem-topbar-sep{width:1px;height:18px;background:var(--cem-border2);margin:0 2px}.cem-tool-btn{padding:4px 9px;border-radius:var(--cem-rs);border:1px solid var(--cem-border);background:var(--cem-surface2);color:var(--cem-text);font-size:13px;cursor:pointer;transition:background .1s,color .1s;line-height:1;display:inline-flex;align-items:center;justify-content:center;min-width:30px;min-height:26px}.cem-tool-btn:hover{background:var(--cem-surface3);color:var(--cem-text-hi)}.cem-tool-btn:disabled{opacity:.35;cursor:not-allowed}.cem-tool-btn.is-active{border-color:#7c6fffe6;background:#7c6fff29;color:var(--cem-text-hi);box-shadow:0 0 0 1px #7c6fff38}.cem-tool-btn--reset{font-size:11px}.cem-tool-btn--theme{color:var(--cem-text-hi)}.cem-tool-icon{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.cem-zoom-badge{font-size:11px;font-weight:700;color:var(--cem-text-dim);min-width:34px;text-align:center}.cem-close-btn{margin-left:6px;width:32px;height:32px;border-radius:999px;border:1.5px solid var(--cem-close-border);background:var(--cem-close-bg);color:var(--cem-close-text);font-size:14px;font-weight:800;cursor:pointer;transition:background .12s,color .12s;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.cem-close-btn:hover{background:#ff323240;color:#fff}.cem-close-btn:disabled{opacity:.45;cursor:wait}.cem-save-btn{margin-left:6px;width:32px;height:32px;border-radius:999px;border:1.5px solid rgba(56,189,248,.45);background:#0ea5e92e;color:#7dd3fc;cursor:pointer;transition:background .12s,color .12s,border-color .12s;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.cem-save-btn:hover{background:#0ea5e94d;color:#fff;border-color:#38bdf8b3}.cem-save-btn:disabled{opacity:.45;cursor:not-allowed}.cem-body{flex:1;display:grid;grid-template-columns:var(--cem-sb-w) 1fr var(--cem-pp-w);min-height:0;overflow:hidden;position:relative}.cem-sidebar{border-right:1px solid var(--cem-border);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--cem-border2) transparent;background:var(--cem-panel-bg)}.cem-sidebar::-webkit-scrollbar{width:5px}.cem-sidebar::-webkit-scrollbar-thumb{background:var(--cem-border2);border-radius:4px}.cem-det{border-bottom:1px solid var(--cem-border)}.cem-det-hdr{list-style:none;display:flex;align-items:center;padding:9px 14px;font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--cem-text-dim);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;background:transparent;transition:background .1s,color .1s}.cem-det-hdr-main{display:inline-flex;align-items:center;gap:8px}.cem-det-hdr-icon{width:20px;height:20px;border-radius:6px;background:linear-gradient(135deg,var(--cem-accent),rgba(56,189,248,.9));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:9px;font-weight:900;letter-spacing:.3px;box-shadow:0 4px 12px #00000029}.cem-det-hdr::-webkit-details-marker{display:none}.cem-det-hdr:before{content:"▶";font-size:8px;margin-right:7px;transition:transform .15s;opacity:.55}.cem-det[open]>.cem-det-hdr{color:var(--cem-text)}.cem-det[open]>.cem-det-hdr:before{transform:rotate(90deg);opacity:1}.cem-det-hdr:hover{background:var(--cem-surface2);color:var(--cem-text-hi)}.cem-det-body{padding:8px 12px 12px}.cem-preset-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}.cem-preset-card-wrap{position:relative}.cem-preset-card{width:100%;min-height:184px;border-radius:10px;border:1px solid var(--cem-border2);background:var(--cem-surface);display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:9px;padding:10px 30px 12px 10px;color:var(--cem-text);cursor:pointer;transition:transform .15s ease,border-color .15s ease,background .15s ease,box-shadow .15s ease;position:relative;overflow:hidden}.cem-preset-card:before{content:"";position:absolute;inset:0;background:var(--preset-accent, linear-gradient(135deg,#3b82f6,#22d3ee));opacity:.14}.cem-preset-card>*{position:relative;z-index:1}.cem-preset-card:hover{transform:translateY(-1px);border-color:var(--cem-accent);background:var(--cem-surface2)}.cem-preset-card.is-active{border-color:var(--cem-accent);box-shadow:0 0 0 1px #7c6fff3d,0 10px 20px #00000029;background:var(--cem-surface2)}.cem-preset-thumb{width:100%;min-height:148px;border-radius:8px;border:1px solid var(--cem-border);background:#0f172a80;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:10px 8px}.cem-overlay[data-editor-theme=light] .cem-preset-thumb{background:#94a3b847}.cem-preset-thumb-card{pointer-events:none;margin:auto;display:block}.cem-preset-delete-btn{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:999px;border:1px solid rgba(248,113,113,.5);background:#0f172ad1;color:#fca5a5;font-size:13px;font-weight:900;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;opacity:1;transition:background .12s ease,color .12s ease,transform .12s ease}.cem-preset-delete-btn:hover{background:#7f1d1deb;color:#fff;transform:scale(1.04)}.cem-preset-card-title{font-size:12px;font-weight:800;color:var(--cem-text-hi);line-height:1.25;text-align:left}.cem-preset-info{padding:10px;border-radius:var(--cem-rs);border:1px solid var(--cem-border);background:var(--cem-surface);font-size:10px;line-height:1.45;color:var(--cem-text-dim)}.cem-preset-info strong{color:var(--cem-text-hi);font-weight:800}.cem-preset-meta{margin-top:6px}.cem-preset-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.cem-preset-tag{padding:2px 6px;border-radius:999px;background:var(--cem-surface2);color:var(--cem-text);font-size:9px;font-weight:700}.cem-preset-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.cem-preset-action-btn{padding:6px 8px;border-radius:var(--cem-rs);border:1px solid var(--cem-border2);background:var(--cem-surface2);color:var(--cem-text);font-size:10px;font-weight:700;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease}.cem-preset-action-btn:hover{background:var(--cem-surface3);border-color:var(--cem-accent);color:var(--cem-text-hi)}.cem-preset-action-btn:disabled{opacity:.5;cursor:wait}.cem-preset-action-btn--ghost{background:transparent}.cem-preset-action-btn--danger{border-color:#f8717166;color:#fca5a5}.cem-preset-action-btn--danger:hover{background:#f871712e;border-color:#f871718f;color:#fff}.cem-preset-form{display:flex;flex-direction:column;gap:8px;margin-top:10px;padding:10px;border-radius:10px;border:1px solid var(--cem-border);background:var(--cem-surface)}.cem-preset-form-actions{display:flex;gap:6px;justify-content:flex-end}.cem-preset-error{padding:8px;border-radius:var(--cem-rs);border:1px solid rgba(248,113,113,.28);background:#f871711f;color:#fca5a5;font-size:10px;line-height:1.4}.cem-community-panel{position:absolute;top:0;bottom:0;left:var(--cem-sb-w);width:clamp(260px,24vw,340px);border-right:1px solid var(--cem-border);background:color-mix(in srgb,var(--cem-bg) 82%,black 18%);z-index:18;display:flex;flex-direction:column;box-shadow:14px 0 30px #00000047}.cem-community-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px;border-bottom:1px solid var(--cem-border)}.cem-community-title-wrap{display:flex;flex-direction:column;gap:2px}.cem-community-title{font-size:12px;font-weight:800;color:var(--cem-text-hi)}.cem-community-subtitle{font-size:10px;color:var(--cem-text-dim)}.cem-community-close{width:26px;height:26px;border-radius:999px;border:1px solid var(--cem-border2);background:var(--cem-surface2);color:var(--cem-text);cursor:pointer}.cem-community-close:hover{border-color:var(--cem-accent);color:var(--cem-text-hi)}.cem-community-toolbar{padding:10px 12px;border-bottom:1px solid var(--cem-border)}.cem-community-search{width:100%;padding:6px 8px;border-radius:var(--cem-rs);border:1px solid var(--cem-border2);background:var(--cem-input-bg);color:var(--cem-input-text);font-size:12px}.cem-community-search:focus{outline:none;border-color:var(--cem-accent)}.cem-community-grid{padding:12px;overflow-y:auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.cem-community-card{border-radius:10px;border:1px solid var(--cem-border2);background:var(--cem-surface);color:var(--cem-text);display:flex;flex-direction:column;align-items:stretch;gap:6px;padding:8px;cursor:pointer;text-align:left;transition:border-color .12s ease,background .12s ease,transform .12s ease}.cem-community-card:hover{border-color:var(--cem-accent);background:var(--cem-surface2);transform:translateY(-1px)}.cem-community-card.is-active{border-color:var(--cem-accent);box-shadow:0 0 0 1px #7c6fff38}.cem-community-thumb{width:100%;min-height:154px;border-radius:8px;border:1px solid var(--cem-border);background:#0f172a80;display:flex;align-items:center;justify-content:center;padding:10px 8px;overflow:hidden}.cem-preset-thumb .cvr-root,.cem-community-thumb .cvr-root{margin:auto;display:block}.cem-community-name{font-size:11px;font-weight:800;color:var(--cem-text-hi);line-height:1.25}.cem-community-meta{font-size:10px;color:var(--cem-text-dim)}.cem-community-empty{padding:16px 14px;font-size:11px;color:var(--cem-text-dim)}.cem-sf{display:flex;flex-direction:column;gap:3px;margin-bottom:8px}.cem-sf:last-child{margin-bottom:0}.cem-sl{font-size:10px;font-weight:600;color:var(--cem-text-dim);letter-spacing:.3px;text-transform:uppercase}.cem-sl--toggle{display:flex;align-items:center;gap:7px;min-height:34px;color:var(--cem-text);text-transform:none;letter-spacing:0;cursor:pointer}.cem-sl--toggle input[type=checkbox]{accent-color:var(--cem-accent);cursor:pointer;width:18px;height:18px}.cem-sl--section{font-size:10px;font-weight:700;color:var(--cem-text-dim);letter-spacing:.5px;text-transform:uppercase;margin:8px 0 4px;padding-bottom:3px;border-bottom:1px solid var(--cem-border)}.cem-srow2{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:6px}.cem-si{padding:5px 8px;border-radius:var(--cem-rs);border:1px solid var(--cem-border2);background:var(--cem-input-bg);color:var(--cem-input-text);font-size:12px;width:100%;box-sizing:border-box;outline:none;transition:border-color .12s;color-scheme:var(--cem-color-scheme)}.cem-si:focus{border-color:var(--cem-accent)}.cem-si--ta{resize:none;font-family:inherit}.cem-si--color{padding:2px;height:30px;cursor:pointer}select.cem-si{cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:28px;background-color:var(--cem-input-bg);background-image:linear-gradient(0deg,#ffffff0f,#ffffff0f),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath d='M3.5 5.5L7 9l3.5-3.5' fill='none' stroke='%23b6c8ff' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat,no-repeat;background-position:0 0,right 9px center;background-size:auto,12px 12px;color:var(--cem-input-text)}select.cem-si:focus{box-shadow:0 0 0 2px #7c6fff52}select.cem-si option{background:var(--cem-select-option-bg);color:var(--cem-input-text)}.cem-rarity-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-top:6px}.cem-rarity-btn{padding:5px 6px;border-radius:var(--cem-rs);border:1.5px solid transparent;font-size:10px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;cursor:pointer;transition:opacity .12s,border-color .12s;opacity:.55}.cem-rarity-btn.is-active{opacity:1;border-color:currentColor}.cem-rarity-btn--common{background:#374151;color:#9ca3af}.cem-rarity-btn--rare{background:#1e3a5f;color:#60a5fa}.cem-rarity-btn--epic{background:#3b0764;color:#c084fc}.cem-rarity-btn--legendary{background:#78350f;color:#fbbf24}.cem-tpl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;margin-bottom:6px}.cem-tpl-btn{padding:8px 4px 6px;border-radius:7px;border:2px solid transparent;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;opacity:.6;transition:opacity .12s,border-color .12s}.cem-tpl-btn:hover{opacity:.85}.cem-tpl-btn.is-active{opacity:1;border-color:#ffffff8c!important}.cem-tpl-icon{font-size:11px;font-weight:900;color:#fff}.cem-tpl-name{font-size:9px;color:#ffffffbf;font-weight:600}.cem-frame-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.cem-frame-btn{padding:5px 4px;border-radius:var(--cem-rs);border:1.5px solid var(--cem-border);background:var(--cem-surface2);color:var(--cem-text-dim);font-size:9px;font-weight:600;cursor:pointer;text-align:center;transition:background .1s,color .1s,border-color .1s}.cem-frame-btn:hover{background:var(--cem-surface3);color:var(--cem-text)}.cem-frame-btn.is-active{background:var(--cem-surface3);border-color:var(--cem-border2);color:var(--cem-text-hi)}.cem-img-thumb-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.cem-img-thumb{width:44px;height:44px;-o-object-fit:cover;object-fit:cover;border-radius:var(--cem-rs);border:1px solid var(--cem-border2);flex-shrink:0}.cem-img-thumb-btns{display:flex;flex-direction:column;gap:4px;flex:1}.cem-dropzone{width:100%;padding:12px;border-radius:var(--cem-r);border:1.5px dashed var(--cem-border2);background:var(--cem-surface);color:var(--cem-text-dim);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:11px;transition:background .12s,border-color .12s,color .12s;margin-bottom:6px}.cem-dropzone:hover{background:var(--cem-surface2);color:var(--cem-text);border-color:var(--cem-accent)}.cem-dropzone--loading{opacity:.6;pointer-events:none}.cem-dropzone-icon{font-size:22px;opacity:.5}.cem-upload-error{font-size:10px;color:#f87171;margin:4px 0 0;padding:4px 6px;border-radius:4px;background:#f871711a}.cem-asset-strip{margin:4px 0 8px}.cem-asset-strip-head{font-size:10px;font-weight:700;color:var(--cem-text-dim);letter-spacing:.35px;text-transform:uppercase;margin-bottom:4px}.cem-asset-strip-list{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;scrollbar-width:thin}.cem-asset-strip-list::-webkit-scrollbar{height:4px}.cem-asset-strip-list::-webkit-scrollbar-thumb{background:var(--cem-border2);border-radius:4px}.cem-asset-chip{min-width:64px;max-width:86px;border:1px solid var(--cem-border);border-radius:8px;background:var(--cem-surface);color:var(--cem-text);display:flex;flex-direction:column;align-items:stretch;padding:4px;gap:4px;cursor:pointer;transition:border-color .12s,background .12s}.cem-asset-chip:hover{border-color:var(--cem-accent);background:var(--cem-surface2)}.cem-asset-chip img{width:100%;aspect-ratio:1 / 1;border-radius:6px;-o-object-fit:cover;object-fit:cover;border:1px solid var(--cem-border2)}.cem-asset-chip span{font-size:9px;line-height:1.2;color:var(--cem-text-dim);text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cem-palette{display:grid;grid-template-columns:repeat(2,1fr);gap:4px}.cem-palette-btn{display:flex;align-items:center;gap:7px;padding:7px 8px;border-radius:var(--cem-rs);border:1px solid var(--cem-border);background:var(--cem-surface);color:var(--cem-text);cursor:pointer;font-size:11px;transition:background .1s,border-color .1s}.cem-palette-btn:hover{background:var(--cem-surface2);border-color:var(--palette-color, var(--cem-accent))}.cem-palette-icon{width:22px;height:22px;border-radius:5px;background:var(--palette-color, var(--cem-accent));display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:900;color:#fff;flex-shrink:0}.cem-palette-label{font-size:11px;font-weight:600;color:var(--cem-text)}.cem-layer-list{display:flex;flex-direction:column;gap:3px}.cem-layer-empty{font-size:11px;color:var(--cem-text-dim);text-align:center;padding:8px 0}.cem-layer-item{display:flex;align-items:center;gap:7px;padding:5px 8px;border-radius:var(--cem-rs);border:1px solid transparent;background:var(--cem-surface);cursor:grab;transition:background .1s,border-color .1s,opacity .1s,transform .1s}.cem-layer-item:hover{background:var(--cem-surface2)}.cem-layer-item.is-hovered{border-color:#38bdf880;box-shadow:inset 0 0 0 1px #38bdf859}.cem-layer-item.is-active{background:var(--cem-surface2);border-color:var(--cem-border2)}.cem-layer-item.is-dragging{opacity:.5}.cem-layer-item.is-locked{cursor:default}.cem-layer-item.is-hidden{opacity:.58}.cem-layer-item.is-drop-target{border-color:var(--cem-accent);box-shadow:inset 0 0 0 1px var(--cem-accent)}.cem-layer-grab{font-size:12px;color:var(--cem-text-dim);letter-spacing:-1px;line-height:1;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0}.cem-layer-type-icon{font-size:12px;width:16px;text-align:center;flex-shrink:0}.cem-layer-label{flex:1;font-size:11px;color:var(--cem-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cem-layer-actions{display:flex;gap:2px}.cem-layer-actions button{padding:2px 5px;border-radius:4px;border:none;background:var(--cem-surface2);color:var(--cem-text-dim);font-size:10px;cursor:pointer;transition:background .1s,color .1s}.cem-layer-actions button:hover{background:var(--cem-surface3);color:var(--cem-text-hi)}.cem-layer-actions button:disabled{opacity:.4;cursor:not-allowed}.cem-layer-del:hover{background:#f8717140!important;color:#f87171!important}.cem-btn{padding:5px 10px;border-radius:var(--cem-rs);border:1px solid var(--cem-border2);background:var(--cem-surface2);color:var(--cem-text);font-size:11px;cursor:pointer;transition:background .1s,color .1s;display:inline-flex;align-items:center;justify-content:center;gap:6px}.cem-btn:hover{background:var(--cem-surface3);color:var(--cem-text-hi)}.cem-btn:disabled{opacity:.35;cursor:not-allowed}.cem-btn--sm{padding:3px 8px;font-size:10px}.cem-btn--primary{background:var(--cem-accent);border-color:transparent;color:#fff;font-weight:700}.cem-btn--primary:hover{background:#9b8fff}.cem-btn--danger{border-color:#f8717166;color:#f87171}.cem-btn--danger:hover{background:#f8717133;color:#fff}.cem-canvas{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;overflow:hidden;background:var(--cem-canvas-bg);position:relative}.cem-canvas-viewport{width:100%;flex:1;min-height:0;display:flex;align-items:center;justify-content:center;padding:16px 20px 8px;overflow:hidden}.cem-face-toggle{display:flex;gap:0;padding:10px 16px 0;align-self:stretch;flex-shrink:0}.cem-face-btn{flex:1;padding:6px 0;border:1.5px solid var(--cem-border2);background:var(--cem-surface);color:var(--cem-text-dim);font-size:12px;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.cem-face-btn:first-child{border-radius:var(--cem-rs) 0 0 var(--cem-rs)}.cem-face-btn:last-child{border-radius:0 var(--cem-rs) var(--cem-rs) 0;border-left:none}.cem-face-btn:hover{background:var(--cem-surface2);color:var(--cem-text)}.cem-face-btn:disabled{opacity:.45;cursor:wait}.cem-face-btn.is-active{background:var(--cem-accent);border-color:var(--cem-accent);color:#fff}.cem-canvas-scroll{display:flex;flex-direction:column;align-items:center;justify-content:center;will-change:transform;transform-origin:center center}.cem-card-stage{perspective:none;padding:12px}.cem-card-frame{width:var(--cem-card-w);height:var(--cem-card-h);flex-shrink:0}.cem-card{transform:none;transform-style:flat;transition:box-shadow .18s ease}.cem-card-toprow{display:flex;justify-content:space-between;align-items:center;padding:7px 8px 0;z-index:2;position:relative}.cem-card-rarity-badge{font-size:8px;font-weight:900;letter-spacing:.8px;text-transform:uppercase;padding:2px 5px;border-radius:4px;background:#0006;color:#fff}[data-rarity=RARE] .cem-card-rarity-badge,.cem-card[data-rarity=RARE] .cem-card-rarity-badge{color:#60a5fa}[data-rarity=EPIC] .cem-card-rarity-badge,.cem-card[data-rarity=EPIC] .cem-card-rarity-badge{color:#c084fc}[data-rarity=LEGENDARY] .cem-card-rarity-badge,.cem-card[data-rarity=LEGENDARY] .cem-card-rarity-badge{color:#fbbf24}.cem-card-cost{width:22px;height:22px;border-radius:50%;background:#0000008c;border:1.5px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900;color:#fff;z-index:2;position:relative}.cem-card-art-zone{flex:1;overflow:hidden;position:relative;z-index:2}.cem-card-art-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.cem-card-info{padding:5px 8px 7px;background:#0000008c;z-index:2;position:relative}.cem-card-name{font-size:11px;font-weight:800;color:#fff;letter-spacing:.3px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.cem-card-desc{font-size:8px;color:#ffffffa6;line-height:1.3;margin-top:2px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.cem-card-back-ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#ffffff40;z-index:2}.cem-card-back-ph span:first-child{font-size:36px}.cem-card-back-ph span:last-child{font-size:11px;letter-spacing:2px;text-transform:uppercase}.cem-blocks-layer{position:absolute;inset:0;z-index:10;pointer-events:auto}.cem-block-hit-layer,.cem-block-chrome-layer{position:absolute;inset:0;overflow:visible!important}.cem-block-hit-layer{z-index:1;pointer-events:auto}.cem-block-chrome-layer{z-index:2;pointer-events:none}.cem-block-hit-target,.cem-block-chrome{position:absolute;box-sizing:border-box;transition:none;overflow:visible!important}.cem-block-hit-target{pointer-events:auto;background:transparent}.cem-block-hit-target.is-locked{cursor:default!important}.cem-block-hit-area{position:absolute;inset:0;background:transparent}.cem-card-root,.cem-card,.cem-blocks-layer{overflow:visible!important}.cem-block-chrome{pointer-events:none}.cem-block-chrome .cem-block-border{position:absolute;inset:0;pointer-events:none;border-radius:4px}.cem-alignment-guide{position:absolute;pointer-events:none;z-index:11;background:#38bdf8f5;box-shadow:0 0 0 1px #38bdf840,0 0 12px #38bdf873}.cem-alignment-guide--vertical{top:0;bottom:0;width:1.5px;transform:translate(-50%)}.cem-alignment-guide--horizontal{left:0;right:0;height:1.5px;transform:translateY(-50%)}.cem-block-chrome--hover .cem-block-border{border:1.5px solid rgba(56,189,248,.72);box-shadow:0 0 0 1px #38bdf829,0 0 10px #38bdf838}.cem-block-chrome--active .cem-block-border{border:2px solid var(--cem-select);box-shadow:0 0 0 1px #38bdf859,0 0 14px #38bdf873}.cem-block-chrome.is-locked .cem-block-border{border-style:dashed}.cem-resize-handle{position:absolute;width:10px;height:10px;border-radius:2px;border:1px solid rgba(15,23,42,.92);background:#f8fafc;box-shadow:0 0 0 1px #38bdf8d9;z-index:12;pointer-events:auto}.cem-resize-handle--nw{top:-6px;left:-6px;cursor:nwse-resize}.cem-resize-handle--ne{top:-6px;right:-6px;cursor:nesw-resize}.cem-resize-handle--se{right:-6px;bottom:-6px;cursor:nwse-resize}.cem-resize-handle--sw{left:-6px;bottom:-6px;cursor:nesw-resize}.cem-resize-handle--n{top:-7px;left:50%;transform:translate(-50%);cursor:ns-resize}.cem-resize-handle--s{bottom:-7px;left:50%;transform:translate(-50%);cursor:ns-resize}.cem-resize-handle--e{right:-7px;top:50%;transform:translateY(-50%);cursor:ew-resize}.cem-resize-handle--w{left:-7px;top:50%;transform:translateY(-50%);cursor:ew-resize}.cem-rotate-handle{position:absolute;top:-32px;left:50%;width:15px;height:15px;border-radius:999px;border:1px solid rgba(255,255,255,.78);background:radial-gradient(circle at 30% 30%,#93c5fd,#0ea5e9);box-shadow:0 0 10px #0ea5e98c;transform:translate(-50%);cursor:grab;z-index:13;pointer-events:auto}.cem-rotate-handle:before{content:"";position:absolute;left:50%;bottom:-13px;width:2px;height:13px;background:#bae6fdd9;transform:translate(-50%);border-radius:99px;pointer-events:none}.cem-rotate-handle:active{cursor:grabbing}.cem-block--container{box-shadow:inset 0 0 0 1px #38bdf866}.cem-canvas-hint{display:flex;align-items:center;gap:8px;padding:8px 16px;font-size:10px;color:var(--cem-text-dim);flex-shrink:0;flex-wrap:wrap;justify-content:center}.cem-canvas-hint kbd{padding:1px 5px;border-radius:4px;border:1px solid var(--cem-border2);background:var(--cem-surface2);color:var(--cem-text);font-size:9px;font-family:monospace}.cem-props-panel{border-left:1px solid var(--cem-border);display:flex;flex-direction:column;background:var(--cem-panel-bg);overflow:hidden}.cem-props-header{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;border-bottom:1px solid var(--cem-border);flex-shrink:0}.cem-props-title{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--cem-text-dim)}.cem-save-error{margin:0 16px 12px;padding:10px 12px;border-radius:var(--cem-rs);border:1px solid rgba(248,113,113,.35);background:#7f1d1d47;color:#fecaca;font-size:12px;text-align:center}.cem-confirm-backdrop{position:absolute;inset:0;z-index:40;display:flex;align-items:center;justify-content:center;padding:24px;background:#020617a8;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.cem-confirm-dialog{position:relative;width:min(420px,100%);padding:18px;border-radius:16px;border:1px solid var(--cem-border2);background:color-mix(in srgb,var(--cem-bg) 84%,black 16%);box-shadow:0 24px 60px #0000006b}.cem-confirm-close{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:999px;border:1px solid var(--cem-border2);background:var(--cem-surface);color:var(--cem-text);cursor:pointer}.cem-confirm-title{font-size:16px;font-weight:800;color:var(--cem-text-hi)}.cem-confirm-copy{margin-top:10px;font-size:12px;line-height:1.5;color:var(--cem-text)}.cem-confirm-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.cem-props-block-type{font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;background:var(--cem-surface2);color:var(--cem-text-dim);text-transform:uppercase;letter-spacing:.3px}.cem-props-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px;color:var(--cem-text-dim)}.cem-props-empty-icon{font-size:32px;opacity:.3}.cem-props-empty p{font-size:11px;text-align:center;line-height:1.5}.cem-props-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:10px 12px;scrollbar-width:thin;scrollbar-color:var(--cem-border2) transparent}.cem-props-content::-webkit-scrollbar{width:4px}.cem-props-content::-webkit-scrollbar-thumb{background:var(--cem-border2);border-radius:4px}.cem-props-type-row{display:flex;align-items:center;gap:8px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--cem-border)}.cem-props-type-icon{width:24px;height:24px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:900;color:#fff;flex-shrink:0}.cem-props-type-icon--card{background:linear-gradient(135deg,#7c6ffff0,#38bdf8e6)}.cem-props-type-label{flex:1;font-size:12px;font-weight:700;color:var(--cem-text-hi)}.cem-props-del-btn{width:24px;height:24px;border-radius:50%;border:1px solid rgba(248,113,113,.5);background:#f8717133;color:#f87171;font-size:12px;font-weight:800;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s}.cem-props-del-btn:hover{background:#f871714d;color:#fff}.cem-props-del-btn:disabled{opacity:.45;cursor:not-allowed}.cem-props-section-title{font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--cem-text-dim);margin:10px 0 5px;padding-bottom:3px;border-bottom:1px solid var(--cem-border)}.cem-pf{display:flex;flex-direction:column;gap:3px;margin-bottom:7px}.cem-card-settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:8px 0 10px}.cem-card-settings-stat{display:flex;flex-direction:column;gap:3px;min-height:56px;padding:10px;border-radius:10px;border:1px solid var(--cem-border);background:color-mix(in srgb,var(--cem-surface) 86%,transparent)}.cem-card-settings-label{font-size:10px;font-weight:700;letter-spacing:.35px;text-transform:uppercase;color:var(--cem-text-dim)}.cem-card-settings-stat strong{font-size:16px;line-height:1.1;color:var(--cem-text-hi)}.cem-pl{font-size:10px;font-weight:600;color:var(--cem-text-dim);letter-spacing:.2px;text-transform:uppercase}.cem-pl--check{display:flex;align-items:center;gap:10px;flex-direction:row;font-size:11px;color:var(--cem-text);cursor:pointer;min-height:24px}.cem-pl--check input[type=checkbox]{cursor:pointer;accent-color:var(--cem-accent);width:18px;height:18px;flex-shrink:0}.cem-pi{padding:5px 8px;border-radius:var(--cem-rs);border:1px solid var(--cem-border2);background:var(--cem-input-bg);color:var(--cem-input-text);font-size:12px;width:100%;box-sizing:border-box;outline:none;transition:border-color .12s;color-scheme:var(--cem-color-scheme)}.cem-pi:focus{border-color:var(--cem-accent)}.cem-pi--ta{resize:none;font-family:inherit}.cem-pi--color{padding:2px;height:30px;cursor:pointer}.cem-pi--compact{text-align:right}.cem-color-palette-field{display:inline-block;position:relative}.cem-color-palette-field--sidebar{display:flex;align-items:center;gap:8px;min-width:0}.cem-color-palette-field--sidebar .cem-si--color{flex:0 0 44px;width:44px;min-width:44px}.cem-range-field{display:grid;grid-template-columns:minmax(0,1fr) 70px;align-items:center;gap:8px}.cem-props-btn-row{display:flex;flex-wrap:wrap;gap:8px}.cem-range{width:100%;margin:0;accent-color:var(--cem-accent);cursor:pointer}.cem-color-history{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.cem-color-history--inline{flex:1 1 auto;margin-top:0;min-width:0}.cem-color-history-btn{width:22px;height:22px;padding:0;border:1px solid var(--cem-border2);border-radius:999px;background:var(--cem-history-color);box-shadow:inset 0 0 0 1px #ffffff1f;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.cem-color-history-btn:hover{transform:translateY(-1px);border-color:var(--cem-accent)}.cem-color-history-btn.is-active{box-shadow:0 0 0 2px #7c6fff52,inset 0 0 0 1px #ffffff2e;border-color:var(--cem-accent)}.cem-color-trigger{width:30px;height:30px;min-width:30px;border-radius:6px;border:2px solid var(--cem-border2);cursor:pointer;flex-shrink:0;box-shadow:inset 0 0 0 1px #ffffff1f,0 1px 3px #0006;transition:border-color .12s,box-shadow .12s;background-clip:padding-box}.cem-color-trigger:hover{border-color:var(--cem-accent);box-shadow:0 0 0 2px #7c6fff40,inset 0 0 0 1px #ffffff29}.cem-color-palette-field{position:relative}.cem-color-picker-popover{position:absolute;top:calc(100% + 6px);left:0;z-index:900;background:var(--cem-input-bg);border:1px solid var(--cem-border2);border-radius:10px;padding:10px;min-width:180px;box-shadow:0 8px 24px #00000080,0 0 0 1px #ffffff0f;display:flex;flex-direction:column;gap:8px}.cem-color-history--popover{margin-top:0;gap:5px}.cem-color-picker-input-row{display:flex;align-items:center;gap:6px}.cem-color-picker-input-row .cem-pi--color{flex:0 0 36px;width:36px;height:26px;padding:2px}.cem-color-picker-hex{font-size:10px;color:var(--cem-text-dim);font-family:monospace;letter-spacing:.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cem-prop-section{border-top:1px solid var(--cem-border);margin-top:4px}.cem-prop-section-hdr{display:flex;align-items:center;gap:6px;width:100%;padding:8px 0 8px 2px;background:none;border:none;color:var(--cem-text-dim);font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;cursor:pointer;text-align:left;transition:color .12s}.cem-prop-section-hdr:hover{color:var(--cem-text)}.cem-prop-section-hdr.is-open{color:var(--cem-accent)}.cem-prop-section-chevron{display:inline-block;width:10px;height:10px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(-45deg);transition:transform .16s ease;margin-top:-2px;flex-shrink:0}.cem-prop-section-hdr.is-open .cem-prop-section-chevron{transform:rotate(45deg);margin-top:2px}.cem-prop-section-body{padding-bottom:8px;display:flex;flex-direction:column;gap:4px}.cem-cpf-popover{position:fixed;z-index:2147483646;background:var(--cem-input-bg);border:1px solid var(--cem-border2);border-radius:10px;padding:10px;width:204px;box-shadow:0 8px 32px #0009,0 0 0 1px #ffffff0f;display:flex;flex-direction:column;gap:8px}.cem-cpf-input-row{display:flex;align-items:center;gap:6px}.cem-cpf-input-row .cem-pi--color{flex:0 0 36px;width:36px;height:26px;padding:2px}.cem-cpf-hex{font-size:10px;color:var(--cem-text-dim);font-family:monospace;letter-spacing:.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.cem-color-trigger--sm{width:20px;height:20px;min-width:20px;border-radius:4px;border:1.5px solid var(--cem-border2);cursor:pointer;flex-shrink:0;box-shadow:inset 0 0 0 1px #ffffff1a,0 1px 2px #0006;transition:border-color .12s;background-clip:padding-box}.cem-color-trigger--sm:hover{border-color:var(--cem-accent)}.cem-fx-row{border:1px solid var(--cem-border);border-radius:7px;background:var(--cem-surface);overflow:hidden;transition:border-color .12s}.cem-fx-row.is-on{border-color:var(--cem-border2);background:var(--cem-surface2)}.cem-fx-hdr{display:flex;align-items:center;gap:6px;padding:6px 8px;min-height:34px}.cem-fx-check{display:flex;align-items:center;gap:0;cursor:pointer;flex-shrink:0;margin:0;min-width:24px;min-height:24px;justify-content:center}.cem-fx-check input[type=checkbox]{accent-color:var(--cem-accent);width:18px;height:18px;cursor:pointer;flex-shrink:0}.cem-fx-name{flex:1;font-size:10px;font-weight:600;color:var(--cem-text-dim);letter-spacing:.3px;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color .12s}.cem-fx-row.is-on .cem-fx-name{color:var(--cem-text)}.cem-fx-body{display:flex;flex-direction:column;gap:5px;padding:0 8px 8px;border-top:1px solid var(--cem-border)}.cem-gradient-editor{display:flex;flex-direction:column;gap:8px;padding:8px;border-radius:8px;border:1px solid var(--cem-border);background:var(--cem-surface)}.cem-gradient-preview{width:100%;height:26px;border-radius:8px;border:1px solid var(--cem-border2);box-shadow:inset 0 0 0 1px #ffffff14}.cem-fx-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px}.cem-fx-row3 .cem-prop-row{margin:0}select.cem-pi{cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:28px;background-color:var(--cem-input-bg);background-image:linear-gradient(0deg,#ffffff0f,#ffffff0f),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath d='M3.5 5.5L7 9l3.5-3.5' fill='none' stroke='%23b6c8ff' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat,no-repeat;background-position:0 0,right 9px center;background-size:auto,12px 12px;color:var(--cem-input-text)}select.cem-pi:focus{box-shadow:0 0 0 2px #7c6fff52}select.cem-pi option{background:var(--cem-select-option-bg);color:var(--cem-input-text)}.cem-props-row2{display:grid;grid-template-columns:1fr 1fr;gap:6px}.cem-props-align-row{display:flex;gap:4px}.cem-align-btn{flex:1;padding:5px;border-radius:var(--cem-rs);border:1.5px solid var(--cem-border);background:var(--cem-surface2);color:var(--cem-text-dim);font-size:13px;cursor:pointer;transition:background .1s,color .1s,border-color .1s}.cem-align-btn:hover{background:var(--cem-surface3);color:var(--cem-text)}.cem-align-btn.is-active{background:var(--cem-surface3);border-color:var(--cem-accent);color:var(--cem-text-hi)}.cem-align-icon{display:flex;flex-direction:column;gap:2px;width:18px;margin:0 auto}.cem-align-icon span{display:block;height:2px;border-radius:999px;background:currentColor}.cem-align-icon--left span:nth-child(1){width:100%}.cem-align-icon--left span:nth-child(2){width:78%}.cem-align-icon--left span:nth-child(3){width:92%}.cem-align-icon--left span:nth-child(4){width:68%}.cem-align-icon--center{align-items:center}.cem-align-icon--center span:nth-child(1){width:88%}.cem-align-icon--center span:nth-child(2){width:64%}.cem-align-icon--center span:nth-child(3){width:100%}.cem-align-icon--center span:nth-child(4){width:72%}.cem-align-icon--right{align-items:flex-end}.cem-align-icon--right span:nth-child(1){width:100%}.cem-align-icon--right span:nth-child(2){width:78%}.cem-align-icon--right span:nth-child(3){width:92%}.cem-align-icon--right span:nth-child(4){width:68%}.cem-align-icon--justify span:nth-child(1),.cem-align-icon--justify span:nth-child(2),.cem-align-icon--justify span:nth-child(3),.cem-align-icon--justify span:nth-child(4){width:100%}.cem-props-img-preview{display:flex;flex-direction:column;gap:6px;margin-bottom:6px}.cem-props-img-preview img{width:100%;border-radius:var(--cem-rs);border:1px solid var(--cem-border2);-o-object-fit:contain;object-fit:contain;max-height:80px}.cem-slot-summary{display:flex;flex-direction:column;gap:2px;margin-bottom:8px;padding:8px;border-radius:var(--cem-rs);border:1px solid var(--cem-border);background:var(--cem-surface);font-size:10px;color:var(--cem-text-dim)}.cem-slot-summary strong{color:var(--cem-text-hi)}.cem-source-policy-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.cem-source-policy-item{padding:6px 8px;border-radius:var(--cem-rs);border:1px solid var(--cem-border);background:var(--cem-surface)}.cem-props-hint{font-size:10px;color:var(--cem-text-dim);line-height:1.4;margin:4px 0}.cem-props-layer-actions{display:flex;align-items:center;gap:4px;margin-top:10px;padding-top:8px;border-top:1px solid var(--cem-border)}.cem-props-layer-actions .cem-props-hint{flex:1;margin:0}.cem-layer-action-btn{flex:0 0 auto;padding:5px 4px;border-radius:var(--cem-rs);border:1px solid var(--cem-border);background:var(--cem-surface);color:var(--cem-text-dim);font-size:10px;font-weight:600;cursor:pointer;text-align:center;transition:background .1s,color .1s}.cem-layer-action-btn:hover{background:var(--cem-surface2);color:var(--cem-text-hi)}@media(max-width:900px){.cem-overlay{--cem-sb-w: 220px;--cem-pp-w: 200px}.cem-community-panel{width:min(300px,calc(100vw - var(--cem-sb-w) - 14px))}}@media(max-width:680px){.cem-body{grid-template-columns:200px 1fr}.cem-props-panel{display:none}.cem-topbar-logo{width:54px;height:54px}.cem-topbar-subname{display:none}.cem-preset-grid{grid-template-columns:1fr}.cem-community-panel{left:0;width:min(320px,100vw)}.cem-community-grid{grid-template-columns:1fr}}.cem-gradient-types{display:flex;gap:4px;margin-bottom:4px}.cem-gradient-type-btn{flex:1;padding:4px 8px;border-radius:var(--cem-rs);border:1px solid var(--cem-border2);background:var(--cem-surface2);color:var(--cem-text-dim);font-size:10px;font-weight:600;cursor:pointer;transition:background .1s,color .1s,border-color .1s}.cem-gradient-type-btn.is-active{background:var(--cem-surface3);border-color:var(--cem-accent);color:var(--cem-text-hi)}.cem-gradient-stops{display:flex;flex-direction:column;gap:5px;margin:4px 0}.cem-gradient-stop-row{display:flex;align-items:center;gap:5px}.cem-gradient-stop-pos{flex:1;display:grid;grid-template-columns:minmax(0,1fr) 38px;gap:4px;align-items:center;min-width:0}.cem-gradient-stop-remove{flex-shrink:0;width:18px;height:18px;border-radius:50%;border:1px solid var(--cem-border2);background:var(--cem-surface2);color:var(--cem-text-dim);font-size:12px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.cem-gradient-stop-remove:hover{background:#ef444426;border-color:#ef444466;color:#f87171}.gamification-page{--gm-primary: #0073e6;--gm-primary-light: #e8f2ff;--gm-primary-dark: #005cb3;--gm-accent: #d4a017;--gm-accent-light: #fff8e6;--gm-green: #16a34a;--gm-green-light: #dcfce7;--gm-red: #dc2626;--gm-bg: #f5f0eb;--gm-bg-card: #ffffff;--gm-bg-subtle: #f0ebe3;--gm-text: #1a1a1a;--gm-text-muted: #6b6b6b;--gm-text-soft: #a0a0a0;--gm-border: #e8e0d6;--gm-border-light: #f0ebe3;--gm-shadow-card: 0 1px 3px rgba(0, 0, 0, .04), 0 4px 12px rgba(0, 0, 0, .03);--gm-shadow-float: 0 8px 30px rgba(0, 0, 0, .12);color:var(--gm-text);width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);padding:0}.gamification-page .page-hero-inner,.gamification-page .page-content{width:100%;max-width:none;padding-left:24px;padding-right:24px}html[data-theme=dark] .gamification-page{--gm-bg: #0e0c0b;--gm-bg-card: #1a1714;--gm-bg-subtle: #181512;--gm-text: #f5f0eb;--gm-text-muted: #a09488;--gm-text-soft: #6b6058;--gm-border: #302a24;--gm-border-light: #262220;--gm-shadow-card: 0 1px 3px rgba(0, 0, 0, .2), 0 4px 12px rgba(0, 0, 0, .15);--gm-shadow-float: 0 8px 30px rgba(0, 0, 0, .35)}.gamification-hero{background:linear-gradient(135deg,#1a0a2e,#16213e 40%,#0f3460,#533483);color:#fff}.gamification-hero .page-hero-inner{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}.gamification-tabs{display:flex;gap:6px;flex-wrap:nowrap;width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:6px 2px 2px;margin:0;justify-content:flex-start}.gamification-page button,.gamification-page [role=button],.gamification-page .gm-pack-card,.gamification-page .gm-featured,.gamification-page .gm-system-card,.gamification-page .gm-library-item,.gamification-page .gm-template-card{cursor:pointer}.gamification-tabs::-webkit-scrollbar{display:none}.gamification-tab{display:inline-flex;flex:0 0 auto;align-items:center;gap:6px;padding:8px 16px;border-radius:999px;border:1.5px solid var(--gm-border);background:var(--gm-bg);font-size:.82rem;font-weight:700;color:var(--gm-text-muted);transition:all .2s ease;white-space:nowrap}.gamification-tab.active{background:var(--gm-text);color:var(--gm-bg-card);border-color:var(--gm-text)}@media(min-width:761px){.gamification-tabs{width:auto;max-width:100%;justify-content:flex-end}}@media(max-width:1024px),(hover:none)and (pointer:coarse)and (orientation:landscape){.gamification-tabs{display:none!important}}.gamification-section{display:none;animation:gmFadeUp .3s ease}.gamification-section.active{display:block}.gm-section-header{margin-bottom:16px}.gm-section-header h2{font-family:Fredoka,sans-serif;font-size:1.1rem;font-weight:700;margin-bottom:4px}.gm-section-header p{color:var(--gm-text-muted);font-size:.85rem;font-weight:600}.gm-hero{border-radius:16px;background:linear-gradient(135deg,#1a0a2e,#16213e 40%,#0f3460,#533483);color:#fff;padding:22px;margin-bottom:18px;position:relative;overflow:hidden}.gm-hero-content h2{font-family:Fredoka,sans-serif;font-size:1.3rem;font-weight:700;margin-bottom:6px}.gm-hero-content p{color:#ffffffb3;font-size:.85rem;font-weight:600;margin-bottom:14px}.gm-hero-stats{display:flex;gap:16px}.gm-hero-stats div{text-align:center}.gm-hero-stats strong{display:block;font-family:Fredoka,sans-serif;font-size:1.1rem;color:gold}.gm-hero-stats span{font-size:.62rem;color:#fff9;text-transform:uppercase;letter-spacing:.4px}.gm-search{background:var(--gm-bg-card);border:1.5px solid var(--gm-border);border-radius:12px;padding:10px 14px;margin-bottom:12px}.gm-search input{width:100%;border:none;outline:none;background:transparent;font-size:.9rem;font-weight:600;color:var(--gm-text)}.gm-category-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px}.gm-category-scroll::-webkit-scrollbar{display:none}.gm-category-chip{padding:7px 14px;border-radius:14px;border:1.5px solid var(--gm-border);background:var(--gm-bg-card);font-size:.74rem;font-weight:700;color:var(--gm-text-muted);cursor:pointer}.gm-category-chip.active{border-color:var(--gm-primary);background:var(--gm-primary-light);color:var(--gm-primary-dark)}.gm-filter-scroll{display:flex;gap:6px;overflow-x:auto;padding-bottom:8px;margin-bottom:10px}.gm-filter-scroll::-webkit-scrollbar{display:none}.gm-filter-pill{padding:6px 12px;border-radius:999px;border:1.5px solid var(--gm-border);background:var(--gm-bg);font-size:.72rem;font-weight:700;color:var(--gm-text-muted);white-space:nowrap}.gm-featured{background:linear-gradient(135deg,#ff6b35,#d4a017,#16a34a);border-radius:16px;padding:18px;display:flex;justify-content:space-between;gap:16px;color:#fff;margin-bottom:18px;cursor:pointer}.gm-featured-info h3{font-family:Fredoka,sans-serif;font-size:1.05rem;margin-bottom:4px}.gm-featured-info p{font-size:.8rem;color:#ffffffd9;margin-bottom:10px}.gm-featured-tag{display:inline-block;font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.4px;padding:3px 10px;border-radius:999px;background:#0000004d;margin-bottom:8px}.gm-featured-price{font-family:Fredoka,sans-serif;font-size:.9rem;font-weight:700;background:#00000059;padding:6px 12px;border-radius:999px;display:inline-block}.gm-featured-avatars{display:flex;align-items:flex-start}.gm-featured-avatar{width:44px;height:44px;border-radius:50%;border:2px solid rgba(255,255,255,.5);background:#fff3;margin-left:-8px;position:relative;overflow:visible}.gm-featured-avatar img{width:52px;height:52px;position:absolute;bottom:-4px;left:50%;transform:translate(-50%);-o-object-fit:contain;object-fit:contain}.gm-section-row{display:flex;align-items:center;justify-content:space-between;margin:12px 0 10px}.gm-section-row h3{font-family:Fredoka,sans-serif;font-size:.95rem;font-weight:700}.gm-link{background:none;border:none;color:var(--gm-primary);font-weight:700;font-size:.75rem}.gm-pack-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px;margin-bottom:16px}.gm-pack-card{background:var(--gm-bg-card);border:1.5px solid var(--gm-border);border-radius:16px;overflow:hidden;box-shadow:var(--gm-shadow-card);text-align:left;cursor:pointer}.gm-pack-preview{height:110px;display:flex;align-items:center;justify-content:center;gap:6px;position:relative;overflow:visible}.gm-pack-avatar{width:48px;height:48px;border-radius:50%;border:2px solid rgba(255,255,255,.6);position:relative;overflow:visible;background:#fff3}.gm-pack-avatar img{width:58px;height:58px;position:absolute;bottom:-4px;left:50%;transform:translate(-50%);-o-object-fit:contain;object-fit:contain}.gm-pack-avatar.large{width:60px;height:60px}.gm-pack-avatar.large img{width:72px;height:72px}.gm-pack-badge{position:absolute;top:8px;left:8px;font-size:.6rem;font-weight:800;padding:3px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.3px;color:#fff}.gm-pack-badge.new{background:var(--gm-green)}.gm-pack-badge.hot{background:var(--gm-red)}.gm-pack-badge.promo{background:var(--gm-accent)}.gm-pack-badge.free{background:#0891b2}.gm-pack-info{padding:10px 12px 12px}.gm-pack-name{font-family:Fredoka,sans-serif;font-weight:700;font-size:.82rem;margin-bottom:2px}.gm-pack-author{font-size:.68rem;color:var(--gm-text-soft);margin-bottom:6px;font-weight:600}.gm-pack-meta{display:flex;align-items:center;justify-content:space-between;font-size:.68rem;font-weight:700;color:var(--gm-text-muted);gap:6px}.gm-pack-rating,.gm-pack-downloads,.gm-pack-price{display:inline-flex;align-items:center;gap:4px}.gm-pack-price.free{color:var(--gm-green)}.gm-system-card{background:var(--gm-bg-card);border:1.5px solid var(--gm-border);border-radius:16px;box-shadow:var(--gm-shadow-card);margin-bottom:12px;cursor:pointer}.gm-system-head{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--gm-border-light)}.gm-system-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;overflow:visible;flex-shrink:0}.gm-system-icon img{width:56px;height:56px;-o-object-fit:contain;object-fit:contain}.gm-system-icon.muted{background:var(--gm-bg-subtle);color:var(--gm-text-muted)}.gm-system-info{flex:1;min-width:0}.gm-system-name{font-family:Fredoka,sans-serif;font-weight:700;font-size:.9rem}.gm-system-meta{font-size:.72rem;color:var(--gm-text-muted);font-weight:600}.gm-system-status{padding:4px 10px;border-radius:999px;font-size:.65rem;font-weight:800;text-transform:uppercase}.gm-system-status.active{background:var(--gm-green-light);color:var(--gm-green)}.gm-system-status.inactive{background:var(--gm-bg-subtle);color:var(--gm-text-soft)}.gm-system-body{padding:12px 16px 14px;display:flex;flex-wrap:wrap;gap:6px}.gm-system-body span{font-size:.7rem;font-weight:700;background:var(--gm-bg);border:1px solid var(--gm-border);padding:4px 10px;border-radius:999px;color:var(--gm-text-muted)}.gm-card{background:var(--gm-bg-card);border:1.5px solid var(--gm-border);border-radius:16px;box-shadow:var(--gm-shadow-card);padding:16px;margin-bottom:16px}.gm-cta{display:flex;flex-direction:column;gap:12px}.gm-cta h3{font-family:Fredoka,sans-serif;font-weight:700;font-size:1rem}.gm-cta p{color:var(--gm-text-muted);font-size:.82rem;font-weight:600}.gm-cta-actions{display:flex;gap:8px;flex-wrap:wrap}.gm-cta-actions button{padding:8px 14px;border-radius:999px;border:none;background:var(--gm-primary-light);color:var(--gm-primary-dark);font-weight:700;font-size:.75rem;cursor:pointer}.gm-cta-actions button.accent{background:var(--gm-accent-light);color:var(--gm-accent)}.gm-library-list{display:flex;flex-direction:column;gap:10px}.gm-library-item{display:flex;align-items:center;gap:12px}.gm-library-icon{width:44px;height:44px;border-radius:12px;overflow:visible;position:relative}.gm-library-icon img{width:54px;height:54px;position:absolute;bottom:-4px;left:50%;transform:translate(-50%);-o-object-fit:contain;object-fit:contain}.gm-library-info{flex:1}.gm-library-name{font-weight:700;font-size:.85rem}.gm-library-meta{font-size:.7rem;color:var(--gm-text-muted)}.gm-library-action{padding:6px 12px;border-radius:999px;border:1.5px solid var(--gm-border);background:var(--gm-bg);font-size:.7rem;font-weight:700;color:var(--gm-primary)}.gm-library-action.applied{background:var(--gm-green-light);border-color:var(--gm-green);color:var(--gm-green)}.gm-creator-hero{background:linear-gradient(135deg,#0f3460,#533483,#e94560);border-radius:16px;padding:22px;color:#fff;display:flex;flex-direction:column;gap:14px;margin-bottom:16px}.gm-creator-hero h2{font-family:Fredoka,sans-serif;font-size:1.2rem;font-weight:700}.gm-creator-hero p{font-size:.85rem;color:#ffffffb3}.gm-creator-stats{display:flex;gap:14px}.gm-creator-stats div{text-align:center}.gm-creator-stats strong{font-family:Fredoka,sans-serif;display:block;font-size:1rem;color:gold}.gm-creator-stats span{font-size:.6rem;color:#fff9;text-transform:uppercase}.gm-creator-cta{align-self:flex-start;padding:9px 18px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#ffffff26;color:#fff;font-weight:700;font-size:.82rem}.gm-card-head{margin-bottom:12px}.gm-card-head h3{font-family:Fredoka,sans-serif;font-weight:700;font-size:.95rem}.gm-card-body{display:flex;flex-direction:column;gap:10px}.gm-template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.gm-template-card{display:flex;flex-direction:column;gap:6px;align-items:center;padding:14px;border-radius:14px;border:1.5px solid var(--gm-border);background:var(--gm-bg);font-size:.75rem;font-weight:700;color:var(--gm-text-muted)}.gm-template-card strong{color:var(--gm-text)}.gm-bottom-nav{position:fixed;left:0;right:0;bottom:0;background:var(--gm-bg-card);border-top:1px solid var(--gm-border);display:flex;padding:6px 8px;gap:6px;z-index:20}.gm-bottom-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.65rem;font-weight:700;background:none;border:none;color:var(--gm-text-soft)}.gm-bottom-item.active{color:var(--gm-primary)}.gm-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:120;animation:gmFade .2s ease}.gm-modal-sheet{width:100%;max-width:520px;background:var(--gm-bg-card);border-radius:20px 20px 0 0;padding:16px 20px 24px;max-height:88vh;overflow-y:auto;box-shadow:var(--gm-shadow-float);animation:gmSlideUp .3s ease}.gm-modal-handle{width:36px;height:4px;border-radius:999px;background:var(--gm-border);margin:0 auto 14px}.gm-modal-title{font-family:Fredoka,sans-serif;font-weight:700;font-size:1.1rem;margin-bottom:6px}.gm-modal-subtitle{color:var(--gm-text-muted);font-size:.8rem;margin-bottom:14px}.gm-detail-preview{border-radius:16px;padding:20px;display:flex;justify-content:center;gap:8px;margin-bottom:16px}.gm-detail-author{display:flex;align-items:center;gap:8px;background:var(--gm-bg);padding:10px 12px;border-radius:12px;margin-bottom:12px}.gm-detail-author-avatar{width:30px;height:30px;border-radius:50%;background:var(--gm-primary-light);display:flex;align-items:center;justify-content:center}.gm-detail-author-name{font-weight:700;font-size:.8rem}.gm-detail-author-badge{font-size:.65rem;color:var(--gm-text-soft)}.gm-detail-stats{display:flex;gap:8px;margin-bottom:12px}.gm-detail-stats div{flex:1;background:var(--gm-bg);border-radius:12px;padding:10px 8px;text-align:center;font-size:.65rem;color:var(--gm-text-muted)}.gm-detail-stats strong{display:block;font-family:Fredoka,sans-serif;font-size:.95rem;color:var(--gm-text)}.gm-detail-description{font-size:.82rem;color:var(--gm-text-muted);margin-bottom:12px;line-height:1.4}.gm-detail-includes{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.gm-detail-include-item{background:var(--gm-bg);padding:8px 10px;border-radius:10px;font-size:.78rem;font-weight:600;color:var(--gm-text-muted)}.gm-detail-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.gm-detail-tags span{font-size:.65rem;font-weight:700;padding:4px 10px;border-radius:999px;background:var(--gm-bg-subtle);color:var(--gm-text-soft)}.gm-detail-actions{display:flex;align-items:center;gap:8px}.gm-detail-price{font-family:Fredoka,sans-serif;font-size:1.1rem;font-weight:700;color:var(--gm-primary);flex-shrink:0}.gm-detail-price.free{color:var(--gm-green)}.gm-detail-buy,.gm-detail-apply{flex:1;padding:10px;border-radius:999px;border:none;font-weight:700;font-size:.8rem;cursor:pointer}.gm-detail-buy{background:var(--gm-primary-light);color:var(--gm-primary-dark)}.gm-detail-apply{background:linear-gradient(135deg,var(--gm-accent),#e6b422);color:#fff}.gm-apply-list{display:flex;flex-direction:column;gap:8px}.gm-apply-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;border:2px solid transparent;background:var(--gm-bg);text-align:left}.gm-apply-item.selected{border-color:var(--gm-primary);background:var(--gm-primary-light)}.gm-apply-avatar{width:40px;height:40px;border-radius:12px}.gm-apply-name{font-weight:700;font-size:.85rem}.gm-apply-meta{font-size:.7rem;color:var(--gm-text-muted)}.gm-apply-check{margin-left:auto;font-size:.7rem;font-weight:700;color:var(--gm-primary)}.gm-modal-actions{display:flex;gap:8px;margin-top:14px}.gm-wizard-steps{display:flex;gap:4px;margin-bottom:14px}.gm-wizard-step{flex:1;height:4px;border-radius:999px;background:var(--gm-border)}.gm-wizard-step.active{background:var(--gm-accent)}.gm-wizard-step.done{background:var(--gm-primary)}.gm-loading{font-size:.9rem;font-weight:700;color:var(--gm-text-muted)}.gm-error{color:var(--gm-red);font-size:.85rem;font-weight:700;margin-bottom:12px}.gm-group-picker{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-size:.78rem;font-weight:700;color:var(--gm-text-muted)}.gm-group-picker select{border:1.5px solid var(--gm-border);border-radius:10px;background:var(--gm-bg-card);color:var(--gm-text);padding:6px 10px;font-weight:700}.gm-grid-row{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:16px}.gm-pill-grid{display:flex;flex-wrap:wrap;gap:8px}.gm-pill{border-radius:999px;padding:6px 12px;font-size:.72rem;font-weight:700;background:var(--gm-bg);border:1px solid var(--gm-border);color:var(--gm-text)}.gm-pill.muted{background:transparent;border-color:var(--gm-border);color:var(--gm-text-muted)}.gm-pill.soft{background:var(--gm-bg-subtle);color:var(--gm-text-muted)}.gm-empty{font-size:.74rem;color:var(--gm-text-soft);font-weight:600}.gm-wizard-content{display:flex;flex-direction:column;gap:12px}.gm-wizard-field label{display:block;font-size:.78rem;font-weight:700;color:var(--gm-text-muted);margin-bottom:6px}.gm-wizard-field input,.gm-wizard-field textarea,.gm-wizard-field select{width:100%;border:1.5px solid var(--gm-border);border-radius:10px;padding:8px 10px;background:var(--gm-bg-card);color:var(--gm-text);font-size:.82rem;font-weight:600}.gm-wizard-field textarea{min-height:70px;resize:vertical}.gm-gradient-grid{display:flex;flex-wrap:wrap;gap:8px}.gm-gradient{width:48px;height:48px;border-radius:12px;border:2px solid transparent;cursor:pointer}.gm-gradient.active{border-color:var(--gm-primary);box-shadow:0 0 0 2px #0073e633}.gm-avatar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:8px}.gm-avatar-option{border:2px solid transparent;border-radius:12px;background:var(--gm-bg);padding:6px;cursor:pointer}.gm-avatar-option img{width:44px;height:44px;-o-object-fit:contain;object-fit:contain}.gm-avatar-option.selected{border-color:var(--gm-primary);box-shadow:0 0 0 2px #0073e626}.gm-wizard-list{display:flex;flex-direction:column;gap:8px}.gm-wizard-list-row{display:flex;align-items:center;gap:8px;border:1px solid var(--gm-border);border-radius:10px;background:var(--gm-bg);padding:8px}.gm-wizard-list-row input,.gm-wizard-list-row select{flex:1;border:1px solid var(--gm-border);border-radius:8px;padding:6px 8px;font-size:.78rem;font-weight:600;background:var(--gm-bg-card)}.gm-wizard-add{align-self:flex-start;border:1px dashed var(--gm-primary);border-radius:999px;background:var(--gm-primary-light);color:var(--gm-primary-dark);font-size:.72rem;font-weight:700;padding:6px 12px;cursor:pointer}.gm-wizard-row{display:flex;align-items:center;gap:8px}.gm-wizard-toggle{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:700;color:var(--gm-text-muted)}.gm-wizard-note{font-size:.72rem;color:var(--gm-text-soft);font-weight:600}.gm-status-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:999px;font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.gm-status-badge--active{background:var(--gm-green-light);color:var(--gm-green)}.gm-status-badge--installed{background:var(--gm-primary-light);color:var(--gm-primary-dark)}.gm-status-badge--free{background:#e0f2fe;color:#0369a1}.gm-status-badge--hot{background:#fee2e2;color:var(--gm-red)}.gm-status-badge--new{background:var(--gm-green-light);color:var(--gm-green)}.gm-status-badge--promo{background:var(--gm-accent-light);color:var(--gm-accent)}.gm-status-badge--run{background:#f3e8ff;color:#7c3aed}.gm-status-badge--draft{background:var(--gm-bg-subtle);color:var(--gm-text-muted);border:1px solid var(--gm-border)}.gm-status-badge--private{background:#eff6ff;color:#2563eb}html[data-theme=dark] .gm-status-badge--free{background:#0c3a54;color:#38bdf8}html[data-theme=dark] .gm-status-badge--run{background:#2e1a47;color:#c084fc}.gm-pack-status-overlay{position:absolute;top:8px;right:8px;z-index:2}.gm-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:6px}.gm-detail-header .gm-modal-title{margin-bottom:0}.gm-detail-header-badges{display:flex;gap:4px;flex-wrap:wrap;flex-shrink:0;margin-top:3px}.gm-detail-contents{margin-bottom:12px}.gm-detail-contents-label{font-size:.68rem;font-weight:700;color:var(--gm-text-soft);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.gm-detail-contents-grid{display:flex;flex-wrap:wrap;gap:6px}.gm-detail-content-chip{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:10px;font-size:.72rem;font-weight:700}.gm-detail-content-chip--asset{background:var(--gm-primary-light);color:var(--gm-primary-dark)}.gm-detail-content-chip--component{background:var(--gm-bg-subtle);color:var(--gm-text-muted)}.gm-detail-content-count{font-family:Fredoka,sans-serif;font-size:.9rem;font-weight:700}.gm-detail-groups{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;padding:10px 12px;background:var(--gm-bg);border-radius:12px}.gm-detail-group-row{display:flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;color:var(--gm-text-muted)}.gm-run-indicator{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--gm-bg-subtle);border:1.5px dashed var(--gm-border);border-radius:10px;font-size:.74rem;font-weight:600;color:var(--gm-text-soft);margin-bottom:12px}.gm-run-indicator--active{background:color-mix(in srgb,#7c3aed 8%,transparent);border-color:#7c3aed;border-style:solid;color:#5b21b6}.gm-run-indicator--active .gm-run-indicator-icon{opacity:1;color:#7c3aed}.gm-run-indicator-label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gm-run-group{color:var(--gm-text-muted);font-weight:500}.gm-run-time{color:var(--gm-text-soft);font-weight:400}.gm-run-indicator-icon{opacity:.45;flex-shrink:0}.gm-system-icon.has-pack{gap:2px;justify-content:center}.gm-system-icon.has-pack img{width:30px;height:30px;-o-object-fit:contain;object-fit:contain;border-radius:0;position:static;transform:none;bottom:auto;left:auto}.gm-library-status{flex-shrink:0}.gm-empty-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px;text-align:center;color:var(--gm-text-muted);font-size:.82rem;font-weight:600}.gm-empty-state-icon{opacity:.35}@media(min-width:1025px){.gm-bottom-nav{display:none}.gm-modal-overlay{align-items:center}.gm-modal-sheet{border-radius:20px}}@media(max-width:1024px),(hover:none)and (pointer:coarse)and (orientation:landscape){.gm-bottom-nav{display:flex!important}}@keyframes gmFadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes gmFade{0%{opacity:0}to{opacity:1}}@keyframes gmSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.gm-studio-wizard{display:flex;flex-direction:column;gap:0;border:1.5px solid var(--gm-border);border-radius:16px;background:var(--gm-bg-card);box-shadow:var(--gm-shadow-card);overflow:hidden}.gm-studio-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--gm-border-light);background:var(--gm-bg)}.gm-studio-header-left{display:flex;flex-direction:column;gap:2px;min-width:0}.gm-studio-step-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gm-text-soft)}.gm-studio-step-title{font-family:Fredoka,sans-serif;font-size:1rem;font-weight:700;color:var(--gm-text)}.gm-studio-step-sub{font-size:.72rem;color:var(--gm-text-muted);font-weight:600}.gm-studio-close-btn{flex-shrink:0;padding:7px 14px;border-radius:999px;border:1.5px solid var(--gm-border);background:var(--gm-bg-card);font-size:.72rem;font-weight:700;color:var(--gm-text-muted);cursor:pointer;white-space:nowrap;transition:border-color .18s ease,color .18s ease}.gm-studio-close-btn:hover:not(:disabled){border-color:var(--gm-primary);color:var(--gm-primary)}.gm-studio-close-btn:disabled{opacity:.5;cursor:not-allowed}.gm-studio-progress{display:flex;gap:3px;padding:10px 18px;background:var(--gm-bg);border-bottom:1px solid var(--gm-border-light)}.gm-studio-progress-seg{flex:1;height:4px;border-radius:999px;background:var(--gm-border);transition:background .25s ease}.gm-studio-progress-seg.active{background:var(--gm-accent)}.gm-studio-content{padding:18px;min-height:320px}.gm-studio-nav{padding:12px 18px;border-top:1px solid var(--gm-border-light);background:var(--gm-bg);display:flex;flex-direction:column;gap:8px}.gm-studio-nav-actions{display:flex;gap:8px;justify-content:flex-end}.gm-studio-step-error{font-size:.75rem;font-weight:600;color:var(--gm-red);margin:0}.gm-studio-save-error{margin-top:4px}.gm-studio-info-banner{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--gm-text-muted);background:var(--gm-bg-subtle);border:1px solid var(--gm-border);border-radius:8px;padding:8px 12px;margin-bottom:12px}.gm-studio-info-banner--warn{color:#a16207;background:#fefce8;border-color:#fde047}.gm-studio-field-hint{font-size:.72rem;color:var(--gm-text-soft);margin:2px 0 0}html[data-theme=dark] .gm-studio-info-banner--warn{color:#fde68a;background:#422006;border-color:#78350f}.gm-studio-continue-list{display:flex;flex-direction:column;gap:8px}.gm-studio-draft-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--gm-border-light)}.gm-studio-draft-row:last-child{border-bottom:none;padding-bottom:0}.gm-studio-draft-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.gm-studio-draft-name{font-size:.85rem;font-weight:700;color:var(--gm-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gm-studio-draft-meta{font-size:.7rem;color:var(--gm-text-muted);font-weight:600}.gm-studio-draft-btn{flex-shrink:0;padding:6px 12px;border-radius:999px;border:1.5px solid var(--gm-primary);background:var(--gm-primary-light);color:var(--gm-primary-dark);font-size:.72rem;font-weight:700;cursor:pointer}.gm-studio-pack-list{display:flex;flex-direction:column;gap:0}.gm-studio-pack-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--gm-border-light)}.gm-studio-pack-row:last-child{border-bottom:none;padding-bottom:0}.gm-studio-pack-preview{width:38px;height:38px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.gm-studio-pack-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.gm-studio-pack-name{font-size:.85rem;font-weight:700;color:var(--gm-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gm-studio-pack-meta{font-size:.7rem;color:var(--gm-text-muted);font-weight:600}.gm-studio-pack-status{flex-shrink:0}.gm-studio-capability-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 0;border-bottom:1px solid var(--gm-border-light);cursor:pointer}.gm-studio-capability-row:last-of-type{border-bottom:none}.gm-studio-capability-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.gm-studio-capability-label{font-size:.82rem;font-weight:700;color:var(--gm-text)}.gm-studio-capability-sub{font-size:.7rem;color:var(--gm-text-muted);font-weight:600}.gm-studio-capability-row input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:40px;height:24px;border-radius:12px;border:1.5px solid var(--gm-border);background:var(--gm-bg);cursor:pointer;position:relative;flex-shrink:0;transition:all .25s ease}.gm-studio-capability-row input[type=checkbox]:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:var(--gm-bg-card);box-shadow:0 1px 3px #00000026;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.gm-studio-capability-row input[type=checkbox]:checked{background:var(--gm-primary);border-color:var(--gm-primary)}.gm-studio-capability-row input[type=checkbox]:checked:after{transform:translate(16px);background:#fff}.gm-studio-theme-preview{border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px}.gm-studio-theme-icon{font-size:1.8rem;flex-shrink:0}.gm-studio-theme-name{font-family:Fredoka,sans-serif;font-size:1rem;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.3)}.gm-studio-review{display:flex;flex-direction:column;gap:12px}.gm-studio-review-header{border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px}.gm-studio-review-name{font-family:Fredoka,sans-serif;font-size:1.05rem;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.3)}.gm-studio-review-sub{font-size:.8rem;color:#fffc;font-weight:600}.gm-studio-review-body{display:flex;flex-direction:column;gap:0;border:1px solid var(--gm-border);border-radius:12px;overflow:hidden}.gm-studio-review-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;border-bottom:1px solid var(--gm-border-light);font-size:.78rem}.gm-studio-review-row:last-child{border-bottom:none}.gm-studio-review-row span:first-child{font-weight:700;color:var(--gm-text-muted);flex-shrink:0}.gm-studio-review-row span:last-child{font-weight:600;color:var(--gm-text);text-align:right}html[data-theme=dark] .gm-studio-wizard{background:var(--gm-bg-card);border-color:var(--gm-border)}html[data-theme=dark] .gm-studio-header,html[data-theme=dark] .gm-studio-progress,html[data-theme=dark] .gm-studio-nav{background:var(--gm-bg-subtle)}html[data-theme=dark] .gm-studio-capability-row input[type=checkbox]{background:var(--gm-bg);border-color:var(--gm-border)}html[data-theme=dark] .gm-studio-capability-row input[type=checkbox]:after{background:var(--gm-bg-card)}.gm-studio-body{display:flex;gap:20px;align-items:flex-start}.gm-studio-preview{width:224px;flex-shrink:0;position:sticky;top:12px;background:var(--gm-bg-subtle);border:1px solid var(--gm-border);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;gap:0}.gm-studio-preview-header{padding:16px 14px;display:flex;align-items:center;gap:10px;min-height:64px}.gm-studio-preview-icon{font-size:1.6rem;flex-shrink:0;filter:drop-shadow(0 1px 3px rgba(0,0,0,.25))}.gm-studio-preview-meta{display:flex;flex-direction:column;gap:2px}.gm-studio-preview-name{font-size:.82rem;font-weight:800;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.35);line-height:1.2}.gm-studio-preview-sub{font-size:.68rem;color:#ffffffbf}.gm-studio-preview-section{padding:10px 14px;border-top:1px solid var(--gm-border-light);display:flex;flex-direction:column;gap:6px}.gm-studio-preview-section-label{font-size:.65rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--gm-text-muted)}.gm-studio-preview-avatars{display:flex;flex-wrap:wrap;gap:4px}.gm-studio-preview-avatar{width:28px;height:28px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid var(--gm-bg-card);background:var(--gm-bg)}.gm-studio-preview-avatar-more{width:28px;height:28px;border-radius:50%;background:var(--gm-bg-subtle);border:2px solid var(--gm-border);font-size:.6rem;font-weight:700;color:var(--gm-text-muted);display:flex;align-items:center;justify-content:center}.gm-studio-preview-chips{display:flex;flex-wrap:wrap;gap:4px}.gm-studio-preview-chip{font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:999px;background:var(--gm-primary-light);color:var(--gm-primary-dark);border:1px solid var(--gm-primary-border, var(--gm-border))}.gm-studio-preview-chip.muted,.gm-studio-preview-chip--warn{background:#fef3c7;color:#92400e;border-color:#fde68a}.gm-studio-preview-meta-row{font-size:.68rem;color:var(--gm-text-soft);display:flex;flex-wrap:wrap;gap:4px}.gm-studio-preview-issues{border-top:1px solid var(--gm-border-light);padding:8px 14px;display:flex;flex-direction:column;gap:4px}.gm-studio-preview-issue{font-size:.68rem;font-weight:600;color:#b45309}.gm-studio-preview-ready{padding:8px 14px;border-top:1px solid var(--gm-border-light);font-size:.68rem;font-weight:700;color:var(--gm-green)}.gm-studio-saving-indicator{font-weight:400;color:var(--gm-text-muted);font-style:italic}.gm-studio-avatar-selection{margin-top:16px;display:flex;flex-direction:column;gap:6px}.gm-studio-preview-avatar-btn{position:relative;background:none;border:none;padding:0;cursor:pointer;border-radius:50%}.gm-studio-preview-avatar-btn img{width:32px;height:32px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid var(--gm-border);display:block;transition:opacity .15s}.gm-studio-preview-avatar-btn:hover img{opacity:.5}.gm-studio-avatar-remove{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:800;color:var(--gm-red);opacity:0;transition:opacity .15s}.gm-studio-preview-avatar-btn:hover .gm-studio-avatar-remove{opacity:1}.gm-review-full{max-width:100%}.gm-review-checklist{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.gm-review-check{display:flex;align-items:baseline;gap:8px;font-size:.8rem;padding:8px 12px;border-radius:8px;border:1px solid transparent}.gm-review-check--ok{background:#f0fdf4;border-color:#bbf7d0;color:#15803d;font-weight:600}.gm-review-check--warn{background:#fffbeb;border-color:#fde68a;color:#b45309;font-weight:600}.gm-review-check--issue{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.gm-review-fix-btn{flex-shrink:0;margin-left:auto;font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:999px;border:1px solid currentColor;background:transparent;cursor:pointer;color:inherit;opacity:.7;transition:opacity .15s}.gm-review-fix-btn:hover{opacity:1}.gm-review-blocks{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.gm-review-block{background:var(--gm-bg-card);border:1px solid var(--gm-border);border-radius:12px;overflow:hidden}.gm-review-block-head{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--gm-bg-subtle);border-bottom:1px solid var(--gm-border-light);font-size:.8rem}.gm-review-block-icon{font-size:.75rem;font-weight:800;flex-shrink:0}.gm-review-block-head strong{flex:1;font-size:.8rem;color:var(--gm-text)}.gm-review-block-body{padding:10px 14px}.gm-studio-review-narrative{font-size:.72rem;color:#ffffffb3;margin-top:4px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.gm-studio-cta-primary{padding:10px 22px;border-radius:999px;border:none;background:var(--gm-primary);color:#fff;font-size:.82rem;font-weight:800;cursor:pointer;transition:opacity .15s,transform .1s}.gm-studio-cta-primary:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.gm-studio-cta-primary:disabled{opacity:.4;cursor:not-allowed}.gm-studio-cta-secondary{padding:9px 18px;border-radius:999px;border:1.5px solid var(--gm-border);background:var(--gm-bg-card);color:var(--gm-text);font-size:.82rem;font-weight:700;cursor:pointer;transition:border-color .15s}.gm-studio-draft-thumb{width:40px;height:40px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.3rem;box-shadow:0 2px 6px #0000001f}.gm-studio-draft-progress{height:3px;background:var(--gm-border);border-radius:999px;overflow:hidden;margin-top:4px}.gm-studio-draft-progress-bar{height:100%;background:var(--gm-primary);border-radius:999px;transition:width .3s ease}.gm-studio-draft-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.gm-studio-draft-del{width:24px;height:24px;border-radius:50%;border:none;background:none;color:var(--gm-text-muted);font-size:.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.gm-studio-draft-del:hover{background:#fee2e2;color:var(--gm-red)}.gm-card-head-count{font-size:.72rem;font-weight:800;padding:2px 8px;border-radius:999px;background:var(--gm-bg-subtle);color:var(--gm-text-muted);border:1px solid var(--gm-border)}@media(max-width:640px){.gm-studio-body{flex-direction:column}.gm-studio-preview{width:100%;position:static;flex-direction:row;flex-wrap:wrap}.gm-studio-preview-header{flex:1 0 100%}.gm-review-blocks{grid-template-columns:1fr}}html[data-theme=dark] .gm-review-check--ok{background:#052e16;border-color:#166534;color:#4ade80}html[data-theme=dark] .gm-review-check--warn{background:#2d1a00;border-color:#78350f;color:#fbbf24}html[data-theme=dark] .gm-review-check--issue{background:#3b0a0a;border-color:#7f1d1d;color:#f87171}html[data-theme=dark] .gm-review-block{background:var(--gm-bg-card);border-color:var(--gm-border)}html[data-theme=dark] .gm-review-block-head{background:var(--gm-bg-subtle)}html[data-theme=dark] .gm-studio-preview,html[data-theme=dark] .gm-studio-cta-secondary{background:var(--gm-bg-card);border-color:var(--gm-border)}html[data-theme=dark] .gm-studio-draft-del:hover{background:#450a0a;color:#f87171}html[data-theme=dark] .gm-status-badge--draft{background:var(--gm-bg-subtle);color:var(--gm-text-muted);border-color:var(--gm-border)}html[data-theme=dark] .gm-status-badge--private{background:#1e3a5f;color:#93c5fd}.gm-studio-header-context{display:flex;align-items:center;gap:8px;margin-bottom:4px}.gm-studio-mode-badge{display:inline-flex;align-items:center;font-size:.65rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:999px;border:1px solid transparent}.gm-studio-mode-badge--creating{background:var(--gm-primary-light);color:var(--gm-primary-dark);border-color:var(--gm-primary-border, var(--gm-border))}.gm-studio-mode-badge--editing-draft{background:#fffbeb;color:#b45309;border-color:#fde68a}.gm-studio-mode-badge--editing-pack{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.gm-studio-mode-badge--duplicating{background:#f5f3ff;color:#7c3aed;border-color:#ddd6fe}.gm-studio-last-saved{font-size:.68rem;color:var(--gm-text-muted);font-style:italic}.gm-studio-pack-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.gm-studio-pack-action-btn{padding:4px 10px;border-radius:999px;border:1.5px solid var(--gm-primary);background:var(--gm-primary-light);color:var(--gm-primary-dark);font-size:.68rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:opacity .15s}.gm-studio-pack-action-btn:hover{opacity:.8}.gm-studio-pack-action-btn--secondary{border-color:var(--gm-border);background:var(--gm-bg-subtle);color:var(--gm-text-muted)}.gm-card-head-hint{font-size:.68rem;color:var(--gm-text-muted);font-weight:400;margin-left:auto}.gm-studio-base-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;padding-top:4px}.gm-studio-base-card{display:flex;flex-direction:column;gap:8px;padding:12px;border:1px solid var(--gm-border);border-radius:12px;background:var(--gm-bg-subtle);transition:border-color .15s}.gm-studio-base-card:hover{border-color:var(--gm-primary)}.gm-studio-base-cover{height:52px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.gm-studio-base-info{display:flex;flex-direction:column;gap:2px;flex:1}.gm-studio-base-name{font-size:.8rem;font-weight:700;color:var(--gm-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gm-studio-base-meta{font-size:.68rem;color:var(--gm-text-muted)}.gm-studio-base-btn{width:100%;padding:6px 0;border-radius:999px;border:1.5px solid var(--gm-primary);background:transparent;color:var(--gm-primary-dark);font-size:.72rem;font-weight:700;cursor:pointer;transition:background .15s,color .15s}.gm-studio-base-btn:hover{background:var(--gm-primary);color:#fff}html[data-theme=dark] .gm-studio-mode-badge--editing-draft{background:#2d1a00;border-color:#78350f;color:#fbbf24}html[data-theme=dark] .gm-studio-mode-badge--editing-pack{background:#1e3a5f;border-color:#1d4ed8;color:#93c5fd}html[data-theme=dark] .gm-studio-mode-badge--duplicating{background:#2e1a47;border-color:#7c3aed;color:#c084fc}html[data-theme=dark] .gm-studio-base-card{background:var(--gm-bg-card);border-color:var(--gm-border)}html[data-theme=dark] .gm-studio-pack-action-btn--secondary{background:var(--gm-bg-subtle);border-color:var(--gm-border)}.gm-avatar-dropzone{display:flex;flex-direction:column;align-items:center;gap:4px;border:2px dashed var(--gm-border);border-radius:12px;padding:20px 16px;cursor:pointer;background:var(--gm-bg);color:var(--gm-text-muted);font-size:.8rem;font-weight:600;transition:border-color .15s,background .15s}.gm-avatar-dropzone:hover{border-color:var(--gm-primary);background:var(--gm-primary-light);color:var(--gm-primary-dark)}.gm-avatar-dropzone-icon{font-size:1.5rem;font-weight:800;color:var(--gm-primary);line-height:1}.gm-avatar-authored-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:14px;margin-top:12px}.gm-avatar-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;border:none;border-radius:0;background:transparent;padding:0;min-width:0}.gm-avatar-card--uploading{opacity:.7}.gm-avatar-card--error{outline:1px solid #ef4444;outline-offset:4px}.gm-avatar-card-media{position:relative;width:100%;display:flex;justify-content:center}.gm-avatar-card-thumb{width:100%;max-width:120px;aspect-ratio:1 / 1;border-radius:0;background:transparent;border:none;display:flex;align-items:center;justify-content:center;overflow:hidden}.gm-avatar-card-thumb img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;display:block}.gm-avatar-card-spinner{display:block;width:20px;height:20px;border:2px solid var(--gm-border);border-top-color:var(--gm-primary);border-radius:50%;animation:gm-spin .7s linear infinite}@keyframes gm-spin{to{transform:rotate(360deg)}}.gm-avatar-card-err-icon{font-size:1.1rem;color:#ef4444;font-weight:800}.gm-avatar-card-body{flex:1;display:flex;flex-direction:column;gap:5px;min-width:0}.gm-avatar-card-name{border:1px solid var(--gm-border);border-radius:7px;padding:4px 8px;font-size:.78rem;font-weight:600;background:var(--gm-bg);color:var(--gm-text);width:100%}.gm-avatar-card-unlock{border:1px solid var(--gm-border);border-radius:7px;padding:3px 6px;font-size:.72rem;font-weight:700;background:var(--gm-bg);color:var(--gm-text-muted);width:100%;max-width:160px}.gm-avatar-card-errmsg{font-size:.68rem;color:#ef4444;font-weight:600;text-align:center}.gm-avatar-card-del{position:absolute;top:2px;right:2px;width:26px;height:26px;border-radius:50%;border:1px solid var(--gm-border);background:#fff;color:var(--gm-text-muted);font-size:.65rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s;z-index:2}.gm-avatar-card-del:hover:not(:disabled){background:#fef2f2;color:#ef4444;border-color:#fca5a5}.gm-avatar-card-del:disabled{opacity:.4;cursor:not-allowed}.gm-modular-section{margin-top:12px;border:1px solid var(--gm-border);border-radius:12px;overflow:hidden}.gm-modular-section-head{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--gm-bg-subtle);border-bottom:1px solid var(--gm-border)}.gm-modular-section-title{font-size:.76rem;font-weight:800;color:var(--gm-text)}.gm-modular-section-count{font-size:.68rem;font-weight:700;color:var(--gm-text-muted)}.gm-modular-base-row{display:flex;align-items:center;gap:10px;padding:10px 12px}.gm-modular-layer-grid{display:flex;flex-direction:column;gap:5px;padding:8px 12px 0}.gm-modular-layer-card{display:flex;align-items:center;gap:8px;border:1px solid var(--gm-border);border-radius:9px;background:var(--gm-bg);padding:6px 8px}.gm-modular-layer-thumb{flex-shrink:0;width:44px;height:44px;border-radius:7px;border:1px solid var(--gm-border);background:var(--gm-bg-card);display:flex;align-items:center;justify-content:center;overflow:hidden}.gm-modular-layer-thumb img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.gm-modular-add-btn{display:flex;align-items:center;justify-content:center;gap:4px;margin:8px 12px 10px;padding:6px 14px;border:1px dashed var(--gm-primary);border-radius:999px;background:var(--gm-primary-light);color:var(--gm-primary-dark);font-size:.71rem;font-weight:700;cursor:pointer;transition:background .12s,color .12s}.gm-modular-add-btn:hover{background:var(--gm-primary);color:#fff}.gm-modular-slot-required{color:#ef4444}.gm-modular-slot-thumb{flex-shrink:0;width:48px;height:48px;border-radius:8px;border:1px solid var(--gm-border);background:var(--gm-bg);display:flex;align-items:center;justify-content:center;overflow:hidden}.gm-modular-slot-thumb img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.gm-modular-slot-empty{font-size:1.1rem;color:var(--gm-text-soft);font-weight:700}.gm-modular-slot-controls{flex:1;display:flex;flex-direction:column;gap:5px;min-width:0}.gm-modular-slot-upload-btn{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--gm-primary);border-radius:999px;background:var(--gm-primary-light);color:var(--gm-primary-dark);font-size:.7rem;font-weight:700;padding:4px 12px;cursor:pointer;transition:background .12s}.gm-modular-slot-upload-btn:hover{background:var(--gm-primary);color:#fff}.gm-modular-slot-name{border:1px solid var(--gm-border);border-radius:7px;padding:3px 7px;font-size:.72rem;font-weight:600;background:var(--gm-bg);color:var(--gm-text)}html[data-theme=dark] .gm-avatar-dropzone{background:var(--gm-bg-card);border-color:var(--gm-border)}html[data-theme=dark] .gm-avatar-dropzone:hover{background:#0073e61a}html[data-theme=dark] .gm-avatar-card{background:transparent;border-color:transparent}html[data-theme=dark] .gm-avatar-card-name,html[data-theme=dark] .gm-avatar-card-unlock,html[data-theme=dark] .gm-modular-slot-name{background:var(--gm-bg);border-color:var(--gm-border);color:var(--gm-text)}html[data-theme=dark] .gm-modular-section{background:var(--gm-bg-card);border-color:var(--gm-border)}html[data-theme=dark] .gm-modular-section-head{background:var(--gm-bg-subtle)}html[data-theme=dark] .gm-modular-layer-card{background:var(--gm-bg-card);border-color:var(--gm-border)}html[data-theme=dark] .gm-avatar-card-del:hover:not(:disabled){background:#450a0a;color:#fca5a5;border-color:#7f1d1d}.gm-empty-state-text{font-size:1rem;font-weight:700;color:var(--gm-text)}.gm-empty-state-sub{font-size:.8rem;font-weight:400;color:var(--gm-text-muted);max-width:320px}.gm-empty-state-cta{margin-top:6px;padding:8px 20px;border-radius:999px;background:var(--gm-primary);color:#fff;font-size:.82rem;font-weight:700;border:none;cursor:pointer;transition:background .14s}.gm-empty-state-cta:hover{background:var(--gm-primary-dark)}.gm-preset-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}.gm-preset-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 13px;border-radius:999px;border:1.5px solid var(--gm-border);background:var(--gm-bg-card);color:var(--gm-text);font-size:.78rem;font-weight:600;cursor:pointer;transition:border-color .12s,background .12s}.gm-preset-chip:hover{border-color:var(--gm-primary);background:var(--gm-primary-light);color:var(--gm-primary-dark)}.gm-card-del-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:1px solid var(--gm-border);background:transparent;color:var(--gm-text-muted);font-size:.7rem;cursor:pointer;flex-shrink:0;transition:background .12s,color .12s,border-color .12s}.gm-card-del-btn:hover{background:#fee2e2;color:#dc2626;border-color:#fca5a5}.gm-roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.gm-role-card{display:flex;flex-direction:column;gap:8px;padding:14px;border:1.5px solid var(--gm-border);border-radius:14px;background:var(--gm-bg-card);box-shadow:var(--gm-shadow-card);transition:border-color .14s,box-shadow .14s}.gm-role-card:hover{border-color:var(--gm-primary);box-shadow:0 2px 10px #0073e61a}.gm-role-card-header{display:flex;align-items:center;gap:10px}.gm-role-card-icon{font-size:1.8rem;line-height:1;flex-shrink:0}.gm-role-card-name-input{flex:1;border:1px solid var(--gm-border);border-radius:8px;padding:5px 10px;font-size:.9rem;font-weight:700;background:var(--gm-bg);color:var(--gm-text)}.gm-role-card-fields{display:flex;flex-direction:column;gap:6px}.gm-role-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:4px}.gm-role-card-default{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--gm-text-muted);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.gm-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.gm-ability-card{display:flex;flex-direction:column;border-radius:14px;overflow:hidden;box-shadow:0 3px 12px #0000002e;color:#fff;position:relative;transition:transform .14s,box-shadow .14s}.gm-ability-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.gm-ability-card-body{padding:12px 10px 8px;display:flex;flex-direction:column;gap:5px;flex:1}.gm-ability-card-rarity{font-size:.6rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;opacity:.75}.gm-ability-card-icon{font-size:1.6rem;line-height:1;margin:4px 0}.gm-ability-card-name{font-size:.82rem;font-weight:700;line-height:1.25}.gm-ability-card-desc{font-size:.7rem;opacity:.75;line-height:1.35;flex:1}.gm-ability-card-footer{padding:8px 10px;background:#0003;display:flex;align-items:center;gap:6px}.gm-ability-card-cost{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:700;background:#ffffff26;border-radius:999px;padding:2px 8px}.gm-ability-card-del{margin-left:auto;width:22px;height:22px;border-radius:50%;border:1px solid rgba(255,255,255,.35);background:#00000040;color:#fffc;font-size:.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s}.gm-ability-card-del:hover{background:#dc2626b3;color:#fff}.gm-ability-card-fields{padding:8px 10px 10px;background:#00000026;display:flex;flex-direction:column;gap:5px}.gm-ability-card-field{font-size:.72rem;border:1px solid rgba(255,255,255,.25);border-radius:7px;background:#0003;color:#fff;padding:5px 8px}.gm-ability-card-field::-moz-placeholder{color:#fff6}.gm-ability-card-field::placeholder{color:#fff6}.gm-ability-card-field option{color:#1a1a1a;background:#fff}.gm-badge-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.gm-badge-medal{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 14px 12px;border:2px solid var(--gm-border);border-radius:18px;background:var(--gm-bg-card);box-shadow:var(--gm-shadow-card);text-align:center;position:relative;transition:border-color .14s,box-shadow .14s}.gm-badge-medal:hover{border-color:var(--gm-accent);box-shadow:0 3px 14px #d4a01726}.gm-badge-medal-icon{font-size:2.2rem;line-height:1}.gm-badge-medal-name{font-size:.88rem;font-weight:700;color:var(--gm-text)}.gm-badge-medal-fields{display:flex;flex-direction:column;gap:5px;width:100%}.gm-badge-medal-del{position:absolute;top:8px;right:8px}.gm-badge-sel{width:100%;font-size:.75rem;border:1px solid var(--gm-border);border-radius:7px;padding:4px 7px;background:var(--gm-bg);color:var(--gm-text)}.gm-scenario-engine-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;width:100%;margin-top:10px}.gm-scenario-engine-btn{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:14px 13px;border:2px solid color-mix(in srgb,var(--sce-color) 30%,var(--gm-border));border-radius:14px;background:color-mix(in srgb,var(--sce-color) 8%,var(--gm-bg-card));cursor:pointer;text-align:left;transition:border-color .14s,background .14s,box-shadow .14s}.gm-scenario-engine-btn:hover{border-color:var(--sce-color);background:color-mix(in srgb,var(--sce-color) 14%,var(--gm-bg-card));box-shadow:0 3px 10px color-mix(in srgb,var(--sce-color) 25%,transparent)}.gm-scenario-engine-btn-icon{font-size:1.6rem;line-height:1}.gm-scenario-engine-btn-label{font-size:.82rem;font-weight:700;color:var(--gm-text)}.gm-scenario-engine-btn-desc{font-size:.72rem;color:var(--gm-text-muted);line-height:1.35}.gm-scenario-list{display:flex;flex-direction:column;gap:14px}.gm-scenario-block{border:2px solid color-mix(in srgb,var(--sce-color) 35%,var(--gm-border));border-radius:14px;background:color-mix(in srgb,var(--sce-color) 6%,var(--gm-bg-card));overflow:hidden}.gm-scenario-block-head{display:flex;align-items:center;gap:10px;padding:12px 14px;background:color-mix(in srgb,var(--sce-color) 12%,var(--gm-bg-card));border-bottom:1px solid color-mix(in srgb,var(--sce-color) 20%,var(--gm-border))}.gm-scenario-block-icon{font-size:1.5rem;line-height:1;flex-shrink:0}.gm-scenario-block-engine{flex:1;display:flex;align-items:center;gap:8px;min-width:0}.gm-scenario-block-engine-label{font-size:.82rem;font-weight:700;color:var(--gm-text)}.gm-scenario-default-badge{font-size:.65rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:2px 8px;border-radius:999px;background:var(--gm-accent-light);color:var(--gm-accent);border:1px solid var(--gm-accent)}.gm-scenario-block-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.gm-scenario-set-default{width:28px;height:28px;border-radius:50%;border:1px solid var(--gm-border);background:var(--gm-bg);color:var(--gm-text-muted);font-size:.82rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.gm-scenario-set-default:hover{background:var(--gm-accent-light);color:var(--gm-accent);border-color:var(--gm-accent)}.gm-scenario-block-fields{padding:12px 14px;display:flex;flex-direction:column;gap:8px}.gm-scenario-block-hint{padding:0 14px 10px;font-size:.72rem;color:var(--gm-text-muted);font-style:italic}.gm-scenario-add-row{display:flex;align-items:flex-start;gap:10px;flex-wrap:wrap;margin-top:6px;padding-top:10px;border-top:1px dashed var(--gm-border)}.gm-scenario-add-label{font-size:.78rem;font-weight:600;color:var(--gm-text-muted);white-space:nowrap;padding-top:4px}html[data-theme=dark] .gm-preset-chip{background:var(--gm-bg-card);border-color:var(--gm-border);color:var(--gm-text)}html[data-theme=dark] .gm-preset-chip:hover{background:#0073e626;border-color:var(--gm-primary);color:#7ab8ff}html[data-theme=dark] .gm-role-card{background:var(--gm-bg-card);border-color:var(--gm-border)}html[data-theme=dark] .gm-role-card-name-input{background:var(--gm-bg);border-color:var(--gm-border);color:var(--gm-text)}html[data-theme=dark] .gm-badge-medal{background:var(--gm-bg-card);border-color:var(--gm-border)}html[data-theme=dark] .gm-badge-medal:hover{border-color:var(--gm-accent)}html[data-theme=dark] .gm-badge-sel{background:var(--gm-bg);border-color:var(--gm-border);color:var(--gm-text)}html[data-theme=dark] .gm-card-del-btn:hover{background:#450a0a;color:#fca5a5;border-color:#7f1d1d}html[data-theme=dark] .gm-scenario-set-default{background:var(--gm-bg);border-color:var(--gm-border);color:var(--gm-text-muted)}html[data-theme=dark] .gm-scenario-add-row{border-top-color:var(--gm-border)}@keyframes shimmerSeg{0%{left:-100%}to{left:100%}}@keyframes gmStepIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes gmStepInBack{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes gmHoloBg{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.gm-studio-wizard{border:none;border-radius:20px;box-shadow:0 4px 24px #00000017,0 1px 4px #0000000f}.gm-studio-header{padding:16px 24px;background:var(--gm-bg);border-bottom:1px solid var(--gm-border-light);gap:16px}.gm-studio-header-left{gap:3px}.gm-studio-header-context{display:flex;align-items:center;gap:8px;margin-bottom:2px}.gm-studio-step-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--gm-primary);opacity:.85}.gm-studio-step-title{font-family:Fredoka,sans-serif;font-size:1.15rem;font-weight:700;color:var(--gm-text);line-height:1.2}.gm-studio-step-sub{font-size:.75rem;color:var(--gm-text-muted);font-weight:600}.gm-studio-close-btn{padding:8px 18px;border-radius:30px;border:2px solid var(--gm-border);background:var(--gm-bg-card);font-size:.75rem;font-weight:700;color:var(--gm-text-muted);cursor:pointer;white-space:nowrap;transition:border-color .18s,color .18s,background .18s;letter-spacing:.01em}.gm-studio-close-btn:hover:not(:disabled){border-color:var(--gm-red);color:var(--gm-red);background:#fff5f5}.gm-studio-progress{display:flex;gap:4px;padding:12px 24px;background:var(--gm-bg);border-bottom:1px solid var(--gm-border-light)}.gm-studio-progress-seg{flex:1;height:5px;border-radius:999px;background:var(--gm-border);transition:background .4s ease}.gm-studio-progress-seg.done{background:var(--gm-primary)}.gm-studio-progress-seg.active{background:#f9a825;position:relative;overflow:hidden;box-shadow:0 0 6px #f9a82599}.gm-studio-progress-seg.active:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:shimmerSeg 1.4s linear infinite}.gm-studio-content{padding:24px 24px 20px;min-height:360px}.gm-wizard-content{animation:gmStepIn .32s cubic-bezier(.4,0,.2,1) both}.gm-wizard-desc{font-size:.82rem;color:var(--gm-text-muted);line-height:1.55;margin-bottom:4px}.gm-wizard-field label{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--gm-text-muted);margin-bottom:7px}.gm-wizard-field input,.gm-wizard-field textarea,.gm-wizard-field select{border:2px solid var(--gm-border);border-radius:11px;padding:9px 12px;font-size:.88rem;font-weight:600;background:var(--gm-bg-card);color:var(--gm-text);transition:border-color .18s,box-shadow .18s;outline:none}.gm-wizard-field input:hover:not(:focus),.gm-wizard-field textarea:hover:not(:focus),.gm-wizard-field select:hover:not(:focus){border-color:#b0c4e8}.gm-wizard-field input:focus,.gm-wizard-field textarea:focus,.gm-wizard-field select:focus{border-color:var(--gm-primary);box-shadow:0 0 0 3px #0073e62e}.gm-field{border:2px solid var(--gm-border);border-radius:10px;padding:8px 11px;font-size:.84rem;font-weight:600;background:var(--gm-bg-card);color:var(--gm-text);transition:border-color .18s,box-shadow .18s;outline:none}.gm-field:hover:not(:focus){border-color:#b0c4e8}.gm-field:focus{border-color:var(--gm-primary);box-shadow:0 0 0 3px #0073e62e}.gm-field--textarea{resize:vertical;min-height:72px;line-height:1.5}.gm-studio-nav{padding:14px 24px;background:var(--gm-bg);border-top:1px solid var(--gm-border-light)}.gm-studio-nav-actions{justify-content:space-between;align-items:center}.gm-studio-nav-actions .gm-detail-apply,.gm-studio-nav-actions button[onClick=wizardNext],.gm-studio-nav-actions>button:last-child:not(.gm-studio-cta-secondary){background:linear-gradient(135deg,#f9a825,#ff8f00);border:none;color:#fff;border-radius:30px;padding:11px 28px;font-size:.88rem;font-weight:800;cursor:pointer;transition:transform .18s,box-shadow .18s;box-shadow:0 4px 16px #f9a82573;letter-spacing:.02em}.gm-studio-nav-actions>button:last-child:not(.gm-studio-cta-secondary):hover:not(:disabled){transform:translateY(-2px);box-shadow:0 7px 22px #f9a82599}.gm-studio-nav-actions>button:first-child{background:var(--gm-bg-card);border:2px solid var(--gm-border);border-radius:30px;padding:10px 20px;font-size:.82rem;font-weight:700;color:var(--gm-text-muted);cursor:pointer;transition:border-color .18s,color .18s}.gm-studio-nav-actions>button:first-child:hover{border-color:var(--gm-primary);color:var(--gm-primary)}.gm-studio-cta-primary{background:linear-gradient(135deg,#1976d2,#1565c0);border:none;color:#fff;border-radius:30px;padding:11px 28px;font-size:.88rem;font-weight:800;cursor:pointer;transition:transform .18s,box-shadow .18s,opacity .18s;box-shadow:0 4px 16px #1976d266}.gm-studio-cta-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 7px 22px #1976d28c}.gm-studio-cta-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.gm-studio-cta-secondary{background:var(--gm-bg-card);border:2px solid var(--gm-border);border-radius:30px;padding:10px 20px;font-size:.82rem;font-weight:700;color:var(--gm-text-muted);cursor:pointer;transition:border-color .18s,color .18s}.gm-studio-cta-secondary:hover:not(:disabled){border-color:var(--gm-primary);color:var(--gm-primary)}.gm-studio-cta-secondary:disabled{opacity:.4;cursor:not-allowed}.gm-studio-body{gap:24px;padding:0}.gm-studio-body .gm-studio-content{flex:1;min-width:0}.gm-studio-preview{width:256px;flex-shrink:0;border-radius:16px;border:1.5px solid var(--gm-border);background:var(--gm-bg-card);box-shadow:var(--gm-shadow-card)}.gm-studio-preview-header{padding:18px 16px;min-height:72px;gap:12px}.gm-studio-preview-icon{font-size:2rem}.gm-studio-preview-name{font-size:.9rem;font-weight:800;line-height:1.2}.gm-studio-preview-section{padding:10px 16px}.gm-studio-preview-chip{font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:999px;background:var(--gm-primary-light);color:var(--gm-primary-dark);border:1px solid rgba(0,115,230,.18)}.gm-studio-preview-chip--warn{background:#fef9c3;color:#a16207;border-color:#fde047}.gm-studio-preview-chip.muted{background:var(--gm-bg-subtle);color:var(--gm-text-muted);border-color:var(--gm-border)}.gm-studio-preview-ready{margin:0 16px 14px;padding:8px 12px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;font-size:.75rem;font-weight:700;color:#15803d}.gm-studio-draft-row{padding:12px 10px;border-radius:12px;border:1.5px solid transparent;transition:border-color .18s,background .18s;margin:0 -2px}.gm-studio-draft-row:hover{border-color:var(--gm-primary);background:var(--gm-primary-light)}.gm-studio-draft-thumb{width:48px;height:48px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 3px 8px #00000026}.gm-studio-draft-name{font-size:.88rem;font-weight:800}.gm-studio-draft-meta{font-size:.72rem;color:var(--gm-text-muted)}.gm-studio-draft-btn{padding:6px 14px;border-radius:30px;border:2px solid var(--gm-primary);background:transparent;color:var(--gm-primary);font-size:.75rem;font-weight:800;cursor:pointer;white-space:nowrap;transition:background .18s,color .18s}.gm-studio-draft-btn:hover{background:var(--gm-primary);color:#fff}.gm-role-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.gm-role-card{position:relative;border:2px solid var(--gm-border);border-radius:16px;background:var(--gm-bg-card);overflow:hidden;box-shadow:0 2px 8px #0000000f;transition:border-color .18s,box-shadow .18s,transform .18s}.gm-role-card:hover{border-color:var(--gm-primary);box-shadow:0 6px 20px #0073e624;transform:translateY(-2px)}.gm-role-card:before{content:"";display:block;height:5px;background:linear-gradient(90deg,var(--gm-primary) 0%,#7c3aed 100%)}.gm-role-card>.gm-card-del-btn{position:absolute;top:12px;right:12px;z-index:2}.gm-role-card-icon-row{display:flex;align-items:flex-start;gap:12px;padding:12px 14px 10px}.gm-role-card-icon{width:52px;height:52px;font-size:1.8rem;text-align:center;border:2px solid var(--gm-border);border-radius:12px;background:var(--gm-bg);cursor:text;flex-shrink:0;line-height:48px;padding:0;color:var(--gm-text);transition:border-color .18s}.gm-role-card-icon:focus{border-color:var(--gm-primary);box-shadow:0 0 0 3px #0073e626;outline:none}.gm-role-card-fields{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.gm-role-card-name,.gm-role-card-desc{width:100%;border:1.5px solid var(--gm-border);border-radius:8px;padding:6px 10px;background:var(--gm-bg);color:var(--gm-text);transition:border-color .18s;outline:none}.gm-role-card-name{font-size:.9rem;font-weight:800}.gm-role-card-desc{font-size:.78rem;font-weight:600;color:var(--gm-text-muted)}.gm-role-card-name:focus,.gm-role-card-desc:focus{border-color:var(--gm-primary);box-shadow:0 0 0 2px #0073e626}.gm-role-card-footer{display:flex;align-items:center;gap:8px;padding:8px 14px 12px;border-top:1px solid var(--gm-border-light);background:var(--gm-bg)}.gm-role-card-fn{flex:1;border:1.5px solid var(--gm-border);border-radius:8px;padding:5px 9px;font-size:.76rem;font-weight:700;background:var(--gm-bg-card);color:var(--gm-text);outline:none;transition:border-color .18s}.gm-role-card-fn:focus{border-color:var(--gm-primary)}.gm-role-card-default{display:flex;align-items:center;gap:5px;font-size:.7rem;font-weight:700;color:var(--gm-text-muted);cursor:pointer;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0}.gm-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.gm-ability-card{display:flex;flex-direction:column;border-radius:16px;overflow:hidden;color:#fff;position:relative;aspect-ratio:5 / 7;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s;cursor:default}.gm-ability-card:hover{transform:translateY(-8px) scale(1.04) rotateY(2deg)}.gm-ability-card[data-rarity=COMMON]{box-shadow:0 6px 20px #50505080;border:4px solid #555}.gm-ability-card[data-rarity=RARE]{box-shadow:0 6px 28px #c8960c99;border:4px solid #c8960c}.gm-ability-card[data-rarity=EPIC]{box-shadow:0 6px 28px #0d47a1a6;border:4px solid #1565c0}.gm-ability-card[data-rarity=LEGENDARY]{box-shadow:0 6px 32px #b400ffa6;border:4px solid #9c27b0;animation:legendaryCardGlow 3s ease-in-out infinite}@keyframes legendaryCardGlow{0%,to{box-shadow:0 6px 32px #b400ffa6}50%{box-shadow:0 8px 44px #f80057b3,0 0 16px #e040fb73}}.gm-ability-card[data-rarity=RARE]:after,.gm-ability-card[data-rarity=EPIC]:after,.gm-ability-card[data-rarity=LEGENDARY]:after{content:"";position:absolute;inset:0;background:linear-gradient(125deg,#fff0 20%,#ffffff14 40%,#ffdc641a,#ffffff14 60%,#fff0 80%);opacity:0;transition:opacity .3s;pointer-events:none;z-index:10;border-radius:12px}.gm-ability-card[data-rarity=RARE]:hover:after,.gm-ability-card[data-rarity=EPIC]:hover:after,.gm-ability-card[data-rarity=LEGENDARY]:hover:after{opacity:1}.gm-ability-card-body{display:flex;flex-direction:column;gap:4px;padding:10px 8px 6px;flex:1}.gm-ability-card-rarity{font-size:.58rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;opacity:.8}.gm-ability-card-icon{font-size:2rem;line-height:1;text-align:center;background:#0003;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;padding:4px 0;margin:2px 0;width:100%;cursor:text;outline:none}.gm-ability-card-icon:focus{border-color:#ffffff80;box-shadow:0 0 0 2px #ffffff26}.gm-ability-card-name{font-size:.75rem;font-weight:800;background:#00000040;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;padding:4px 6px;width:100%;outline:none}.gm-ability-card-name:focus{border-color:#ffffff80}.gm-ability-card-desc{font-size:.65rem;font-style:italic;background:#0000002e;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#fffc;padding:3px 6px;width:100%;line-height:1.35;outline:none;flex:1}.gm-ability-card-footer{padding:6px 8px;background:#0000004d;display:flex;align-items:center;gap:5px;border-top:1px solid rgba(255,255,255,.07)}.gm-ability-card-cost-label{display:flex;align-items:center;gap:3px;font-size:.65rem;font-weight:800;color:#ffffffb3;white-space:nowrap}.gm-ability-card-cost{width:38px;font-size:.7rem;font-weight:800;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;padding:3px 4px;text-align:center;outline:none}.gm-ability-card-rarity-sel{flex:1;font-size:.62rem;font-weight:700;background:#ffffff1a;border:1px solid rgba(255,255,255,.18);border-radius:6px;color:#fff;padding:3px 4px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-align:center;outline:none}.gm-ability-card-rarity-sel option{background:#1a0a2e;color:#fff}.gm-ability-card-meta{padding:5px 8px 7px;background:#00000038;display:flex;gap:4px}.gm-ability-card-arch,.gm-ability-card-unlock-sel{flex:1;font-size:.62rem;font-weight:700;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#ffffffd9;padding:3px 5px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-align:center;outline:none}.gm-ability-card-arch::-moz-placeholder{color:#ffffff59}.gm-ability-card-arch::placeholder{color:#ffffff59}.gm-ability-card-arch option,.gm-ability-card-unlock-sel option{background:#1a0a2e;color:#fff}.gm-card-del-btn--dark{position:absolute;top:8px;right:8px;z-index:5;width:22px;height:22px;border-radius:50%;background:#00000080;border:1.5px solid rgba(255,255,255,.3);color:#ffffffbf;font-size:.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.gm-card-del-btn--dark:hover{background:#dc2626bf;color:#fff;border-color:transparent}.gm-badge-gallery{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.gm-badge-medal{border-radius:20px;padding:18px 14px 14px;border-width:2.5px;transition:transform .18s,box-shadow .18s,border-color .18s}.gm-badge-medal:hover{transform:translateY(-3px);box-shadow:0 6px 20px #d4a01733}.gm-badge-medal:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--gm-accent) 0%,#f59e0b 100%);border-radius:18px 18px 0 0}.gm-badge-medal-icon{font-size:2.6rem;margin-top:6px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}.gm-badge-medal-name{font-size:.9rem;font-weight:800}.gm-badge-sel{font-size:.78rem;border-radius:8px;padding:5px 9px;border-width:1.5px}.gm-scenario-engine-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:14px}.gm-scenario-engine-btn{padding:16px 14px;border-radius:16px;transition:border-color .18s,background .18s,box-shadow .18s,transform .18s}.gm-scenario-engine-btn:hover{transform:translateY(-3px)}.gm-scenario-engine-btn-icon{font-size:1.8rem;margin-bottom:2px}.gm-scenario-block{border-radius:16px}.gm-empty-state{padding:36px 24px;gap:12px}.gm-empty-state-icon{font-size:3rem;opacity:.4;filter:drop-shadow(0 2px 4px rgba(0,0,0,.12))}.gm-empty-state-text{font-size:1.05rem;font-weight:800}.gm-empty-state-sub{font-size:.82rem;max-width:360px}.gm-review-blocks{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.gm-review-block{border-radius:14px;border-width:1.5px;transition:border-color .18s,box-shadow .18s}.gm-review-block:hover{border-color:var(--gm-primary);box-shadow:0 3px 12px #0073e61a}.gm-studio-review-header{border-radius:16px;padding:22px 24px;margin-bottom:24px}.gm-studio-review-name{font-family:Fredoka,sans-serif;font-size:1.6rem;font-weight:700}.gm-wizard-add{align-self:flex-start;display:inline-flex;align-items:center;gap:7px;border:2.5px dashed var(--gm-primary);border-radius:30px;background:transparent;color:var(--gm-primary);font-size:.82rem;font-weight:700;padding:8px 18px;cursor:pointer;transition:background .18s,color .18s}.gm-wizard-add:hover{background:var(--gm-primary-light)}@media(max-width:1024px){.gm-studio-body{flex-direction:column}.gm-studio-preview{width:100%;position:static;flex-direction:row;flex-wrap:wrap;border-radius:14px}.gm-studio-preview-header{flex:1 0 100%}.gm-studio-preview-section{flex:1 0 140px;border-top:none;border-right:1px solid var(--gm-border-light)}.gm-studio-preview-section:last-child{border-right:none}.gm-roles-grid,.gm-role-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.gm-cards-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.gm-badge-gallery{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.gm-scenario-engine-grid{grid-template-columns:repeat(3,1fr)}.gm-review-blocks{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.gm-studio-content{padding:16px}.gm-studio-header{padding:12px 16px}.gm-studio-progress{padding:10px 16px}.gm-studio-nav{padding:12px 16px}.gm-studio-step-title{font-size:1rem}.gm-role-grid,.gm-roles-grid{grid-template-columns:1fr}.gm-cards-grid{grid-template-columns:repeat(2,1fr)}.gm-badge-gallery{grid-template-columns:1fr}.gm-scenario-engine-grid{grid-template-columns:repeat(2,1fr)}.gm-review-blocks{grid-template-columns:1fr}.gm-studio-nav-actions{flex-direction:column-reverse;gap:10px}.gm-studio-nav-actions>button{width:100%;justify-content:center;text-align:center}.gm-studio-close-btn{font-size:.7rem;padding:6px 12px}}@media(min-width:1025px)and (max-width:1280px){.gm-studio-preview{width:220px}}@media(min-width:1281px){.gm-studio-preview{width:272px}.gm-studio-content{padding:28px 32px 24px}.gm-studio-header{padding:18px 32px}.gm-studio-progress{padding:14px 32px}.gm-studio-nav{padding:16px 32px}.gm-cards-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}html[data-theme=dark] .gm-studio-wizard{box-shadow:0 4px 24px #00000059,0 1px 4px #0003}html[data-theme=dark] .gm-studio-close-btn:hover:not(:disabled){background:#3b0a0a;border-color:#ef4444;color:#f87171}html[data-theme=dark] .gm-studio-draft-row:hover{background:#0073e61a;border-color:var(--gm-primary)}html[data-theme=dark] .gm-wizard-field input:focus,html[data-theme=dark] .gm-wizard-field textarea:focus,html[data-theme=dark] .gm-wizard-field select:focus,html[data-theme=dark] .gm-field:focus{box-shadow:0 0 0 3px #0073e640}html[data-theme=dark] .gm-role-card{border-color:var(--gm-border);background:var(--gm-bg-card)}html[data-theme=dark] .gm-role-card:hover{border-color:var(--gm-primary);box-shadow:0 6px 20px #0073e633}html[data-theme=dark] .gm-role-card-icon,html[data-theme=dark] .gm-role-card-name,html[data-theme=dark] .gm-role-card-desc,html[data-theme=dark] .gm-role-card-fn{background:var(--gm-bg);border-color:var(--gm-border);color:var(--gm-text)}html[data-theme=dark] .gm-role-card-footer{background:var(--gm-bg-subtle);border-top-color:var(--gm-border)}html[data-theme=dark] .gm-studio-preview{background:var(--gm-bg-card);border-color:var(--gm-border)}html[data-theme=dark] .gm-studio-preview-chip{background:#0073e62e;color:#7ab8ff;border-color:#0073e64d}html[data-theme=dark] .gm-studio-preview-ready{background:#052e16;border-color:#166534;color:#4ade80}html[data-theme=dark] .gm-studio-draft-btn{border-color:var(--gm-primary);color:var(--gm-primary)}html[data-theme=dark] .gm-studio-draft-btn:hover{background:var(--gm-primary);color:#fff}html[data-theme=dark] .gm-badge-medal:before{background:linear-gradient(90deg,#b45309 0%,var(--gm-accent) 100%)}html[data-theme=dark] .gm-review-block:hover{border-color:var(--gm-primary);box-shadow:0 3px 12px #0073e626}html[data-theme=dark] .gm-wizard-add{color:#7ab8ff;border-color:#7ab8ff}html[data-theme=dark] .gm-wizard-add:hover{background:#0073e626}.gm-studio-header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.gm-studio-icon-btn{width:38px;height:38px;border-radius:10px;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .18s,transform .14s,box-shadow .18s;flex-shrink:0}.gm-studio-icon-btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.gm-studio-icon-btn--save{background:#0073e61a;color:var(--gm-primary)}.gm-studio-icon-btn--save:hover:not(:disabled){background:#0073e62e;transform:scale(1.08);box-shadow:0 2px 8px #0073e633}.gm-studio-icon-btn--close{background:#dc262614;color:var(--gm-red)}.gm-studio-icon-btn--close:hover:not(:disabled){background:#dc262629;transform:scale(1.08);box-shadow:0 2px 8px #dc262626}html[data-theme=dark] .gm-studio-icon-btn--save{background:#0073e626;color:#7ab8ff}html[data-theme=dark] .gm-studio-icon-btn--save:hover:not(:disabled){background:#0073e647}html[data-theme=dark] .gm-studio-icon-btn--close{background:#dc26261f;color:#f87171}html[data-theme=dark] .gm-studio-icon-btn--close:hover:not(:disabled){background:#dc262640}.gm-studio-preview{margin:16px 0;border-radius:18px;overflow:hidden}.gm-studio-preview-header{border-radius:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:22px 16px 18px;gap:8px;min-height:100px}.gm-studio-preview-icon{font-size:2.4rem;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}.gm-studio-preview-meta{align-items:center;text-align:center}.gm-studio-preview-name{font-size:1rem;font-weight:800;text-align:center}.gm-studio-preview-sub{text-align:center;font-size:.72rem}.gm-studio-preview-section{padding:12px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.gm-studio-preview-section-label{font-size:.65rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--gm-text-muted)}.gm-studio-preview-chips{display:flex;flex-wrap:wrap;gap:5px;justify-content:center}.gm-studio-preview-meta-row{font-size:.72rem;color:var(--gm-text-muted);font-weight:600;display:flex;align-items:center;gap:5px;justify-content:center;flex-wrap:wrap}.gm-studio-preview-issues{padding:8px 14px 12px;display:flex;flex-direction:column;gap:4px;align-items:center}.gm-studio-preview-ready{margin:0 14px 14px;text-align:center}.gm-studio-preview-avatars--centered{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.gm-studio-preview-avatar--square{width:36px;height:36px;border-radius:8px;-o-object-fit:contain;object-fit:contain;background:transparent;border:none}.gm-role-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px}.gm-role-card{position:relative;border-radius:16px;overflow:hidden;border:4px solid #1565c0;background:linear-gradient(160deg,#0d1b40,#0a1128 60%,#060c1c);box-shadow:0 6px 22px #0d47a18c;color:#fff;display:flex;flex-direction:column;aspect-ratio:5 / 7;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s;cursor:default}.gm-role-card:before{content:none}.gm-role-card:hover{transform:translateY(-8px) scale(1.04) rotateY(2deg);box-shadow:0 14px 36px #0d47a1a6}.gm-role-card-titlebar{background:linear-gradient(90deg,#041030,#0d2a6e);padding:8px 10px 6px;display:flex;align-items:center;gap:6px;flex-shrink:0}.gm-role-card-icon-row{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at 35% 35%,#0d47a1,#011540,#000814);position:relative;padding:10px 8px;gap:6px;min-height:0}.gm-role-card-icon{font-size:2.8rem;width:64px;height:64px;background:#00000040;border:1px solid rgba(255,255,255,.2);border-radius:12px;color:inherit;text-align:center;line-height:64px;padding:0;flex-shrink:0;outline:none;cursor:text}.gm-role-card-icon:focus{border-color:#ffffff80;box-shadow:0 0 0 2px #ffffff26}.gm-role-card-fields{display:flex;flex-direction:column;gap:5px;width:100%}.gm-role-card-name,.gm-role-card-desc{width:100%;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:7px;color:#fff;outline:none;transition:border-color .18s}.gm-role-card-name{font-size:.78rem;font-weight:800;padding:5px 8px;text-align:center}.gm-role-card-desc{font-size:.65rem;font-style:italic;padding:4px 8px;text-align:center;color:#ffffffbf}.gm-role-card-name::-moz-placeholder,.gm-role-card-desc::-moz-placeholder{color:#ffffff59}.gm-role-card-name::placeholder,.gm-role-card-desc::placeholder{color:#ffffff59}.gm-role-card-name:focus,.gm-role-card-desc:focus{border-color:#ffffff80}.gm-role-card-footer{background:#000000d9;padding:6px 8px;display:flex;gap:5px;align-items:center;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}.gm-role-card-fn{flex:1;font-size:.62rem;font-weight:700;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#d4b896;padding:4px 5px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-align:center;outline:none}.gm-role-card-fn option{background:#0d1b40;color:#fff}.gm-role-card-default{display:flex;align-items:center;gap:4px;font-size:.6rem;font-weight:700;color:#ffffff8c;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;white-space:nowrap;flex-shrink:0}.gm-role-card>.gm-card-del-btn{position:absolute;top:8px;right:8px;z-index:10;background:#0000008c;border-color:#ffffff4d;color:#ffffffb3}.gm-role-card>.gm-card-del-btn:hover{background:#dc2626bf;border-color:transparent;color:#fff}.gm-role-card:after{content:"";position:absolute;inset:0;background:linear-gradient(125deg,#fff0 20%,#ffffff0f 40%,#ffdc6414,#ffffff0f 60%,#fff0 80%);opacity:0;transition:opacity .3s;pointer-events:none;z-index:5}.gm-role-card:hover:after{opacity:1}.gm-badge-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:20px}.gm-badge-medal{position:relative;display:flex;flex-direction:column;align-items:stretch;gap:0;padding:0;border:none;border-radius:16px;background:linear-gradient(160deg,#2a1800,#1a0d00 60%,#0d0600);box-shadow:0 6px 22px #c8960c80;color:#fff;text-align:left;aspect-ratio:5 / 7;overflow:hidden;border:4px solid #c8960c;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s}.gm-badge-medal:before{content:none}.gm-badge-medal:hover{transform:translateY(-8px) scale(1.04) rotateY(-2deg);box-shadow:0 14px 36px #c8960ca6,0 0 18px #ffd7004d;border-color:gold}.gm-badge-medal-icon{font-size:3rem;display:flex;align-items:center;justify-content:center;flex:1;background:radial-gradient(ellipse at 35% 35%,#5c3d00,#1a1000,#060400);padding:14px 8px;min-height:0;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}.gm-badge-medal-name{font-size:.8rem;font-weight:800;color:#f5e6c8;text-align:center;padding:7px 10px 5px;background:linear-gradient(90deg,#3a2000,#5c3800);border-top:1px solid rgba(200,150,20,.25);flex-shrink:0}.gm-badge-medal-fields{display:flex;flex-direction:column;gap:4px;padding:5px 8px 7px;background:#000000d9;border-top:1px solid rgba(255,255,255,.05);flex-shrink:0}.gm-badge-sel{font-size:.62rem;font-weight:700;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#d4b896;padding:4px 5px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-align:center;outline:none;width:100%}.gm-badge-sel option{background:#1a0a00;color:#fff}.gm-badge-medal-del{position:absolute;top:8px;right:8px;z-index:10}.gm-badge-medal-del>.gm-card-del-btn{background:#0000008c;border-color:#ffffff4d;color:#ffffffb3}.gm-badge-medal-del>.gm-card-del-btn:hover{background:#dc2626bf;color:#fff;border-color:transparent}.gm-badge-medal:after{content:"";position:absolute;inset:0;background:linear-gradient(125deg,#fff0 20%,#ffffff0f 40%,#ffdc641f,#ffffff0f 60%,#fff0 80%);opacity:0;transition:opacity .3s;pointer-events:none;z-index:5}.gm-badge-medal:hover:after{opacity:1}.gm-badge-medal input[type=text],.gm-badge-medal textarea{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#f5e6c8;font-size:.72rem;font-weight:700;padding:5px 8px;text-align:center;width:100%;outline:none;resize:none}.gm-badge-medal input[type=text]::-moz-placeholder,.gm-badge-medal textarea::-moz-placeholder{color:#ffffff4d}.gm-badge-medal input[type=text]::placeholder,.gm-badge-medal textarea::placeholder{color:#ffffff4d}.gm-badge-medal input[type=text]:focus,.gm-badge-medal textarea:focus{border-color:#ffd70080;box-shadow:0 0 0 2px #ffd7001a}@media(max-width:1024px){.gm-role-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.gm-badge-gallery{grid-template-columns:repeat(auto-fill,minmax(145px,1fr))}.gm-studio-preview{margin:12px 0}}@media(max-width:640px){.gm-role-grid,.gm-badge-gallery{grid-template-columns:repeat(2,1fr)}}.gm-studio-wizard{position:relative}.gm-wizard-float-back{position:absolute;bottom:24px;left:24px;z-index:30;background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid var(--gm-border);color:var(--gm-text-muted);font-family:inherit;font-size:.88rem;font-weight:700;cursor:pointer;padding:11px 22px;border-radius:30px;display:flex;align-items:center;gap:7px;box-shadow:0 4px 20px #0000001a;transition:background .2s,box-shadow .2s,transform .2s,color .2s}.gm-wizard-float-back:hover:not(:disabled){background:#fff;color:var(--gm-primary);border-color:var(--gm-primary);box-shadow:0 6px 24px #0073e62e;transform:translate(-3px)}.gm-wizard-float-back:disabled{opacity:.4;cursor:not-allowed}.gm-wizard-float-next-wrap{position:absolute;bottom:24px;right:24px;z-index:30;display:flex;gap:10px;align-items:center}.gm-wizard-float-next{background:linear-gradient(135deg,#f9a825,#ff8f00);border:none;color:#fff;font-family:inherit;font-size:.95rem;font-weight:800;cursor:pointer;padding:12px 32px;border-radius:30px;display:flex;align-items:center;gap:8px;box-shadow:0 5px 20px #f9a82580;transition:transform .2s,box-shadow .2s,opacity .2s;letter-spacing:.02em}.gm-wizard-float-next:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 9px 28px #f9a825a6}.gm-wizard-float-next:disabled{opacity:.4;cursor:not-allowed;transform:none}.gm-studio-nav-errors{padding:8px 24px 0;display:flex;flex-direction:column;gap:4px;margin-bottom:64px}.gm-studio-content{padding-bottom:88px}.gm-badge-medal-desc{font-size:.65rem;font-style:italic;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#ffffffb3;padding:4px 8px;text-align:center;width:100%;outline:none;resize:none}.gm-badge-medal-desc::-moz-placeholder{color:#ffffff4d}.gm-badge-medal-desc::placeholder{color:#ffffff4d}.gm-badge-medal-desc:focus{border-color:#ffd70080}.gm-badge-medal-selects{display:flex;flex-direction:column;gap:4px}html[data-theme=dark] .gm-wizard-float-back{background:#1a1714eb;border-color:var(--gm-border);color:var(--gm-text-muted)}html[data-theme=dark] .gm-wizard-float-back:hover:not(:disabled){background:var(--gm-bg-card);color:#7ab8ff;border-color:var(--gm-primary)}@media(max-width:640px){.gm-wizard-float-back{bottom:16px;left:16px;padding:9px 16px;font-size:.82rem}.gm-wizard-float-next-wrap{bottom:16px;right:16px}.gm-wizard-float-next{padding:10px 20px;font-size:.88rem}.gm-studio-content{padding-bottom:80px}}.gm-studio-header{padding:10px 20px;min-height:unset}.gm-studio-header-left{flex:1;min-width:0;gap:0}.gm-studio-header-row{display:flex;align-items:center;flex-wrap:wrap;gap:7px;min-width:0}.gm-studio-header-divider{color:var(--gm-text-soft);font-size:.75rem;font-weight:400;-webkit-user-select:none;-moz-user-select:none;user-select:none}.gm-studio-header-row .gm-studio-step-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--gm-primary)}.gm-studio-header-row .gm-studio-step-title{font-family:Fredoka,sans-serif;font-size:.95rem;font-weight:700;color:var(--gm-text)}.gm-studio-header-row .gm-studio-step-sub{font-size:.75rem;color:var(--gm-text-muted);font-weight:600}.gm-studio-header-row .gm-studio-last-saved,.gm-studio-header-row .gm-studio-saving-indicator{font-size:.68rem}.gm-wizard-float-back{position:fixed;bottom:28px;left:28px;z-index:200}.gm-wizard-float-next-wrap{position:fixed;bottom:28px;right:28px;z-index:200}.gm-studio-content{padding-bottom:32px}.gm-studio-preview{margin:12px 12px 12px 0}.gm-studio-preview-header{padding:20px 18px 16px}.gm-studio-preview-section{padding:10px 18px}.gm-studio-preview-ready{margin:0 18px 16px}@media(max-width:640px){.gm-wizard-float-back{bottom:72px;left:16px;padding:9px 16px;font-size:.82rem}.gm-wizard-float-next-wrap{bottom:72px;right:16px}.gm-wizard-float-next{padding:10px 20px;font-size:.88rem}.gm-studio-content{padding-bottom:24px}}.gm-studio-header{display:grid!important;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;padding:10px 16px;min-height:unset}.gm-studio-header-left{display:flex;align-items:center;gap:8px;flex:unset;min-width:0;justify-content:flex-start}.gm-studio-header-center{display:flex;align-items:center;gap:7px;justify-content:center;white-space:nowrap}.gm-studio-header-center .gm-studio-step-label{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--gm-primary);opacity:.8}.gm-studio-header-center .gm-studio-step-title{font-family:Fredoka,sans-serif;font-size:1.25rem;font-weight:700;color:var(--gm-text);letter-spacing:-.01em}.gm-studio-header-center .gm-studio-header-divider{font-size:.75rem;color:var(--gm-text-soft)}.gm-studio-header-center .gm-studio-step-sub{font-size:.78rem;color:var(--gm-text-muted);font-weight:500}.gm-studio-header-actions{justify-content:flex-end;display:flex;align-items:center;gap:6px}.gm-logo-upload-area{margin-top:6px}.gm-logo-preview-wrap{position:relative;display:inline-block}.gm-logo-preview-img{max-width:180px;max-height:140px;-o-object-fit:contain;object-fit:contain;border-radius:12px;background:repeating-conic-gradient(#3a3a4a 0% 25%,#28283a 0% 50%) 0 0 / 16px 16px;padding:6px;display:block}.gm-logo-remove-btn{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;background:var(--gm-danger, #dc2626);color:#fff;border:none;cursor:pointer;font-size:.7rem;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .15s}.gm-logo-remove-btn:hover{background:#b91c1c}.gm-logo-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:18px 24px;border:2px dashed var(--gm-border, rgba(255,255,255,.15));border-radius:12px;background:#ffffff08;cursor:pointer;transition:border-color .2s,background .2s;min-width:160px;max-width:220px;text-align:center}.gm-logo-dropzone:hover,.gm-logo-dropzone:focus-within{border-color:var(--gm-primary, #1976d2);background:#1976d20f}.gm-logo-dropzone--loading{opacity:.7;pointer-events:none}.gm-logo-dropzone-icon{font-size:1.6rem}.gm-logo-dropzone-text{font-size:.85rem;font-weight:600;color:var(--gm-text)}.gm-logo-dropzone-hint{font-size:.72rem;color:var(--gm-text-muted)}.gm-studio-preview-header--has-logo{padding:0;overflow:hidden;min-height:130px;display:flex;align-items:stretch}.gm-studio-preview-logo-overlay{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;width:100%;padding:8px 12px 12px;gap:6px}.gm-studio-preview-logo-overlay-img{max-width:100%;max-height:100px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(0,0,0,.35));flex-shrink:0}.gm-studio-preview-name--on-logo{font-size:.85rem;font-weight:700;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.6);text-align:center}.gm-studio-theme-logo-img{max-height:64px;max-width:120px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}@media(max-width:640px){.gm-studio-header{grid-template-columns:auto 1fr auto;gap:8px;padding:8px 12px}.gm-studio-header-center{flex-wrap:wrap;white-space:normal;gap:4px}.gm-studio-header-center .gm-studio-step-title{font-size:1rem}.gm-studio-header-left .gm-studio-last-saved{display:none}}.gm-paso5-main{display:flex;flex-direction:column;gap:16px;width:100%}.gm-cardback-section{background:var(--gm-bg-card, rgba(255,255,255,.04));border:1px solid var(--gm-border, rgba(255,255,255,.1));border-radius:14px;padding:14px 18px;display:flex;flex-direction:column;gap:10px}.gm-cardback-section-head{display:flex;flex-direction:column;gap:2px}.gm-cardback-section-title{font-size:.88rem;font-weight:700;color:var(--gm-text)}.gm-cardback-section-hint{font-size:.72rem;color:var(--gm-text-muted)}.gm-cardback-has{display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap}.gm-cardback-card-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}.gm-cardback-card{width:80px;aspect-ratio:5/7;border-radius:8px;overflow:hidden;background:var(--gm-bg-card, #1e1e2e);border:2px solid var(--gm-border);display:flex;align-items:center;justify-content:center}.gm-cardback-card-img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.gm-cardback-label{font-size:.65rem;color:var(--gm-text-muted);text-align:center}.gm-cardback-btns{display:flex;flex-direction:column;gap:6px;padding-top:4px}.gm-cardback-btn{padding:6px 12px;border-radius:8px;font-size:.78rem;font-weight:600;cursor:pointer;border:none;transition:opacity .15s;text-align:center}.gm-cardback-btn:hover{opacity:.85}.gm-cardback-btn--change{background:var(--gm-primary, #1976d2);color:#fff}.gm-cardback-btn--remove{background:#dc26261f;color:#ef4444;border:1px solid rgba(220,38,38,.25)}.gm-cardback-empty{display:flex;align-items:center;gap:10px}.gm-paso5-cards-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.gm-paso5-cards-label{font-size:.88rem;font-weight:700;color:var(--gm-text);display:flex;align-items:center;gap:6px}.gm-paso5-cards-count{background:var(--gm-primary, #1976d2);color:#fff;font-size:.68rem;font-weight:700;padding:1px 7px;border-radius:99px}.gm-paso5-edit-hint{font-size:.72rem;color:var(--gm-primary, #1976d2);font-weight:600}.gm-ability-card--clickable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:transform .15s,box-shadow .15s,outline .15s}.gm-ability-card--clickable:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 24px #00000059}.gm-ability-card--selected{outline:3px solid var(--gm-primary, #1976d2);outline-offset:3px;transform:translateY(-3px) scale(1.02);box-shadow:0 0 0 6px #1976d226,0 8px 24px #0000004d}.gm-ability-card-icon-display{font-size:1.85rem;text-align:center;line-height:1;z-index:1}.gm-ability-card-renderer{align-self:center;border-radius:0;overflow:visible}.gm-ability-card-snapshot{width:100%;height:auto;border-radius:12px;display:block}.gm-ability-card-mini-bg-art{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.gm-ability-card-mini-block{position:absolute;text-shadow:0 1px 2px rgba(0,0,0,.7);overflow:hidden}.gm-ability-card-mini-block--image{padding:0}.gm-ability-card-mini-block--image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.gm-ability-card-mini-block--divider{padding:0}.gm-ability-card-mini-divider-line{width:100%;height:2px;background:currentColor;opacity:.75;border-radius:999px}.gm-ability-card-mini-block--description,.gm-ability-card-mini-block--container{white-space:normal;line-height:1.2}.gm-ability-card-mini-block--stat,.gm-ability-card-mini-block--badge,.gm-ability-card-mini-block--tag,.gm-ability-card-mini-block--title,.gm-ability-card-mini-block--subtitle{white-space:nowrap;text-transform:none}.gm-ability-card-mini-block--stat{letter-spacing:.02em}.gm-ability-card-art-preview{width:calc(100% - 16px);height:92px;margin:6px 8px 4px;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.18);background:#00000040}.gm-ability-card-art-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.gm-ability-card-name-display{font-size:.78rem;font-weight:700;color:#fff;text-align:center;padding:0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gm-ability-card-desc-display{font-size:.62rem;color:#ffffffa6;text-align:center;padding:4px 8px 2px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.gm-ability-card-cost-badge{font-size:.68rem;font-weight:700;color:#fffc}.gm-ability-card-tpl-badge{font-size:.78rem;margin-left:auto}.gm-paso5-add-row{display:flex;flex-direction:column;gap:8px}.gm-card-editor-panel{width:296px;flex-shrink:0;background:var(--gm-bg-card, rgba(255,255,255,.04));border:1px solid var(--gm-border, rgba(255,255,255,.12));border-radius:16px;display:flex;flex-direction:column;max-height:calc(100vh - 160px);overflow-y:auto;position:sticky;top:12px}.gm-card-editor-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:1px solid var(--gm-border, rgba(255,255,255,.1));position:sticky;top:0;background:var(--gm-bg-card, #1a1a2e);z-index:2;border-radius:16px 16px 0 0}.gm-card-editor-title{font-size:.88rem;font-weight:700;color:var(--gm-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:210px}.gm-card-editor-close{background:none;border:none;color:var(--gm-text-muted);cursor:pointer;font-size:.9rem;padding:4px 6px;border-radius:6px;line-height:1;transition:background .15s,color .15s}.gm-card-editor-close:hover{background:#dc26261f;color:#ef4444}.gm-card-editor-section{padding:14px 16px;border-bottom:1px solid var(--gm-border, rgba(255,255,255,.07));display:flex;flex-direction:column;gap:10px}.gm-card-editor-section:last-child{border-bottom:none}.gm-card-editor-section-title{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--gm-primary, #1976d2);opacity:.9}.gm-card-editor-field{display:flex;flex-direction:column;gap:4px}.gm-card-editor-field label{font-size:.72rem;font-weight:600;color:var(--gm-text-soft)}.gm-card-editor-field input,.gm-card-editor-field select,.gm-card-editor-field textarea{padding:6px 10px;border-radius:8px;border:1px solid var(--gm-border);background:var(--gm-bg, rgba(0,0,0,.2));color:var(--gm-text);font-size:.8rem}.gm-card-editor-icon-input{font-size:1.4rem!important;text-align:center;width:56px!important}.gm-card-editor-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.gm-template-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.gm-tpl-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px;border-radius:10px;border:2px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s,box-shadow .15s;min-height:56px}.gm-tpl-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.gm-tpl-btn--active{box-shadow:0 0 0 3px #fff6,0 4px 14px #0006;transform:translateY(-2px) scale(1.04)}.gm-tpl-btn-icon{font-size:1.2rem;line-height:1}.gm-tpl-btn-name{font-size:.62rem;font-weight:700;color:#ffffffe6;text-shadow:0 1px 2px rgba(0,0,0,.5)}.gm-frame-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.gm-frame-btn{padding:6px 4px;border-radius:8px;border:2px solid var(--gm-border, rgba(255,255,255,.15));background:var(--gm-bg, rgba(0,0,0,.2));color:var(--gm-text);font-size:.68rem;font-weight:600;cursor:pointer;transition:transform .12s,box-shadow .12s;text-align:center}.gm-frame-btn:hover{transform:scale(1.04)}.gm-frame-btn--active{background:#1976d226;box-shadow:0 0 0 2px var(--gm-primary, #1976d2)}.gm-card-editor-previews{display:flex;gap:12px;justify-content:center}.gm-card-preview-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}.gm-card-preview-label{font-size:.65rem;color:var(--gm-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.gm-card-preview-face{width:90px;aspect-ratio:5/7;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:6px 5px 5px;gap:3px;overflow:hidden;position:relative;border:2px solid rgba(255,255,255,.12)}.gm-card-preview-face--back{background:var(--gm-bg-card, #1e1e2e);border:2px solid var(--gm-border)}.gm-card-preview-rarity-badge{font-size:.48rem;font-weight:800;text-transform:uppercase;color:#ffffffb3;letter-spacing:.06em;align-self:flex-start}.gm-card-preview-icon{font-size:1.5rem;line-height:1;padding:4px 0 2px}.gm-card-preview-name{font-size:.6rem;font-weight:700;color:#fff;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;padding:0 3px}.gm-card-preview-desc{font-size:.52rem;color:#fff9;text-align:center;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;padding:0 3px}.gm-card-preview-footer{margin-top:auto;display:flex;justify-content:space-between;width:100%;padding:0 3px;font-size:.54rem;color:#ffffffb3}.gm-card-preview-back-img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.gm-card-preview-back-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;height:100%;font-size:.58rem;color:var(--gm-text-muted);text-align:center}.gm-card-preview-back-empty span:first-child{font-size:1.6rem}.gm-studio-capability-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:8px}.gm-studio-capability-card{position:relative;display:flex;flex-direction:column;gap:10px;padding:14px 14px 12px;border-radius:16px;border:1.5px solid var(--gm-border);background:var(--gm-bg-card);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);overflow:hidden}.gm-studio-capability-card:before{content:"";position:absolute;inset:0;border-radius:16px;background:linear-gradient(135deg,transparent 60%,rgba(255,255,255,.04));pointer-events:none}.gm-studio-capability-card:hover:not(.is-locked){background:var(--gm-bg-subtle);border-color:#4d78ff66;transform:translateY(-2px);box-shadow:0 8px 20px #0038aa29}.gm-studio-capability-card.is-on{border-color:#7c5cff85;background:#7c5cff14;box-shadow:0 0 0 1px #7c5cff2e inset,0 8px 24px #7c5cff26}.gm-studio-capability-card.is-off{opacity:.56}.gm-studio-capability-card.is-locked{cursor:default}.gm-studio-capability-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.gm-studio-capability-left{display:flex;align-items:flex-start;gap:8px;flex:1;min-width:0}.gm-studio-capability-icon{width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:900;letter-spacing:.05em;color:#fff;background:linear-gradient(135deg,#7c5cff,#3db5ff);box-shadow:0 2px 8px #7c5cff59;flex-shrink:0}.gm-studio-capability-card.is-off .gm-studio-capability-icon{background:#ffffff1f;box-shadow:none}.gm-studio-capability-copy{min-width:0;display:flex;flex-direction:column;gap:3px}.gm-studio-capability-label{font-family:Fredoka,sans-serif;font-size:.9rem;font-weight:800;color:var(--gm-text);line-height:1.2}.gm-studio-capability-sub{font-size:.7rem;line-height:1.38;color:var(--gm-text-muted);font-weight:600}.gm-studio-capability-preview{position:relative;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:#00000047;min-height:110px;display:flex;align-items:center;justify-content:center;padding:8px}.gm-studio-capability-card.is-off .gm-studio-capability-preview{opacity:.34;filter:grayscale(.6)}.gm-studio-capability-foot{display:flex;align-items:center;justify-content:space-between;gap:8px}.gm-studio-capability-count{font-size:.64rem;font-weight:700;color:var(--gm-text-soft)}.gm-studio-capability-card.is-on .gm-studio-capability-count{color:#3db5ff}.gm-studio-capability-lock{font-size:.58rem;font-weight:800;padding:2px 7px;border-radius:5px;color:#f8c765;border:1px solid rgba(245,158,11,.3);background:#f59e0b24;text-transform:uppercase;letter-spacing:.06em}.gm-studio-capability-switch{position:relative;width:58px;height:34px;flex-shrink:0}.gm-studio-capability-switch-input{position:absolute;inset:0;opacity:0;margin:0;cursor:pointer;z-index:2}.gm-studio-capability-switch-track{width:100%;height:100%;border-radius:999px;border:2px solid rgba(255,255,255,.18);background:#ffffff1a;display:block;position:relative;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease}.gm-studio-capability-switch-thumb{position:absolute;top:4px;left:4px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #00000073;transition:transform .22s cubic-bezier(.4,0,.2,1),background .2s ease}.gm-studio-capability-switch-input:checked+.gm-studio-capability-switch-track{background:#7c5cff;border-color:#7c5cff;box-shadow:0 0 12px #7c5cff8c}.gm-studio-capability-switch-input:checked+.gm-studio-capability-switch-track .gm-studio-capability-switch-thumb{transform:translate(24px)}.gm-studio-capability-switch-input:focus-visible+.gm-studio-capability-switch-track{outline:2px solid #3db5ff;outline-offset:2px}.gm-studio-capability-switch-input:disabled{cursor:not-allowed}.gm-studio-capability-switch-input:disabled+.gm-studio-capability-switch-track{opacity:.75}.gm-studio-capability-preview--avatars{background:radial-gradient(ellipse at 60% 30%,#1e2a4a,#0d1020);gap:10px}.gm-cap-preview-avatar-main{width:64px;height:64px;border-radius:50%;position:relative;background:linear-gradient(135deg,#7c5cff,#3db5ff);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #7c5cff80,0 0 0 3px #ffffff1a}.gm-cap-preview-avatar-main-img{width:78%;height:78%;-o-object-fit:contain;object-fit:contain}.gm-cap-preview-avatar-main-fallback{font-size:1.8rem}.gm-cap-preview-avatar-level{position:absolute;right:-4px;bottom:-4px;background:#f59e0b;color:#111;font-size:.52rem;font-weight:900;border-radius:8px;padding:1px 5px;border:2px solid #0d1020}.gm-cap-preview-avatar-stack{display:flex;flex-direction:column;gap:4px}.gm-cap-preview-avatar-mini{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#5f7af7,#3db5ff);border:2px solid rgba(255,255,255,.15);font-size:.78rem;display:inline-flex;align-items:center;justify-content:center}.gm-cap-preview-avatar-mini:nth-child(2){background:linear-gradient(135deg,#f59e0b,#f87171)}.gm-cap-preview-avatar-mini:nth-child(3){background:linear-gradient(135deg,#34d399,#3db5ff)}.gm-studio-capability-preview--roles{flex-direction:column;background:radial-gradient(ellipse at 40% 60%,#1a1035,#0d0f1a);gap:5px}.gm-cap-preview-role-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;border:1px solid transparent;font-size:.64rem;font-weight:800}.gm-cap-preview-role-chip.is-amber{background:#f6d36526;border-color:#f6d36566;color:#f6d365}.gm-cap-preview-role-chip.is-blue{background:#4da6ff26;border-color:#4da6ff66;color:#4da6ff}.gm-cap-preview-role-chip.is-green{background:#34d39926;border-color:#34d39966;color:#34d399}.gm-studio-capability-preview--cards{background:radial-gradient(ellipse at 50% 80%,#1a0f35,#0d0c1a);gap:10px}.gm-cap-preview-mini-card{width:62px;height:96px;aspect-ratio:5 / 8;border-radius:7px;border:1.5px solid rgba(124,92,255,.52);background:linear-gradient(160deg,#2a1a55,#1a1040);overflow:hidden;box-shadow:0 4px 16px #7c5cff4d;transform:rotate(-4deg);display:flex;flex-direction:column}.gm-cap-preview-mini-card.is-alt{transform:rotate(2deg) translateY(-3px);border-color:#3db5ffa6;box-shadow:0 6px 20px #3db5ff59}.gm-cap-preview-mini-card-head{padding:3px 4px 2px;display:flex;align-items:center;justify-content:space-between;font-size:.36rem;font-weight:900;color:#c4b5fd}.gm-cap-preview-mini-card-head span:last-child{width:12px;height:12px;border-radius:50%;background:#f59e0b;color:#111;display:inline-flex;align-items:center;justify-content:center}.gm-cap-preview-mini-card.is-alt .gm-cap-preview-mini-card-head span:last-child{background:#3db5ff}.gm-cap-preview-mini-card-art{height:42px;display:flex;align-items:center;justify-content:center;font-size:1rem;background:linear-gradient(135deg,#7c5cff,#3db5ff)}.gm-cap-preview-mini-card-foot{margin-top:auto;border-top:1px solid rgba(255,255,255,.08);padding:2px 4px 3px;font-size:.36rem;font-weight:900;color:#f6d365;text-align:center}.gm-studio-capability-preview--badges{background:radial-gradient(ellipse at 50% 30%,#1a1505,#0d0f1a);gap:10px}.gm-cap-preview-badge-main{width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#f87171);border:2px solid rgba(255,255,255,.12);display:inline-flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:0 0 16px #f59e0b59}.gm-cap-preview-badge-main img{width:70%;height:70%;-o-object-fit:contain;object-fit:contain}.gm-cap-preview-badge-stack{display:flex;flex-direction:column;gap:5px}.gm-cap-preview-badge-stack span{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.15);display:inline-flex;align-items:center;justify-content:center;font-size:.82rem}.gm-cap-preview-badge-stack span:nth-child(1){background:linear-gradient(135deg,#7c5cff,#3db5ff)}.gm-cap-preview-badge-stack span:nth-child(2){background:linear-gradient(135deg,#34d399,#3db5ff)}.gm-cap-preview-badge-stack span:nth-child(3){background:linear-gradient(135deg,#f59e0b,#f87171)}.gm-studio-capability-preview--scenarios{background:radial-gradient(ellipse at 60% 40%,#0f2a1a,#0a1510)}.gm-cap-preview-board-bg{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:.14}.gm-cap-preview-board{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr);gap:2px}.gm-cap-preview-board span{width:20px;height:20px;border-radius:3px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;display:inline-flex;align-items:center;justify-content:center;font-size:.62rem}.gm-cap-preview-board span.is-water{background:#3db5ff26;border-color:#3db5ff3d}.gm-cap-preview-board span.is-land{background:#34d3991f;border-color:#34d39938}.gm-cap-preview-board span.is-path{background:#ffffff12;border-color:#ffffff24}.gm-cap-preview-board span.is-special{background:#f59e0b26;border-color:#f59e0b4d}.gm-cap-preview-board span.is-player{background:#7c5cff4d;border-color:#7c5cff80}.gm-studio-capability-preview--shop{background:radial-gradient(ellipse at 40% 30%,#1a0f1a,#0d0c1a);gap:6px}.gm-cap-preview-shop-item{width:58px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;padding:6px 5px 5px;display:flex;flex-direction:column;align-items:center;gap:3px}.gm-cap-preview-shop-item.is-featured{border-color:#f59e0b59;background:#f59e0b0f;transform:scale(1.04)}.gm-cap-preview-shop-item span{font-size:1.1rem}.gm-cap-preview-shop-item small{font-size:.5rem;font-weight:900;color:#f6d365}.gm-studio-capability-preview--teams{background:radial-gradient(ellipse at 50% 50%,#0f1a2a,#0a0e1a);gap:8px}.gm-cap-preview-team{flex:1;max-width:92px;border-radius:8px;padding:6px;border:1px solid transparent;text-align:center}.gm-cap-preview-team.is-blue{background:#3db5ff14;border-color:#3db5ff40}.gm-cap-preview-team.is-red{background:#f8717114;border-color:#f8717140}.gm-cap-preview-team strong{display:block;font-family:Fredoka,sans-serif;font-size:1.1rem;line-height:1}.gm-cap-preview-team.is-blue strong{color:#3db5ff}.gm-cap-preview-team.is-red strong{color:#f87171}.gm-cap-preview-team small{font-size:.5rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em;color:var(--gm-text-muted)}.gm-cap-preview-team-vs{font-size:.62rem;font-weight:900;color:var(--gm-text-soft)}.gm-studio-capability-preview--inventory{background:radial-gradient(ellipse at 30% 70%,#0f1a0f,#0a0d1a)}.gm-cap-preview-inventory-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}.gm-cap-preview-inventory-grid span{width:26px;height:26px;border-radius:5px;border:1px solid rgba(255,255,255,.1);background:#ffffff08;display:inline-flex;align-items:center;justify-content:center;font-size:.76rem}.gm-cap-preview-inventory-grid span.is-item{border-color:#34d3994d;background:#34d3990f}.gm-cap-preview-inventory-grid span.is-rare{border-color:#7c5cff66;background:#7c5cff14}.gm-studio-capability-preview--fallback{background:radial-gradient(ellipse at 30% 20%,#1e293b,#0f172a)}.gm-studio-capability-preview--fallback span{font-size:1.2rem}.gm-studio-preview-section--capabilities{align-items:stretch;text-align:left}.gm-studio-preview-section--capabilities .gm-studio-preview-cap-summary{display:flex;flex-direction:column;gap:4px;background:#7c5cff14;border:1px solid rgba(124,92,255,.22);border-radius:10px;padding:10px 12px}.gm-studio-preview-section--capabilities .gm-studio-preview-cap-summary strong{font-size:.78rem;color:var(--gm-text);font-weight:800}.gm-studio-preview-section--capabilities .gm-studio-preview-cap-summary span{font-size:.67rem;color:#3db5ff;font-weight:700}.gm-studio-preview-section--capabilities .gm-studio-preview-cap-includes{font-size:.66rem;color:var(--gm-text-muted);line-height:1.4}.gm-studio-preview-section--capabilities .gm-studio-preview-cap-gallery{display:flex;flex-direction:column;gap:5px}.gm-studio-preview-section--capabilities .gm-studio-preview-cap-item{display:flex;align-items:center;gap:7px;min-width:0}.gm-studio-preview-section--capabilities .gm-studio-preview-cap-thumb{width:22px;height:22px;border-radius:5px;overflow:hidden;border:1px solid rgba(124,92,255,.3);background:linear-gradient(135deg,#7c5cff,#3db5ff);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.gm-studio-preview-section--capabilities .gm-studio-preview-cap-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.gm-studio-preview-section--capabilities .gm-studio-preview-cap-fallback{font-size:.72rem}.gm-studio-preview-section--capabilities .gm-studio-preview-cap-name{font-size:.65rem;font-weight:700;color:var(--gm-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gm-studio-preview-section--capabilities .gm-studio-preview-chips{justify-content:flex-start}.gm-studio-preview-section--capabilities .gm-studio-preview-chip{font-size:.6rem;font-weight:800;border-radius:999px;padding:3px 8px;border:1px solid rgba(124,92,255,.25);background:#7c5cff26;color:#3db5ff}html[data-theme=dark] .gm-studio-capability-card{border-color:#ffffff14;background:#ffffff0a}html[data-theme=dark] .gm-studio-capability-card:hover:not(.is-locked){background:#1c2035;border-color:#7c5cff5c;box-shadow:0 8px 24px #7c5cff2e}html[data-theme=dark] .gm-studio-capability-card.is-on{background:#7c5cff12}@media(max-width:760px){.gm-studio-capability-grid{grid-template-columns:1fr 1fr}}@media(max-width:520px){.gm-studio-capability-grid{grid-template-columns:1fr}.gm-studio-capability-header{gap:8px}.gm-studio-capability-switch{width:54px;height:32px}.gm-studio-capability-switch-thumb{width:20px;height:20px}.gm-studio-capability-switch-input:checked+.gm-studio-capability-switch-track .gm-studio-capability-switch-thumb{transform:translate(22px)}}.gm-capabilities-mobile-summary{display:none}@media(max-width:900px){.gm-studio-wizard.gm-studio-wizard--capabilities-step .gm-studio-header-actions{display:none!important}.gm-studio-wizard.gm-studio-wizard--capabilities-step .gm-studio-header{grid-template-columns:1fr;gap:6px;align-items:flex-start}.gm-studio-wizard.gm-studio-wizard--capabilities-step .gm-studio-header-left,.gm-studio-wizard.gm-studio-wizard--capabilities-step .gm-studio-header-center{justify-content:flex-start}.gm-studio-wizard.gm-studio-wizard--capabilities-step .gm-studio-header-center{white-space:normal;flex-wrap:wrap}.gm-studio-wizard.gm-studio-wizard--capabilities-step .gm-studio-preview{display:none!important}.gm-studio-wizard.gm-studio-wizard--capabilities-step .gm-capabilities-mobile-summary{margin-top:12px;display:flex;flex-direction:column;gap:8px;padding:12px;border-radius:12px;border:1px solid rgba(124,92,255,.2);background:#7c5cff14}.gm-capabilities-mobile-summary-label{font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--gm-text-soft)}.gm-capabilities-mobile-summary-main{display:flex;flex-direction:column;gap:2px}.gm-capabilities-mobile-summary-main strong{font-size:.84rem;color:var(--gm-text)}.gm-capabilities-mobile-summary-main span{font-size:.7rem;font-weight:700;color:#3db5ff}.gm-capabilities-mobile-summary-includes{margin:0;font-size:.69rem;line-height:1.4;color:var(--gm-text-muted)}.gm-capabilities-mobile-summary-list{display:grid;grid-template-columns:1fr;gap:6px}.gm-capabilities-mobile-summary-item{display:flex;align-items:center;gap:8px;min-width:0}.gm-capabilities-mobile-summary-item-thumb{width:22px;height:22px;border-radius:6px;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid rgba(124,92,255,.3);background:linear-gradient(135deg,#7c5cff,#3db5ff);font-size:.76rem}.gm-capabilities-mobile-summary-item-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.gm-capabilities-mobile-summary-item-text{font-size:.72rem;font-weight:700;color:var(--gm-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.gm-role-card--summary,.gm-badge-medal--summary{cursor:pointer;position:relative;padding-bottom:36px}.gm-role-card--summary.is-editing,.gm-badge-medal--summary.is-editing{box-shadow:0 0 0 2px #7c5cff8c,0 12px 32px #00000059}.gm-role-card-summary-icon,.gm-badge-medal-summary-icon{width:64px;height:64px;border-radius:14px;border:1px solid rgba(124,92,255,.35);background:linear-gradient(135deg,#7c5cff38,#3db5ff24);display:flex;align-items:center;justify-content:center;font-size:2rem;margin:8px auto 10px}.gm-role-card-summary-name,.gm-badge-medal-summary-name{font-size:.92rem;font-weight:800;color:var(--gm-text);text-align:center}.gm-role-card-summary-desc,.gm-badge-medal-summary-desc{margin-top:6px;font-size:.75rem;color:var(--gm-text-muted);text-align:center;line-height:1.4}.gm-role-card-summary-meta,.gm-badge-medal-summary-meta{margin-top:8px;font-size:.68rem;text-align:center;color:var(--gm-text-soft);font-weight:700}.gm-role-card-summary-edit,.gm-badge-medal-summary-edit{position:absolute;left:12px;right:12px;bottom:10px;border-radius:999px;border:1px solid rgba(124,92,255,.45);background:#7c5cff1f;color:#8dc8ff;font-size:.68rem;font-weight:800;padding:6px 8px;text-transform:uppercase;letter-spacing:.05em;text-align:center}.gm-fs-editor-overlay{position:fixed;inset:0;z-index:9200;background:#060a16d1;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.gm-fs-editor-sheet{width:100%;height:100%;background:radial-gradient(circle at 20% 0%,#3e59aa52,#0d1224f5 50%,#090d1e);display:flex;flex-direction:column}.gm-fs-editor-header{min-height:70px;padding:14px 18px;border-bottom:1px solid rgba(124,92,255,.28);display:flex;align-items:center;justify-content:space-between;gap:12px;background:#060a16bf}.gm-fs-editor-header-title-wrap{min-width:0}.gm-fs-editor-eyebrow{display:block;font-size:.66rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gm-text-soft);font-weight:800}.gm-fs-editor-header h3{margin:4px 0 0;font-size:1.05rem;color:var(--gm-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gm-fs-editor-close{border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:var(--gm-text);font-size:.86rem;font-weight:700;padding:8px 12px;cursor:pointer}.gm-fs-editor-close:hover{border-color:#f8717199;background:#f8717124;color:#ffd2d2}.gm-fs-editor-body{flex:1;overflow:auto;padding:22px}.gm-fs-editor-body--single{display:flex;justify-content:center}.gm-fs-editor-panel{width:min(720px,100%);border-radius:16px;border:1px solid rgba(124,92,255,.32);background:#0f162cc7;padding:16px;display:grid;gap:12px}.gm-fs-editor-panel label{display:grid;gap:6px;color:var(--gm-text-soft);font-size:.74rem;font-weight:700;letter-spacing:.03em}.gm-fs-editor-input{border:1px solid rgba(255,255,255,.16);border-radius:10px;background:#070c1ab3;color:var(--gm-text);padding:10px 12px;font-size:.9rem;font-family:inherit}.gm-fs-editor-input:focus{outline:none;border-color:#7c5cffd1;box-shadow:0 0 0 3px #7c5cff33}.gm-fs-editor-input--icon{width:84px;text-align:center;font-size:1.8rem;padding:8px}.gm-fs-editor-textarea{resize:vertical;min-height:102px;line-height:1.45}.gm-fs-editor-check{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;color:var(--gm-text)}@media(max-width:768px){.gm-fs-editor-header{min-height:64px;padding:12px}.gm-fs-editor-close{font-size:.78rem;padding:7px 10px}.gm-fs-editor-body{padding:12px}.gm-fs-editor-panel{border-radius:14px;padding:12px}}.gm-studio-body .gm-studio-preview{margin:0}.gm-paso5-main .gm-cards-grid{display:flex;flex-wrap:wrap;gap:14px;justify-content:flex-start;align-content:flex-start}.gm-paso5-main .gm-cards-grid>.gm-ability-card{width:176px;flex:0 0 176px}.gm-ability-card--has-visual{aspect-ratio:unset;background:transparent;border:none!important;animation:none!important;box-shadow:none!important;overflow:visible;padding:0}.gm-ability-card--has-visual:after{display:none!important}.gm-ability-card--has-visual:hover,.gm-ability-card--has-visual.gm-ability-card--selected{transform:translateY(-2px) scale(1.01)!important;box-shadow:none!important}.gm-ability-card--has-visual.gm-ability-card--selected{outline:2px solid rgba(37,99,235,.72);outline-offset:5px}.gm-ability-card--has-visual .gm-ability-card-renderer{width:auto;justify-content:center;align-items:center;display:flex;overflow:visible}.gm-ability-card--has-visual .gm-ability-card-renderer.cvr-root{overflow:visible}.gm-ability-card--has-visual .gm-ability-card-surface.cvs-card{box-shadow:0 0 0 1px #ffffff14,0 18px 52px #000000b3,0 0 40px #7c6fff26}.gm-ability-card-mini-toprow{position:absolute;top:7px;left:7px;right:7px;z-index:3;display:flex;align-items:center;justify-content:space-between}.gm-ability-card-mini-rarity{font-size:.52rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase;padding:2px 5px;border-radius:4px;color:#f8fafc;background:#0000006b}.gm-ability-card-mini-cost{width:20px;height:20px;border-radius:50%;border:1.4px solid rgba(255,255,255,.34);background:#0000008c;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.68rem;font-weight:900}.gm-ability-card-footer--compact{padding:4px 8px 6px;border-top:none;background:transparent;justify-content:flex-end}@media(max-width:640px){.gm-paso5-main .gm-cards-grid>.gm-ability-card{width:calc(50% - 8px);flex-basis:calc(50% - 8px)}}@media(max-width:420px){.gm-paso5-main .gm-cards-grid>.gm-ability-card{width:100%;flex-basis:100%}}.admin-tools{padding:24px;text-align:left;display:flex;flex-direction:column;gap:16px}.admin-tools-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.admin-tools-header h2{margin:0 0 6px;font-size:1.4rem}.admin-tools-header p{margin:0;color:var(--text-secondary)}.admin-tools-status{font-size:.85rem;color:var(--text-secondary)}.admin-tools-error{background:#e6000014;color:var(--accent-600);border-radius:var(--radius-md);padding:10px 14px;font-size:.9rem}.admin-tools-list{display:grid;gap:14px}.admin-tool-item{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:14px 16px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary)}.admin-tool-name{font-weight:700;margin-bottom:4px}.admin-tool-summary{color:var(--text-secondary);font-size:.9rem}.admin-tool-toggle{border:0;border-radius:999px;padding:8px 16px;font-weight:700;cursor:pointer}.admin-tool-toggle.on{background:#00e63d26;color:var(--success-600)}.admin-tool-toggle.off{background:#e600001f;color:var(--accent-600)}.admin-tool-controls{min-width:320px;display:grid;gap:10px;justify-items:end}.admin-tool-geo{display:grid;gap:6px;width:320px}.admin-tool-label{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em}.admin-tool-select,.admin-tool-input{height:38px;font-size:.9rem}.admin-tool-geo-save{justify-self:end}.admin-tools-empty{text-align:center;color:var(--text-secondary);padding:12px 0}@media(max-width:720px){.admin-tool-item{flex-direction:column;align-items:flex-start}.admin-tool-controls,.admin-tool-geo{width:100%;min-width:0}.admin-tool-toggle{width:100%}.admin-tool-geo-save{width:100%;justify-self:stretch}}.tools-page .page-content{max-width:1200px}.tools-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.tools-card{padding:20px;text-align:left;display:flex;flex-direction:column;gap:16px}.tools-card-link{text-decoration:none;color:inherit;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.tools-card-link:hover{transform:translateY(-2px);border-color:var(--primary-300);box-shadow:var(--shadow-md)}.tools-card-exams{border-color:#7c3aed4d;background:radial-gradient(circle at 10% 18%,rgba(168,85,247,.18),transparent 44%),radial-gradient(circle at 90% 85%,rgba(124,58,237,.12),transparent 40%),var(--bg-card)}.tools-card-lab{border-color:#0f4fb55c;background:radial-gradient(circle at 10% 18%,rgba(131,184,255,.28),transparent 44%),radial-gradient(circle at 92% 12%,rgba(46,138,255,.2),transparent 40%),var(--bg-card)}.tools-lab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:52px;height:26px;border-radius:999px;font-size:.68rem;letter-spacing:.04em;font-weight:900;color:#fff;background:linear-gradient(135deg,#0f4fb5,#2e8aff)}.tools-card.is-locked{opacity:.65}.tools-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.tools-card-title{font-family:var(--font-display);font-size:1.2rem;margin:0 0 6px}.tools-card-subtitle{color:var(--text-secondary);margin:0}.tools-lock{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:var(--bg-secondary);color:var(--text-secondary);flex:0 0 auto}.tools-lock-icon{width:18px;height:18px}.tools-lock.open{background:#00e63d1f;color:var(--success-600)}.tools-lock.closed{background:#e600001f;color:var(--accent-600)}.tools-card-actions{display:flex;gap:12px}.tools-search{padding:24px;text-align:left;display:flex;flex-direction:column;gap:20px}.tools-search-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}.tools-search-title{font-family:var(--font-display);font-size:1.6rem;margin:0 0 8px}.tools-search-subtitle{color:var(--text-secondary);margin:0}.tools-search-actions{display:flex;gap:12px}.tools-search-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.tools-results{width:100%}.tools-results-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.tools-centre-card{padding:20px;display:flex;flex-direction:column;gap:12px;text-align:left}.tools-centre-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.tools-centre-title{font-size:1.1rem;margin:0 0 6px}.tools-centre-location{margin:0;color:var(--text-secondary);font-size:.95rem}.tools-centre-badge{background:var(--primary-50);color:var(--primary-700);font-weight:700;font-size:.75rem;padding:6px 10px;border-radius:999px}.tools-centre-meta{display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));font-size:.9rem}.tools-centre-label{display:block;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:2px}.tools-empty{padding:24px;text-align:center}.tools-empty h3{margin:0 0 8px}@media(max-width:900px){.tools-search-header{flex-direction:column;align-items:stretch}.tools-search-actions,.tools-card-actions,.tools-search-actions .btn,.tools-card-actions .btn{width:100%}}.ai-tools-page{width:100%;max-width:1200px;text-align:left}.page-shell.ai-tools-shell-bg:before{background:linear-gradient(135deg,#0b3f8f,#1e6dd0 38%,#93c3ff)}.page-shell.ai-tools-shell-bg:after{background:radial-gradient(circle at 12% 12%,rgba(14,86,187,.5),transparent 55%),radial-gradient(circle at 88% 18%,rgba(98,168,255,.35),transparent 60%),radial-gradient(circle at 20% 82%,rgba(19,93,196,.25),transparent 55%),radial-gradient(circle at 80% 85%,rgba(255,255,255,.25),transparent 60%)}html[data-theme=dark] .page-shell.ai-tools-shell-bg:before{background:linear-gradient(135deg,#071a33,#0f2f5b 40%,#1d4f87)}html[data-theme=dark] .page-shell.ai-tools-shell-bg:after{background:radial-gradient(circle at 10% 10%,rgba(51,122,214,.35),transparent 55%),radial-gradient(circle at 90% 20%,rgba(129,175,255,.2),transparent 60%),radial-gradient(circle at 20% 85%,rgba(62,137,235,.2),transparent 55%),radial-gradient(circle at 80% 85%,rgba(255,255,255,.08),transparent 60%)}.ai-tools-shell{--ai-50: #eef2ff;--ai-500: #6366f1;--ai-600: #4f46e5;--ai-700: #4338ca;background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;min-height:min(860px,calc(100vh - 180px));overflow:hidden;width:100%}.ai-tools-header{display:grid;grid-template-columns:minmax(240px,1.2fr) minmax(220px,1fr) auto;align-items:center;gap:16px;padding:16px 20px;border-bottom:2px solid var(--border-color);background:linear-gradient(90deg,rgba(99,102,241,.12),transparent 70%)}.ai-tools-header-left{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.ai-tools-avatar{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,var(--ai-500),#8b5cf6);display:inline-flex;align-items:center;justify-content:center;position:relative;box-shadow:0 8px 18px #6366f133;overflow:hidden}.ai-tools-avatar img{width:70%;height:70%;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.ai-tools-avatar-ring{position:absolute;inset:-3px;border-radius:16px;border:2px solid rgba(99,102,241,.4);animation:ai-ring 2.6s ease-in-out infinite}@keyframes ai-ring{0%{transform:scale(.94);opacity:.4}50%{transform:scale(1);opacity:.1}to{transform:scale(.94);opacity:.4}}.ai-tools-header-info{display:flex;flex-direction:column;gap:2px}.ai-tools-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700}.ai-tools-subline{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.7rem;font-weight:700}.ai-tools-status{color:var(--ai-600);display:inline-flex;align-items:center;gap:6px}.ai-tools-status:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--ai-500);box-shadow:0 0 0 6px #6366f126}.ai-tools-dot{width:6px;height:6px;border-radius:50%;background:var(--border-color)}.ai-tools-context{color:var(--text-secondary);font-weight:600}.ai-tools-header-center{display:flex;justify-content:center}.ai-tools-group{display:grid;grid-template-columns:auto minmax(180px,1fr);grid-template-rows:auto auto;align-items:center;gap:6px 10px;font-size:.7rem;color:var(--text-secondary);font-weight:700;padding:10px 12px;border-radius:14px;border:1.5px solid var(--border-color);background:var(--bg-secondary);min-width:min(360px,100%)}.ai-tools-group label{font-weight:700;color:var(--text-secondary)}.ai-tools-group-select{min-width:180px}.ai-tools-group-meta{grid-column:1 / -1;font-weight:700;color:var(--text-secondary)}.ai-tools-header-actions{display:flex;gap:8px}.ai-tools-icon-btn{width:38px;height:38px;border-radius:12px;border:1.5px solid var(--border-color);background:var(--bg-card);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s ease}.ai-tools-icon-btn:hover{border-color:var(--ai-500);color:var(--ai-600);background:var(--ai-50)}.ai-tools-modes{display:flex;gap:6px;padding:8px 16px;border-bottom:2px solid var(--border-color);background:var(--bg-secondary);overflow-x:auto}.ai-tools-modes::-webkit-scrollbar{display:none}.ai-tools-mode{border:none;background:transparent;padding:8px 14px;border-radius:999px;font-weight:700;font-size:.75rem;color:var(--text-secondary);display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:all .2s ease}.ai-tools-mode.active{color:var(--ai-600);background:var(--ai-50);border:1.5px solid rgba(99,102,241,.2)}.ai-tools-body{flex:1;min-height:0;display:flex;flex-direction:column;background:var(--bg-secondary)}.ai-tools-panel{display:none;flex:1;min-height:0}.ai-tools-panel.active{display:flex;flex-direction:column}.ai-panel-scroll{flex:1;overflow-y:auto;padding:18px 20px;display:flex;flex-direction:column;gap:14px}.ai-chat-scroll{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px}.ai-chat-scroll::-webkit-scrollbar,.ai-panel-scroll::-webkit-scrollbar{width:6px}.ai-chat-scroll::-webkit-scrollbar-thumb,.ai-panel-scroll::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:999px}.ai-chat-welcome{text-align:center;padding:24px 10px;display:flex;flex-direction:column;gap:8px}.ai-chat-welcome-icon{width:64px;height:64px;border-radius:20px;background:linear-gradient(135deg,var(--ai-500),#8b5cf6);display:inline-flex;align-items:center;justify-content:center;margin:0 auto;box-shadow:0 12px 24px #6366f133}.ai-chat-welcome-icon img{width:70%;height:70%;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 6px 10px rgba(0,0,0,.18))}.ai-chat-welcome-title{font-family:var(--font-display);font-size:1.1rem}.ai-chat-welcome-sub{color:var(--text-secondary);font-size:.8rem}.ai-chat-chips{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:8px}.ai-chat-chip{border-radius:999px;border:1.5px solid var(--border-color);background:var(--bg-card);padding:6px 12px;font-size:.7rem;font-weight:700;cursor:pointer;transition:all .2s ease}.ai-chat-chip:hover{border-color:var(--ai-500);background:var(--ai-50);color:var(--ai-600)}.ai-chat-msg{display:flex;gap:8px;max-width:88%}.ai-chat-msg.user{align-self:flex-end;flex-direction:row-reverse}.ai-chat-avatar{width:32px;height:32px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;background:var(--ai-50);color:var(--ai-600);flex-shrink:0;overflow:hidden}.ai-chat-avatar img{width:70%;height:70%;-o-object-fit:contain;object-fit:contain}.ai-chat-avatar.user{background:var(--primary-50);color:var(--primary-600)}.ai-chat-bubble{background:var(--bg-card);border:1px solid var(--border-color);padding:10px 14px;border-radius:14px;font-size:.82rem;line-height:1.5;display:flex;flex-direction:column;gap:6px;position:relative}.ai-chat-msg.user .ai-chat-bubble{background:linear-gradient(135deg,var(--ai-500),var(--ai-600));color:#fff;border-color:transparent}.ai-chat-msg.ai .ai-chat-bubble{padding-right:68px}.ai-chat-copy{position:absolute;top:8px;right:10px;border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:999px;padding:3px 10px;font-size:.65rem;font-weight:700;cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.ai-chat-copy:hover{border-color:var(--ai-500);color:var(--ai-600);background:var(--ai-50)}.ai-chat-time{font-size:.6rem;color:var(--text-secondary)}.ai-chat-msg.user .ai-chat-time{color:#ffffffb3}.ai-chat-typing{display:inline-flex;gap:6px;padding:8px 12px}.ai-chat-typing span{width:6px;height:6px;border-radius:50%;background:var(--ai-500);opacity:.4;animation:ai-typing 1.2s infinite}.ai-chat-typing span:nth-child(2){animation-delay:.2s}.ai-chat-typing span:nth-child(3){animation-delay:.4s}@keyframes ai-typing{0%,to{opacity:.4;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}.ai-chat-input{padding:14px 20px;border-top:2px solid var(--border-color);background:var(--bg-secondary);display:flex;flex-direction:column;gap:10px;align-items:stretch}.ai-chat-field{flex:1;min-height:72px;resize:vertical;line-height:1.5}.ai-chat-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.ai-chat-toolbar-group{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;font-weight:700;color:var(--text-secondary)}.ai-chat-select{min-width:120px}.ai-chat-input .btn{align-self:flex-end}.ai-chat-error{margin:0 20px 16px}.ai-insight-card{border-radius:var(--radius-lg);border:2px solid var(--border-color);background:var(--bg-card);padding:16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}.ai-insight-header{display:flex;align-items:flex-start;gap:12px}.ai-insight-icon{width:38px;height:38px;border-radius:12px;background:var(--ai-50);color:var(--ai-600);display:inline-flex;align-items:center;justify-content:center;font-size:1rem}.ai-insight-title{font-weight:700;font-size:.9rem}.ai-insight-desc{font-size:.75rem;color:var(--text-secondary)}.ai-insight-badge{margin-left:auto;font-size:.6rem;font-weight:700;padding:4px 8px;border-radius:999px;background:var(--ai-50);color:var(--ai-600)}.ai-insight-actions{display:flex;gap:8px}.ai-generate-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.ai-generate-card{border-radius:var(--radius-lg);border:2px solid var(--border-color);background:var(--bg-card);padding:14px;text-align:center;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.ai-generate-card:hover{border-color:var(--ai-500);transform:translateY(-2px);box-shadow:var(--shadow-md)}.ai-generate-icon{width:46px;height:46px;border-radius:14px;background:var(--ai-50);color:var(--ai-600);display:inline-flex;align-items:center;justify-content:center;margin:0 auto 8px;font-size:1.2rem}.ai-generate-name{font-weight:700;font-size:.85rem;margin-bottom:4px}.ai-generate-desc{font-size:.65rem;color:var(--text-secondary)}.ai-generator-panel{border-radius:var(--radius-lg);border:2px solid var(--border-color);background:var(--bg-card);padding:16px;display:flex;flex-direction:column;gap:14px}.ai-generator-panel.active{border-color:#6366f166;box-shadow:var(--shadow-md)}.ai-generator-title{font-family:var(--font-display);font-size:1rem}.ai-tools-row{display:flex;gap:16px;flex-wrap:wrap}.ai-tools-field{flex:1 1 240px}.ai-tools-textarea{min-height:140px;resize:vertical}.ai-tools-textarea.small{min-height:90px}.ai-tools-actions{display:flex;gap:10px}.ai-tools-output{padding:14px;border-radius:var(--radius-md);border:2px solid var(--border-color);background:var(--bg-secondary);display:flex;flex-direction:column;gap:12px}.ai-tools-output pre{margin:0;white-space:pre-wrap;font-family:var(--font-sans)}.ai-action-card{border-radius:var(--radius-lg);border:2px solid var(--border-color);background:var(--bg-card);padding:14px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-sm)}.ai-action-icon{width:40px;height:40px;border-radius:12px;background:var(--ai-50);color:var(--ai-600);display:inline-flex;align-items:center;justify-content:center;font-size:1rem}.ai-action-title{font-weight:700;font-size:.85rem}.ai-action-desc{font-size:.7rem;color:var(--text-secondary)}.ai-action-info{flex:1;min-width:0}.ai-action-status{margin-top:6px;font-size:.68rem;font-weight:700;color:var(--text-secondary)}.ai-tools-alert{margin:12px 20px 0}@media(max-width:900px){.ai-tools-header{grid-template-columns:1fr;align-items:flex-start}.ai-tools-header-center{width:100%;justify-content:flex-start}.ai-tools-group{width:100%;min-width:0}.ai-tools-header-actions{width:100%;justify-content:flex-end}.ai-tools-group{flex-wrap:wrap}.ai-tools-group-select{width:100%}.ai-chat-input{flex-direction:column;align-items:stretch}}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1.5px solid var(--border)}.btn-secondary:hover{background:var(--bg-tertiary, var(--bg-secondary));border-color:var(--border-strong, var(--border))}.btn-danger{background:#e600001f;color:var(--accent-600);border:1.5px solid rgba(230,0,0,.3)}.btn-danger:hover{background:#e6000033}.field-label{display:block;font-size:.82rem;font-weight:700;letter-spacing:.03em;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase}.field-input{width:100%;padding:10px 14px;background:var(--bg-secondary);border:1.5px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-base);font-size:.95rem;color:var(--text-primary);outline:none;transition:border-color .18s,box-shadow .18s;box-sizing:border-box}.field-input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #0073e61f}.field-input::-moz-placeholder{color:var(--text-muted, var(--text-secondary));opacity:.6}.field-input::placeholder{color:var(--text-muted, var(--text-secondary));opacity:.6}textarea.field-input{resize:vertical;min-height:80px}select.field-input{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.text-error{color:var(--accent-600);font-size:.9rem;margin:0}.controls-page .page-content{max-width:1100px}.controls-hero-actions{display:flex;gap:12px;flex-wrap:wrap}.controls-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.control-card{padding:20px 22px;display:flex;flex-direction:column;gap:14px;text-align:left;text-decoration:none;color:inherit;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.control-card:hover{transform:translateY(-2px);border-color:var(--primary-300);box-shadow:var(--shadow-md)}.control-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.control-card-title{font-family:var(--font-display);font-size:1.1rem;margin:0 0 4px;line-height:1.3}.control-card-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:.82rem;color:var(--text-secondary)}.control-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:.75rem;font-weight:700;background:var(--bg-secondary);color:var(--text-secondary);white-space:nowrap}.control-badge.stage{background:#0073e61a;color:var(--primary-600)}.control-badge.difficulty-1,.control-badge.difficulty-2{background:#00e63d1a;color:var(--success-600)}.control-badge.difficulty-3{background:#e6a8001a;color:var(--warning-600)}.control-badge.difficulty-4{background:#e600001a;color:var(--accent-600)}.control-badge.difficulty-5{background:#6c00e61f;color:#7c3aed}.control-card-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:8px;border-top:1px solid var(--border-subtle)}.control-card-stats{font-size:.82rem;color:var(--text-secondary)}.control-card-actions{display:flex;gap:8px}.diff-dots{display:flex;gap:3px;align-items:center}.diff-dot{width:8px;height:8px;border-radius:50%;background:var(--border)}.diff-dot.active{background:var(--primary-500)}.controls-empty{grid-column:1 / -1;padding:48px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.controls-empty-icon{font-size:3rem;opacity:.4}.controls-empty h3{margin:0;font-size:1.2rem}.controls-empty p{margin:0;color:var(--text-secondary)}.controls-confirm-overlay{position:fixed;inset:0;z-index:400;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}.controls-confirm-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 32px;max-width:400px;width:100%;box-shadow:var(--shadow-xl)}.controls-confirm-box h3{margin:0 0 10px;font-size:1.1rem}.controls-confirm-box p{margin:0 0 24px;color:var(--text-secondary);font-size:.95rem}.controls-confirm-actions{display:flex;gap:10px;justify-content:flex-end}@media(max-width:640px){.controls-grid{grid-template-columns:1fr}.controls-hero-actions{flex-direction:column}}.editor-page .page-content{max-width:900px}.editor-breadcrumb{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--text-secondary);margin-bottom:8px}.editor-breadcrumb a{color:var(--primary-500);text-decoration:none}.editor-breadcrumb a:hover{text-decoration:underline}.editor-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:24px}.editor-header-info h1{font-size:1.4rem;margin:0 0 4px}.editor-header-info p{margin:0;color:var(--text-secondary);font-size:.9rem}.editor-header-actions{display:flex;gap:10px;flex-wrap:wrap}.q-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.q-item{display:flex;align-items:flex-start;gap:12px;padding:16px 18px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card);transition:border-color .15s}.q-item:hover{border-color:var(--primary-300)}.q-item-number{width:28px;height:28px;border-radius:50%;background:var(--primary-50);color:var(--primary-600);font-size:.82rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex:0 0 auto;margin-top:2px}.q-item-body{flex:1;min-width:0}.q-item-type-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:.72rem;font-weight:800;background:#0073e61a;color:var(--primary-600);margin-bottom:6px}.q-item-question{font-size:.95rem;font-weight:600;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.q-item-meta{font-size:.8rem;color:var(--text-secondary)}.q-item-actions{display:flex;gap:6px;flex:0 0 auto}.q-add-area{display:flex;justify-content:center;padding:16px 0}.q-panel{padding:24px;border:1.5px solid var(--primary-300);border-radius:var(--radius-lg);background:var(--bg-card);box-shadow:var(--shadow-sm);margin-bottom:16px}.q-editor-section{display:flex;flex-direction:column;gap:16px}.q-type-selector{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border-subtle)}.q-type-chip{display:flex;align-items:center;gap:6px;padding:7px 14px;border:1.5px solid var(--border);border-radius:999px;font-size:.82rem;font-weight:700;cursor:pointer;background:var(--bg-card);color:var(--text-secondary);transition:all .15s}.q-type-chip:hover{border-color:var(--primary-300);color:var(--primary-500)}.q-type-chip.active{border-color:var(--primary-500);color:var(--primary-600);background:#0073e614}.q-field-group{display:flex;flex-direction:column;gap:6px}.q-option-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.q-correct-btn{width:32px;height:32px;border-radius:50%;border:2px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);font-size:.82rem;font-weight:800;cursor:pointer;flex:0 0 auto;display:flex;align-items:center;justify-content:center;transition:all .15s}.q-correct-btn.is-correct{border-color:var(--success-500);background:#00e63d1f;color:var(--success-600)}.q-remove-btn{width:28px;height:28px;border-radius:50%;border:none;background:#e600001a;color:var(--accent-600);font-size:1rem;cursor:pointer;flex:0 0 auto;display:flex;align-items:center;justify-content:center;transition:background .15s}.q-remove-btn:hover{background:#e6000033}.q-add-btn{align-self:flex-start;margin-top:4px}.q-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.88rem;color:var(--text-secondary)}.q-toggle input{cursor:pointer}.q-tf-row{display:flex;gap:12px}.q-tf-btn{flex:1;padding:12px;border:2px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card);font-size:1rem;font-weight:700;cursor:pointer;transition:all .15s;color:var(--text-secondary)}.q-tf-btn.is-true{border-color:var(--success-500);background:#00e63d1a;color:var(--success-600)}.q-tf-btn.is-false{border-color:var(--accent-500);background:#e600001a;color:var(--accent-600)}.q-tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;min-height:28px}.q-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;font-size:.82rem;font-weight:600;background:#0073e61a;color:var(--primary-600)}.q-tag button{background:none;border:none;cursor:pointer;color:var(--primary-500);padding:0;font-size:.9rem;line-height:1}.q-order-badge{width:28px;height:28px;border-radius:6px;background:var(--bg-secondary);color:var(--text-secondary);font-size:.82rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.q-move-btn{background:none;border:1px solid var(--border);border-radius:4px;padding:0 4px;cursor:pointer;font-size:.75rem;color:var(--text-secondary);line-height:1.4;transition:background .1s}.q-move-btn:hover:not(:disabled){background:var(--bg-secondary)}.q-move-btn:disabled{opacity:.35;cursor:not-allowed}.q-footer{padding-top:14px;border-top:1px solid var(--border-subtle)}.q-panel-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-subtle)}.q-error{color:var(--accent-600);font-size:.88rem;margin:0}.q-item.is-editing{flex-direction:column;border-color:var(--primary-400)}@media(max-width:640px){.editor-header{flex-direction:column}.editor-header-actions{width:100%}.editor-header-actions .btn{flex:1}.q-type-selector{gap:6px}.q-type-chip{font-size:.75rem;padding:6px 10px}}.student-v2{--sv2-blue-900: #0a3c9a;--sv2-blue-700: #0065d9;--sv2-blue-500: #2f8cff;--sv2-yellow: #ffc935;--sv2-ink: #0f172a;--sv2-slate: #667085;--sv2-border: #d8e2f2;--sv2-card: #ffffff;display:grid;gap:16px;padding-bottom:92px}.student-v2-hero{background:linear-gradient(135deg,var(--sv2-blue-900),var(--sv2-blue-700) 55%,var(--sv2-blue-500));border-radius:22px;color:#fff;padding:18px;box-shadow:0 12px 30px #02246e47}.student-v2-hero-row{display:flex;gap:12px;align-items:center}.student-v2-avatar-wrap{position:relative;width:84px;height:84px;flex-shrink:0}.student-v2-avatar{width:84px;height:84px;border-radius:50%;border:3px solid rgba(255,255,255,.52);background:#ffffff29;display:grid;place-items:center;overflow:hidden;font-size:1.8rem;font-weight:800}.student-v2-avatar img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.student-v2-level-chip{position:absolute;right:-6px;top:-4px;padding:3px 7px;border-radius:999px;background:var(--sv2-yellow);color:#111827;font-size:.68rem;font-weight:900;border:2px solid rgba(255,255,255,.7)}.student-v2-hero-info h1{font-family:Fredoka,"Baloo 2",Nunito,sans-serif;font-size:clamp(1.2rem,4.8vw,1.9rem);line-height:1.05;margin:3px 0 6px}.student-v2-kicker{text-transform:uppercase;letter-spacing:.5px;font-size:.68rem;font-weight:800;opacity:.84}.student-v2-tags{display:flex;flex-wrap:wrap;gap:6px}.student-v2-tags span{border-radius:999px;padding:4px 9px;background:#ffffff2e;font-size:.68rem;font-weight:800}.student-v2-xp{margin-top:14px;padding:11px 12px;border-radius:14px;background:#ffffff1f;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.student-v2-xp-head{display:flex;justify-content:space-between;gap:8px;font-size:.75rem;font-weight:700;margin-bottom:7px}.student-v2-xp-track{height:10px;border-radius:999px;background:#00000042;overflow:hidden}.student-v2-xp-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#ffd54d,#ffb300);transition:width .35s ease-in-out}.student-v2-hero-actions{margin-top:12px;display:flex;gap:8px}.student-v2-btn{border:none;border-radius:12px;padding:10px 12px;font-size:.8rem;font-weight:800;cursor:pointer;transition:transform .15s ease}.student-v2-btn:active{transform:scale(.96)}.student-v2-btn.primary{background:#fff;color:#0f2f85}.student-v2-btn.ghost{background:#ffffff2e;color:#fff}.student-v2-btn.small{padding:8px 10px;font-size:.74rem}.student-v2-stats{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.student-v2-stats article{border-radius:14px;border:1px solid var(--sv2-border);background:var(--sv2-card);box-shadow:0 8px 18px #0f172a12;padding:10px;display:grid;gap:2px}.student-v2-stats .emoji{font-size:1.05rem}.student-v2-stats strong{font-size:1.22rem;font-family:Fredoka,"Baloo 2",Nunito,sans-serif;color:var(--sv2-ink);line-height:1}.student-v2-stats span{color:var(--sv2-slate);font-weight:700;font-size:.7rem}.student-v2-panel{display:grid;gap:10px}.student-v2-card{border-radius:16px;border:1px solid var(--sv2-border);background:var(--sv2-card);padding:14px;box-shadow:0 10px 20px #0f172a12}.student-v2-card.mission{background:linear-gradient(135deg,#7028e4,#9f4dff);color:#fff;border:none}.student-v2-card.mission .student-v2-card-head span{color:#ffed87}.student-v2-card-head{display:flex;justify-content:space-between;gap:10px;margin-bottom:8px}.student-v2-card-head h3{margin:0;font-size:.94rem;font-family:Fredoka,"Baloo 2",Nunito,sans-serif}.student-v2-card-head span{font-size:.75rem;font-weight:800;color:var(--sv2-blue-700)}.student-v2-card p{margin:0 0 10px;line-height:1.35;font-size:.82rem}.student-v2-quick-settings{display:grid;gap:8px}.student-v2-quick-settings button{border:1px solid var(--sv2-border);background:#f8fbff;border-radius:12px;padding:9px 10px;display:flex;align-items:center;gap:7px;font-weight:700;color:var(--sv2-ink);cursor:pointer}.student-v2-quick-settings button.danger{border-color:#f2c7cb;color:#b31b2c}.student-v2-game-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.student-v2-game-card{border-radius:14px;border:1px solid var(--sv2-border);background:var(--sv2-card);padding:12px;display:grid;gap:6px;box-shadow:0 10px 20px #0f172a0f}.student-v2-game-card .emoji{font-size:1.4rem}.student-v2-game-card h3{margin:0;font-size:.9rem;font-family:Fredoka,"Baloo 2",Nunito,sans-serif}.student-v2-game-card p{margin:0;color:var(--sv2-slate);font-size:.74rem}.student-v2-game-card.featured{background:linear-gradient(160deg,#121826,#26334f);border:1px solid rgba(57,75,117,.88)}.student-v2-game-card.featured h3,.student-v2-game-card.featured p{color:#fff}.student-v2-game-card.featured .student-v2-btn{background:#ffd975;color:#1f2937}.student-v2-board-list,.student-v2-schedule,.student-v2-ranking{display:grid;gap:8px}.student-v2-board-item,.student-v2-schedule-item,.student-v2-ranking-item{border-radius:12px;border:1px solid var(--sv2-border);background:var(--sv2-card);padding:11px 12px}.student-v2-board-item .kind{display:inline-flex;padding:3px 7px;border-radius:999px;background:#eff6ff;color:#1e40af;font-size:.66rem;font-weight:800;margin-bottom:6px}.student-v2-board-item h3{margin:0 0 4px;font-size:.88rem}.student-v2-board-item p{margin:0;color:var(--sv2-slate);font-size:.76rem}.student-v2-schedule-item{display:grid;grid-template-columns:72px minmax(0,1fr);gap:8px;align-items:start}.student-v2-schedule-item .hour{font-weight:900;color:#0f2f85;font-size:.78rem}.student-v2-schedule-item h3{margin:0 0 2px;font-size:.84rem}.student-v2-schedule-item p{margin:0;font-size:.75rem;color:var(--sv2-slate)}.student-v2-ranking-item{display:grid;grid-template-columns:52px minmax(0,1fr) auto;gap:8px;align-items:center}.student-v2-ranking-item .pos{font-weight:900;color:#1e3a8a}.student-v2-ranking-item .name{font-weight:700}.student-v2-ranking-item .score{font-weight:800;color:#0f2f85}.student-v2-ranking-item.me{border-color:#9dc3ff;background:#eef5ff}.student-v2-bottom-nav{position:fixed;left:50%;transform:translate(-50%);bottom:10px;width:min(760px,calc(100% - 20px));border-radius:18px;padding:8px;border:1px solid var(--sv2-border);background:#fffffff0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:4px;z-index:50}.student-v2-bottom-nav button{border:none;border-radius:12px;padding:8px 6px;background:transparent;color:#5b6478;display:grid;place-items:center;gap:2px;font-size:.65rem;font-weight:700;cursor:pointer}.student-v2-bottom-nav button.active{background:#eaf2ff;color:#0f2f85}@media(min-width:920px){.student-v2{gap:18px}.student-v2-stats,.student-v2-game-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@font-face{font-family:Super Bubble;src:url(/assets/fonts/all-super-font/SuperBubble-Rpaj3.ttf) format("truetype");font-style:normal;font-weight:400;font-display:swap}@font-face{font-family:Super Foods;src:url(/assets/fonts/all-super-font/SuperFoods-2OxXo.ttf) format("truetype");font-style:normal;font-weight:400;font-display:swap}@font-face{font-family:Super Funnel;src:url(/assets/fonts/all-super-font/SuperFunnel-p7nmD.ttf) format("truetype");font-style:normal;font-weight:400;font-display:swap}@font-face{font-family:Super Milk;src:url(/assets/fonts/all-super-font/SuperMilk-nRq9Y.ttf) format("truetype");font-style:normal;font-weight:400;font-display:swap}:root{--font-sans: "Nunito", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;--font-display: "Fredoka", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;--font-game: "Press Start 2P", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;--font-super-bubble: "Super Bubble", "Fredoka", system-ui, sans-serif;--font-super-foods: "Super Foods", "Fredoka", system-ui, sans-serif;--font-super-funnel: "Super Funnel", "Fredoka", system-ui, sans-serif;--font-super-milk: "Super Milk", "Fredoka", system-ui, sans-serif;--primary-50: #e6f3ff;--primary-100: #b3d9ff;--primary-200: #80bfff;--primary-300: #4da6ff;--primary-400: #1a8cff;--primary-500: #0073e6;--primary-600: #005cb3;--primary-700: #004580;--primary-800: #002e4d;--primary-900: #00171a;--accent-50: #ffe6e6;--accent-100: #ffb3b3;--accent-200: #ff8080;--accent-300: #ff4d4d;--accent-400: #ff1a1a;--accent-500: #e60000;--accent-600: #b30000;--accent-700: #800000;--accent-800: #4d0000;--accent-900: #1a0000;--success-500: #00e63d;--success-600: #00b330;--warning-500: #e6a800;--warning-600: #b38300;--xp-bronze: #cd7f32;--xp-silver: #c0c0c0;--xp-gold: #ffd700;--xp-platinum: #e5e4e2;--xp-diamond: #b9f2ff;--white: #ffffff;--black: #1a1a1a;--gray-100: #f5f5f5;--gray-200: #e5e5e5;--gray-300: #d4d4d4;--gray-400: #a3a3a3;--gray-500: #737373;--gray-600: #525252;--gray-700: #404040;--gray-800: #262626;--bg-primary: var(--white);--bg-secondary: var(--gray-100);--bg-card: var(--white);--text-primary: var(--black);--text-secondary: var(--gray-600);--border-color: var(--gray-200);--radius-sm: 10px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px rgba(0,0,0,.1);--shadow-lg: 0 10px 15px rgba(0,0,0,.1);--shadow-xl: 0 18px 50px rgba(0,0,0,.18);--shadow-game: 0 6px 0 rgba(0,0,0,.2);--container-max: 1100px}html[data-theme=dark]{--bg-primary: #0b1220;--bg-secondary: #0f1a2f;--bg-card: #121f38;--text-primary: #f5f7ff;--text-secondary: rgba(245, 247, 255, .72);--border-color: rgba(255,255,255,.1)}*{box-sizing:border-box}html,body{height:100%}html{overflow-x:hidden}body{overflow-x:hidden;margin:0;font-family:var(--font-sans);background:var(--bg-secondary);color:var(--text-primary)}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}.container{width:min(var(--container-max),calc(100% - 32px));margin:0 auto}.bg-game{background:radial-gradient(circle at top,var(--primary-50),var(--bg-secondary) 55%,var(--bg-secondary))}.text-dark-900{color:var(--text-primary)}.text-dark-400,.text-muted{color:var(--text-secondary)}.text-primary{color:var(--primary-500)}.text-accent{color:var(--accent-500)}.text-success{color:var(--success-500)}.text-warning{color:var(--warning-500)}.font-display{font-family:var(--font-display)}.font-game{font-family:var(--font-game)}.font-super-bubble{font-family:var(--font-super-bubble)}.font-super-foods{font-family:var(--font-super-foods)}.font-super-funnel{font-family:var(--font-super-funnel)}.font-super-milk{font-family:var(--font-super-milk)}@media(prefers-reduced-motion:no-preference){*{scroll-behavior:smooth}}.bb-bg-game{background:radial-gradient(900px 500px at 15% 15%,rgba(47,107,255,.2),transparent 60%),radial-gradient(700px 450px at 85% 25%,rgba(255,59,107,.12),transparent 55%),radial-gradient(900px 600px at 40% 90%,rgba(32,201,151,.1),transparent 60%),var(--bb-bg)}.bg-game{background:var(--bb-bg)}.bg-game.bb-bg-game{background:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius-md);border:none;text-decoration:none;font-weight:700;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:all .2s ease}.btn:active{transform:translateY(2px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-sm{padding:8px 16px;font-size:.875rem}.btn-lg{padding:16px 32px;font-size:1.125rem}.btn-xl{padding:20px 40px;font-size:1.25rem;border-radius:var(--radius-lg)}.btn-primary{color:#fff;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));box-shadow:0 4px 0 var(--primary-700)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 0 var(--primary-700)}.btn-primary:active{transform:translateY(2px);box-shadow:0 2px 0 var(--primary-700)}.btn-accent{color:#fff;background:linear-gradient(135deg,var(--accent-500),var(--accent-600));box-shadow:0 4px 0 var(--accent-700)}.btn-accent:hover{transform:translateY(-2px);box-shadow:0 6px 0 var(--accent-700)}.btn-accent:active{transform:translateY(2px);box-shadow:0 2px 0 var(--accent-700)}.btn-success{color:#fff;background:linear-gradient(135deg,#00ff4d,var(--success-500));box-shadow:0 4px #008f26}.btn-success:hover{transform:translateY(-2px);box-shadow:0 6px #008f26}.btn-success:active{transform:translateY(2px);box-shadow:0 2px #008f26}.btn-warning{color:#fff;background:linear-gradient(135deg,#ffc800,var(--warning-500));box-shadow:0 4px #8a6500}.btn-warning:hover{transform:translateY(-2px);box-shadow:0 6px #8a6500}.btn-warning:active{transform:translateY(2px);box-shadow:0 2px #8a6500}.btn-outline{background:transparent;color:var(--primary-500);border:3px solid var(--primary-500);box-shadow:none}.btn-outline:hover{background:var(--primary-500);color:#fff}.btn-ghost{background:transparent;color:var(--text-primary);border:none}.btn-ghost:hover{background:var(--bg-secondary)}.btn-game{font-family:var(--font-display);font-size:1.25rem;padding:16px 32px;border-radius:var(--radius-lg);text-transform:uppercase;letter-spacing:1px;position:relative;overflow:hidden}.btn-game:after{content:"";position:absolute;top:0;left:-120%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);transition:left .5s ease}.btn-game:hover:after{left:120%}.btn-icon{width:44px;height:44px;padding:0;border-radius:50%}.app-navbar{position:fixed;top:0;left:0;right:0;z-index:100;background:transparent;border-bottom:1px solid transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;--landing-nav-height: 54px;transition:background .25s ease,border-color .25s ease,box-shadow .25s ease,backdrop-filter .25s ease}.app-navbar.at-top{background:transparent;border-bottom:1px solid transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.app-navbar.is-scrolled{background:#ffffffc7;border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}html[data-theme=dark] .app-navbar{background:transparent;border-bottom:1px solid transparent;box-shadow:none}html[data-theme=dark] .app-navbar.at-top{background:transparent;border-bottom:1px solid transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}html[data-theme=dark] .app-navbar.is-scrolled{background:#0c1220c7;border-bottom:1px solid rgba(255,255,255,.08)}.app-navbar.at-top .app-navbar-link,.app-navbar.at-top .app-navbar-compact-title{color:#fff}.app-navbar.at-top .app-navbar-link-icon{color:#ffffffe6}.app-navbar.at-top .app-navbar-link:hover,.app-navbar.at-top .app-navbar-link.active{color:#fff}.app-navbar.at-top .app-navbar-link:hover{opacity:.85}.app-navbar-inner{height:var(--landing-nav-height, 64px);width:100%;max-width:none;margin:0;padding:0 24px 0 14px;display:flex;align-items:center;justify-content:flex-start;gap:16px}.app-navbar-brand{display:flex;align-items:center;gap:12px}.app-navbar-logo{height:62px;width:auto;display:block;-o-object-fit:contain;object-fit:contain;transform:translateY(8px);max-height:62px}.app-navbar-logo-budychess{height:40px;max-height:40px;transform:translateY(0)}.app-navbar-menu{display:flex;align-items:center;gap:12px;font-size:.9rem;margin-left:auto}.app-mobile-menu{position:relative;display:none;z-index:170}.app-mobile-menu-trigger{width:44px;height:44px;border-radius:10px;border:none;background:transparent;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:0;cursor:pointer;transition:background .2s ease}.app-mobile-menu-trigger:hover{background:#ffffff1a}.app-mobile-menu-trigger-bar{display:block;width:22px;height:2px;border-radius:999px;background:#fff;transition:transform .3s ease,opacity .3s ease,background .3s ease}.app-mobile-menu-trigger.open .app-mobile-menu-trigger-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}.app-mobile-menu-trigger.open .app-mobile-menu-trigger-bar:nth-child(2){opacity:0;transform:scaleX(0)}.app-mobile-menu-trigger.open .app-mobile-menu-trigger-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.app-navbar.is-scrolled .app-mobile-menu-trigger{background:#fff3}.app-navbar.is-scrolled .app-mobile-menu-trigger:hover{background:#ffffff59}.app-navbar.is-scrolled .app-mobile-menu-trigger-bar{background:#334155}html[data-theme=dark] .app-navbar.is-scrolled .app-mobile-menu-trigger{background:#0f172a59}html[data-theme=dark] .app-navbar.is-scrolled .app-mobile-menu-trigger:hover{background:#0f172a8c}html[data-theme=dark] .app-navbar.is-scrolled .app-mobile-menu-trigger-bar{background:#ffffffeb}.app-mobile-menu-backdrop{position:fixed;inset:var(--landing-nav-height, 64px) 0 0;border:none;background:#07122873;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:165}.app-mobile-menu-drawer{position:fixed;top:var(--landing-nav-height, 64px);left:0;right:0;padding:18px 14px 22px;background:#08162ef5;border-top:1px solid rgba(255,255,255,.14);box-shadow:0 18px 44px #00000061;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:175;transform:translateY(-112%);opacity:0;pointer-events:none;transition:transform .28s ease,opacity .28s ease}.app-mobile-menu-drawer.open{transform:translateY(0);opacity:1;pointer-events:auto}.app-mobile-menu-links{display:flex;flex-direction:column;gap:4px}.app-mobile-menu-links .app-navbar-link{width:100%;border-radius:12px;padding:12px 14px;color:#ffffffeb;font-size:1rem;font-weight:700}.app-mobile-menu-links .app-navbar-link-icon{color:#ffffffe0}.app-mobile-menu-links .app-navbar-link:hover,.app-mobile-menu-links .app-navbar-link.active{background:#ffffff29;color:#fff}.app-navbar.is-scrolled .app-mobile-menu-drawer{background:#fffffff2;border-top-color:#0f172a1a;box-shadow:0 18px 38px #0f172a26}.app-navbar.is-scrolled .app-mobile-menu-links .app-navbar-link{color:#1f2937}.app-navbar.is-scrolled .app-mobile-menu-links .app-navbar-link-icon{color:#475569}.app-navbar.is-scrolled .app-mobile-menu-links .app-navbar-link:hover,.app-navbar.is-scrolled .app-mobile-menu-links .app-navbar-link.active{background:#0073e61a;color:var(--primary-600)}html[data-theme=dark] .app-navbar.is-scrolled .app-mobile-menu-backdrop{background:#02081285}html[data-theme=dark] .app-navbar.is-scrolled .app-mobile-menu-drawer{background:#0a1428f5;border-top-color:#94a3b842;box-shadow:0 20px 44px #00000080}html[data-theme=dark] .app-navbar.is-scrolled .app-mobile-menu-links .app-navbar-link{color:#e8f1ff}html[data-theme=dark] .app-navbar.is-scrolled .app-mobile-menu-links .app-navbar-link-icon{color:#9bc1ff}html[data-theme=dark] .app-navbar.is-scrolled .app-mobile-menu-links .app-navbar-link:hover,html[data-theme=dark] .app-navbar.is-scrolled .app-mobile-menu-links .app-navbar-link.active{background:#4da6ff3d;color:#fff}.app-navbar-link{display:inline-flex;align-items:center;gap:7px;color:var(--text-primary);font-weight:600;text-decoration:none;transition:color .2s ease;line-height:1}.app-navbar-link-icon,.app-icon{flex:0 0 auto;width:16px;height:16px}.app-navbar-link:hover,.app-navbar-link.active{color:var(--primary-600)}.app-navbar-select{padding:8px 10px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-weight:600}.app-navbar-select:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 2px #1a8cff38}.app-navbar-select option{color:#0f172a;background:#fff}html[data-theme=dark] .app-navbar-select{background:#162a4a;color:#f5f7ff;border-color:#fff3}html[data-theme=dark] .app-navbar-select option{color:#f5f7ff;background:#162a4a}.app-navbar-actions{display:flex;align-items:center;gap:12px}.app-navbar-budychess-group-wrap{display:inline-flex;align-items:center;min-width:150px}.app-navbar-budychess-controls{display:inline-flex;align-items:center;gap:8px}.app-navbar-budychess-tabs{display:inline-flex;align-items:center;gap:6px}.app-navbar-budychess-tab{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(120,173,241,.5);background:#0e1d2f73;color:#e6f0ff;border-radius:999px;font-size:.74rem;font-weight:800;line-height:1;padding:6px 10px;transition:all .16s ease}.app-navbar-budychess-tab-icon{width:13px;height:13px;flex:0 0 auto}.app-navbar-budychess-tab:hover{border-color:#8ec0ffe0;color:#fff}.app-navbar-budychess-tab.active{border-color:#8ec0fff2;background:#477ab86b;color:#fff}.app-navbar-budychess-group-label{font-size:.68rem;font-weight:800;line-height:1;color:var(--text-secondary);text-align:left}.app-navbar-budychess-group-select{min-height:32px;padding:6px 28px 6px 10px}.app-navbar.at-top .app-navbar-budychess-group-label{color:#ffffffdb}.app-navbar.app-navbar-budychess .app-navbar-budychess-group-wrap{min-width:136px}.app-navbar.app-navbar-budychess .app-navbar-budychess-tab{padding:5px 9px;font-size:.72rem}.app-navbar.app-navbar-budychess .app-navbar-budychess-controls{max-width:62vw;overflow-x:auto;scrollbar-width:none}.app-navbar.app-navbar-budychess .app-navbar-budychess-controls::-webkit-scrollbar{display:none}.app-navbar-compact .app-navbar-inner{padding:0 14px;gap:10px}.app-navbar.app-navbar-budychess{--landing-nav-height: 44px}.app-navbar.app-navbar-budychess.at-top{background:transparent;border-bottom:1px solid transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.app-navbar.app-navbar-budychess.is-scrolled{background:#1a2a3ce0;border-bottom:1px solid rgba(176,199,228,.22);box-shadow:0 2px 16px #00000047;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-navbar.app-navbar-budychess .app-navbar-inner{height:44px;padding:0 10px;gap:8px}.app-navbar.app-navbar-budychess .app-navbar-brand{gap:0}.app-navbar.app-navbar-budychess .app-compact-menu{align-self:flex-start;margin-left:10px}.app-navbar.app-navbar-budychess .app-compact-menu-dropdown{margin-top:0}.app-navbar.app-navbar-budychess .app-compact-menu-trigger{width:72px;height:72px;align-self:flex-start;margin-top:5px;transform:none;border-radius:8px;overflow:visible;padding:0}.app-navbar.app-navbar-budychess .app-compact-menu-trigger img{width:72px;height:72px;max-width:none;max-height:none;transform:none}.app-navbar.app-navbar-budychess .app-navbar-logo-budychess{height:72px;max-height:72px}.app-navbar.app-navbar-budychess.app-navbar-compact .app-compact-menu-trigger{width:72px;height:72px;align-self:flex-start;margin-top:5px;transform:none;border-radius:8px;overflow:visible;padding:0}.app-navbar.app-navbar-budychess.app-navbar-compact .app-compact-menu-trigger img{width:72px;height:72px;transform:none}.app-navbar.app-navbar-budychess.app-navbar-compact .app-navbar-brand{margin-right:6px}.app-navbar.app-navbar-budychess .app-navbar-compact-title.is-budychess{display:none}.app-navbar.app-navbar-budychess .app-navbar-compact-title{font-size:.96rem;gap:8px}.app-navbar.app-navbar-budychess .app-navbar-compact-date{font-size:1rem}.app-navbar.app-navbar-budychess .app-navbar-actions{gap:6px}.app-navbar.app-navbar-budychess .app-tool-btn{width:34px;height:34px}.app-navbar.app-navbar-budychess .app-avatar-btn{width:36px;height:36px;border-width:2px}.app-compact-menu-backdrop{position:fixed;inset:var(--landing-nav-height, 64px) 0 0;border:none;background:#08142d38;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:140;cursor:default}.app-compact-menu{z-index:150}.app-navbar-compact .app-compact-menu{margin-left:-8px}.app-compact-menu-trigger{width:100px;height:100px;border-radius:12px;border:none;background:transparent;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform .18s ease}.app-compact-menu-trigger img{width:74px;height:74px;-o-object-fit:contain;object-fit:contain}.app-compact-menu.open .app-compact-menu-trigger{transform:translateY(6px) scale(1.02)}.app-compact-menu-trigger{transform:translateY(10px)}.app-navbar-compact-title{text-decoration:none;color:var(--text-primary);font-family:var(--font-display);font-size:1.1rem;font-weight:700;display:none;flex-direction:row;align-items:center;gap:10px;line-height:1.1;white-space:nowrap}@media(orientation:landscape){.app-navbar-compact-title{display:flex}}.app-navbar-compact-weather{width:34px;height:34px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:var(--primary-50);color:var(--primary-600);box-shadow:inset 0 1px #ffffffbf}.app-navbar-weather-icon{width:20px;height:20px}.app-navbar-compact-date{font-family:var(--font-display);font-size:1.2rem}.app-navbar-compact-time{font-size:1.1rem;font-weight:700;opacity:.8}.app-navbar-compact-temp{font-size:1rem;font-weight:700;opacity:.9}.app-navbar-compact-temps{font-size:1rem;font-weight:700;opacity:.85;letter-spacing:.01em}.app-navbar.at-top .app-navbar-compact-temps{color:#fff}.app-navbar.at-top .app-navbar-compact-weather{background:#ffffff2e;color:#fff;box-shadow:none}html[data-theme=dark] .app-navbar.is-scrolled .app-navbar-compact-weather{background:#4da6ff33;color:#cfe3ff}.app-compact-menu-dropdown{min-width:250px;width:min(320px,calc(100vw - 20px));left:0;right:auto;margin-top:10px;border-color:var(--primary-200);box-shadow:0 16px 38px #002a673d;transform-origin:top left;z-index:160}.app-compact-menu.open .app-compact-menu-dropdown{animation:app-compact-menu-in .2s ease}@keyframes app-compact-menu-in{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(8px) scale(1)}}.app-compact-menu-links{display:flex;flex-direction:column;gap:2px}.app-compact-menu-links .app-navbar-link{width:100%;border-radius:10px;padding:9px 10px;color:var(--text-primary);font-weight:700}.app-compact-menu-links .app-navbar-link:hover,.app-compact-menu-links .app-navbar-link.active{background:var(--primary-50)}.app-navbar.at-top .app-compact-menu-dropdown{background:#0c1a36eb;border-color:#ffffff29;box-shadow:0 18px 44px #00000059;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-navbar.at-top .app-compact-menu-links .app-navbar-link{color:#fff}.app-navbar.at-top .app-compact-menu-links .app-navbar-link-icon{color:#ffffffd9}.app-navbar.at-top .app-compact-menu-links .app-navbar-link:hover,.app-navbar.at-top .app-compact-menu-links .app-navbar-link.active{background:#ffffff29;color:#fff}.app-navbar.at-top .app-compact-menu-backdrop{background:#07122873;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}html[data-theme=dark] .app-compact-menu-dropdown{background:#0f1f3d;border-color:#80b0f970;box-shadow:0 18px 42px #0000008f}html[data-theme=dark] .app-compact-menu-links .app-navbar-link{color:#e8f1ff}html[data-theme=dark] .app-compact-menu-links .app-navbar-link-icon{color:#9bc1ff}html[data-theme=dark] .app-compact-menu-links .app-navbar-link:hover{background:#4da6ff38;color:#fff}html[data-theme=dark] .app-compact-menu-links .app-navbar-link.active{background:#4da6ff4d;color:#fff}.app-navbar-compact .app-navbar-actions{margin-left:auto;flex:1 1 auto;min-width:0;justify-content:flex-end;gap:8px;position:relative;z-index:150}.app-navbar-compact .app-tool-btn{width:36px;height:36px}.app-group-tools-btn{width:38px;height:38px;flex:0 0 auto;border-radius:50%;border:1px solid #b7c9ea;background:linear-gradient(180deg,#f8fbff,#e7f0ff);color:var(--primary-600);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:inset 0 1px #fffc,0 2px 8px #00419126;transition:all .2s ease,box-shadow .2s ease}.app-group-tools-btn:hover{transform:translateY(-1px);border-color:var(--primary-500);background:linear-gradient(180deg,#fff,#dce9ff);box-shadow:inset 0 1px #fffffff2,0 6px 14px #00419138}.app-group-quick-actions{display:inline-flex;align-items:center;gap:6px;max-width:min(70vw,420px);min-width:0;overflow:visible;padding:2px 0 3px;scrollbar-width:none}.app-group-quick-actions::-webkit-scrollbar{display:none}.app-group-quick-popover{position:relative;display:inline-flex;align-items:center}.app-group-quick-popover-menu{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(-4px);display:inline-flex;align-items:center;gap:6px;padding:6px 8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:210}.app-group-quick-popover-menu.open{opacity:1;pointer-events:auto;transform:translate(-50%) translateY(0)}.app-group-quick-popover-menu.floating{position:fixed;left:var(--popover-left, 50%);top:var(--popover-top, 72px);transform:translate(-50%) translateY(0);opacity:1;pointer-events:auto;z-index:980}.app-group-quick-popover-item{width:28px;height:28px;border-radius:9px;border:1px solid #b7c9ea;background:linear-gradient(180deg,#f8fbff,#e7f0ff);color:var(--primary-700);font-size:.8rem;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform .15s ease,border-color .15s ease}.app-group-quick-popover-item:hover{transform:translateY(-1px);border-color:var(--primary-500)}.app-group-quick-popover-item:disabled{opacity:.45;cursor:not-allowed;transform:none;border-color:#b7c9ea}html[data-theme=dark] .app-group-quick-popover-menu{background:#101827;border-color:#223154;box-shadow:0 10px 22px #00000059}html[data-theme=dark] .app-group-quick-popover-item{background:linear-gradient(180deg,#1a253b,#0f1a2c);border-color:#2c3b5e;color:#d7e5ff}.app-group-quick-btn{width:34px;height:34px;flex:0 0 auto;border-radius:50%;border:1px solid #b7c9ea;background:linear-gradient(180deg,#f8fbff,#e7f0ff);color:var(--primary-600);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:inset 0 1px #ffffffd1,0 2px 8px #0041911f;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.app-group-quick-btn:hover{transform:translateY(-1px);border-color:var(--primary-500);box-shadow:inset 0 1px #fffffff2,0 6px 14px #00419133}.app-group-quick-btn.active{background:linear-gradient(180deg,#e4f1ff,#cfe4ff);border-color:var(--primary-500);color:var(--primary-700)}.app-group-quick-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:inset 0 1px #ffffffd1,0 2px 8px #00419114}.app-group-quick-btn:disabled:hover{transform:none;border-color:#b7c9ea}.app-navbar-compact .app-avatar-btn{width:38px;height:38px}@media(max-width:520px){.app-compact-menu-dropdown{width:min(320px,calc(100vw - 12px));left:0}.app-navbar-compact-title{display:none}.app-compact-menu-trigger{width:78px;height:78px}.app-compact-menu-trigger img{width:56px;height:56px}.app-group-quick-actions{max-width:min(74vw,320px)}}.app-tool-btn{width:40px;height:40px;border-radius:50%;border:1px solid #b7c9ea;background:linear-gradient(180deg,#f8fbff,#e7f0ff);color:var(--primary-600);display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer;box-shadow:inset 0 1px #fffc,0 2px 8px #00419126;transition:all .2s ease,box-shadow .2s ease}.app-tool-btn:hover{transform:translateY(-1px);border-color:var(--primary-500);background:linear-gradient(180deg,#fff,#dce9ff);box-shadow:inset 0 1px #fffffff2,0 6px 14px #00419138}.app-tool-btn-icon{width:18px;height:18px}.app-avatar-btn{width:42px;height:42px;border-radius:50%;border:3px solid var(--bg-card);background:linear-gradient(135deg,var(--primary-400),var(--primary-600));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;cursor:pointer;box-shadow:var(--shadow-md);overflow:hidden}.app-avatar-btn img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.app-dropdown{position:relative}.app-dropdown-menu{position:absolute;top:100%;right:0;min-width:220px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:14px;box-shadow:var(--shadow-lg);padding:8px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease;z-index:200}.app-dropdown-menu .app-navbar-select{width:100%}.app-dropdown.open .app-dropdown-menu{opacity:1;visibility:visible;transform:translateY(8px)}.app-dropdown-header{padding:10px 12px;border-bottom:2px dashed var(--border-color);margin-bottom:6px}.app-dropdown-title{font-weight:700;font-size:.95rem}.app-dropdown-subtitle{font-size:.8rem;color:var(--text-secondary)}.app-dropdown-item{width:100%;text-align:left;padding:10px 12px;border-radius:10px;background:transparent;border:none;color:var(--text-primary);font-weight:600;cursor:pointer;display:flex;align-items:center;gap:10px;text-decoration:none;transition:background .2s ease,color .2s ease}.app-dropdown-item:hover{background:var(--primary-50);color:var(--primary-600)}.app-dropdown-icon{width:16px;height:16px;flex:0 0 auto}.app-dropdown-divider{height:2px;background:var(--border-color);margin:6px 8px}.chess-notif-wrap .app-dropdown-menu{width:min(360px,calc(100vw - 20px));min-width:320px;max-height:min(72vh,560px);overflow:hidden;display:grid;grid-template-rows:auto 1fr}.chess-notif-btn{position:relative}.chess-notif-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;border-radius:999px;border:2px solid var(--bg-card);background:var(--accent-500);color:#fff;padding:0 4px;display:inline-flex;align-items:center;justify-content:center;font-size:.66rem;font-weight:800;line-height:1}.chess-notif-menu{padding:0}.chess-notif-header{padding:10px 12px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:8px}.chess-notif-header strong{font-size:.85rem;font-weight:800}.chess-notif-header span{font-size:.75rem;font-weight:700;color:var(--text-secondary)}.chess-notif-empty{padding:14px 12px;color:var(--text-secondary);font-size:.8rem}.chess-push-strip{padding:8px 12px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.72rem;color:var(--text-secondary)}.chess-push-btn{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:8px;padding:5px 8px;font-size:.7rem;font-weight:700;cursor:pointer}.chess-push-btn:hover{border-color:var(--primary-500);color:var(--primary-600)}.chess-notif-list{padding:8px;display:grid;gap:8px;align-content:start;overflow:auto}.chess-notif-item{border:1px solid var(--border-color);border-radius:10px;background:var(--bg-secondary);padding:8px;display:grid;gap:8px}.chess-notif-main{display:grid;gap:4px}.chess-notif-title{display:flex;align-items:center;justify-content:space-between;gap:8px}.chess-notif-title strong{font-size:.82rem;font-weight:800}.chess-notif-title span{font-size:.7rem;font-weight:800;color:var(--primary-600)}.chess-notif-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.72rem;color:var(--text-secondary)}.chess-notif-message{margin:0;font-size:.76rem;line-height:1.35;color:var(--text-secondary)}.chess-notif-general.is-read{opacity:.82}.chess-notif-general.is-warning{border-color:#ffc1076b}.chess-notif-general.is-error{border-color:#e74c3c6b}.chess-notif-general.is-success{border-color:#27ae606b}.chess-notif-level{display:inline-flex;align-items:center;padding:2px 7px;border-radius:999px;font-size:.66rem;font-weight:700;letter-spacing:.01em;background:#64748b29;color:var(--text-secondary)}.chess-notif-level.is-success{background:#27ae6029;color:#1f8b4d}.chess-notif-level.is-warning{background:#ffc10729;color:#9a6a00}.chess-notif-level.is-error{background:#e74c3c29;color:#b53a2a}.chess-notif-actions{display:flex;align-items:center;justify-content:flex-end;gap:6px}.chess-notif-action{width:28px;height:28px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.chess-notif-action svg{width:14px;height:14px}.chess-notif-action.is-accept{color:var(--success-500)}.chess-notif-action.is-decline{color:var(--accent-500)}.chess-invite-toast-stack{position:fixed;left:14px;bottom:14px;z-index:420;display:grid;gap:10px;width:min(360px,calc(100vw - 28px));pointer-events:none}.chess-active-match-banner{position:fixed;top:calc(var(--landing-nav-height, 54px) + 10px);right:14px;z-index:425;width:min(360px,calc(100vw - 28px));border:1px solid rgba(120,173,241,.44);border-radius:14px;background:#142337eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-lg);padding:10px 12px;display:grid;gap:10px;pointer-events:auto}.chess-active-match-body{display:grid;gap:3px}.chess-active-match-body strong{font-size:.86rem;font-weight:800;color:var(--text-primary)}.chess-active-match-body span{font-size:.76rem;color:var(--text-secondary)}.chess-active-match-open{justify-self:end}@media(max-width:640px){.chess-active-match-banner{right:10px;left:10px;width:auto}}@media(max-width:768px){.app-navbar-inner{padding:0 16px;gap:8px}.app-navbar-brand{margin-right:auto}.app-mobile-menu{display:inline-flex;align-items:center}.app-navbar-menu{display:none}.app-navbar-actions{margin-left:0;gap:6px}.app-navbar-logo{height:44px;transform:translateY(2px)}}@media(min-width:769px){.app-mobile-menu-backdrop,.app-mobile-menu-drawer{display:none!important}}@media(max-width:480px){.app-navbar-inner{padding:0 12px;gap:6px}.app-navbar-menu{gap:4px}.app-navbar-logo{height:38px;transform:translateY(1px)}.app-tool-btn,.app-avatar-btn{width:36px;height:36px}}@media(max-width:400px){.app-dropdown-menu{right:-8px;min-width:min(220px,calc(100vw - 24px))}}.chess-invite-toast{pointer-events:auto;border:1px solid var(--border-color);border-radius:14px;background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-lg);padding:12px;display:grid;gap:8px}.chess-invite-toast-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.chess-invite-toast-head strong{font-size:.9rem;font-weight:800}.chess-invite-toast-time{font-size:.75rem;font-weight:800;color:var(--warning-500)}.chess-invite-toast-text{margin:0;color:var(--text-secondary);font-size:.8rem;line-height:1.35}.chess-invite-toast-actions{display:flex;align-items:center;gap:8px}.chess-invite-toast-actions .btn{flex:0 0 auto;min-width:0}.chess-invite-toast-dismiss{margin-left:auto;width:30px;height:30px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);font-size:1rem;line-height:1;cursor:pointer}.app-shell{background:var(--bg-card);--landing-nav-height: 54px}.app-shell.app-shell-budychess{--landing-nav-height: 44px}.app-main{padding-top:calc(var(--landing-nav-height, 64px) + 24px);padding-bottom:40px}.app-main.app-main-budychess{padding-top:calc(var(--landing-nav-height, 64px) + 6px);padding-bottom:0}.page-shell{position:relative;isolation:isolate;display:flex;flex-direction:column;gap:0}.page-shell:before{content:"";position:fixed;inset:0;background:var(--bg-primary);z-index:-2}.page-shell:after{content:"";position:fixed;inset:-20% -10%;background:radial-gradient(circle at 10% 10%,rgba(0,115,230,.12),transparent 55%),radial-gradient(circle at 90% 20%,rgba(230,0,0,.08),transparent 60%),radial-gradient(circle at 20% 80%,rgba(0,115,230,.1),transparent 55%),radial-gradient(circle at 80% 90%,rgba(255,215,0,.08),transparent 60%);opacity:.8;animation:page-bg 18s ease-in-out infinite;z-index:-1;pointer-events:none}@keyframes page-bg{0%{transform:translateZ(0) scale(1)}50%{transform:translate3d(0,-2%,0) scale(1.03)}to{transform:translateZ(0) scale(1)}}.page-hero{position:relative;overflow:hidden;border-radius:0;padding:calc(26px + var(--landing-nav-height, 64px)) 32px 26px;color:#fff;background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-700) 100%);box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-top:calc(-1 * (var(--landing-nav-height, 64px) + 24px))}.page-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top,rgba(255,255,255,.28),transparent 60%);opacity:.7}.page-hero:after{content:"";position:absolute;top:-120px;right:-140px;width:240px;height:240px;border-radius:50%;background:#ffffff26}.page-hero-inner{position:relative;z-index:1;max-width:640px}.page-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border-radius:999px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-weight:700;font-size:.85rem;margin-bottom:12px}.page-title{font-family:var(--font-display);font-size:2.2rem;font-weight:700;line-height:1.1;margin-bottom:8px}.page-subtitle{font-size:1.05rem;opacity:.9}.page-hero-actions{position:relative;z-index:1}.page-content{width:100%;max-width:920px;margin:0 auto;padding:24px 20px 56px;display:flex;flex-direction:column;gap:20px;text-align:center}.page-stack{display:flex;flex-direction:column;gap:20px}.page-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));justify-items:center}.page-empty{width:100%;max-width:520px;margin:0 auto;text-align:center}@media(max-width:768px){.app-navbar-inner{padding:0 16px}.app-navbar-logo{height:48px}.page-hero{padding:calc(22px + var(--landing-nav-height, 64px)) 18px 22px}.page-title{font-size:1.9rem}.page-content{padding:22px 16px 48px}}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:2px solid var(--border-color);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.card-elevated{box-shadow:var(--shadow-md)}.card-header{padding:20px 24px;border-bottom:2px solid var(--border-color);font-family:var(--font-display);font-weight:600;font-size:1.15rem}.card-body{padding:24px}.card-footer{padding:16px 24px;border-top:2px solid var(--border-color);background:var(--bg-secondary)}.card-game{border:3px solid var(--primary-500);box-shadow:0 6px 0 var(--primary-600)}.card-game:hover{transform:translateY(-6px);box-shadow:0 12px 0 var(--primary-600)}.form-group{margin-bottom:20px}.form-label{display:block;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.input{width:100%;padding:12px 16px;font-size:1rem;border:2px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-primary);transition:all .2s ease}.input-sm{padding:8px 12px;font-size:.875rem;border-radius:var(--radius-sm)}.input-inline{width:auto;min-width:110px}.input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.input-game{border-width:3px;border-color:var(--primary-500);border-radius:var(--radius-lg);padding:14px 20px}.input-error{border-color:var(--accent-500)}.input-error:focus{box-shadow:0 0 0 3px var(--accent-100)}.input-success{border-color:var(--success-500)}.form-error{margin-top:8px;color:var(--accent-500);font-size:.85rem;font-weight:600}.input-icon-wrapper{position:relative}.input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%)}.input-icon-wrapper .input{padding-left:40px}.alert{padding:12px 16px;border-radius:var(--radius-md);border-left:4px solid;display:flex;align-items:flex-start;gap:10px;font-size:.9rem}.alert-icon{font-weight:700;line-height:1;margin-top:2px}.alert-content{flex:1}.alert-title{font-weight:700;margin-bottom:4px}.alert-info{background:var(--primary-50);border-color:var(--primary-500);color:var(--primary-700)}.alert-success{background:#e6fff0;border-color:var(--success-500);color:#062}.alert-warning{background:#fff8e6;border-color:var(--warning-500);color:#8a6500}.alert-error{background:var(--accent-50);border-color:var(--accent-500);color:var(--accent-700)}.app-message{border:1px solid rgba(182,205,236,.26);border-radius:var(--radius-md);background:#152132b8;color:var(--text-primary);display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 12px}.app-message.is-compact{padding:8px 10px;gap:8px}.app-message-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0}.app-message-body{min-width:0;display:grid;gap:2px}.app-message-title{font-size:.76rem;font-weight:800;letter-spacing:.03em;text-transform:uppercase;color:#e7f0ff}.app-message-text{font-size:.8rem;color:#d7e5f7}.app-message-actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.app-message-info{border-color:#3b82f661;background:#1f488042}.app-message-success{border-color:#10b98161;background:#084d3d52}.app-message-warning{border-color:#f59e0b6b;background:#6b4a114d}.app-message-error{border-color:#ef444470;background:#6b1f2d4d}.modal-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:18px;z-index:9999}.modal{width:min(680px,100%);background:var(--bg-card);border-radius:var(--radius-xl);border:2px solid var(--border-color);box-shadow:var(--shadow-xl);overflow:hidden}.modal-header{padding:18px 20px;border-bottom:2px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-title{font-family:var(--font-display);font-weight:800;font-size:1.15rem}.modal-body{padding:20px}.modal-footer{padding:16px 20px;border-top:2px solid var(--border-color);background:var(--bg-secondary);display:flex;justify-content:flex-end;gap:10px}.progress{height:12px;background:var(--bg-secondary);border-radius:20px;overflow:hidden;border:2px solid var(--border-color)}.progress-bar{height:100%;border-radius:20px;transition:width .5s ease}.progress-bar-primary{background:linear-gradient(90deg,var(--primary-400),var(--primary-600))}.progress-bar-accent{background:linear-gradient(90deg,var(--accent-400),var(--accent-600))}.progress-bar-success{background:linear-gradient(90deg,#00ff4d,var(--success-500))}.progress-bar-warning{background:linear-gradient(90deg,#ffc800,var(--warning-500))}
