:root{--bg-primary: #06040a;--bg-secondary: #0c0a14;--bg-tertiary: #141020;--bg-elevated: #1c162c;--text-primary: #ece4f4;--text-secondary: #9890b0;--text-muted: #524a6a;--accent: #00e5ff;--accent-alt: #ff3a8c;--accent-hover: #33ebff;--accent-orange: #ff6a2b;--accent-gold: #fbbf24;--brand-gradient: linear-gradient(135deg, #ff3a8c, #ff6a2b);--brand-gradient-wide: linear-gradient(135deg, #ff3a8c, #ff6a2b, #fbbf24);--board-light: #1e2448;--board-dark: #0e1430;--piece-white: #f0f4ff;--piece-black: #000000;--quantum-ring: #ff3a8c;--selection: #00e5ff;--legal-target: #22c55e;--split-first: #3b82f6;--split-second: #f59e0b;--merge-source-a: #8b5cf6;--merge-source-b: #ec4899;--merge-target: #eab308;--danger: #ef4444;--success: #22c55e;--warning: #f59e0b;--border: rgba(255, 255, 255, .06);--border-light: rgba(255, 255, 255, .1);--font-heading: "Chakra Petch", "Syne", sans-serif;--font-body: "Oxanium", "Outfit", sans-serif;--font-mono: "JetBrains Mono", monospace;--space-1: 2px;--space-2: 4px;--space-3: 8px;--space-4: 12px;--space-5: 16px;--space-6: 24px;--space-7: 32px;--space-8: 48px;--radius-sm: 2px;--radius-md: 4px;--radius-lg: 8px;--radius-xl: 12px;--radius-pill: 999px;--duration-fast: .15s;--duration-normal: .2s;--duration-slow: .3s;--z-board: 1;--z-piece: 2;--z-topbar: 10;--z-menu: 50;--z-overlay: 100;--z-toast: 200;--z-modal: 300;--z-drag-ghost: 500;--board-chrome-h: 180px;--board-chrome-w: 340px;--board-square-radius: 3px;--board-gap: var(--space-1);--clip-corner: polygon(12px 0%, 100% 0%, 100% calc(100% - 12px) , calc(100% - 12px) 100%, 0% 100%, 0% 12px);--clip-corner-sm: polygon(8px 0%, 100% 0%, 100% calc(100% - 8px) , calc(100% - 8px) 100%, 0% 100%, 0% 8px)}@keyframes fade-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes glow-breathe{0%,to{opacity:.4}50%{opacity:.7}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes ring-pulse{0%,to{opacity:var(--ring-opacity, .75)}50%{opacity:calc(var(--ring-opacity, .75) * .5)}}@keyframes toast-in{0%{opacity:0;transform:translate(30px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes overlay-slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes hero-glow{0%,to{background-position:0% 50%;filter:blur(60px)}50%{background-position:100% 50%;filter:blur(80px)}}@keyframes stat-count{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes border-glow-pulse{0%,to{border-color:#00e5ff26}50%{border-color:#00e5ff4d}}@keyframes title-reveal{0%{opacity:0;letter-spacing:.5em;filter:blur(8px)}to{opacity:1;letter-spacing:.12em;filter:blur(0)}}@keyframes brand-gradient-flow{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes star-twinkle{0%,to{opacity:.15}50%{opacity:.6}}@keyframes corner-accent-pulse{0%,to{opacity:.3}50%{opacity:.6}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font-body);font-weight:300;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(1.5px 1.5px at 12% 18%,rgba(0,229,255,.35),transparent),radial-gradient(1.2px 1.2px at 28% 65%,rgba(255,58,140,.3),transparent),radial-gradient(1.8px 1.8px at 45% 8%,rgba(255,106,43,.25),transparent),radial-gradient(1px 1px at 62% 42%,rgba(255,255,255,.2),transparent),radial-gradient(1.4px 1.4px at 78% 72%,rgba(0,229,255,.2),transparent),radial-gradient(1.2px 1.2px at 88% 25%,rgba(255,58,140,.2),transparent),radial-gradient(1.6px 1.6px at 35% 88%,rgba(255,106,43,.18),transparent),radial-gradient(.9px .9px at 55% 52%,rgba(200,180,255,.15),transparent),radial-gradient(1.3px 1.3px at 5% 78%,rgba(255,255,255,.15),transparent),radial-gradient(1.7px 1.7px at 92% 88%,rgba(255,58,140,.15),transparent),radial-gradient(.8px .8px at 18% 42%,rgba(0,229,255,.18),transparent),radial-gradient(1.1px 1.1px at 72% 15%,rgba(255,106,43,.12),transparent);background-size:380px 320px,320px 280px,420px 360px,280px 240px,360px 300px,300px 260px,260px 320px,340px 300px,400px 340px,380px 320px,300px 260px,350px 290px;pointer-events:none;z-index:0}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 0%,rgba(255,58,140,.06) 0%,transparent 45%),radial-gradient(ellipse at 70% 0%,rgba(255,106,43,.04) 0%,transparent 40%),radial-gradient(ellipse at 50% 40%,transparent 35%,rgba(0,0,0,.55) 100%);pointer-events:none;z-index:0}#app{height:100vh;display:flex;flex-direction:column;overflow:hidden;position:relative;z-index:1}#screen-container{flex:1;overflow-y:auto;overflow-x:hidden}h1,h2,h3{font-family:var(--font-heading);font-weight:700;line-height:1.15;letter-spacing:.04em;text-transform:uppercase}h1{font-size:2.2rem}h2{font-size:1.4rem}h3{font-size:1rem}strong{font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:4px;border:1px solid var(--border-light);background:var(--bg-tertiary);color:var(--text-primary);font-family:var(--font-heading);font-size:13px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.btn:hover{background:var(--bg-elevated);border-color:#ffffff26;box-shadow:0 0 20px #00e5ff0f}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.btn-sm{padding:6px 14px;font-size:11px;border-radius:3px}.btn-primary{background:var(--brand-gradient);background-size:200% 200%;border:1px solid rgba(255,58,140,.4);color:#fff;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.3);clip-path:var(--clip-corner-sm)}.btn-primary:hover{background-size:200% 200%;animation:brand-gradient-flow 3s ease infinite;border-color:#ff3a8c99;box-shadow:0 0 30px #ff3a8c33,0 0 60px #ff6a2b1a}.btn-secondary{background:transparent;border-color:var(--border-light)}.btn-secondary:hover{border-color:#ff3a8c80;color:var(--accent-alt);box-shadow:0 0 20px #ff3a8c14}.btn-accent{background:linear-gradient(135deg,var(--accent),#00b8d4);border-color:#00e5ff4d;color:#000;font-weight:600;clip-path:var(--clip-corner-sm)}.btn-accent:hover{box-shadow:0 0 25px #00e5ff33}.btn-danger{border-color:#ef444466;color:var(--danger);background:#ef444414}.btn-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger);box-shadow:0 0 20px #ef444433}.btn-topbar{background:transparent;border-color:#ffffff14;color:var(--text-secondary);font-size:11px;padding:6px 14px}.btn-topbar:hover{border-color:#ff3a8c66;color:var(--text-primary);background:#ff3a8c0f;box-shadow:none}.btn-back{background:transparent;border:none;color:var(--text-muted);padding:6px 0;font-size:13px;gap:4px;text-transform:uppercase;letter-spacing:.06em}.btn-back:hover{color:var(--accent-alt);background:transparent;border:none;box-shadow:none}@keyframes home-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes home-glow-drift{0%,to{transform:translate(-50%,-40%) scale(1);opacity:.6}33%{transform:translate(-45%,-35%) scale(1.1);opacity:.8}66%{transform:translate(-55%,-45%) scale(.95);opacity:.5}}@keyframes home-border-flow{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes home-hero-shimmer{0%{background-position:-200% center}to{background-position:200% center}}.home-screen{display:flex;flex-direction:column;height:100vh;overflow:hidden;animation:fade-in .3s ease}.home-topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;border-bottom:1px solid rgba(255,255,255,.04);flex-shrink:0;animation:home-fade-in .4s ease .1s both}.home-brand{display:flex;align-items:center;gap:10px;color:var(--text-secondary)}.home-brand-icon{display:flex;color:var(--accent);opacity:.8}.home-brand-text{font-family:var(--font-heading);font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;background:var(--brand-gradient);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:brand-gradient-flow 6s ease infinite}.home-brand-badge{font-family:var(--font-heading);font-size:9px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);opacity:.5;margin-left:4px}.home-topbar-right{display:flex;align-items:center;gap:16px}.topbar-short{display:none}.home-user{display:flex;align-items:center;gap:10px}.user-name{color:var(--text-muted);font-size:12px;font-family:var(--font-mono)}.home-auth-btn{padding:6px 16px;border-radius:6px;border:1px solid rgba(255,45,120,.4);background:#ff2d7814;color:var(--accent-alt);font-family:var(--font-body);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;letter-spacing:.02em}.home-auth-btn:hover{background:#ff2d7826;border-color:#ff2d7899;box-shadow:0 0 16px #ff2d781f}.home-auth-btn--profile{border-color:var(--border-light);background:transparent;color:var(--text-secondary)}.home-auth-btn--profile:hover{border-color:var(--accent);color:var(--accent);background:#00e5ff0a;box-shadow:0 0 12px #00e5ff14}.home-body{flex:1;display:flex;align-items:center;justify-content:center;overflow-y:auto;overflow-x:hidden}.home-hero{position:relative;padding:32px 36px 40px;overflow:visible;display:flex;flex-direction:column;align-items:center;gap:40px;max-width:780px;width:100%;animation:home-fade-in .5s ease .15s both}.home-hero-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:1000px;height:700px;background:radial-gradient(ellipse at 30% 50%,rgba(255,58,140,.12) 0%,transparent 55%),radial-gradient(ellipse at 70% 40%,rgba(255,106,43,.08) 0%,transparent 50%),radial-gradient(ellipse at 50% 60%,rgba(0,229,255,.05) 0%,transparent 60%);pointer-events:none;filter:blur(40px);animation:home-glow-drift 12s ease-in-out infinite}.home-hero-text{position:relative;z-index:1;text-align:center}.home-title{font-family:var(--font-heading);font-size:clamp(2.4rem,5vw,3.4rem);font-weight:700;letter-spacing:.1em;text-transform:uppercase;line-height:.9;color:#fff;position:relative;z-index:1;text-shadow:0 0 40px rgba(255,58,140,.2),0 0 80px rgba(255,106,43,.12)}.home-title-accent{background:var(--brand-gradient);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:brand-gradient-flow 4s ease infinite}.home-footer{position:fixed;bottom:max(12px,env(safe-area-inset-bottom,0px));left:0;right:0;display:flex;justify-content:center;align-items:center;gap:var(--space-5);z-index:1}.home-version{font-size:10px;letter-spacing:.05em;color:var(--text-muted, rgba(255, 255, 255, .2));-webkit-user-select:none;user-select:none;background:none;border:none;padding:4px 8px;cursor:pointer;font-family:var(--font-mono);transition:color var(--duration-fast) ease}.home-version:hover{color:var(--accent, #00e5ff)}.home-footer-legal{display:flex;gap:var(--space-4)}.home-footer-legal a{font-family:var(--font-body);font-size:10px;color:var(--text-muted, rgba(255, 255, 255, .2));text-decoration:none;transition:color var(--duration-fast) ease}.home-footer-legal a:hover{color:var(--accent, #00e5ff)}.home-subtitle{color:var(--text-secondary);font-size:13px;font-weight:400;letter-spacing:.12em;text-transform:uppercase;margin-top:12px;font-family:var(--font-heading);position:relative;z-index:1}.home-early-access{color:var(--text-tertiary, #6a5a62);font-size:11px;font-weight:400;letter-spacing:.04em;margin-top:10px;position:relative;z-index:1;opacity:.8}.home-hero-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;width:100%;position:relative;z-index:1}.mode-hero-card{position:relative;padding:18px 22px 16px;border-radius:2px;border:1px solid rgba(255,255,255,.08);background:#0c0a14cc;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);cursor:pointer;text-align:left;font-family:var(--font-body);color:var(--text-primary);overflow:hidden;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;clip-path:var(--clip-corner)}.mode-hero-card:after{content:"";position:absolute;top:0;left:0;width:24px;height:24px;border-left:2px solid transparent;border-top:2px solid transparent;pointer-events:none;transition:border-color .3s ease}.mode-hero-card-bg{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity .35s ease}.mode-hero-card--orange .mode-hero-card-bg{background:linear-gradient(135deg,rgba(255,106,43,.1) 0%,rgba(255,58,140,.04) 50%,transparent 80%)}.mode-hero-card--magenta .mode-hero-card-bg{background:linear-gradient(135deg,rgba(255,58,140,.12) 0%,rgba(255,106,43,.05) 50%,transparent 80%)}.mode-hero-card:hover .mode-hero-card-bg{opacity:1}.mode-hero-card--orange{border-color:#ff6a2b40;border-left:3px solid rgba(255,106,43,.7)}.mode-hero-card--orange:after{border-left-color:#ff6a2b80;border-top-color:#ff6a2b80}.mode-hero-card--magenta{border-color:#ff3a8c40;border-left:3px solid rgba(255,58,140,.7)}.mode-hero-card--magenta:after{border-left-color:#ff3a8c80;border-top-color:#ff3a8c80}.mode-hero-card:hover{transform:translateY(-3px)}.mode-hero-card--orange:hover{border-color:#ff6a2b80;box-shadow:0 8px 32px #00000080,0 0 40px #ff6a2b1f}.mode-hero-card--orange:hover:after{border-left-color:#ff6a2bcc;border-top-color:#ff6a2bcc}.mode-hero-card--magenta:hover{border-color:#ff3a8c80;box-shadow:0 8px 32px #00000080,0 0 40px #ff3a8c1f}.mode-hero-card--magenta:hover:after{border-left-color:#ff3a8ccc;border-top-color:#ff3a8ccc}.mode-hero-card:active{transform:translateY(-1px) scale(.99)}.mode-hero-card-content{display:flex;align-items:center;gap:10px;position:relative;z-index:1;margin-bottom:6px}.mode-hero-card-icon{font-size:22px;line-height:1;filter:saturate(1.3)}.mode-hero-card-label{font-family:var(--font-heading);font-weight:600;font-size:15px;letter-spacing:.08em;text-transform:uppercase;flex:1}.mode-hero-card-arrow{font-size:18px;color:var(--text-muted);transition:transform .2s ease,color .2s ease}.mode-hero-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:6px;border-radius:9px;font-size:11px;font-weight:700;font-family:var(--font-body);line-height:1;background:#00e5ff33;color:var(--accent);animation:corr-pulse 2s ease-in-out infinite;vertical-align:middle}.mode-hero-card--orange:hover .mode-hero-card-arrow{transform:translate(4px);color:var(--accent-orange)}.mode-hero-card--magenta:hover .mode-hero-card-arrow{transform:translate(4px);color:var(--accent-alt)}.mode-hero-card-desc{font-size:12px;line-height:1.5;color:var(--text-secondary);position:relative;z-index:1;font-weight:300}.home-modes{display:flex;flex-direction:column;gap:28px;padding:8px 36px 48px}.mode-section{animation:home-fade-in .5s ease both}.mode-section:nth-child(1){animation-delay:.3s}.mode-section:nth-child(2){animation-delay:.4s}.mode-section:nth-child(3){animation-delay:.5s}.mode-section-title{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px;padding-left:2px;display:flex;align-items:center;gap:12px}.mode-section-title:after{content:"";flex:1;height:1px;background:linear-gradient(to right,var(--border),transparent 80%)}.mode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}.mode-card{display:flex;align-items:flex-start;gap:14px;padding:16px 18px;border-radius:2px;border:1px solid rgba(255,255,255,.06);background:#0c0a1499;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text-primary);cursor:pointer;text-align:left;font-family:var(--font-body);width:100%;position:relative;overflow:hidden;transition:all .25s ease}.mode-card-glow{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity .3s ease;background:radial-gradient(ellipse at 20% 30%,rgba(0,229,255,.04),transparent 70%);pointer-events:none}.mode-card:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:inherit;padding:1px;background:linear-gradient(135deg,rgba(0,229,255,.15),transparent 40%,transparent 60%,rgba(255,45,120,.1));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s ease;pointer-events:none}.mode-card:hover:not(.disabled):before{opacity:1}.mode-card:hover:not(.disabled) .mode-card-glow{opacity:1}.mode-card:hover:not(.disabled){border-color:#ffffff14;transform:translateY(-2px);box-shadow:0 6px 24px #00000059}.mode-card:active:not(.disabled){transform:translateY(0) scale(.99)}.mode-card.disabled{opacity:.4;cursor:not-allowed}.mode-card.disabled .mode-card-glow{display:none}.mode-card-icon{font-size:24px;line-height:1;flex-shrink:0;margin-top:1px;filter:saturate(1.1)}.mode-card-content{flex:1;min-width:0;position:relative;z-index:1}.mode-card-title{font-family:var(--font-heading);font-weight:600;font-size:13px;margin-bottom:3px;letter-spacing:.08em;text-transform:uppercase}.mode-card-desc{color:var(--text-muted);font-size:12px;line-height:1.45}.mode-card-badge{position:absolute;top:10px;right:10px;background:#ff2d781a;color:var(--accent-alt);font-size:8px;font-weight:600;font-family:var(--font-heading);padding:2px 8px;border-radius:2px;border:1px solid rgba(255,45,120,.15);letter-spacing:.1em;text-transform:uppercase;z-index:1}@media(max-width:640px){.home-hero{padding:24px 20px 28px}.home-body{align-items:flex-start}.home-hero-actions{grid-template-columns:1fr}.home-modes{padding:8px 20px 40px}.mode-grid{grid-template-columns:1fr}.home-topbar{padding:12px 16px}.home-title{font-size:2.2rem}.home-brand-badge{display:none}.home-topbar-right{gap:6px}.btn-topbar{padding:4px 8px;font-size:.72rem}.topbar-full{display:none}.topbar-short{display:inline}}.setup-screen{max-width:640px;margin:0 auto;padding:40px 28px;animation:fade-up .5s ease}.setup-header{display:flex;align-items:center;gap:16px;margin-bottom:36px}.setup-header h2{font-size:1.5rem;font-weight:700;letter-spacing:.1em}.setup-body{display:flex;flex-direction:column;gap:28px}.setup-section{display:flex;flex-direction:column;gap:10px;padding:20px;background:#0c0a1499;border:1px solid var(--border);border-radius:2px;clip-path:var(--clip-corner);position:relative}.setup-section:before{content:"";position:absolute;top:0;left:0;width:16px;height:16px;border-left:1px solid rgba(0,229,255,.2);border-top:1px solid rgba(0,229,255,.2);pointer-events:none}.setup-label{font-family:var(--font-heading);font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.18em}.setup-options{display:flex;gap:8px;flex-wrap:wrap}.option-btn{padding:10px 18px;border-radius:3px;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);font-size:12px;font-family:var(--font-heading);font-weight:500;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:all .2s ease}.option-btn.active{border-color:var(--accent);color:var(--accent);background:#00e5ff14;box-shadow:0 0 16px #00e5ff14,inset 0 0 8px #00e5ff0a}.option-btn:hover:not(.active){border-color:var(--border-light);background:var(--bg-elevated)}.setup-time-grid{display:flex;flex-direction:column;gap:14px}.setup-time-presets{display:flex;gap:8px;flex-wrap:wrap}.setup-time-custom{display:flex;gap:14px}.setup-time-custom label{display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.02em}.setup-time-custom input{padding:8px 12px;border-radius:3px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-mono);font-size:14px;width:110px;transition:border-color .2s}.setup-time-custom input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 12px #00e5ff1a}.setup-side-visual{display:flex;gap:10px}.setup-side-btn{flex:1;padding:16px;border-radius:3px;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;text-align:center;font-family:var(--font-heading);letter-spacing:.06em}.setup-side-btn.active{border-color:var(--accent);background:#00e5ff0f;box-shadow:0 0 20px #00e5ff1a}.setup-side-btn:hover:not(.active){border-color:var(--border-light)}.setup-side-icon{font-size:36px;display:flex;align-items:center;justify-content:center;margin-bottom:6px}.setup-side-icon .piece-svg{width:1em;height:1em}.setup-side-label{font-size:13px;font-weight:600}.btn-start{margin-top:4px;padding:16px 32px;font-size:15px;font-weight:600;letter-spacing:.1em;border-radius:2px;clip-path:var(--clip-corner)}.gameplay-screen{display:grid;height:100vh;height:100dvh;overflow:hidden;grid-template-areas:"topbar" "center" "status";grid-template-rows:auto 1fr auto}[data-mode=sandbox]{--board-chrome-h: 150px;--board-chrome-w: 560px}.gameplay-topbar{grid-area:topbar;z-index:var(--z-topbar)}.gameplay-topbar-center{display:flex;align-items:center}.gameplay-mode-label{font-family:var(--font-heading);font-size:14px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary)}.gameplay-topbar-actions{display:flex;align-items:center;gap:4px}.sound-toggle-btn{opacity:.7;transition:opacity .15s}.sound-toggle-btn:hover{opacity:1}.gameplay-center-group,.gameplay-center{grid-area:center;display:flex;align-items:center;justify-content:center;gap:24px;padding:16px 24px;overflow:hidden}.gameplay-board-col{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.gameplay-top-slot,.gameplay-bottom-slot{width:min(calc(100vh - var(--board-chrome-h)),calc(100vw - var(--board-chrome-w)));max-width:640px;align-self:flex-end}.gameplay-top-banner,.gameplay-bottom-banner{padding:6px 0}.player-banner{max-width:none}.gameplay-board-area{display:flex;align-items:center;justify-content:center;min-height:0}.gameplay-captured-panel{display:flex;flex-direction:column;align-self:center;transform:translateY(22px)}.gameplay-right-panel{display:flex;flex-direction:column;width:260px;flex-shrink:0;align-self:center;height:60vh;transform:translateY(22px);background:#14102099;border:1px solid var(--border);border-radius:3px;padding:0 12px;margin:0 8px;overflow:hidden}.gameplay-info-tabs,.gameplay-right-panel .gameplay-captured-tab{display:none}.gameplay-status,.gameplay-footer{grid-area:status}.board-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.board-coords{position:relative;display:grid;grid-template-columns:auto 1fr;grid-template-rows:1fr auto;gap:0}.board-rank-labels,.board-file-labels{display:none}.board-coords.show-coords{gap:4px}.board-coords.show-coords .board-rank-labels{display:flex;flex-direction:column;justify-content:space-around;align-items:center;padding:0 3px;grid-column:1;grid-row:1}.board-coords.show-coords .board-file-labels{display:flex;justify-content:space-around;align-items:center;padding:3px 0;grid-column:2;grid-row:2}.board-coords.show-coords .board{grid-column:2;grid-row:1}.board-coord-label{font-family:var(--font-mono);font-size:10px;font-weight:500;color:var(--text-muted);-webkit-user-select:none;user-select:none;line-height:1;opacity:.7}.board{position:relative;display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);gap:var(--board-gap);touch-action:none;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;width:min(calc(100vh - var(--board-chrome-h)),calc(100vw - var(--board-chrome-w)));height:min(calc(100vh - var(--board-chrome-h)),calc(100vw - var(--board-chrome-w)));max-width:640px;max-height:640px;border-radius:4px;overflow:visible;box-shadow:0 16px 48px #0009,0 0 0 1px #00e5ff0f,0 0 80px #00e5ff08}.square{display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--board-square-radius);border:2px solid transparent;cursor:pointer;position:relative;transition:border-color .15s,box-shadow .15s;overflow:visible;-webkit-user-select:none;user-select:none}.square *{-webkit-user-select:none;user-select:none}.light{background:var(--board-light)}.dark{background:var(--board-dark)}.selected{border-color:var(--selection);box-shadow:inset 0 0 16px #00e5ff33,0 0 8px #00e5ff26}.last-move{background-color:#ffaa0026}.last-move.light{background-color:#fa03}.legal-target{border-color:var(--legal-target)}.legal-target:before{content:"";position:absolute;width:28%;height:28%;border-radius:50%;background:var(--legal-target);opacity:.45;box-shadow:0 0 8px #22c55e4d}.split-first-target{border-color:var(--split-first);box-shadow:inset 0 0 12px #3b82f640}.split-second-target{border-color:var(--split-second);box-shadow:inset 0 0 12px #f59e0b40}.merge-source-a{border-color:var(--merge-source-a);box-shadow:inset 0 0 12px #8b5cf640}.merge-source-b{border-color:var(--merge-source-b);box-shadow:inset 0 0 12px #ec489940}.merge-target{border-color:var(--merge-target);box-shadow:inset 0 0 10px #eab30833}.overlay-phase{background-image:linear-gradient(135deg,rgba(0,229,255,.15),transparent 55%)}.entanglement-ring{position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;width:calc(100% + 20px);height:calc(100% + 20px);pointer-events:none;z-index:3;overflow:visible}.entanglement-web-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:4;overflow:visible}.exact-probability-badge{position:absolute;bottom:1px;left:50%;transform:translate(-50%);font-family:var(--font-mono);font-size:9px;font-weight:700;line-height:1;padding:1px 4px;border-radius:3px;pointer-events:none;z-index:5;white-space:nowrap;color:#fffffff2;background:#000000a6;opacity:0;transition:opacity .15s ease}.square:hover .exact-probability-badge{opacity:1}.phase-indicator{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:3;transform:rotate(var(--phase-deg, 0deg))}.phase-tick{position:absolute;top:2px;left:50%;transform:translate(-50%) rotate(45deg);width:7px;height:7px;background:#dcff64e6;box-shadow:0 0 4px #dcff6499,0 0 8px #dcff644d;filter:drop-shadow(0 0 3px rgba(120,180,255,.6))}.sandbox-menu-divider{height:1px;background:#ffffff14;margin:4px 8px}.sandbox-menu-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#ffffff59;padding:4px 12px 2px;-webkit-user-select:none;user-select:none}.sandbox-menu-item.active,.sandbox-menu-item.active i{color:#60a5fa}.sq-label{position:absolute;font-family:var(--font-mono);font-size:10px;font-weight:600;line-height:1;-webkit-user-select:none;user-select:none;pointer-events:none;z-index:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.sq-label-rank{top:-1px;left:0}.sq-label-file{bottom:-1px;right:0}.light .sq-label{color:#3a4478;text-shadow:none}.dark .sq-label{color:#283060;text-shadow:none}.piece-token{position:relative;display:inline-flex;align-items:center;justify-content:center;width:78%;height:78%;border-radius:999px;background:#ffffff0f;box-shadow:inset 0 0 0 1px #ffffff1a,0 2px 6px #00000080;z-index:2}.piece-ring-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;width:78%;height:78%;z-index:2}.ring-gauge{position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;width:calc(100% + 4px);height:calc(100% + 4px);pointer-events:none;z-index:2;overflow:visible}.ring-gauge circle.ring-glow{fill:none;stroke:var(--ring-color, var(--quantum-ring));stroke-width:12;stroke-linecap:round;stroke-dasharray:calc(var(--ring-fill, .5) * 276.46) 276.46;stroke-dashoffset:calc((1 - var(--ring-fill, .5)) * -138.23);transform:rotate(-90deg);transform-origin:center;opacity:calc(var(--ring-opacity, .75) * .4);filter:blur(3px);animation:ring-pulse 2.5s ease-in-out infinite}.ring-gauge circle.ring-main{fill:none;stroke:var(--ring-color, var(--quantum-ring));stroke-width:7;stroke-linecap:round;stroke-dasharray:calc(var(--ring-fill, .5) * 276.46) 276.46;stroke-dashoffset:calc((1 - var(--ring-fill, .5)) * -138.23);transform:rotate(-90deg);transform-origin:center;opacity:var(--ring-opacity, .75);animation:ring-pulse 2.5s ease-in-out infinite}.ring-gauge circle.ring-core{fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-dasharray:calc(var(--ring-fill, .5) * 276.46) 276.46;stroke-dashoffset:calc((1 - var(--ring-fill, .5)) * -138.23);transform:rotate(-90deg);transform-origin:center;opacity:calc(var(--ring-opacity, .75) * .6);animation:ring-pulse 2.5s ease-in-out infinite}.measurement-anim-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:20}.measurement-anim-eye,.measurement-anim-result{position:absolute;transform:translate(-50%,-65%);display:flex;align-items:center;justify-content:center;pointer-events:none;background:#000000b3;border-radius:50%}.measurement-anim-eye svg{width:85%;height:85%;filter:drop-shadow(0 0 8px rgba(56,233,233,.8)) drop-shadow(0 0 16px rgba(56,233,233,.4))}.measurement-anim-eye{animation:meas-eye-pulse .6s ease-in-out}@keyframes meas-eye-pulse{0%{opacity:0;transform:translate(-50%,-65%) scale(.6)}30%{opacity:1;transform:translate(-50%,-65%) scale(1.05)}to{opacity:1;transform:translate(-50%,-65%) scale(1)}}.measurement-anim-result{animation:meas-result-pop .3s ease}.measurement-anim-result svg{width:55%;height:55%;filter:drop-shadow(0 0 4px currentColor)}@keyframes meas-result-pop{0%{transform:translate(-50%,-50%) scale(.4);opacity:0}60%{transform:translate(-50%,-50%) scale(1.15)}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.board.overlays-active .ring-gauge circle.ring-glow{opacity:.15;animation:none}.board.overlays-active .ring-gauge circle.ring-main{opacity:.35;animation:none}.board.overlays-active .ring-gauge circle.ring-core{opacity:.2;animation:none}.piece-symbol{font-size:min(4.2vw,42px);line-height:1;display:flex;align-items:center;justify-content:center}.piece-svg{width:1em;height:1em;display:block;fill:currentColor}.piece-symbol.piece-white{color:var(--piece-white);filter:drop-shadow(0 1px 0 rgba(0,0,0,.3)) drop-shadow(0 2px 4px rgba(0,0,0,.7))}.piece-symbol.piece-black{color:var(--piece-black);filter:drop-shadow(0 -1px 0 rgba(255,255,255,.5)) drop-shadow(0 1px 0 rgba(0,0,0,.7)) drop-shadow(0 0 4px rgba(255,255,255,.2))}.piece-token:has(.piece-white){background:radial-gradient(circle at 40% 32%,#ffffff2e,#a0b4d20f);box-shadow:inset 0 0 0 1.5px #ffffff26,0 2px 6px #00000080}.piece-token:has(.piece-black){background:radial-gradient(circle at 40% 32%,#aa9bbe99,#7864918c);box-shadow:inset 0 0 0 1.5px #ffffff2e,0 2px 6px #0009}.piece-token .piece-symbol.piece-white{color:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}.piece-token .piece-symbol.piece-black{color:var(--piece-black);filter:drop-shadow(0 -1px 0 rgba(255,255,255,.5)) drop-shadow(0 1px 0 rgba(0,0,0,.7)) drop-shadow(0 0 4px rgba(255,255,255,.2))}.player-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 16px;border-radius:3px;background:#0c0a1480;border:1px solid var(--border);width:100%;transition:all .25s ease}.player-banner.active{border-color:#00e5ff80;box-shadow:0 0 24px #00e5ff26;background:#00e5ff14}.player-info{display:flex;align-items:center;gap:8px}.player-color-dot{width:10px;height:10px;border-radius:50%}.player-color-dot.white{background:var(--piece-white);box-shadow:0 0 6px #e8ecf44d}.player-color-dot.black{background:var(--piece-black);border:1px solid var(--text-muted)}.player-name{font-family:var(--font-heading);font-weight:600;font-size:14px}.player-elo{color:var(--text-muted);font-size:12px;font-family:var(--font-mono)}.player-timer{font-family:var(--font-heading);font-size:17px;font-weight:600;color:var(--text-primary);padding:4px 12px;background:var(--bg-primary);border-radius:3px;border:1px solid var(--border);min-width:74px;text-align:center;letter-spacing:.08em}.status-bar{width:100%;max-width:640px;padding:4px 0}.status-main{font-size:14px;color:var(--text-primary);font-weight:500}.status-measurement{font-size:13px;color:var(--warning);margin-top:3px;margin-left:16px;margin-right:16px;font-family:var(--font-mono)}.status-info{display:flex;gap:20px;font-size:12px;color:var(--text-muted);margin-top:4px;font-family:var(--font-mono)}.move-history{border-radius:3px;background:#14102099;border:1px solid var(--border);overflow:hidden}.move-history-header{padding:10px 14px;font-family:var(--font-heading);font-weight:600;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.18em;border-bottom:1px solid var(--border)}.move-history-list{max-height:200px;overflow-y:auto;padding:4px 0}.move-history-empty{padding:18px;text-align:center;color:var(--text-muted);font-size:12px;font-family:var(--font-mono)}.move-row{display:grid;grid-template-columns:32px 1fr 1fr;gap:4px;padding:3px 14px;font-family:var(--font-mono);font-size:12px;transition:background .15s}.move-row:hover{background:#ffffff08}.move-num{color:var(--text-muted);opacity:.6}.move-white,.move-black{color:var(--text-secondary)}.move-cell{cursor:pointer;border-radius:3px;padding:1px 4px;transition:background .12s}.move-cell:hover{background:#ffffff14}.move-cell.active{background:#ff2d782e;color:var(--accent-magenta, #ff2d78);font-weight:600}.move-white.blocked,.move-black.blocked{color:var(--warning);opacity:.7}.history-nav-controls{display:flex;justify-content:center;gap:4px;padding:6px 0 2px}.history-nav-btn{background:#14102099;border:1px solid var(--border);color:var(--text-secondary);font-size:16px;line-height:1;padding:6px 14px;border-radius:4px;cursor:pointer;transition:background .12s,color .12s;font-family:var(--font-mono)}.history-nav-btn:hover:not(:disabled){background:#ffffff14;color:var(--text-primary)}.history-nav-btn:disabled{opacity:.3;cursor:default}.history-viewing-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:5px 12px;background:#ff2d781f;border:1px solid rgba(255,45,120,.25);border-radius:4px;font-family:var(--font-mono);font-size:12px;color:var(--accent-magenta, #ff2d78);margin-bottom:4px}.history-viewing-label{opacity:.9}.history-live-link{background:none;border:none;color:var(--accent-magenta, #ff2d78);cursor:pointer;font-family:var(--font-mono);font-size:12px;text-decoration:underline;padding:0}.history-live-link:hover{opacity:.8}.gameplay-board-area.viewing-history .gameplay-board{opacity:.75;pointer-events:none}.captured-pieces{display:flex;flex-direction:column;gap:4px;padding:8px 0}.captured-row{display:flex;gap:2px;align-items:center;flex-wrap:wrap;min-height:20px;font-size:16px}.captured-group{letter-spacing:-2px;display:inline}.captured-icon{font-style:normal;display:inline-flex;align-items:center}.captured-icon .piece-svg{width:1em;height:1em}.captured-white{color:var(--piece-white)}.captured-black{color:#8a8fa8}.captured-partial{filter:saturate(.5)}.material-advantage{font-size:11px;font-weight:600;font-family:var(--font-mono);color:var(--accent);margin-left:4px}.quantum-inspector{border-radius:3px;background:#14102099;border:1px solid var(--border);padding:12px 14px}.inspector-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.inspector-header h3{font-family:var(--font-heading);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted)}.inspector-toggle{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted);cursor:pointer;font-family:var(--font-mono)}.inspector-toggle input{margin:0;accent-color:var(--accent)}.inspector-capabilities{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);margin-bottom:8px;opacity:.7}.inspector-empty{color:var(--text-muted);font-size:12px}.inspector-detail{font-size:12px}.inspector-square{font-family:var(--font-mono);font-size:20px;font-weight:700;color:var(--accent);margin-bottom:4px;letter-spacing:.05em}.inspector-prob{color:var(--text-secondary);margin-bottom:10px;font-family:var(--font-mono);font-size:12px}.inspector-section{margin-bottom:8px}.inspector-label{font-family:var(--font-heading);font-weight:700;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:3px}.inspector-section ul{list-style:none;padding-left:0}.inspector-section li{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);padding:1px 0}.inspector-none{color:var(--text-muted);font-style:italic}.inspector-value{color:var(--text-muted)}.sandbox-editor{border-radius:3px;background:#14102099;border:1px solid var(--border);padding:16px 20px}.sandbox-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.sandbox-header h3{font-family:var(--font-heading);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted)}.sandbox-controls{display:flex;gap:6px}.sandbox-controls-play,.sandbox-controls-edit{display:none}.sandbox-palette-play-btn{margin-bottom:8px}.sandbox-palette-play-btn .btn{width:100%}@keyframes gentle-pulse{0%,to{box-shadow:0 0 #ff3a8c00}50%{box-shadow:0 0 12px 2px #ff3a8c40}}.sandbox-play-toggle:not(.btn-danger){animation:gentle-pulse 2.5s ease-in-out infinite}.sandbox-palette-with-actions{display:flex;flex-direction:column;align-items:center;gap:8px}.sandbox-palette-actions{display:flex;flex-direction:column;gap:6px;width:100%}.sandbox-palette-actions .btn{width:100%}.sandbox-palette{display:flex;gap:4px}.sandbox-palette-row{display:flex;flex-direction:column;gap:4px}.sandbox-piece{display:flex;align-items:center;justify-content:center;border-radius:3px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);width:60px;height:60px;padding:0;cursor:grab;transition:all .2s ease;position:relative;flex-shrink:0;touch-action:none}.sandbox-piece:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d,0 0 12px #00e5ff14}.sandbox-piece:active{cursor:grabbing;transform:scale(.93)}.sandbox-piece.selected{border-color:var(--accent);box-shadow:0 0 12px #00e5ff40,inset 0 0 8px #00e5ff1a;background:#00e5ff14}.sandbox-piece-token{width:42px;height:42px}.sandbox-piece .piece-symbol{font-size:34px}.sandbox-piece .piece-bare{font-size:38px}.sandbox-piece-eraser{font-size:16px;color:var(--text-muted);font-weight:600}.sandbox-hint{font-size:11px;color:var(--text-muted);margin-top:6px}.sandbox-fen-row{margin-top:10px;display:flex;align-items:center;gap:6px}.sandbox-fen-row .sandbox-fen-input{flex:1;min-width:0}.sandbox-fen-input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg-primary);color:var(--text-muted);font-family:var(--font-mono);font-size:12px;outline:none;transition:border-color .2s}.sandbox-fen-input:focus{border-color:var(--accent)}.gameover-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px;text-align:center;animation:fade-in .5s ease}.gameover-result{margin-bottom:48px;animation:fade-up .6s ease .1s both}.gameover-eyebrow{font-family:var(--font-heading);font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px}.gameover-title{font-family:var(--font-heading);font-size:clamp(2.4rem,6vw,4rem);font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:linear-gradient(135deg,var(--accent) 0%,#fff 40%,var(--accent-alt) 70%,var(--accent-gold) 100%);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:brand-gradient-flow 4s ease infinite;text-shadow:none}.gameover-reason{color:var(--text-muted);font-size:13px;margin-top:10px;font-family:var(--font-heading);letter-spacing:.12em;text-transform:uppercase;font-weight:400}.gameover-stats{display:flex;gap:16px;margin-bottom:48px;flex-wrap:wrap;justify-content:center;animation:fade-up .6s ease .3s both}.stat{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 28px;background:#0c0a1499;border:1px solid var(--border);border-radius:2px;min-width:110px;transition:border-color .3s;clip-path:var(--clip-corner-sm);position:relative}.stat:before{content:"";position:absolute;top:0;left:0;width:12px;height:12px;border-left:1px solid rgba(0,229,255,.2);border-top:1px solid rgba(0,229,255,.2);pointer-events:none}.stat:hover{border-color:#00e5ff33}.stat-value{font-family:var(--font-heading);font-size:28px;font-weight:700;color:var(--accent);animation:stat-count .5s ease .5s both;letter-spacing:.02em}.stat-label{font-family:var(--font-heading);font-size:9px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.16em}.gameover-actions{display:flex;gap:14px;animation:fade-up .6s ease .5s both}.gameover-export{display:flex;gap:12px;margin-top:12px;animation:fade-up .6s ease .7s both;opacity:.7}.gameover-export:hover{opacity:1}.auth-screen{max-width:420px;margin:0 auto;padding:48px 28px;animation:fade-up .5s ease}.auth-form,.auth-profile{margin-top:28px}.auth-form h2,.auth-profile h2{margin-bottom:24px;font-weight:800;letter-spacing:.04em}.auth-form label{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;font-size:11px;font-family:var(--font-heading);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.auth-form input{padding:12px 16px;border-radius:3px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-family:var(--font-body);font-size:15px;transition:all .2s ease}.auth-form input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 16px #00e5ff14}.auth-form .btn-primary{width:100%;margin-top:8px;padding:14px;font-size:15px}.auth-error{color:var(--danger);font-size:13px;margin-bottom:14px;padding:10px 14px;background:#ef444414;border:1px solid rgba(239,68,68,.15);border-radius:3px;font-family:var(--font-mono);font-size:12px}.profile-info{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}.profile-field{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:3px;font-size:14px}.profile-field span{color:var(--text-muted);font-size:12px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#050810bf;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fade-in .2s ease}.modal-dialog{background:var(--bg-secondary);border:1px solid rgba(255,58,140,.1);border-radius:2px;padding:28px;max-width:440px;width:90%;box-shadow:0 24px 64px #0009,0 0 40px #ff3a8c0a;animation:fade-up .3s ease;clip-path:var(--clip-corner)}.modal-header{font-family:var(--font-heading);font-size:18px;font-weight:700;margin-bottom:12px}.modal-body{color:var(--text-secondary);font-size:14px;margin-bottom:24px;line-height:1.6}.modal-actions{display:flex;gap:10px;justify-content:flex-end}#modal-container:not(.modal-open){display:none}.toast-container{position:fixed;top:16px;right:16px;display:flex;flex-direction:column;gap:8px;z-index:var(--z-toast);pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:3px;background:#0c0a14e6;border:1px solid var(--border);font-size:13px;font-family:var(--font-body);box-shadow:0 8px 32px #00000080;pointer-events:all;animation:toast-in .35s ease-out;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);clip-path:var(--clip-corner-sm)}.toast-info{border-color:#00e5ff4d}.toast-success{border-color:#22c55e4d}.toast-warning{border-color:#f59e0b4d}.toast-error{border-color:#ef44444d}.toast-message{flex:1}.toast-close{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:0 2px;line-height:1;transition:color .15s}.toast-close:hover{color:var(--text-primary)}.timer-display{display:flex;gap:8px}.timer-side{display:flex;align-items:center;gap:6px;padding:4px 12px;border-radius:8px;background:var(--bg-primary);border:1px solid var(--border);font-family:var(--font-mono);font-size:14px;transition:border-color .2s}.timer-side.active{border-color:#00e5ff4d}.timer-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.timer-value{font-weight:600}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff1f}.sandbox-layout,[data-mode=sandbox]{display:grid;height:100vh;height:100dvh;overflow:hidden;grid-template-areas:"topbar" "center" "controls";grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr) auto}[data-mode=sandbox] .gameplay-topbar{grid-area:topbar}.sandbox-center-group,[data-mode=sandbox] .gameplay-center{grid-area:center;display:flex;align-items:center;justify-content:center;gap:24px;overflow:hidden;padding:16px 24px}.sandbox-board-col,[data-mode=sandbox] .gameplay-board-col{display:flex;flex-direction:column;align-items:stretch}.sandbox-fen-bar{padding:0 0 16px}.sandbox-layout .gameplay-board-area,[data-mode=sandbox] .gameplay-board-area{overflow:hidden;padding:0;display:flex;align-items:flex-start;justify-content:center}.sandbox-palette-area{display:flex;align-self:stretch;align-items:flex-start;padding-top:0}.sandbox-palette-area .sandbox-editor{margin-top:auto;margin-bottom:auto;transform:translateY(22px)}.sandbox-statusbar{grid-area:status;display:none}.sandbox-controls{grid-area:controls}.sandbox-topbar{flex-wrap:wrap;min-height:52px;box-sizing:border-box;z-index:var(--z-topbar)}.sandbox-topbar-brand:hover{opacity:.8}.sandbox-menu-wrap{position:relative}.sandbox-menu-toggle{font-size:18px}.sandbox-menu-dropdown{display:none;position:absolute;top:100%;right:0;margin-top:6px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:6px;padding:4px 0;min-width:180px;z-index:var(--z-menu);box-shadow:0 8px 24px #00000080}.sandbox-menu-dropdown.open{display:flex;flex-direction:column}.sandbox-menu-item{display:flex;align-items:center;gap:8px;padding:10px 16px;background:none;border:none;color:var(--text-secondary);font-family:var(--font-body);font-size:13px;cursor:pointer;text-align:left;white-space:nowrap}.sandbox-menu-item:hover{background:#ffffff0f;color:var(--text-primary)}.sandbox-topbar-center{display:flex;align-items:center;gap:10px}.sandbox-mode-label{font-family:var(--font-heading);font-size:14px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary)}.sandbox-topbar-actions{display:flex;gap:2px;align-items:center}.btn-icon{min-width:32px;min-height:28px;padding:4px 8px;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center}.sandbox-drag-ghost{position:fixed;pointer-events:none;z-index:var(--z-drag-ghost);font-size:36px;line-height:1;transform:translate(-50%,-50%);filter:drop-shadow(0 4px 12px rgba(0,0,0,.6));opacity:.9;transition:opacity .1s}.sandbox-drag-ghost .piece-token{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%}.sandbox-drag-ghost .piece-symbol{font-size:32px}.sandbox-phase-controls{display:flex;align-items:center;gap:8px}.sandbox-phase-pill{padding:4px 14px;border-radius:20px;font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase}.sandbox-phase-pill.editing{background:var(--bg-tertiary);color:var(--accent);border:1px solid var(--border)}.sandbox-phase-pill.playing{background:var(--accent);color:var(--bg-primary)}.sandbox-play-toggle{text-transform:uppercase;letter-spacing:.08em;font-weight:600}.sandbox-toggles{display:flex;align-items:center;gap:16px}.sandbox-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;font-family:var(--font-body);font-size:11px;color:var(--text-muted);white-space:nowrap}.sandbox-toggle input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:14px;height:14px;border:1px solid var(--border);border-radius:3px;background:transparent;cursor:pointer;position:relative;flex-shrink:0}.sandbox-toggle input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.sandbox-toggle input[type=checkbox]:checked:after{content:"✓";position:absolute;top:-1px;left:1px;font-size:11px;color:var(--bg-primary);font-weight:700}.sandbox-toggle span{-webkit-user-select:none;user-select:none}.sandbox-measurement-toggle{display:flex;align-items:center;gap:6px}.sandbox-toggle-label{font-family:var(--font-body);font-size:11px;color:var(--text-muted);white-space:nowrap}.sandbox-measurement-btns{display:flex;gap:2px}.sandbox-measurement-btn{padding:3px 10px;border-radius:4px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-family:var(--font-mono);font-size:10px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.sandbox-measurement-btn:hover{border-color:var(--border-light);color:var(--text-secondary)}.sandbox-measurement-btn.active{border-color:var(--accent);color:var(--accent);background:#00e5ff0f}.gameplay-moves-header{display:flex;align-items:center;justify-content:space-between;padding:10px 0;font-family:var(--font-heading);font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);flex-shrink:0}.gameplay-moves-header-left{display:flex;align-items:center;gap:4px}.gameplay-moves-header-right{display:flex;align-items:center;gap:6px}.sandbox-undo-btn:disabled{opacity:.2;cursor:default}.sandbox-rule-icon{position:relative;font-size:14px;color:var(--text-muted);opacity:.35;background:none;border:none;padding:6px 8px;margin:-4px 0;cursor:pointer;transition:opacity .15s,color .15s}.sandbox-rule-icon:hover{opacity:.6}.sandbox-rule-icon.active{color:var(--accent);opacity:.8}.sandbox-editing-instructions{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 16px;text-align:center}.sandbox-instructions-text{font-family:var(--font-body);font-size:13px;color:var(--text-muted);line-height:1.6;margin:0}.sandbox-play-link{color:var(--accent);font-weight:700;cursor:pointer;text-decoration:none}.sandbox-play-link:hover{text-decoration:underline}.sandbox-instructions-play{padding:8px 32px;font-size:14px;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.gameplay-moves-panel{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.gameplay-info-tab{background:none;border:none;padding:2px 0;font-family:var(--font-heading);font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);cursor:pointer;opacity:.5;transition:opacity .15s,color .15s}.gameplay-info-tab.active{color:var(--text-secondary);opacity:1;border-bottom:2px solid var(--accent)}.gameplay-info-tab:hover{opacity:.8}.gameplay-tab-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.gameplay-tab-pane{display:block}.gameplay-info-tab[data-tab=captured],.gameplay-right-panel .move-history-header{display:none}[data-mode=sandbox] .gameplay-right-panel{display:flex;flex-direction:column;width:280px;flex:0 0 auto;align-self:center;height:60vh;transform:translateY(22px);background:#14102099;border:1px solid var(--border);border-radius:3px;padding:0 12px;margin:0 8px;overflow:hidden}.sandbox-palette-area{padding:8px}.sandbox-layout[data-phase=playing] .sandbox-palette-area .sandbox-palette,.sandbox-layout[data-phase=playing] .sandbox-palette-area .sandbox-palette-actions,[data-mode=sandbox][data-phase=playing] .sandbox-palette-area .sandbox-palette,[data-mode=sandbox][data-phase=playing] .sandbox-palette-area .sandbox-palette-actions{pointer-events:none;opacity:.3}.sandbox-statusbar{padding:6px 16px;border-top:1px solid var(--border)}.sandbox-controls{display:flex;align-items:center;gap:6px;padding:6px 12px;border-top:1px solid var(--border);background:var(--bg-secondary)}.sandbox-fen-bar{display:flex;align-items:center;gap:6px}.sandbox-fen-bar-input{flex:1;min-width:0;padding:6px 10px;border:1px solid var(--border);border-radius:4px;background:var(--bg-primary);color:var(--text-muted);font-family:var(--font-mono);font-size:12px;outline:none}.sandbox-fen-bar-input:focus{border-color:var(--accent)}.sandbox-toggles-mobile{display:none}.sandbox-phase-bar{display:none;align-items:center;justify-content:center;gap:10px;padding:12px 16px}.sandbox-phase-hint{font-family:var(--font-body);font-size:14px;color:var(--text-muted)}.sandbox-layout[data-phase=playing] .sandbox-editing-only,[data-mode=sandbox][data-phase=playing] .sandbox-editing-only,.sandbox-layout[data-phase=editing] .sandbox-playing-only,[data-mode=sandbox][data-phase=editing] .sandbox-playing-only,.sandbox-topbar .sandbox-topbar-center{display:none}[data-mode=sandbox]>.gameplay-topbar>.gameplay-topbar-center{display:none}.sandbox-layout[data-phase=playing] .sandbox-phase-bar,[data-mode=sandbox][data-phase=playing] .sandbox-phase-bar,.sandbox-layout[data-phase=editing] .sandbox-measurement-toggle,[data-mode=sandbox][data-phase=editing] .sandbox-measurement-toggle{display:none}.sandbox-layout[data-phase=playing] .sandbox-toggle,[data-mode=sandbox][data-phase=playing] .sandbox-toggle{pointer-events:none;opacity:.4}.piece-bare{font-size:min(5.5vw,48px);line-height:1;-webkit-user-select:none;user-select:none}.piece-bare.piece-white{color:#fff;filter:drop-shadow(0 1px 0 rgba(0,0,0,.25)) drop-shadow(0 2px 4px rgba(0,0,0,.6))}.piece-bare.piece-black{color:var(--piece-black);filter:drop-shadow(0 -1px 0 rgba(255,255,255,.5)) drop-shadow(0 1px 0 rgba(0,0,0,.7)) drop-shadow(0 0 4px rgba(255,255,255,.2))}.piece-glow.piece-white{color:#fff;filter:drop-shadow(0 0 1px rgba(255,255,255,.8)) drop-shadow(0 1px 0 rgba(0,0,0,.25)) drop-shadow(0 2px 3px rgba(0,0,0,.5))}.piece-glow.piece-black{color:var(--piece-black);filter:drop-shadow(0 -1px 0 rgba(255,255,255,.5)) drop-shadow(0 1px 0 rgba(0,0,0,.7)) drop-shadow(0 0 4px rgba(255,255,255,.2))}.piece-outlined.piece-white{color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.7))}.piece-outlined.piece-white .piece-svg{stroke:var(--accent);stroke-width:1.5px;paint-order:stroke fill}.piece-outlined.piece-black{color:#0a0a0a;filter:drop-shadow(0 2px 4px rgba(0,0,0,.8))}.piece-outlined.piece-black .piece-svg{stroke:var(--accent);stroke-width:2px;paint-order:stroke fill}.piece-token-translucent{position:relative;display:inline-flex;align-items:center;justify-content:center;width:70%;height:70%;border-radius:999px;background:#ffffff0f;box-shadow:inset 0 0 0 1px #ffffff1a,0 2px 8px #0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.piece-token-translucent:has(.piece-white){background:#ffffff1a;box-shadow:inset 0 0 0 1px #ffffff2e,0 2px 8px #0000004d}.piece-token-translucent:has(.piece-black){background:#a08cb440;box-shadow:inset 0 0 0 1px #ffffff1a,0 2px 8px #0006}.piece-token-translucent .piece-symbol.piece-white{color:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.piece-token-translucent .piece-symbol.piece-black{color:var(--piece-black);filter:drop-shadow(0 -1px 0 rgba(255,255,255,.5)) drop-shadow(0 1px 0 rgba(0,0,0,.7)) drop-shadow(0 0 4px rgba(255,255,255,.2))}[data-sandbox-theme=void] .board{background:var(--border)}[data-sandbox-theme=void] .sandbox-topbar{border-bottom:1px solid var(--border)}[data-sandbox-theme=amber] .board{box-shadow:0 8px 40px #00000080,inset 0 0 0 1px var(--border);border-radius:6px;overflow:visible}[data-sandbox-theme=amber] .gameplay-right-panel{font-family:var(--font-body)}[data-sandbox-theme=quantum-lab] .gameplay-board-area{position:relative}[data-sandbox-theme=quantum-lab] .gameplay-board-area:before{content:"";position:absolute;top:50%;left:50%;width:500px;height:500px;background:radial-gradient(circle,rgba(255,45,120,.05),transparent 70%);transform:translate(-50%,-50%);pointer-events:none}[data-sandbox-theme=quantum-lab] .board{box-shadow:0 0 60px #ff2d780d,0 12px 40px #0006;border:1px solid var(--border);border-radius:12px;overflow:visible}[data-sandbox-theme=emerald] .sandbox-layout:after,[data-sandbox-theme=emerald][data-mode=sandbox]:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);pointer-events:none;z-index:100}[data-sandbox-theme=emerald] .board{border:1px solid var(--accent);background:var(--border)}[data-sandbox-theme=rose-glass] .sandbox-layout,[data-sandbox-theme=rose-glass][data-mode=sandbox]{background-image:radial-gradient(ellipse at 30% 20%,rgba(251,113,133,.05),transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(190,80,120,.03),transparent 50%)}[data-sandbox-theme=rose-glass] .gameplay-right-panel{background:#3c1e2d66;border-radius:16px;border:1px solid rgba(251,113,133,.12);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);margin:12px 0 12px 12px}[data-sandbox-theme=rose-glass] .sandbox-topbar,[data-sandbox-theme=rose-glass] .gameplay-topbar{background:#28141e99;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}[data-sandbox-theme=rose-glass] .board{box-shadow:0 0 80px #fb71850a,0 16px 48px #0006;border:1px solid rgba(251,113,133,.12);border-radius:16px;overflow:visible}[data-sandbox-theme=rose-glass] .sandbox-palette-area{background:#3c1e2d66;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(251,113,133,.12)}.sandbox-layout .board-container,[data-mode=sandbox] .board-container,.sandbox-layout .board-coords,[data-mode=sandbox] .board-coords{max-width:100%;max-height:100%}@media(max-width:768px){.gameplay-center-group,[data-mode=vs_ai] .gameplay-center,[data-mode=online] .gameplay-center,[data-mode=correspondence] .gameplay-center{flex-direction:column;gap:0;padding:8px}.gameplay-board-col{flex:0 0 auto;width:100%}.gameplay-top-slot,.gameplay-bottom-slot{width:100%;max-width:none;align-self:stretch}.gameplay-captured-panel{display:none}[data-mode=vs_ai] .gameplay-right-panel,[data-mode=online] .gameplay-right-panel,[data-mode=correspondence] .gameplay-right-panel{width:100%;height:auto;flex:1;min-height:0;border:none;border-top:1px solid var(--border);border-radius:0;margin:8px 0 0;padding:8px 12px;transform:none;background:var(--bg-secondary)}.gameplay-info-tabs{display:flex;gap:12px;padding:8px 0 4px;flex-shrink:0}.gameplay-right-panel .gameplay-tab-content{flex:1;min-height:0}.gameplay-right-panel .gameplay-tab-pane{display:none}.gameplay-right-panel .gameplay-tab-pane.active{display:block;flex:1;min-height:0;overflow-y:auto}.gameplay-right-panel .gameplay-captured-tab{display:none}.gameplay-right-panel .gameplay-captured-tab.active{display:block}.gameplay-right-panel .move-history-list{max-height:none}.board{--board-chrome-h: 220px;--board-chrome-w: 16px;max-width:none;max-height:none}.gameplay-eval-bar{position:static;display:flex;flex-direction:row;width:100%;gap:6px}.gameplay-eval-bar .eval-bar{flex-direction:column;gap:2px}.gameplay-eval-bar .eval-bar-track{width:100%;height:8px;min-height:8px}.gameplay-eval-bar .eval-bar-track--classical{border-radius:4px 4px 0 0}.gameplay-eval-bar .eval-bar-track--quantum{border-radius:0 0 4px 4px}.gameplay-eval-bar .eval-bar-fill{top:0;bottom:0;left:0;right:auto;height:100%!important;transition:width .6s ease;border-radius:4px 0 0 4px}.gameplay-eval-bar .eval-bar-fill--quantum{border-top:none;border-right:2px solid rgba(255,255,255,.6)}.gameplay-eval-bar .eval-bar-labels{flex-direction:column;gap:2px;min-width:28px}.piece-token,.piece-ring-wrap{width:92%;height:92%}.ring-gauge{top:-4px;right:-4px;bottom:-4px;left:-4px;width:calc(100% + 8px);height:calc(100% + 8px)}.gameplay-eval-bar .eval-bar-label{text-align:right;font-size:9px}.gameplay-controls{padding-bottom:calc(12px + env(safe-area-inset-bottom,0px))}.home-hero{padding:40px 20px 32px}.home-title{font-size:2.4rem}.mode-grid,.mode-grid--featured{grid-template-columns:1fr}.gameover-screen{padding:24px 16px}.gameover-title{font-size:2rem}.gameover-actions{flex-direction:column;width:100%;max-width:280px}.gameover-actions .btn{width:100%;min-height:48px}.gameover-stats{gap:10px}.stat{min-width:90px;padding:14px 18px}.setup-side-visual{flex-direction:column}.setup-screen{padding:24px 16px}.modal-dialog{padding:20px;width:94%}.modal-actions{flex-direction:column;gap:8px}.modal-actions .btn{width:100%;min-height:48px;justify-content:center}.play-overlay-root{align-items:stretch;justify-content:stretch}.play-overlay{clip-path:none!important;border-radius:0;width:100%;max-height:none;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:fade-in .2s ease}.play-overlay-body{padding:12px 16px 24px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.play-overlay-header{padding:16px 16px 0}.play-overlay-close{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.play-overlay-body .setup-side-visual{flex-direction:row}.play-overlay-body .setup-side-btn{padding:12px 8px}.play-overlay-body .setup-side-icon{font-size:28px}.play-overlay-body .btn-start{min-height:52px;font-size:16px}.option-btn{min-height:44px;padding:10px 16px}.btn-back{min-height:44px;padding:10px 0}.toast-container{top:12px;right:12px;left:12px}.toast{width:100%}.sandbox-layout,.sandbox-layout[data-sandbox-theme],[data-mode=sandbox]{display:flex!important;flex-direction:column!important;height:100vh!important;height:100dvh!important;overflow:hidden!important}.sandbox-center-group,[data-mode=sandbox] .gameplay-center{flex:1;min-height:0;flex-direction:column;align-items:stretch;gap:0;padding:0}.sandbox-center-group .sandbox-palette-area,[data-mode=sandbox] .gameplay-center .sandbox-palette-area{padding:clamp(4px,1vh,12px) 4px;order:2;align-self:center;width:auto;flex:0 0 auto}.sandbox-center-group .sandbox-palette-area .sandbox-editor,[data-mode=sandbox] .gameplay-center .sandbox-palette-area .sandbox-editor{margin-top:0;margin-bottom:0;transform:none}.sandbox-center-group .sandbox-board-col,[data-mode=sandbox] .gameplay-center .gameplay-board-col{flex:0 0 auto;order:1}.sandbox-center-group .sandbox-fen-bar,[data-mode=sandbox] .gameplay-center .sandbox-fen-bar{padding:clamp(4px,2vh,48px) 12px clamp(4px,1vh,12px)}.sandbox-center-group .gameplay-board-area,[data-mode=sandbox] .gameplay-center .gameplay-board-area{padding:4px 0 16px;display:flex;align-items:center;justify-content:center}.sandbox-fen-bar{padding:12px 16px 4px}.sandbox-fen-bar-input{font-size:14px}.sandbox-fen-copy,.sandbox-fen-paste{flex-shrink:0}.sandbox-phase-bar{grid-area:phasebar;display:flex;padding:clamp(4px,1vh,12px) 16px;font-size:clamp(11px,1.8vh,14px)}@media(max-height:700px){.sandbox-phase-bar{display:none}}.sandbox-toggles-mobile{grid-area:toggles;display:flex;align-items:center;justify-content:center;gap:14px;padding:6px 12px}.sandbox-toggles-mobile .sandbox-toggle{font-size:14px;gap:8px;min-height:36px}.sandbox-toggles-mobile .sandbox-toggle input[type=checkbox]{width:22px;height:22px}.sandbox-toggles-mobile .sandbox-toggle input[type=checkbox]:checked:after{font-size:16px;top:0;left:3px}.sandbox-toggles-mobile .sandbox-toggle-label{font-size:14px}.sandbox-toggles-mobile .sandbox-measurement-btn{padding:5px 12px;font-size:13px;min-height:32px}.sandbox-topbar .sandbox-toggles,.sandbox-topbar .sandbox-phase-pill{display:none}.sandbox-layout .gameplay-board-area,[data-mode=sandbox] .gameplay-board-area{display:flex;align-items:flex-end;justify-content:center;padding:4px 4px 2px;overflow:hidden}[data-mode=sandbox] .board{--board-chrome-h: 260px}[data-mode=sandbox][data-phase=playing] .board{--board-chrome-h: 280px}.sandbox-layout .sandbox-info-panel,[data-mode=sandbox] .gameplay-right-panel{width:100%;height:auto;flex:1;min-height:0;border:none;border-top:1px solid var(--border);border-radius:0;overflow:hidden;padding:8px 12px;margin-top:14px;flex-direction:column;transform:none;background:var(--bg-secondary);order:3}[data-mode=sandbox] .gameplay-right-panel .gameplay-moves-header{flex-shrink:0}[data-mode=sandbox] .gameplay-right-panel .gameplay-moves-panel{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}[data-mode=sandbox] .gameplay-right-panel .gameplay-move-history{flex:1;min-height:0;overflow-y:auto}[data-mode=sandbox] .gameplay-right-panel .gameplay-captured-tab{flex-shrink:0}.gameplay-info-tab[data-tab=captured]{display:inline}.gameplay-tab-pane{display:none}.gameplay-tab-pane.active{display:block;flex:1;min-height:0;overflow-y:auto}.gameplay-tab-content{flex:1;min-height:0}[data-mode=sandbox] .gameplay-right-panel .move-history{overflow:visible}[data-mode=sandbox] .gameplay-right-panel .move-history-list{max-height:none}[data-mode=sandbox][data-phase=editing] .gameplay-right-panel{display:none!important}[data-mode=sandbox][data-phase=playing] .gameplay-right-panel{display:flex!important}.sandbox-layout .sandbox-statusbar,[data-mode=sandbox] .sandbox-statusbar,.sandbox-layout[data-phase=playing] .sandbox-palette-area,[data-mode=sandbox][data-phase=playing] .sandbox-palette-area{display:none!important}.sandbox-layout[data-phase=playing] .sandbox-toggles-mobile .sandbox-toggle,[data-mode=sandbox][data-phase=playing] .sandbox-toggles-mobile .sandbox-toggle{display:none}.sandbox-topbar{padding:12px 16px;gap:8px;flex-wrap:wrap}.sandbox-phase-controls{gap:6px}.sandbox-phase-pill{font-size:11px;padding:5px 12px;min-height:28px;display:flex;align-items:center}.sandbox-play-toggle{font-size:12px;padding:5px 14px;min-height:32px}.sandbox-toggles{gap:10px;flex-wrap:wrap}.sandbox-toggle{font-size:12px;gap:6px;min-height:32px}.sandbox-toggle input[type=checkbox]{width:18px;height:18px}.sandbox-toggle input[type=checkbox]:checked:after{font-size:13px;top:0;left:2px}.sandbox-toggle-label{font-size:12px}.sandbox-measurement-btn{padding:4px 10px;font-size:11px;min-height:28px}.sandbox-topbar-actions{gap:2px}.btn-icon{min-width:36px;min-height:32px;padding:4px 8px;font-size:16px}.sandbox-palette-area{padding:2px 4px}.sandbox-editor{padding:2px 4px;background:none;border:none}.sandbox-palette-with-actions{flex-direction:column;justify-content:center}.sandbox-palette-actions{display:none}.sandbox-palette{flex-direction:column;gap:3px}.sandbox-palette-row{flex-direction:row;justify-content:center;gap:3px}.sandbox-palette-area .sandbox-piece{width:clamp(40px,7vh,60px);height:clamp(40px,7vh,60px)}.sandbox-piece .piece-symbol{font-size:34px}.sandbox-piece .piece-bare{font-size:38px}.sandbox-piece-token{width:42px;height:42px}.sandbox-fen-row{display:none}.sandbox-controls-play,.sandbox-controls-edit{display:inline-flex}.sandbox-layout[data-phase=playing] .sandbox-controls-edit,[data-mode=sandbox][data-phase=playing] .sandbox-controls-edit{pointer-events:none;opacity:.3}.sandbox-palette-play-btn{display:none}.sandbox-palette-actions{display:none!important}.sandbox-controls{justify-content:center;gap:8px;padding:clamp(4px,1.5vh,12px) 16px;padding-bottom:max(clamp(8px,2vh,20px),calc(env(safe-area-inset-bottom,8px) + 4px))}.sandbox-controls .btn,.sandbox-controls .btn-sm{min-height:clamp(32px,5vh,44px);padding:clamp(4px,1vh,8px) 20px;font-size:14px}.piece-bare,.piece-glow{font-size:min(9vw,42px)}.piece-symbol{font-size:min(8vw,36px)}}@media(max-width:480px){.home-title{font-size:1.8rem;letter-spacing:.06em}.home-hero{padding:24px 16px 20px}.home-subtitle{font-size:11px}.home-toolbar{flex-direction:column;align-items:flex-start}.mode-hero-card{padding:18px 16px 14px}.mode-hero-card-icon{font-size:22px}.mode-hero-card-label{font-size:15px}[data-mode=sandbox] .board{--board-chrome-h: 270px;--board-chrome-w: 12px}[data-mode=sandbox][data-phase=playing] .board{--board-chrome-h: 290px}.sandbox-palette-area .sandbox-piece{width:clamp(36px,6.5vh,52px);height:clamp(36px,6.5vh,52px)}.sandbox-piece .piece-symbol{font-size:28px}.sandbox-piece .piece-bare{font-size:32px}.sandbox-piece-token{width:36px;height:36px}.sandbox-topbar{padding:10px 16px;gap:6px}.sandbox-phase-pill{font-size:10px;padding:4px 10px;min-height:26px}.sandbox-play-toggle{font-size:11px;padding:4px 12px;min-height:28px}.sandbox-toggle{font-size:10px;min-height:28px}.sandbox-toggle input[type=checkbox]{width:16px;height:16px}.sandbox-measurement-btn{padding:3px 8px;font-size:10px;min-height:26px}.btn-icon{min-width:32px;min-height:28px;font-size:14px}.play-overlay-body{padding-bottom:calc(28px + env(safe-area-inset-bottom,0px))}.setup-section{padding:14px}.setup-time-custom{flex-direction:column;gap:10px}.setup-time-custom input{width:100%}}.play-overlay-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center}.play-overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.play-overlay{position:relative;z-index:1;background:var(--bg-secondary, #0c0a14);border:1px solid rgba(255,58,140,.12);border-radius:2px;width:min(440px,90vw);max-height:85vh;overflow-y:auto;box-shadow:0 24px 80px #000000b3,0 0 40px #ff3a8c0a;clip-path:var(--clip-corner);animation:fade-up .3s ease}.play-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.play-overlay-header h2{margin:0;font-size:20px;font-weight:600}.play-overlay-close{background:none;border:none;color:var(--text-muted, #888);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .15s,background .15s}.play-overlay-close:hover{color:var(--text-primary, #fff);background:var(--bg-hover, rgba(255, 255, 255, .08))}.play-overlay-body{padding:16px 24px 24px;display:flex;flex-direction:column;gap:16px}.play-overlay-body .btn-start{margin-top:8px;width:100%;padding:12px;font-size:16px}@keyframes ai-thinking-pulse{0%,to{opacity:.5}50%{opacity:1}}.player-banner.ai-thinking{animation:ai-thinking-pulse 2s ease-in-out infinite}@media(min-width:769px){.gameplay-board-col{position:relative}.gameplay-eval-bar{position:absolute;right:100%;top:0;bottom:0;display:flex;flex-direction:column;gap:3px;width:32px;margin-right:8px}.gameplay-eval-bar .eval-bar-fill{width:100%!important}}.eval-bar{display:flex;flex-direction:row;flex-shrink:0;gap:2px;flex:1}.eval-bar-track{flex:1;position:relative;overflow:hidden}.eval-bar-track--classical{border-radius:5px 0 0 5px;background:#ffffff14}.eval-bar-track--quantum{border-radius:0 5px 5px 0;background:#000}.eval-bar-fill{position:absolute;bottom:0;left:0;right:0;transition:height .6s ease;border-radius:0}.eval-bar-fill--classical{background:#ffffffb3}.eval-bar-fill--quantum{background:#e6267a;border-top:2px solid rgba(255,255,255,.6)}.eval-bar-labels{display:flex;flex-direction:row;justify-content:space-around;gap:2px;flex-shrink:0}.eval-bar-label{font-size:8px;line-height:1;font-variant-numeric:tabular-nums;font-family:var(--font-mono);white-space:nowrap;text-align:center;flex:1}.eval-bar-label--classical{color:#ffffffb3}.eval-bar-label--quantum{color:#e6267a}.promotion-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal, 100);background:#0000004d;border-radius:4px}.promotion-picker{position:absolute;display:flex;z-index:calc(var(--z-modal, 100) + 1);border-radius:var(--radius-md, 6px);overflow:hidden;box-shadow:0 8px 32px #0009,0 0 0 1px #00e5ff26,0 0 24px #00e5ff0f}.promotion-option{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1;border:none;cursor:pointer;background:var(--bg-secondary, #0c0a14);transition:background .12s,transform .1s;padding:0}.promotion-option:first-child{border-radius:var(--radius-md, 6px) var(--radius-md, 6px) 0 0}.promotion-option:last-child{border-radius:0 0 var(--radius-md, 6px) var(--radius-md, 6px)}.promotion-option:hover{background:var(--bg-tertiary, #141020);transform:scale(1.08);z-index:1}.promotion-option:active{transform:scale(.96)}.promotion-option .piece-token{display:flex;align-items:center;justify-content:center;width:80%;aspect-ratio:1;border-radius:50%}.promotion-option .piece-symbol{font-size:clamp(20px,4vw,36px);line-height:1}.online-lobby-screen{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.online-lobby-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;padding:2rem 1.5rem;max-width:640px;margin:0 auto;width:100%}.online-lobby-card{background:var(--surface-2, rgba(255 255 255 / .04));border:1px solid var(--border-1, rgba(255 255 255 / .08));border-radius:.75rem;padding:1.5rem;text-align:center;width:100%}.online-lobby-card--matchmaking{max-width:480px}.online-lobby-heading{font-family:var(--font-heading);font-size:1rem;font-weight:600;margin:0 0 .35rem;color:var(--text-1, #fff);letter-spacing:.06em;text-transform:uppercase}.online-lobby-desc{font-size:.8rem;color:var(--text-2, rgba(255 255 255 / .6));margin:0 0 1rem}.online-lobby-btn{min-width:120px}.online-lobby-divider{font-size:.75rem;color:var(--text-3, rgba(255 255 255 / .4));text-transform:uppercase;letter-spacing:.1em}.online-lobby-friend-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%}.matchmaking-options{display:flex;flex-direction:column;gap:1rem}.time-preset-group{display:flex;flex-direction:column;gap:.35rem}.time-preset-label{font-family:var(--font-heading);font-size:.65rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.time-preset-row{display:flex;gap:.5rem;justify-content:center}.option-btn--sm{padding:6px 14px;font-size:.8rem}.matchmaking-queue-btns{display:flex;gap:.75rem;justify-content:center;margin-top:.25rem}.matchmaking-status{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:1rem 0;font-size:.9rem;color:var(--text-secondary)}.matchmaking-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:matchmaking-spin .8s linear infinite}@keyframes matchmaking-spin{to{transform:rotate(360deg)}}.lobby-stats-bar{display:flex;align-items:center;gap:1rem;padding:.6rem 1rem;background:#ffffff08;border:1px solid var(--border);border-radius:.5rem;width:100%;flex-wrap:wrap}.lobby-stat-item{display:flex;align-items:center;gap:.4rem;white-space:nowrap}.lobby-stat-icon{font-size:.85rem}.lobby-stat-label{color:var(--text-muted);font-family:var(--font-heading);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase}.lobby-stat-value{font-family:var(--font-mono);font-size:.85rem;color:var(--accent);font-weight:600}.lobby-stat-divider{width:1px;height:1.2rem;background:var(--border-light)}.lobby-stat-breakdown{display:flex;gap:.4rem;flex-wrap:wrap;margin-left:auto}.lobby-stat-tc{font-family:var(--font-mono);font-size:.7rem;color:var(--text-secondary);padding:.15rem .5rem;background:#ffffff0a;border-radius:.25rem}.lobby-stat-count{color:var(--accent);font-weight:600}.lobby-stat-empty{font-size:.7rem;color:var(--text-muted);font-style:italic}.waiting-host-settings{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:420px}.waiting-setting-group{display:flex;flex-direction:column;gap:.5rem}.waiting-time-presets{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center}@media(max-width:640px){.online-lobby-body{padding:1rem 1rem 1.5rem;justify-content:flex-start}.online-lobby-friend-row{grid-template-columns:1fr}.online-lobby-btn{min-height:44px}.online-lobby-input{min-height:44px;font-size:1rem}.option-btn--sm{min-height:44px;padding:10px 14px}.online-lobby-card{padding:1.25rem 1rem}}.online-lobby-join-row{display:flex;gap:.75rem;justify-content:center}.online-lobby-input{background:var(--surface-1, rgba(255 255 255 / .06));border:1px solid var(--border-1, rgba(255 255 255 / .12));border-radius:.5rem;padding:.5rem .75rem;font-size:1.1rem;color:var(--text-1, #fff);text-transform:uppercase;letter-spacing:.15em;width:160px;text-align:center;font-family:monospace}.online-lobby-input::placeholder{color:var(--text-3, rgba(255 255 255 / .3));text-transform:none;letter-spacing:normal}.waiting-room-screen{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.waiting-room-body{flex:1;display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem 1rem;max-width:480px;margin:0 auto;width:100%}.waiting-room-code-section{text-align:center}.waiting-room-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-2, rgba(255 255 255 / .6));margin:0 0 .5rem}.waiting-room-code{font-size:2.5rem;font-weight:700;font-family:monospace;letter-spacing:.25em;color:var(--accent, #ff2d78);cursor:pointer;padding:.5rem 1rem;border:2px dashed var(--border-1, rgba(255 255 255 / .15));border-radius:.75rem;transition:border-color .2s}.waiting-room-code:hover{border-color:var(--accent, #ff2d78)}.waiting-room-hint{font-size:.8rem;color:var(--text-3, rgba(255 255 255 / .4));margin:.5rem 0 0}.waiting-room-players{width:100%}.waiting-room-players-heading{font-size:.9rem;font-weight:600;color:var(--text-2, rgba(255 255 255 / .7));margin:0 0 .75rem}.waiting-room-member-list{display:flex;flex-direction:column;gap:.5rem}.waiting-member{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--surface-2, rgba(255 255 255 / .04));border:1px solid var(--border-1, rgba(255 255 255 / .08));border-radius:.5rem}.waiting-member--self{border-color:var(--accent, #ff2d78)}.waiting-member--empty{color:var(--text-3, rgba(255 255 255 / .3));font-style:italic;justify-content:center;border-style:dashed}.waiting-member-name{font-weight:500;color:var(--text-1, #fff)}.waiting-member-role{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3, rgba(255 255 255 / .4))}.waiting-side-select{width:100%;text-align:center}.waiting-room-actions{display:flex;align-items:center;gap:1rem}.waiting-ready-btn{min-width:160px;font-size:1rem;padding:.75rem 1.5rem}.waiting-opponent-ready{font-size:.85rem;color:#4ade80;font-weight:500}.waiting-leave-btn{color:var(--text-3, rgba(255 255 255 / .4))}.waiting-room-status{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-3, rgba(255 255 255 / .4))}.waiting-connection-dot{width:8px;height:8px;border-radius:50%;background:#ef4444}.waiting-connection-dot.connected{background:#4ade80}.mode-hero-card--cyan{--hero-card-accent: #22d3ee;border-color:#22d3ee40;border-left:3px solid rgba(34,211,238,.7)}.mode-hero-card--cyan .mode-hero-card-bg{background:linear-gradient(135deg,#22d3ee1f,#22d3ee08)}.mode-hero-card--cyan .mode-hero-card-icon{color:#22d3ee}.mode-hero-card--cyan:after{border-left-color:#22d3ee80;border-top-color:#22d3ee80}.mode-hero-card--cyan:hover{border-color:#22d3ee80;box-shadow:0 8px 32px #00000080,0 0 40px #22d3ee1f}.mode-hero-card--cyan:hover:after{border-left-color:#22d3eecc;border-top-color:#22d3eecc}.mode-hero-card--cyan:hover .mode-hero-card-arrow{transform:translate(4px);color:#22d3ee}.mode-hero-card--cyan:hover .mode-hero-card-bg{opacity:1}.changelog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;animation:fade-in .2s ease}.changelog-overlay.hidden{display:none}.changelog-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#050810bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.changelog-panel{position:relative;background:var(--bg-secondary);border:1px solid rgba(0,229,255,.1);border-radius:2px;width:90%;max-width:520px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 24px 64px #0009,0 0 40px #00e5ff0a;animation:fade-up .3s ease;clip-path:var(--clip-corner)}.changelog-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 28px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.changelog-title{font-family:var(--font-heading);font-size:18px;font-weight:700;margin:0}.changelog-subtitle{font-size:12px;color:var(--text-muted);margin:4px 0 0}.changelog-close{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 8px;line-height:1;transition:color var(--duration-fast) ease}.changelog-close:hover{color:var(--text-primary)}.changelog-content{padding:20px 28px 28px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.changelog-intro{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}.changelog-empty{font-size:13px;color:var(--text-muted);margin:0}.changelog-entry{background:#ffffff05;border:1px solid var(--border);border-radius:2px;padding:16px 20px}.changelog-entry-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.changelog-entry-title{font-family:var(--font-heading);font-size:14px;font-weight:700;margin:0}.changelog-entry-date{font-size:11px;color:var(--text-muted);margin:2px 0 0}.changelog-badge{font-size:10px;font-family:var(--font-mono);font-weight:600;color:var(--accent, #00e5ff);background:#00e5ff14;border:1px solid rgba(0,229,255,.15);border-radius:2px;padding:2px 8px;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.changelog-entry-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.changelog-item h5{font-family:var(--font-heading);font-size:12px;font-weight:600;margin:0;color:var(--text-primary)}.changelog-item p{font-size:12px;color:var(--text-secondary);margin:2px 0 0;line-height:1.5}.changelog-item--heading{margin-top:6px}.changelog-item--heading h5{color:var(--text-muted);text-transform:uppercase;font-size:10px;letter-spacing:.1em}.changelog-item--bullet{padding-left:14px;position:relative}.changelog-item--bullet:before{content:"•";position:absolute;left:2px;color:var(--text-muted);font-size:12px}.changelog-notes{font-size:12px;color:var(--text-muted);font-style:italic;margin:12px 0 0;padding-left:12px;border-left:2px solid var(--border);line-height:1.5}.auth-screen{max-width:540px;margin:0 auto;padding:2rem 1rem}.auth-profile{display:flex;flex-direction:column;gap:1.5rem}.profile-header{display:flex;align-items:center;gap:1rem}.profile-header h2{margin:0;font-size:1.4rem}.profile-email{margin:0;font-size:.85rem;color:var(--text-muted)}.profile-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;flex-shrink:0}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.profile-stats .stat{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:var(--surface, #1a1a2e);border:1px solid var(--border, #333);border-radius:6px}.profile-stats .stat-value{font-size:1.3rem;font-weight:700}.profile-stats .stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:.2rem}.profile-games h3{font-size:1rem;margin:0 0 .75rem}.game-list{display:flex;flex-direction:column;gap:.5rem}.game-row{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:var(--surface, #1a1a2e);border:1px solid var(--border, #333);border-radius:4px;font-size:.85rem}.game-mode{font-weight:600;min-width:60px}.game-result{font-weight:600;min-width:80px}.game-result--decisive{color:var(--text)}.game-result--draw{color:var(--text-muted)}.game-moves,.game-quantum{color:var(--text-muted);font-size:.8rem}.game-date{margin-left:auto;color:var(--text-muted);font-size:.8rem}.auth-form{text-align:center;max-width:320px;margin:4rem auto 0}.auth-subtitle{color:var(--text-muted);margin:.5rem 0 1.5rem;font-size:.9rem}.auth-form .btn{display:block;width:100%;margin-bottom:.5rem}.auth-error{background:#dc262626;border:1px solid rgba(220,38,38,.4);color:#fca5a5;border-radius:8px;padding:.6rem .8rem;margin-bottom:1rem;font-size:.85rem;text-align:center}.auth-form .btn:disabled{opacity:.6;cursor:not-allowed}.leaderboard-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body)}.leaderboard-header{display:flex;align-items:center;gap:var(--space-5);padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border)}.leaderboard-title{font-family:var(--font-heading);font-size:1.4rem;font-weight:600;margin:0;background:var(--brand-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.leaderboard-body{flex:1;padding:var(--space-6);max-width:720px;width:100%;margin:0 auto}.leaderboard-loading,.leaderboard-empty{text-align:center;color:var(--text-muted);padding:var(--space-8) 0;font-size:.95rem}.leaderboard-table{display:flex;flex-direction:column;gap:2px}.lb-header-row{display:grid;grid-template-columns:48px 1fr 80px 64px 90px;align-items:center;padding:var(--space-3) var(--space-4);color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-light)}.lb-row{display:grid;grid-template-columns:48px 1fr 80px 64px 90px;align-items:center;padding:var(--space-4);border-radius:var(--radius-md);transition:background var(--duration-fast)}.lb-row:hover{background:var(--bg-tertiary)}.lb-row--me{background:#00e5ff0f;border:1px solid rgba(0,229,255,.15)}.lb-row--me:hover{background:#00e5ff1a}.lb-rank{font-family:var(--font-mono);font-size:.9rem;color:var(--text-secondary);text-align:center}.lb-rank--1{color:var(--accent-gold);font-weight:700;font-size:1.05rem}.lb-rank--2{color:silver;font-weight:700}.lb-rank--3{color:#cd7f32;font-weight:700}.lb-player{display:flex;align-items:center;gap:var(--space-3);min-width:0}.lb-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0}.lb-avatar--placeholder{display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);color:var(--text-secondary);font-size:.8rem;font-weight:600}.lb-username{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.9rem}.lb-you{color:var(--accent);font-size:.75rem}.lb-rating{font-family:var(--font-mono);font-weight:700;font-size:.95rem;color:var(--accent);text-align:right}.lb-games,.lb-wld{font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary);text-align:right}@media(max-width:540px){.lb-header-row,.lb-row{grid-template-columns:36px 1fr 60px 80px}.lb-games{display:none}.leaderboard-body{padding:var(--space-4)}}.public-profile-screen{max-width:540px;margin:0 auto;padding:2rem 1rem}.public-profile-card{display:flex;flex-direction:column;gap:1.5rem}.public-profile-loading,.public-profile-not-found,.public-profile-no-games{text-align:center;color:var(--text-muted);padding:3rem 1rem;font-size:.95rem}.public-profile-not-found h2{margin:0 0 .5rem;color:var(--text-primary)}.public-profile-badge{display:inline-block;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:.15em .5em;border-radius:3px;vertical-align:middle;margin-left:.4rem}.badge-free{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--text-muted)}.badge-premium{background:linear-gradient(135deg,#fbbf24,#ff6a2b);color:#000}.public-profile-meta{margin:.2rem 0 0;font-size:.8rem;color:var(--text-muted)}.public-profile-rating{display:flex;flex-direction:column;align-items:center;padding:1rem;background:var(--bg-elevated);border:1px solid var(--border, #333);border-radius:8px;gap:.2rem}.public-profile-rating-value{font-size:2.2rem;font-weight:800;font-family:var(--font-display, "Chakra Petch", sans-serif);background:var(--brand-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.public-profile-rating-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.public-profile-rd{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.public-profile-rd-tag{font-size:.65rem;padding:.1em .4em;border-radius:3px;background:var(--bg-tertiary);color:var(--text-muted);margin-left:.3rem}.profile-avatar-placeholder{width:56px;height:56px;border-radius:50%;background:var(--bg-elevated);border:2px solid var(--text-muted);flex-shrink:0}.game-result--win{color:#22c55e}.game-result--loss{color:#ef4444}.game-opponent-cell{font-size:.85rem;color:var(--text-secondary);min-width:80px}.game-opponent-link{color:var(--accent);cursor:pointer;text-decoration:none}.game-opponent-link:hover{text-decoration:underline}.game-opponent{color:var(--text-muted)}.lb-username--link{color:inherit;text-decoration:none;cursor:pointer}.lb-username--link:hover{color:var(--accent);text-decoration:underline}@media(max-width:540px){.public-profile-screen{padding:1rem .75rem}.profile-stats{grid-template-columns:repeat(3,1fr)}.game-row{flex-wrap:wrap;gap:.4rem}.game-opponent-cell{min-width:unset}}.mode-hero-card--purple{--card-accent: #8b5cf6;border-color:#8b5cf640;border-left:3px solid rgba(139,92,246,.7)}.mode-hero-card--purple .mode-hero-card-bg{background:radial-gradient(ellipse at 30% 20%,rgba(139,92,246,.25),transparent 70%)}.mode-hero-card--purple .mode-hero-card-icon{color:#8b5cf6}.mode-hero-card--purple:after{border-left-color:#8b5cf680;border-top-color:#8b5cf680}.mode-hero-card--purple:hover{border-color:#8b5cf680;box-shadow:0 8px 32px #00000080,0 0 40px #8b5cf61f}.mode-hero-card--purple:hover:after{border-left-color:#8b5cf6cc;border-top-color:#8b5cf6cc}.mode-hero-card--purple:hover .mode-hero-card-arrow{transform:translate(4px);color:#8b5cf6}.mode-hero-card--purple:hover .mode-hero-card-bg{opacity:1}.correspondence-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg-primary)}.corr-body{flex:1;max-width:640px;width:100%;margin:0 auto;padding:var(--space-6) var(--space-4)}.corr-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.corr-title{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0}.corr-new-btn{font-size:.85rem;padding:var(--space-2) var(--space-4)}.corr-empty,.corr-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-4);text-align:center}.corr-empty-text,.corr-loading-text{font-family:var(--font-body);font-size:1.1rem;color:var(--text-secondary);margin:0 0 var(--space-2) 0}.corr-empty-sub{font-family:var(--font-body);font-size:.9rem;color:var(--text-muted);margin:0}.corr-section{margin-bottom:var(--space-6)}.corr-section-title{font-family:var(--font-display);font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--space-3) 0}.corr-game-list{display:flex;flex-direction:column;gap:var(--space-2)}.corr-game-card{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid rgba(255,255,255,.06);border-radius:10px;cursor:pointer;transition:background .15s,border-color .15s;text-align:left;font-family:var(--font-body)}.corr-game-card:hover{background:var(--bg-tertiary);border-color:#ffffff1f}.corr-game-card--active{border-left:3px solid var(--accent)}.corr-game-card--completed{opacity:.7}.corr-game-card-left{display:flex;align-items:center;gap:var(--space-3);min-width:0}.corr-game-side{font-size:1.4rem;line-height:1;flex-shrink:0}.corr-game-info{display:flex;flex-direction:column;min-width:0}.corr-game-opponent{font-size:.95rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.corr-game-meta{font-size:.8rem;color:var(--text-muted)}.corr-game-card-right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.corr-game-time{font-size:.78rem;color:var(--text-muted);font-family:var(--font-mono);white-space:nowrap}.corr-badge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.corr-badge--your-turn{background:#00e5ff26;color:var(--accent);animation:corr-pulse 2s ease-in-out infinite}.corr-badge--waiting{background:#ffffff0f;color:var(--text-muted)}.corr-badge--won{background:#22c55e26;color:#22c55e}.corr-badge--lost{background:#ef444426;color:#ef4444}.corr-badge--draw{background:#fbbf2426;color:var(--accent-gold)}@keyframes corr-pulse{0%,to{opacity:1}50%{opacity:.6}}.corr-badge--code{background:#6366f126;color:#a5b4fc;font-family:monospace;font-size:13px;letter-spacing:2px;padding:4px 10px;-webkit-user-select:all;user-select:all}.corr-join-row{display:flex;gap:8px;align-items:center}.corr-input{flex:1;padding:10px 12px;font-size:15px;font-family:monospace;letter-spacing:2px;text-transform:uppercase;background:#ffffff0d;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#fff;outline:none;min-height:44px}.corr-input:focus{border-color:var(--accent-pink);box-shadow:0 0 0 2px #ff2d7826}.corr-input::placeholder{color:#ffffff40;letter-spacing:1px}.corr-challenge-card{border-style:dashed}.btn-small{padding:4px 12px;font-size:12px}@media(max-width:540px){.corr-body{padding:var(--space-4) var(--space-3)}.corr-game-card{padding:var(--space-3) var(--space-3);min-height:56px}.corr-game-time{display:none}.corr-new-btn{min-height:44px;padding:var(--space-2) var(--space-4)}.corr-join-row .btn{min-height:44px}}.spectate-list-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg-primary)}.spectate-list-body{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-6) var(--space-5);max-width:700px;margin:0 auto;width:100%}.spectate-loading{color:var(--text-secondary);font-family:var(--font-body);font-size:1rem;padding:var(--space-8) 0;text-align:center}.spectate-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-8) var(--space-5);text-align:center}.spectate-empty-icon{font-size:3rem;opacity:.5}.spectate-empty-title{font-family:var(--font-heading);font-size:1.4rem;color:var(--text-primary);margin:0}.spectate-empty-desc{font-family:var(--font-body);font-size:.9rem;color:var(--text-secondary);margin:0;max-width:320px}.spectate-game-list{display:flex;flex-direction:column;gap:var(--space-3);width:100%}.spectate-game-card{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5) var(--space-5);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--duration-fast),background var(--duration-fast);text-align:left;width:100%;font-family:var(--font-body);color:var(--text-primary)}.spectate-game-card:hover{border-color:var(--accent);background:var(--bg-tertiary)}.spectate-game-players{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.spectate-player{display:flex;align-items:center;gap:var(--space-2)}.spectate-player-piece{font-size:1.2rem;display:inline-flex;align-items:center}.spectate-player-piece .piece-svg{width:1em;height:1em}.spectate-player--white .spectate-player-piece{color:var(--piece-white)}.spectate-player--black .spectate-player-piece{color:var(--accent-orange)}.spectate-player-name{font-size:.95rem;font-weight:600;color:var(--text-primary)}.spectate-vs{font-size:.8rem;color:var(--text-muted);font-style:italic}.spectate-game-meta{display:flex;gap:var(--space-4);flex-wrap:wrap}.spectate-meta-item{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.spectate-view-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg-primary)}.spectate-view-body{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-4) var(--space-5);gap:var(--space-4)}.spectate-view-info{text-align:center}.spectate-view-players{display:flex;align-items:center;gap:var(--space-4);justify-content:center;flex-wrap:wrap}.spectate-view-player{display:flex;align-items:center;gap:var(--space-2)}.spectate-view-player-piece{font-size:1.4rem;display:inline-flex;align-items:center}.spectate-view-player-piece .piece-svg{width:1em;height:1em}.spectate-view-player-piece.piece-white{color:var(--piece-white)}.spectate-view-player-piece.piece-black{color:var(--accent-orange)}.spectate-view-player-name{font-family:var(--font-heading);font-size:1.05rem;color:var(--text-primary);font-weight:600}.spectate-view-vs{font-size:.85rem;color:var(--text-muted);font-style:italic}.spectate-view-board-wrap{width:100%;max-width:min(80vw,80vh,560px);aspect-ratio:1}.spectate-board{display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);width:100%;height:100%;border-radius:var(--radius-lg);overflow:hidden;border:2px solid var(--border-light)}.spectate-square{position:relative;display:flex;align-items:center;justify-content:center;user-select:none;-webkit-user-select:none}.spectate-square.light{background:var(--board-light)}.spectate-square.dark{background:var(--board-dark)}.spectate-square.quantum{box-shadow:inset 0 0 8px #ff3a8c40}.spectate-piece{font-size:clamp(1.2rem,5vw,2.8rem);line-height:1;pointer-events:none;display:flex;align-items:center;justify-content:center}.spectate-piece .piece-svg{width:1em;height:1em}.spectate-square.piece-white .spectate-piece{color:var(--piece-white);filter:drop-shadow(0 1px 4px rgba(0,0,0,.5))}.spectate-square.piece-black .spectate-piece{color:var(--accent-orange);filter:drop-shadow(0 1px 4px rgba(0,0,0,.5))}.spectate-view-status{text-align:center}.spectate-view-meta{display:flex;gap:var(--space-5);justify-content:center;flex-wrap:wrap;padding:var(--space-2) 0}.spectate-status-badge{font-weight:600;text-transform:uppercase;letter-spacing:.04em}.spectate-status-badge--live{color:var(--success)}.spectate-status-badge--completed{color:var(--text-muted)}@media(max-width:600px){.spectate-list-body{padding:var(--space-4) var(--space-3)}.spectate-game-card{padding:var(--space-4)}.spectate-view-board-wrap{max-width:95vw}.spectate-view-players{gap:var(--space-2)}.spectate-view-player-name{font-size:.9rem}}.consent-banner{position:fixed;bottom:0;left:0;right:0;z-index:10000;padding:var(--space-5);background:var(--bg-elevated);border-top:1px solid var(--border-light);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);animation:consent-slide-up .3s ease-out}@keyframes consent-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.consent-banner-inner{max-width:960px;margin:0 auto;display:flex;align-items:center;gap:var(--space-6)}.consent-banner-text{flex:1}.consent-banner-text p{font-family:var(--font-body);font-size:.85rem;color:var(--text-secondary);line-height:1.5;margin:0}.consent-banner-text a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.consent-banner-actions{display:flex;gap:var(--space-3);flex-shrink:0}.consent-btn{font-family:var(--font-heading);font-size:.85rem;padding:var(--space-3) var(--space-6);border:none;border-radius:var(--radius-md);cursor:pointer;transition:opacity .15s}.consent-btn:hover{opacity:.85}.consent-btn--accept{background:var(--brand-gradient);color:#fff}.consent-btn--decline{background:transparent;color:var(--text-secondary);border:1px solid var(--border-light)}@media(max-width:600px){.consent-banner-inner{flex-direction:column;text-align:center;gap:var(--space-4)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-to-content{position:absolute;top:-100%;left:0;z-index:10000;padding:8px 16px;background:var(--accent);color:var(--bg-primary);font-family:Chakra Petch,sans-serif;font-weight:600;letter-spacing:.04em;text-decoration:none;transition:top .15s ease}.skip-to-content:focus{top:12px;outline:none}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 4px #00e5ff26}.btn-primary:focus-visible{outline-color:#fff;box-shadow:0 0 0 4px #ff3a8c40}.square:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;z-index:3}.option-btn:focus-visible,.setup-side-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.mode-hero-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 4px #00e5ff26}.toast-close:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.promotion-option:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.sandbox-menu-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.consent-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.home-hero-glow,.mode-hero-card-bg{animation:none!important;opacity:.3}.toast,.modal-backdrop,.modal-dialog{animation:none!important}.ring-gauge circle{animation:none!important}.entanglement-ring circle{animation:none!important}.consent-banner{animation:none!important}}@media(prefers-contrast:more){:root{--bg-primary: #000000;--bg-secondary: #0a0a0a;--bg-tertiary: #141414;--bg-elevated: #1e1e1e;--text-primary: #ffffff;--text-secondary: #cccccc;--text-muted: #888888;--border: rgba(255, 255, 255, .25);--border-light: rgba(255, 255, 255, .4);--board-light: #2a2a5a;--board-dark: #0a0a2a}.btn{border-width:2px}.btn-primary{border-color:#ff3a8ccc}.btn-secondary{border-color:#ffffff80}.square{border:1px solid rgba(255,255,255,.12)}.square.selected{border-color:var(--selection);border-width:2px}.square.legal-target{border-color:var(--legal-target);border-width:2px}.toast{border-width:2px}.toast-info{border-color:#00e5ff99}.toast-success{border-color:#22c55e99}.toast-warning{border-color:#f59e0b99}.toast-error{border-color:#ef444499}.modal-dialog{border-width:2px;border-color:#ff3a8c66}.exact-probability-badge{font-weight:700;border:1px solid rgba(255,255,255,.3)}.piece-symbol{filter:contrast(1.2)}*:focus-visible{outline-width:3px}}.pwa-install-banner{position:fixed;bottom:16px;left:50%;transform:translate(-50%);z-index:9000;display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 24px #00000080;font-family:Oxanium,sans-serif;font-size:.85rem;color:var(--text-secondary);max-width:calc(100vw - 32px)}.pwa-install-btn{padding:6px 14px;border:none;border-radius:6px;background:var(--accent);color:var(--bg-primary);font-family:Chakra Petch,sans-serif;font-weight:600;font-size:.8rem;cursor:pointer;white-space:nowrap;transition:opacity .15s}.pwa-install-btn:hover{opacity:.85}.pwa-install-dismiss{background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;padding:2px 4px;line-height:1}.pwa-install-dismiss:hover{color:var(--text-primary)}.guide-screen{display:flex;flex-direction:column;height:100dvh;background:var(--bg-primary);color:var(--text-primary)}.guide-topbar{display:flex;align-items:center;gap:12px;padding:8px 16px;background:var(--bg-secondary, rgba(255,255,255,.03));border-bottom:1px solid var(--border, rgba(255,255,255,.06));flex-shrink:0}.guide-back-btn{font-size:.85rem;opacity:.7}.guide-back-btn:hover{opacity:1}.guide-topbar-nav{display:flex;gap:4px;margin-left:auto}.guide-tab{padding:6px 14px;border-radius:6px;font-size:.85rem;color:var(--text-muted, rgba(255,255,255,.5));text-decoration:none;transition:background .15s,color .15s}.guide-tab:hover{color:var(--text-primary);background:#ffffff0d}.guide-tab.active{color:var(--accent, #00e5ff);background:#00e5ff14}.guide-layout{display:flex;flex:1;min-height:0;overflow:hidden}.guide-sidebar{width:200px;flex-shrink:0;padding:20px 12px;border-right:1px solid var(--border, rgba(255,255,255,.06));overflow-y:auto;display:flex;flex-direction:column;gap:2px}.guide-sidebar-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted, rgba(255,255,255,.4));margin-bottom:8px;padding:0 8px}.guide-sidebar-link{display:block;padding:5px 8px;border-radius:4px;font-size:.8rem;color:var(--text-muted, rgba(255,255,255,.55));text-decoration:none;transition:background .15s,color .15s}.guide-sidebar-link:hover{color:var(--text-primary);background:#ffffff0d}.guide-content{flex:1;overflow-y:auto;padding:32px 48px 80px;max-width:800px}.guide-screen--index .guide-content{max-width:960px;margin:0 auto}.guide-article h1{font-family:var(--font-display, "Chakra Petch", sans-serif);font-size:2rem;font-weight:700;margin:0 0 8px;background:linear-gradient(135deg,#ff3a8c,#ff6a2b,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.guide-lead{font-size:1.05rem;color:var(--text-muted, rgba(255,255,255,.6));margin:0 0 32px;line-height:1.6}.guide-section{margin-bottom:48px;scroll-margin-top:24px}.guide-section h2{font-family:var(--font-display, "Chakra Petch", sans-serif);font-size:1.35rem;font-weight:600;margin:0 0 12px;color:var(--text-primary)}.guide-section h3{font-size:1rem;font-weight:600;margin:24px 0 8px;color:var(--text-primary);opacity:.85}.guide-section p{font-size:.92rem;line-height:1.7;margin:0 0 12px;color:var(--text-secondary, rgba(255,255,255,.75))}.guide-section ul,.guide-section ol{padding-left:20px;margin:0 0 16px}.guide-section li{font-size:.92rem;line-height:1.7;margin-bottom:4px;color:var(--text-secondary, rgba(255,255,255,.75))}.guide-section strong{color:var(--text-primary)}.guide-section em{font-style:italic;color:var(--accent, #00e5ff)}.guide-section code{font-family:var(--font-mono, "JetBrains Mono", monospace);font-size:.85em;background:#ffffff0f;padding:2px 6px;border-radius:3px}.guide-section--muted{opacity:.6}.diagram-row{display:flex;align-items:center;gap:16px;margin:16px 0;flex-wrap:nowrap}.diagram-row--wrap{flex-wrap:wrap}.diagram-arrow{font-size:1.4rem;color:var(--text-muted, rgba(255,255,255,.4))}.diagram-callout{margin:20px 0;padding:16px;border-radius:8px;background:#ffffff05;border:1px solid rgba(255,255,255,.06)}.demo-piece-wrap{display:inline-flex;flex-direction:column;align-items:center;gap:6px}.demo-piece-square{position:relative;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#ffffff0a;border-radius:8px}.demo-piece-square--dark{background:#00000080;border-radius:50%}.guide-measure-icon{display:flex;align-items:center;justify-content:center;width:80%;height:80%}.guide-measure-icon svg{width:100%;height:100%;filter:drop-shadow(0 0 6px rgba(56,233,233,.5))}.demo-piece-square .ring-gauge{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;width:calc(100% + 8px);height:calc(100% + 8px)}.demo-piece-square .entanglement-ring{position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;width:calc(100% + 20px);height:calc(100% + 20px)}.demo-piece-square .phase-indicator{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.demo-piece-square .piece-token,.demo-piece-square .piece-symbol{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:999px}.demo-piece-square .piece-svg{width:28px;height:28px}.demo-piece-label{font-size:.7rem;color:var(--text-muted, rgba(255,255,255,.5));text-align:center;max-width:80px;line-height:1.3}.inline-piece{display:inline-flex;align-items:center;justify-content:center;width:1.2em;height:1.2em;vertical-align:-.15em}.inline-piece .piece-svg{width:100%;height:100%}.mini-board-figure{margin:16px 0;display:inline-block}.mini-board{display:grid;gap:0;border-radius:6px;overflow:hidden;border:1px solid rgba(255,255,255,.08);position:relative}.mini-board-figure.mini-board-sm .mini-board{width:min(280px,70vw)}.mini-board-figure.mini-board-md .mini-board{width:min(360px,80vw)}.mini-board-figure.mini-board-lg .mini-board{width:min(440px,85vw)}.mini-sq{aspect-ratio:1}.mini-sq.square{border-color:transparent!important}.mini-sq.square.selected{box-shadow:inset 0 0 0 2px var(--accent, #00e5ff)}.mini-sq.square.legal-target{box-shadow:inset 0 0 0 2px var(--legal-target, #22c55e)}.mini-sq.square.last-move{box-shadow:none}.sq-light{background:#ffffff14}.sq-dark{background:#ffffff08}.sq-light.last-move{background:#fa03}.sq-dark.last-move{background:#ffaa0026}.mini-sq .piece-symbol{font-size:24px}.mini-sq .ring-gauge{position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;width:calc(100% + 4px);height:calc(100% + 4px);z-index:2}.mini-board-label{position:absolute;bottom:1px;left:50%;transform:translate(-50%);font-size:.55rem;color:var(--text-muted, rgba(255,255,255,.5));white-space:nowrap;pointer-events:none}.mini-board-caption{font-size:.8rem;color:var(--text-muted, rgba(255,255,255,.5));margin-top:8px;text-align:center;font-style:italic}.mini-coord-rank{position:absolute;top:2px;left:3px;font-size:.5rem;color:var(--text-muted, rgba(255,255,255,.3));pointer-events:none}.mini-coord-file{position:absolute;bottom:2px;right:3px;font-size:.5rem;color:var(--text-muted, rgba(255,255,255,.3));pointer-events:none}.mini-web-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:4}.step-sequence{display:flex;align-items:flex-start;gap:8px;margin:16px 0;overflow-x:auto;padding-bottom:8px}.step-item{display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0}.step-number{width:22px;height:22px;border-radius:50%;background:var(--accent, #00e5ff);color:#000;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700}.step-label{font-size:.75rem;color:var(--text-muted, rgba(255,255,255,.55));text-align:center;max-width:180px;line-height:1.3}.step-arrow{font-size:1.4rem;color:var(--text-muted, rgba(255,255,255,.3));align-self:center;margin-top:24px}.mode-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.mode-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.mode-icon--orange{background:#ff6a2b26}.mode-icon--magenta{background:#ff3a8c26}.mode-icon--cyan{background:#00e5ff26}.mode-icon--purple{background:#8b5cf626}.mode-header h2{margin:0}.notation-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:.85rem}.notation-table th{text-align:left;padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.1);color:var(--text-muted, rgba(255,255,255,.5));font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.notation-table td{padding:6px 12px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text-secondary, rgba(255,255,255,.75))}.notation-table code{font-family:var(--font-mono, "JetBrains Mono", monospace);font-size:.85em;background:#ffffff0f;padding:2px 6px;border-radius:3px}.coming-soon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:12px}.coming-soon-item{padding:16px;border-radius:8px;background:#ffffff05;border:1px dashed rgba(255,255,255,.08)}.coming-soon-icon{font-size:1.5rem;margin-bottom:8px;display:block}.coming-soon-item h3{margin:0 0 4px;font-size:.95rem}.coming-soon-item p{font-size:.82rem;margin:0}.guide-index{padding:32px 0}.guide-index-header{text-align:center;margin-bottom:40px}.guide-index-header h1{font-family:var(--font-display, "Chakra Petch", sans-serif);font-size:2.2rem;font-weight:700;margin:0 0 8px;background:linear-gradient(135deg,#ff3a8c,#ff6a2b,#fbbf24);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.guide-index-subtitle{font-size:1rem;color:var(--text-muted, rgba(255,255,255,.55));margin:0}.guide-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.guide-card{display:flex;flex-direction:column;padding:24px;border-radius:12px;text-decoration:none;color:var(--text-primary);background:#ffffff08;border:1px solid rgba(255,255,255,.06);transition:background .2s,border-color .2s,transform .2s;position:relative;overflow:hidden}.guide-card:hover{background:#ffffff0d;border-color:#ffffff1a;transform:translateY(-2px)}.guide-card--magenta:hover{border-color:#ff3a8c4d}.guide-card--cyan:hover{border-color:#00e5ff4d}.guide-card--orange:hover{border-color:#ff6a2b4d}.guide-card--green:hover{border-color:#34d3994d}.guide-card-icon{font-size:2rem;margin-bottom:12px}.guide-card-title{font-family:var(--font-display, "Chakra Petch", sans-serif);font-size:1.2rem;font-weight:600;margin:0 0 6px}.guide-card-desc{font-size:.85rem;color:var(--text-muted, rgba(255,255,255,.55));line-height:1.5;margin:0;flex:1}.guide-card-arrow{font-size:1.2rem;margin-top:12px;color:var(--text-muted, rgba(255,255,255,.3));transition:color .15s,transform .15s}.guide-card:hover .guide-card-arrow{color:var(--text-primary);transform:translate(4px)}.idemo{display:flex;flex-direction:column;align-items:center;gap:12px}.idemo-hint{font-size:.88rem;color:var(--text-secondary, rgba(255,255,255,.75));text-align:center;min-height:1.4em;transition:color .2s}.idemo-hint--done{color:var(--accent, #00e5ff);font-weight:600}.idemo-board-wrap{touch-action:none;user-select:none;-webkit-user-select:none}.idemo-board{display:grid;gap:0;border-radius:6px;overflow:hidden;border:1px solid rgba(255,255,255,.08);width:280px;position:relative;cursor:pointer}.idemo-sq{aspect-ratio:1}.idemo-sq.square{border-color:transparent!important}.idemo-sq.square.selected{box-shadow:inset 0 0 0 2px var(--accent, #00e5ff)}.idemo-sq.square.legal-target{box-shadow:inset 0 0 0 2px var(--legal-target, #22c55e)}.idemo-sq.square.last-move{box-shadow:none}.idemo-board .piece-symbol{font-size:28px;pointer-events:none}.idemo-board .piece-token{pointer-events:none}.idemo-coord-rank{position:absolute;top:1px;left:2px;font-size:.5rem;line-height:1;color:#ffffff4d;pointer-events:none;z-index:5}.idemo-coord-file{position:absolute;bottom:1px;right:2px;font-size:.5rem;line-height:1;color:#ffffff4d;pointer-events:none;z-index:5}.idemo-sq .ring-gauge{position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;width:calc(100% + 4px);height:calc(100% + 4px);z-index:2;pointer-events:none}.idemo-piece-picker{display:flex;gap:4px;flex-wrap:wrap;justify-content:center}.idemo-piece-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--text-muted, rgba(255,255,255,.5));cursor:pointer;transition:background .15s,border-color .15s,color .15s}.idemo-piece-btn:hover{background:#ffffff0f;color:var(--text-primary)}.idemo-piece-btn.active{background:#00e5ff1a;border-color:#00e5ff4d;color:var(--text-primary)}.idemo-piece-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.idemo-piece-icon .piece-svg{width:20px;height:20px}.idemo-piece-label{font-size:.65rem;line-height:1}.idemo-scenario-bar{display:flex;gap:4px;justify-content:center}.idemo-scenario-btn{padding:3px 10px;border-radius:4px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--text-muted, rgba(255,255,255,.5));font-size:.75rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.idemo-scenario-btn:hover{background:#ffffff0f;color:var(--text-primary)}.idemo-scenario-btn.active{background:#00e5ff14;border-color:#00e5ff40;color:var(--accent, #00e5ff)}.idemo-scenario-wrap{min-height:28px}.idemo-success-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000040;border-radius:inherit;pointer-events:none;z-index:10;animation:idemo-success-fade .3s ease}@keyframes idemo-success-fade{0%{opacity:0}to{opacity:1}}.idemo-success-check{width:48px;height:48px;filter:drop-shadow(0 0 10px rgba(52,211,153,.5))}.idemo-check-circle{stroke-dasharray:151;stroke-dashoffset:151;animation:idemo-circle-draw .4s ease .1s forwards}@keyframes idemo-circle-draw{to{stroke-dashoffset:0}}.idemo-check-path{stroke-dasharray:40;stroke-dashoffset:40;animation:idemo-check-draw .3s ease .35s forwards}@keyframes idemo-check-draw{to{stroke-dashoffset:0}}.idemo-shake{animation:idemo-shake .4s ease}@keyframes idemo-shake{0%,to{transform:translate(0)}15%{transform:translate(-6px)}30%{transform:translate(5px)}45%{transform:translate(-4px)}60%{transform:translate(3px)}75%{transform:translate(-2px)}}.idemo-disabled-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0000004d;border-radius:inherit;pointer-events:none;z-index:10;animation:idemo-success-fade .2s ease}.idemo-disabled-x{width:44px;height:44px;filter:drop-shadow(0 0 8px rgba(239,68,68,.4))}.idemo-x-circle{stroke-dasharray:151;stroke-dashoffset:151;animation:idemo-circle-draw .3s ease forwards}.idemo-x-line1{stroke-dasharray:23;stroke-dashoffset:23;animation:idemo-check-draw .2s ease .15s forwards}.idemo-x-line2{stroke-dasharray:23;stroke-dashoffset:23;animation:idemo-check-draw .2s ease .25s forwards}.idemo-hint--disabled{color:var(--text-muted, rgba(255,255,255,.45));font-style:italic}.idemo-hint--error{color:#ef4444e6;font-weight:600}.idemo-measurement-pair{max-width:100%}.idemo-measurement-boards{display:flex;gap:16px;justify-content:center;align-items:flex-start}.idemo-measurement-col{display:flex;flex-direction:column;align-items:center;gap:6px}.idemo-measurement-label{font-family:var(--font-mono, "JetBrains Mono", monospace);font-size:.85rem;font-weight:700;padding:2px 10px;border-radius:4px}.idemo-measurement-label--m0{color:#ef4444d9;background:#ef44441a}.idemo-measurement-label--m1{color:#34d399e6;background:#34d3991a}.idemo-measurement-label--detail{font-weight:500;font-size:.72rem;font-family:var(--font-body, "Oxanium", sans-serif);line-height:1.4;padding:4px 8px;text-align:center;max-width:200px}.idemo-measurement-col .idemo-board{width:200px}.idemo-measure-eye,.idemo-measure-result{position:absolute;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:10;background:#000000b3;border-radius:50%}.idemo-measure-eye svg{width:85%;height:85%}.idemo-measure-result svg{width:55%;height:55%}.idemo-measure-eye svg{filter:drop-shadow(0 0 8px rgba(56,233,233,.8)) drop-shadow(0 0 16px rgba(56,233,233,.4))}.idemo-measure-eye{transform:translate(-50%,-65%);animation:idemo-eye-pulse .8s ease-in-out infinite}@keyframes idemo-eye-pulse{0%,to{opacity:.7;transform:translate(-50%,-65%) scale(.9)}50%{opacity:1;transform:translate(-50%,-65%) scale(1.1)}}.idemo-measure-result{animation:idemo-result-pop .3s ease}.idemo-measure-result svg{filter:drop-shadow(0 0 4px currentColor)}@keyframes idemo-result-pop{0%{transform:translate(-50%,-50%) scale(.4);opacity:0}60%{transform:translate(-50%,-50%) scale(1.15)}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.idemo-hint-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:10}.idemo-hint-tap{position:absolute;transform:translate(-50%,-50%);border-radius:50%;border:2px solid rgba(0,229,255,.6);animation:idemo-pulse 1.5s ease-in-out infinite;box-shadow:0 0 12px #00e5ff4d}@keyframes idemo-pulse{0%,to{transform:translate(-50%,-50%) scale(.8);opacity:.4}50%{transform:translate(-50%,-50%) scale(1.1);opacity:1}}.idemo-hint-drag{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.idemo-reset{font-size:.75rem;padding:4px 14px;border-radius:4px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--text-muted, rgba(255,255,255,.5));cursor:pointer;transition:background .15s,color .15s}.idemo-reset:hover{background:#ffffff14;color:var(--text-primary)}.touch-only{display:none}.desktop-only{display:revert}@media(pointer:coarse){.desktop-only{display:none}.touch-only{display:revert}}@media(max-width:768px){.guide-sidebar{display:none}.guide-content{padding:20px 16px 60px}.guide-topbar-nav{gap:2px}.guide-tab{padding:4px 10px;font-size:.8rem}.step-sequence{gap:4px}.guide-cards{grid-template-columns:1fr}.idemo-board{width:min(85vw,320px)}.idemo-measurement-col .idemo-board{width:min(42vw,180px)}.idemo-measurement-boards{gap:8px}}.replay-screen{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg-primary)}.replay-body{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-4) var(--space-6);gap:var(--space-3)}.replay-loading,.replay-error{display:flex;align-items:center;justify-content:center;padding:var(--space-16);color:var(--text-secondary);font-family:var(--font-heading);font-size:1.1rem}.replay-players{display:flex;align-items:center;gap:var(--space-4);justify-content:center;flex-wrap:wrap}.replay-player{display:flex;align-items:center;gap:var(--space-2)}.replay-player-piece{font-size:1.4rem;display:inline-flex;align-items:center}.replay-player-piece .piece-svg{width:1em;height:1em}.replay-player-piece.piece-white{color:var(--piece-white)}.replay-player-piece.piece-black{color:var(--accent-orange)}.replay-player-name{font-family:var(--font-heading);font-size:1.05rem;color:var(--text-primary);font-weight:600}.replay-result-badge{font-family:var(--font-heading);font-size:.9rem;font-weight:700;color:var(--accent-magenta);background:#ff2d781a;border:1px solid rgba(255,45,120,.25);border-radius:var(--radius-md);padding:var(--space-1) var(--space-3)}.replay-result-detail{font-family:var(--font-body);font-size:.85rem;color:var(--text-secondary);text-align:center}.replay-main{display:flex;gap:var(--space-6);width:100%;max-width:900px;justify-content:center;align-items:flex-start}.replay-board-column{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.replay-board-wrap{width:min(65vw,65vh,480px);aspect-ratio:1}.replay-board{display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);width:100%;height:100%;border-radius:var(--radius-lg);overflow:hidden;border:2px solid var(--border-light)}.replay-square{position:relative;display:flex;align-items:center;justify-content:center;user-select:none;-webkit-user-select:none}.replay-square.light{background:var(--board-light)}.replay-square.dark{background:var(--board-dark)}.replay-square.quantum{box-shadow:inset 0 0 8px #ff3a8c40}.replay-square.replay-last-move{background:#ffbf002e}.replay-square.light.replay-last-move{background:#ffbf0038}.replay-piece{font-size:clamp(1.2rem,5vw,2.8rem);line-height:1;pointer-events:none;display:flex;align-items:center;justify-content:center}.replay-piece .piece-svg{width:1em;height:1em}.replay-square.piece-white .replay-piece{color:var(--piece-white);filter:drop-shadow(0 1px 4px rgba(0,0,0,.5))}.replay-square.piece-black .replay-piece{color:var(--accent-orange);filter:drop-shadow(0 1px 4px rgba(0,0,0,.5))}.replay-controls{display:flex;align-items:center;gap:var(--space-2)}.replay-btn{font-family:var(--font-heading);font-size:1.2rem;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-light);border-radius:var(--radius-md);background:#14102099;color:var(--text-primary);cursor:pointer;transition:background .15s,border-color .15s}.replay-btn:hover{background:#ff2d781f;border-color:var(--accent-magenta)}.replay-btn--play{background:#ff2d7826;color:var(--accent-magenta);font-size:1rem}.replay-btn--speed{font-size:.8rem;width:40px;color:var(--text-secondary)}.replay-ply-indicator{font-family:var(--font-body);font-size:.85rem;color:var(--text-secondary);text-align:center}.replay-sidebar{width:220px;flex-shrink:0;border-radius:var(--radius-md);background:#14102099;border:1px solid var(--border-light);display:flex;flex-direction:column;max-height:min(65vw,65vh,480px)}.replay-move-list-header{padding:10px 14px;font-family:var(--font-heading);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);border-bottom:1px solid var(--border-light)}.replay-move-list{flex:1;overflow-y:auto;padding:var(--space-2) 0}.replay-move-row{display:grid;grid-template-columns:36px 1fr 1fr;gap:2px;padding:1px var(--space-2)}.replay-move-num{font-family:var(--font-body);font-size:.8rem;color:var(--text-secondary);text-align:right;padding-right:var(--space-2);line-height:1.8}.replay-move-cell{font-family:var(--font-mono, monospace);font-size:.82rem;color:var(--text-primary);padding:2px var(--space-2);border-radius:3px;cursor:pointer;line-height:1.8;transition:background .12s}.replay-move-cell:hover{background:#ffffff0f}.replay-move-cell.active{background:#ff2d782e;color:var(--accent-magenta);font-weight:600}.replay-move-cell.blocked{opacity:.5;text-decoration:line-through}.game-row[data-action=replay-game]{cursor:pointer;transition:background .12s}.game-row[data-action=replay-game]:hover{background:#ffffff0a}.game-replay-icon{font-size:.85rem;color:var(--text-secondary);display:flex;align-items:center;opacity:.5;transition:opacity .15s,color .15s}.game-row[data-action=replay-game]:hover .game-replay-icon{opacity:1;color:var(--accent-magenta)}@media(max-width:768px){.replay-main{flex-direction:column;align-items:center}.replay-board-wrap{width:min(90vw,90vh,480px)}.replay-sidebar{width:100%;max-width:min(90vw,480px);max-height:200px}}
