:root{color-scheme:light;--bg: var(--tg-bg, #faf9fe);--card: var(--tg-card, #ffffff);--card-strong: var(--tg-card-strong, #eef4fb);--card-soft: #f1f2f6;--line: rgba(36, 161, 222, .15);--line-strong: rgba(15, 23, 42, .1);--text: var(--tg-text, #101828);--subtle: var(--tg-hint, #667085);--primary: var(--tg-button, #24a1de);--primary-strong: var(--tg-primary-strong, #046c9d);--primary-soft: rgba(36, 161, 222, .14);--green: #0b8a3d;--green-soft: rgba(11, 138, 61, .14);--gold: #d1a200;--gold-soft: rgba(209, 162, 0, .16);--danger: #c81e1e;--danger-soft: rgba(200, 30, 30, .12);--shadow: 0 18px 40px rgba(15, 23, 42, .08);--radius-xl: 36px;--radius-lg: 28px;--radius-md: 22px;--radius-sm: 18px;--safe-bottom: calc(24px + env(safe-area-inset-bottom, 0px)) ;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}:root[data-theme=dark]{color-scheme:dark;--bg: var(--tg-bg, #0b1015);--card: var(--tg-card, #121a22);--card-strong: var(--tg-card-strong, #18222d);--card-soft: #1d2732;--line: rgba(120, 193, 234, .16);--line-strong: rgba(255, 255, 255, .08);--text: var(--tg-text, #f6f8fb);--subtle: var(--tg-hint, #9bacbf);--primary-soft: rgba(36, 161, 222, .2);--shadow: 0 18px 40px rgba(0, 0, 0, .28)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:radial-gradient(circle at top,rgba(36,161,222,.08),transparent 34%),var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent}button{font:inherit}.app-shell{min-height:100vh}.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:calc(14px + env(safe-area-inset-top,0px)) 20px 14px;background:color-mix(in srgb,var(--bg) 74%,transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.topbar--inner{gap:12px;padding-inline:12px}.brand{display:flex;align-items:center;gap:14px}.brand__logo{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;background:linear-gradient(180deg,#44b9f1,#1a91cf);color:#fff;box-shadow:0 10px 20px #24a1de4d}.brand__title,.screen-title{margin:0;font-size:24px;line-height:1.15;font-weight:800;letter-spacing:-.03em;color:var(--primary-strong)}.screen-title{flex:1;text-align:center;font-size:20px}.wallet-pill{display:inline-flex;align-items:center;gap:10px;min-height:50px;padding:8px 10px 8px 14px;border-radius:999px;background:color-mix(in srgb,var(--card) 82%,transparent);border:1px solid var(--line);box-shadow:var(--shadow)}.wallet-pill span{font-size:15px;font-weight:700}.page{width:min(100%,540px);margin:0 auto;padding:10px 20px calc(104px + var(--safe-bottom))}.page--store{display:flex;flex-direction:column;gap:26px}.page--secondary{display:flex;align-items:center;min-height:calc(100vh - 164px)}.page--chess{display:flex;flex-direction:column;gap:18px;padding-bottom:var(--safe-bottom)}.hero-card{position:relative;overflow:hidden;min-height:340px;border-radius:var(--radius-lg);background:#0d1218;box-shadow:var(--shadow)}.hero-card__overlay,.game-tile__fade{position:absolute;inset:0;background:linear-gradient(180deg,#0000000a,#000000d1)}.hero-card__content{position:absolute;inset:auto 22px 22px;z-index:2;display:flex;align-items:end;justify-content:space-between;gap:16px}.hero-card__title{margin:10px 0 8px;color:#fff;font-size:28px;line-height:1.02;font-weight:800;letter-spacing:-.04em}.meta-row{display:inline-flex;align-items:center;gap:6px;color:#ffffffdb;font-size:14px}.art{position:absolute;inset:0;overflow:hidden}.art--hero{background:radial-gradient(circle at 15% 20%,rgba(95,216,255,.14),transparent 22%),radial-gradient(circle at 85% 10%,rgba(255,255,255,.08),transparent 26%),linear-gradient(135deg,#04070a,#111a21 46%,#1c2c37)}.art--chess .art__piece,.art--space:before,.art--space:after,.art--tetris:before,.art--tetris:after,.art--puzzle:before,.art--puzzle:after{position:absolute}.art--chess:before{content:"";position:absolute;inset:18% 14% 8%;border-radius:18px;transform:perspective(580px) rotateX(72deg);background:linear-gradient(90deg,rgba(255,255,255,.08) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.08) 75%,transparent 75%),linear-gradient(rgba(255,255,255,.08) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.08) 75%,transparent 75%),linear-gradient(135deg,#ffffff14,#ffffff05);background-size:25% 100%,100% 25%,100% 100%;border:1px solid rgba(255,255,255,.12)}.art__piece{color:#f8fcffd6;text-shadow:0 12px 30px rgba(255,255,255,.18);filter:drop-shadow(0 10px 24px rgba(0,0,0,.4))}.art__piece--queen{top:14%;left:42%;font-size:110px}.art__piece--king{bottom:18%;left:18%;font-size:78px;opacity:.66}.art__piece--rook{right:18%;bottom:20%;font-size:72px;opacity:.72}.art--space{background:radial-gradient(circle at 50% 20%,rgba(255,118,205,.42),transparent 22%),radial-gradient(circle at 72% 26%,rgba(255,226,102,.18),transparent 18%),linear-gradient(160deg,#080716,#2d1148 52%,#081326)}.art--space:before{content:"";width:120px;height:18px;left:36%;top:48%;border-radius:999px;background:linear-gradient(90deg,#6fe3ff,#fff 42%,#ff8ddb);transform:rotate(-24deg);box-shadow:0 0 26px #6fe3ff73}.art--space:after{content:"";width:80px;height:4px;left:28%;top:60%;border-radius:999px;background:linear-gradient(90deg,#ff9f4300,#ff9f43);transform:rotate(-24deg);box-shadow:0 0 18px #ff9f4399}.art--tetris{background:linear-gradient(180deg,#080b10,#181d28)}.art--tetris:before,.art--tetris:after{content:"";width:46px;height:46px;border-radius:10px;box-shadow:58px 26px #1d9bf0,14px 68px #ef4444,72px 90px #ef4444,126px 112px #1d9bf0,104px 54px #ffffff14;transform:rotate(18deg)}.art--tetris:before{left:34px;top:26px;background:#ef4444}.art--tetris:after{left:92px;top:10px;background:#1d9bf0}.art--puzzle{background:radial-gradient(circle at 80% 20%,rgba(255,255,255,.32),transparent 22%),linear-gradient(180deg,#d8987f,#f1d09d)}.art--puzzle:before,.art--puzzle:after{content:"";border-radius:50%;background:radial-gradient(circle at 32% 28%,#ffffffeb,#ffffff1a 38%,#fff0)}.art--puzzle:before{width:120px;height:120px;left:18px;bottom:24px;background-color:#6ed2bce6;box-shadow:84px 10px #ffb866d9,138px 58px #fdd588b8,44px -54px #ff8888c2}.art--puzzle:after{width:86px;height:86px;right:42px;top:32px;background-color:#ffb07dd9;box-shadow:-96px 60px #fff4bec7,48px 62px #6ed2bcb8}.section-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-header--compact{margin-top:-4px;margin-bottom:-8px}.section-header h2{margin:0;font-size:20px;line-height:1.2;font-weight:800;letter-spacing:-.02em}.link-button{border:0;background:none;color:var(--primary-strong);font-size:15px;font-weight:700}.chips-row{display:flex;gap:12px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}.chips-row::-webkit-scrollbar,.moves-strip::-webkit-scrollbar{display:none}.category-chip{border:1px solid rgba(148,163,184,.18);border-radius:999px;background:color-mix(in srgb,var(--card) 70%,transparent);color:var(--text);padding:14px 24px;white-space:nowrap;font-weight:600;box-shadow:inset 0 1px #ffffff47}.category-chip--active{background:linear-gradient(180deg,#40b8f1,#1f9ee0);color:#fff;box-shadow:0 14px 30px #24a1de3d}.games-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px 16px}.game-tile{display:flex;flex-direction:column;gap:12px}.game-tile__art{position:relative;min-height:244px;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow)}.game-tile__meta{position:absolute;inset:auto 12px 12px;z-index:2;display:flex;align-items:end;justify-content:space-between;gap:8px}.game-tile__players{display:inline-flex;align-items:center;gap:4px;color:#ffffffeb;font-size:12px}.game-tile__body h3{margin:0;font-size:17px;font-weight:700;letter-spacing:-.02em}.game-tile__body p{margin:6px 0 0;color:var(--subtle);font-size:13px;line-height:1.35}.chip{display:inline-flex;align-items:center;min-height:28px;padding:0 12px;border-radius:999px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.chip--green{background:#0e9f48e0;color:#fff}.chip--blue{background:#24a1dee0;color:#fff}.chip--gold{background:#f1c71fe0;color:#332402}.primary-button,.secondary-button,.control-button,.icon-button{border:0;transition:transform .14s ease,opacity .14s ease,background-color .14s ease}.primary-button:active,.secondary-button:active,.control-button:active,.icon-button:active,.category-chip:active{transform:scale(.98)}.primary-button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:56px;padding:0 28px;border-radius:999px;background:linear-gradient(180deg,#1ea7e7,#0d84bf);color:#fff;box-shadow:0 18px 34px #24a1de47;font-weight:700}.primary-button--wide{width:100%}.secondary-button{width:100%;min-height:42px;border-radius:999px;background:color-mix(in srgb,var(--card) 66%,var(--card-soft));color:var(--text);font-weight:600}.secondary-button--inline{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:auto;min-width:0;padding:0 18px}.bottom-nav{position:fixed;left:50%;bottom:max(16px,env(safe-area-inset-bottom,0px));z-index:35;display:grid;grid-template-columns:repeat(3,1fr);gap:6px;width:min(calc(100% - 24px),540px);transform:translate(-50%);padding:12px;border-radius:32px;background:color-mix(in srgb,var(--card) 88%,transparent);border:1px solid var(--line);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.bottom-nav__item{display:inline-flex;flex-direction:column;align-items:center;gap:8px;min-height:74px;padding:8px 10px;border:0;border-radius:22px;background:transparent;color:var(--text);font-size:14px}.bottom-nav__item--active{color:var(--primary-strong);background:#7bccf43d}.bottom-nav__icon{display:grid;place-items:center;width:44px;height:44px;border-radius:18px}.bottom-nav__item--active .bottom-nav__icon{background:#ffffffa8}.icon-button{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;background:transparent;color:var(--primary-strong);flex-shrink:0}.icon-button--ghost{pointer-events:none}.feature-panel,.player-card,.status-card,.result-card{border-radius:var(--radius-lg);background:color-mix(in srgb,var(--card) 90%,transparent);border:1px solid var(--line);box-shadow:var(--shadow)}.feature-panel{display:flex;flex-direction:column;align-items:center;width:100%;padding:36px 24px;text-align:center}.feature-panel__icon{display:grid;place-items:center;width:62px;height:62px;margin-bottom:18px;border-radius:22px;background:linear-gradient(180deg,#24a1de2e,#24a1de14);color:var(--primary-strong)}.feature-panel h2{margin:0 0 10px;font-size:28px;font-weight:800;letter-spacing:-.03em}.feature-panel p{margin:0 0 26px;color:var(--subtle);line-height:1.5}.player-card,.status-card{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px}.status-card{background:linear-gradient(180deg,#24a1de14,#24a1de0a);border-width:2px}.profile-chip{position:relative;display:flex;align-items:center;gap:14px}.profile-chip__name{margin:0 0 4px;font-size:17px;font-weight:800}.profile-chip__subline{display:inline-flex;align-items:center;gap:4px;margin:0;color:var(--subtle);font-size:14px}.avatar{display:grid;place-items:center;font-size:16px;font-weight:800;color:#fff;border:3px solid rgba(255,255,255,.72);box-shadow:0 8px 20px #0f172a24}.avatar--small{width:34px;height:34px;border-width:2px;font-size:12px}.avatar--profile{background:linear-gradient(135deg,#0d2b45,#1f7a8c)}.avatar--grandmaster,.avatar--you{width:56px;height:56px;border-radius:50%}.presence{position:absolute;left:40px;bottom:0;width:16px;height:16px;border-radius:50%;border:3px solid var(--card)}.presence--green{background:var(--green)}.presence--blue{background:var(--primary-strong)}.timer-card{min-width:132px;padding:12px 16px;border-radius:28px;background:color-mix(in srgb,var(--card-soft) 72%,transparent);text-align:right}.timer-card span{display:block;margin-bottom:2px;color:var(--subtle);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.timer-card strong{color:var(--danger);font-size:26px;line-height:1;font-weight:800}.timer-card--active{background:linear-gradient(180deg,#096e9f,#075c88);box-shadow:0 16px 28px #075c883d}.timer-card--active span{color:#f0f9ffbd}.timer-card--active strong{color:#fff}.moves-strip{display:flex;gap:10px;overflow-x:auto}.move-pill{display:inline-flex;align-items:center;gap:8px;padding:12px 16px;border-radius:999px;background:color-mix(in srgb,var(--card) 62%,var(--card-soft));white-space:nowrap;font-size:15px;font-weight:700}.move-pill__index{color:#667085a3}.move-pill--current{border:2px solid rgba(36,161,222,.86);box-shadow:0 10px 24px #24a1de1f}.board-shell{position:relative}.board-glow{position:absolute;inset:-8px;border-radius:34px;background:radial-gradient(circle at center,rgba(36,161,222,.18),transparent 66%);filter:blur(16px)}.board{position:relative;z-index:1;display:grid;grid-template-columns:repeat(8,minmax(0,1fr));overflow:hidden;border:6px solid rgba(255,255,255,.62);border-radius:32px;box-shadow:var(--shadow)}.square{position:relative;aspect-ratio:1;display:grid;place-items:center;border:0;padding:0}.square--light{background:#f4f6f8}.square--dark{background:#56b1e2}.square--selected{box-shadow:inset 0 0 0 3px #0b84bed1}.square--last-move{background-image:linear-gradient(180deg,#f8d34e52,#f8d34e1f)}.piece{position:relative;z-index:1;font-size:clamp(28px,7.2vw,48px);line-height:1;-webkit-user-select:none;user-select:none;text-shadow:0 4px 10px rgba(15,23,42,.14)}.piece--w{color:transparent;background:radial-gradient(circle at 28% 24%,#fffffffa 0% 24%,#dff2fff5 42%,#a6d8fff0 72%,#7ab2eaeb),linear-gradient(180deg,#fffffffa,#d7f0fff0 52%,#8dc0eef2);-webkit-background-clip:text;background-clip:text;-webkit-text-stroke:1px rgba(109,151,192,.82);text-shadow:0 1px 0 rgba(255,255,255,.96),0 0 10px rgba(197,229,255,.45),0 6px 14px rgba(25,77,130,.2),0 10px 18px rgba(15,23,42,.18);filter:drop-shadow(0 2px 0 rgba(255,255,255,.7)) drop-shadow(0 5px 10px rgba(33,65,99,.18))}.piece--b{color:#111827;text-shadow:0 1px 0 rgba(255,255,255,.12),0 4px 10px rgba(15,23,42,.18)}.legal-target{width:18px;height:18px;border-radius:50%;background:#ffffff47;border:3px solid rgba(16,24,40,.76)}.coord{position:absolute;color:#0f172a61;font-size:11px;font-weight:800}.coord--rank{top:6px;left:6px}.coord--file{right:8px;bottom:4px}.square--dark .coord{color:#ffffff85}.controls{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.control-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:92px;border-radius:28px;background:color-mix(in srgb,var(--card) 64%,var(--card-soft));color:var(--text)}.control-button[disabled]{opacity:.5}.control-button span{font-size:14px;font-weight:600}.control-button--danger{background:color-mix(in srgb,var(--card) 72%,white);color:var(--danger);border:1px solid rgba(200,30,30,.2)}.insights{display:flex;flex-direction:column;gap:12px}.insight{margin:0;padding:0 4px;color:var(--subtle);font-size:14px}.insight--accent{color:var(--primary-strong);font-weight:700}.result-card{display:flex;flex-direction:column;gap:16px;padding:18px}.result-card p{margin:0;font-size:15px;line-height:1.5}.sheet-backdrop{position:fixed;inset:0;z-index:70;display:flex;align-items:end;justify-content:center;padding:20px;background:#02061759;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.mode-sheet{width:min(100%,540px);border-radius:34px;background:color-mix(in srgb,var(--card) 94%,transparent);border:1px solid var(--line);box-shadow:var(--shadow);padding:14px 18px 22px}.mode-sheet__handle{width:64px;height:6px;margin:0 auto 16px;border-radius:999px;background:#94a3b859}.mode-sheet__header h2{margin:0 0 8px;font-size:24px;font-weight:800;letter-spacing:-.03em}.mode-sheet__header p{margin:0;color:var(--subtle);line-height:1.45}.mode-grid{display:grid;gap:12px;margin-top:18px}.mode-card{display:flex;align-items:center;gap:14px;width:100%;border:1px solid var(--line);border-radius:24px;background:color-mix(in srgb,var(--card) 68%,var(--card-soft));padding:16px;text-align:left}.mode-card--accent{background:linear-gradient(180deg,#24a1de29,#24a1de14);border-color:#24a1de47}.mode-card__icon,.match-banner,.connection-pill,.multiplayer-panel,.multiplayer-actions{display:flex}.mode-card__icon{align-items:center;justify-content:center;width:52px;height:52px;border-radius:20px;background:#ffffffb8;color:var(--primary-strong);flex-shrink:0}.mode-card strong{display:block;margin-bottom:4px;font-size:17px;font-weight:800}.mode-card span{color:var(--subtle);font-size:14px;line-height:1.4}.match-banner{align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:24px;background:color-mix(in srgb,var(--card) 80%,transparent);border:1px solid var(--line)}.match-banner strong,.multiplayer-panel strong{display:block;font-size:18px;font-weight:800;letter-spacing:.04em}.match-banner__eyebrow{display:block;margin-bottom:3px;color:var(--subtle);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.connection-pill{align-items:center;gap:6px;min-height:34px;padding:0 12px;border-radius:999px;font-size:12px;font-weight:700;text-transform:uppercase}.connection-pill--connected{background:var(--green-soft);color:var(--green)}.connection-pill--connecting{background:#24a1de24;color:var(--primary-strong)}.connection-pill--disconnected,.connection-pill--error{background:var(--danger-soft);color:var(--danger)}.multiplayer-panel{flex-direction:column;gap:12px;padding:16px;border-radius:28px;background:color-mix(in srgb,var(--card) 88%,transparent);border:1px solid var(--line)}.multiplayer-panel__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.multiplayer-panel p{margin:0;color:var(--subtle);font-size:14px;line-height:1.45}.multiplayer-actions{gap:10px;flex-wrap:wrap}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.toast{position:fixed;left:50%;bottom:calc(98px + var(--safe-bottom));z-index:60;transform:translate(-50%);width:min(calc(100% - 32px),380px);padding:14px 16px;border-radius:18px;background:#101828e6;color:#fff;text-align:center;font-size:14px;box-shadow:0 18px 34px #0000003d}@media(max-width:420px){.page{padding-inline:16px}.hero-card{min-height:306px}.hero-card__content{inset-inline:16px;bottom:16px;flex-direction:column;align-items:stretch}.hero-card__title{font-size:24px}.games-grid{grid-template-columns:1fr 1fr;gap:16px 12px}.game-tile__art{min-height:206px}.controls{gap:10px}.control-button{min-height:84px;border-radius:24px}.player-card,.status-card,.sheet-backdrop{padding:12px}.timer-card{min-width:118px;padding-inline:14px}}
