@import "https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=JetBrains+Mono:wght@400;500;700&display=swap";.chessboard-wrapper{--board-corner-radius:8px;--board-corner-radius-large:10px;--board-corner-radius-base:18px;flex-direction:column;align-items:center;width:100%;display:flex}.chessboard-wrapper.theme-classic{--board-light:#f0d9b5;--board-dark:#b58863;--highlight-from:#9bc70069;--highlight-to:#9bc70069;--selected:#14551e80;--legal-dot:#0000001f;--legal-capture:#14551e4d;--check:#ff000080;--knight-aura:#6299241f}.chessboard-wrapper.theme-slate{--board-light:#dee3e6;--board-dark:#8ca2ad;--highlight-from:#9bc70069;--highlight-to:#9bc70069;--selected:#14551e80;--legal-dot:#0000001a;--legal-capture:#14551e4d;--check:#ff000080;--knight-aura:#62992426}.chessboard-wrapper.theme-rosewood{--board-light:#f0d2b4;--board-dark:#b06040;--highlight-from:#9bc70069;--highlight-to:#9bc70069;--selected:#14551e80;--legal-dot:#0000001f;--legal-capture:#14551e4d;--check:#ff000080;--knight-aura:#6299241f}.board-surface{box-sizing:border-box;border-radius:var(--board-corner-radius);width:100%;max-width:580px;margin:0 auto;position:relative;overflow:hidden;box-shadow:0 0 0 1px #00000080,0 8px 48px #000000b3}.chessboard-wrapper:not(.board--3d) .board-surface{border-radius:var(--board-corner-radius);box-shadow:0 0 0 1px #ffffff0d,0 12px 28px #00000047}.chessboard-wrapper:not(.board--3d) .board-grid{border-radius:var(--board-corner-radius);overflow:hidden}.chessboard-wrapper:not(.board--3d) .square:hover .piece-image{filter:drop-shadow(0 5px 8px #00000047);transform:translateY(-1px)scale(1.03)}.chessboard-wrapper:not(.board--3d) .square--holding .piece-image,.chessboard-wrapper:not(.board--3d) .square--holding:hover .piece-image{filter:drop-shadow(0 7px 10px #0000004d);transform:translateY(-2px)scale(1.05)}.board-grid{grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);gap:0;width:100%;display:grid}.square{aspect-ratio:1;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;background:0 0;border:none;outline:none;justify-content:center;align-items:center;width:100%;padding:0;display:flex;position:relative}.square--light{background:var(--board-light)}.square--dark{background:var(--board-dark)}.square--selected{background:var(--selected)!important}.square--selected.square--light{background:color-mix(in srgb, var(--board-light) 60%, var(--selected))!important}.square--selected.square--dark{background:color-mix(in srgb, var(--board-dark) 60%, var(--selected))!important}.square--last-from,.square--last-to{position:relative}.square--last-from:before,.square--last-to:before{content:"";background:var(--highlight-to);pointer-events:none;z-index:1;position:absolute;inset:0}.square--legal{cursor:pointer}.square--legal:after{content:"";background:var(--legal-dot);pointer-events:none;z-index:2;border-radius:50%;width:28%;height:28%;position:absolute}.square--capture:after{content:"";border:3px solid var(--legal-capture);pointer-events:none;z-index:2;background:0 0;border-radius:50%;width:80%;height:80%;position:absolute}.square--aura{position:relative}.square--aura:before{content:"";background:var(--knight-aura);pointer-events:none;z-index:0;position:absolute;inset:0}.square--check{position:relative}.square--check:before{content:"";pointer-events:none;z-index:1;background:radial-gradient(#f009 0%,#f003 40%,#0000 68%);position:absolute;inset:0}.piece-shell{pointer-events:none;z-index:3;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.piece-shell--aura:before{content:"";z-index:0;background:radial-gradient(circle,#ceea8657 0%,#62992429 42%,#0000 74%);border-radius:50%;position:absolute;inset:14%;box-shadow:0 0 14px #6299242e}.piece-image{pointer-events:none;filter:drop-shadow(0 1px 2px #0000004d);z-index:3;width:85%;height:85%;transition:transform .2s,filter .2s,opacity .2s;position:relative}.square:hover .piece-image{filter:drop-shadow(0 3px 5px #00000073);transform:scale(1.05)}.piece-shell--aura .piece-image{filter:drop-shadow(0 0 5px #ceea8680)drop-shadow(0 2px 4px #00000057);transform:translateY(-1px)scale(1.035)}.square:hover .piece-shell--aura .piece-image{filter:drop-shadow(0 0 7px #d8f4949e)drop-shadow(0 3px 5px #0000006b);transform:translateY(-2px)scale(1.08)}.piece{text-transform:uppercase;z-index:3;border:2px solid #0000004d;border-radius:50%;place-items:center;width:80%;height:80%;font-size:clamp(14px,3vmin,24px);font-weight:700;transition:transform .1s,box-shadow .1s,border-color .1s;display:grid;position:relative}.piece--w{color:#333;background:#fff;box-shadow:inset 0 2px 4px #fff6,0 2px 4px #0003}.piece--b{color:#f0f0f0;background:#333;box-shadow:inset 0 2px 4px #ffffff1a,0 2px 4px #0000004d}.piece-shell--aura .piece{transform:translateY(-1px)scale(1.035)}.piece-shell--aura .piece--w{border-color:#629924b8;box-shadow:inset 0 2px 4px #fff6,0 0 0 2px #ceea8659,0 4px 10px #4668163d}.piece-shell--aura .piece--b{border-color:#d8f494b3;box-shadow:inset 0 2px 4px #ffffff1a,0 0 0 2px #8cc03c57,0 4px 10px #00000057}.square:hover .piece-shell--aura .piece{transform:translateY(-2px)scale(1.08)}.piece-aura-mark{color:#efffc4;text-shadow:0 0 6px #e2ff9f99;z-index:4;background:#2c490feb;border-radius:999px;place-items:center;width:18%;min-width:11px;height:18%;min-height:11px;font-size:clamp(8px,1.45vmin,12px);line-height:1;display:grid;position:absolute;top:12%;right:12%;box-shadow:0 0 0 1px #e2ff9f61,0 0 10px #a0d64473}.file-label,.rank-label{letter-spacing:0;text-transform:lowercase;pointer-events:none;z-index:4;font-size:9px;font-weight:700;line-height:1;position:absolute}.square--light .file-label,.square--light .rank-label{color:var(--board-dark);opacity:.7}.square--dark .file-label,.square--dark .rank-label{color:var(--board-light);opacity:.7}.file-label{bottom:2px;right:3px}.rank-label{top:2px;left:3px}.chessboard-wrapper.board--3d .board-surface{perspective:1100px;perspective-origin:50% 10%;box-shadow:none;overflow:visible}.chessboard-wrapper.board--3d .board-grid{transform-style:preserve-3d;border-radius:var(--board-corner-radius);transition:transform .5s cubic-bezier(.34,1.56,.64,1);transform:rotateX(16deg);box-shadow:0 40px 90px #000000d9,0 10px 24px #0000008c}.chessboard-wrapper.board--3d .piece-shell{transform-style:preserve-3d}.chessboard-wrapper.board--3d .piece-image{filter:drop-shadow(0 2px 2px #ffffff24)drop-shadow(0 7px 12px #00000075);width:88%;height:88%}.chessboard-wrapper.board--3d .square--occupied .piece-image{transform:translateZ(10px)}.chessboard-wrapper.board--3d .square--last-to .piece-image,.chessboard-wrapper.board--3d .square--last-to .piece{animation:.38s cubic-bezier(.22,1,.36,1) forwards piece-land-3d}@keyframes piece-land-3d{0%{opacity:.5;transform:translateY(-22px)scale(1.18)}60%{opacity:1;transform:translateY(2px)scale(1.04)}to{opacity:1;transform:translateY(0)scale(1)}}.chessboard-wrapper.board--3d .square:hover .piece-image{filter:drop-shadow(0 3px 3px #ffffff2e)drop-shadow(0 10px 14px #00000094);transform:translateY(-3px)translateZ(16px)scale(1.05)}.chessboard-wrapper.board--3d .square--holding .piece-image,.chessboard-wrapper.board--3d .square--holding:hover .piece-image{filter:drop-shadow(0 4px 4px #ffffff38)drop-shadow(0 11px 16px #0000009e);transform:translateY(-4px)translateZ(20px)scale(1.06)}.chessboard-wrapper.board--realistic .board-surface{filter:drop-shadow(0 20px 40px #00000075)}.chessboard-wrapper.board--realistic .board-grid{border-radius:var(--board-corner-radius-large);overflow:hidden;transform:rotateX(24deg)rotate(-.4deg);box-shadow:0 55px 85px #000000c7,0 18px 32px #0006,inset 0 0 0 1px #ffffff14}.chessboard-wrapper.board--realistic .board-surface:before{content:"";border-radius:0 0 var(--board-corner-radius-base) var(--board-corner-radius-base);background:linear-gradient(180deg, color-mix(in srgb, var(--board-dark) 78%, #3b2417), color-mix(in srgb, var(--board-dark) 52%, #170f09)), linear-gradient(90deg, #ffffff14, transparent 18%, transparent 82%, #00000029);transform-origin:top;pointer-events:none;height:26px;position:absolute;top:100%;left:2.5%;right:2.5%;transform:translateY(-10px)perspective(500px)rotateX(-58deg);box-shadow:0 18px 24px #00000057}.chessboard-wrapper.board--realistic .board-surface:after{content:"";filter:blur(5px);pointer-events:none;background:radial-gradient(#00000057,#0000);border-radius:999px;height:18px;position:absolute;top:calc(100% + 8px);left:8%;right:8%}.chessboard-wrapper.board--realistic .board-grid:before{content:"";pointer-events:none;background:linear-gradient(180deg, #ffffff2e, transparent 20%, transparent 70%, #00000038), repeating-linear-gradient(90deg, color-mix(in srgb, var(--board-dark) 32%, transparent) 0 8px, color-mix(in srgb, var(--board-light) 18%, transparent) 8px 16px);mix-blend-mode:soft-light;z-index:1;position:absolute;inset:0}.chessboard-wrapper.board--realistic .board-grid:after{content:"";pointer-events:none;box-shadow:inset 0 0 0 10px color-mix(in srgb, var(--board-dark) 38%, transparent), inset 0 0 0 1px #ffffff0f;z-index:1;position:absolute;inset:0}.chessboard-wrapper.board--realistic .square--light{background:linear-gradient(135deg, #ffffff29, transparent 50%), linear-gradient(135deg, color-mix(in srgb, var(--board-light) 88%, #fff4df), color-mix(in srgb, var(--board-light) 76%, var(--board-dark)))}.chessboard-wrapper.board--realistic .square--dark{background:linear-gradient(135deg, #ffffff14, transparent 48%), linear-gradient(135deg, color-mix(in srgb, var(--board-dark) 90%, #cf9d70), color-mix(in srgb, var(--board-dark) 68%, #2d1a10))}.chessboard-wrapper.board--realistic .piece-image{filter:drop-shadow(0 1px #ffffff38)drop-shadow(0 6px 6px #00000042)drop-shadow(0 14px 18px #0000006b);width:90%;height:90%}.chessboard-wrapper.board--realistic .square--occupied .piece-image{transform:translateZ(16px)scale(1.02)}.chessboard-wrapper.board--realistic .square--occupied .piece-shell{transform:translateZ(2px)}.chessboard-wrapper.board--realistic .square--last-from{box-shadow:inset 0 0 0 999px color-mix(in srgb, var(--board-dark) 20%, transparent)}.chessboard-wrapper.board--realistic .square--last-to{box-shadow:inset 0 0 0 999px color-mix(in srgb, var(--board-light) 26%, #c7a34d)}.chessboard-wrapper.board--realistic .square:hover .piece-image{filter:drop-shadow(0 2px #ffffff3d)drop-shadow(0 10px 12px #00000047)drop-shadow(0 20px 22px #00000075);transform:translateY(-4px)translateZ(24px)scale(1.08)}.chessboard-wrapper.board--realistic .square--holding .piece-image,.chessboard-wrapper.board--realistic .square--holding:hover .piece-image{transform:translateY(-5px)translateZ(26px)scale(1.1)}.chessboard-wrapper.board--realistic .square--selected{box-shadow:inset 0 0 0 2px color-mix(in srgb, var(--board-light) 58%, #fff3c2), inset 0 0 28px color-mix(in srgb, var(--board-light) 18%, #d7b049)}.chessboard-wrapper.board--realistic .square--legal:after{background:color-mix(in srgb, var(--board-dark) 34%, transparent)}.chessboard-wrapper.board--realistic .square--capture:after{border-color:color-mix(in srgb, var(--board-dark) 38%, #7b2018)}.chessboard-wrapper.board--realistic .board-hand{filter:sepia(.12)saturate(.72)brightness(1.02)drop-shadow(0 14px 18px #00000061)}.chessboard-wrapper.board--realistic .board-hand-piece,.chessboard-wrapper.board--realistic .board-move-piece{filter:drop-shadow(0 1px #ffffff38)drop-shadow(0 5px 8px #0000004d)drop-shadow(0 12px 16px #00000061)}.board-hand-overlay{pointer-events:none;z-index:8;position:absolute;inset:0}.board-hand-carry{left:var(--hand-x);top:var(--hand-y);opacity:1;width:0;height:0;transition:opacity .12s ease-out;position:absolute}.board-hand-overlay--move .board-hand-carry{opacity:1}.board-move-piece{left:var(--hand-x);top:var(--hand-y);filter:drop-shadow(0 3px 4px #0000006b);width:42px;height:42px;margin-top:-21px;margin-left:-21px;position:absolute}.board-move-piece.board-hand-piece--text{border-width:2px;width:42px;min-width:42px;height:42px;min-height:42px;font-size:1rem;line-height:1}.board-move-piece--move{transition:transform 50ms linear;top:0;left:0;transform:scale(1.05)}.board-hand{left:var(--hand-x);top:var(--hand-y);filter:drop-shadow(0 12px 18px #00000059);transform-origin:30% 28%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cdefs%3E%3CradialGradient id='bg' cx='35%25' cy='30%25' r='75%25'%3E%3Cstop offset='0%25' stop-color='%23f6f9fd'/%3E%3Cstop offset='56%25' stop-color='%23c2ccd7'/%3E%3Cstop offset='100%25' stop-color='%23727c88'/%3E%3C/radialGradient%3E%3C/defs%3E%3Cpath d='M19 56c-6.4 0-11.5-5-11.5-11.4V31.5c0-2.6 2.1-4.7 4.7-4.7s4.7 2.1 4.7 4.7V19.7c0-2.8 2.3-5.1 5.1-5.1s5.1 2.3 5.1 5.1V30h2V16.4c0-2.8 2.3-5.1 5.1-5.1s5.1 2.3 5.1 5.1V30h2V18.8c0-2.8 2.3-5.1 5.1-5.1s5.1 2.3 5.1 5.1V32h2v-8.3c0-2.6 2.1-4.7 4.7-4.7s4.7 2.1 4.7 4.7v15.6C63.5 48.7 56.2 56 47.2 56H19Z' fill='url(%23bg)' stroke='%2357616e' stroke-width='2.1' stroke-linejoin='round'/%3E%3Cpath d='M17 50.5c2.8 1.8 5 2.5 8.4 2.5h21.8c7.4 0 13.4-6 13.4-13.4' fill='none' stroke='%23ffffff' stroke-opacity='.3' stroke-width='2'/%3E%3C/svg%3E");background-size:cover;width:58px;height:58px;margin-top:-28px;margin-left:-6px;position:absolute}.board-hand-piece{left:var(--hand-x);top:var(--hand-y);filter:drop-shadow(0 3px 4px #0000006b);width:42px;height:42px;margin-top:-4px;margin-left:-21px;position:absolute}.board-hand-piece--text{border-width:2px;width:42px;min-width:42px;height:42px;min-height:42px;font-size:1rem;line-height:1}.board-hand--idle{animation:1.35s ease-in-out infinite alternate hand-idle}.board-hand-piece--idle{animation:1.35s ease-in-out infinite alternate hand-piece-idle}.board-hand--move{transition:transform 50ms linear;top:0;left:0;transform:rotate(-8deg)scale(1)}.board-hand-piece--move{margin-left:calc(-21px + var(--piece-grip-x,-5px));margin-top:calc(-4px + var(--piece-grip-y,1px));transition:transform 50ms linear;top:0;left:0;transform:scale(1.05)}.board-hand-overlay--active .board-hand--move{transform:translateY(0) rotate(var(--hand-tilt,-2deg)) scale(1)}.board-hand-overlay--active .board-hand-piece--move,.board-hand-overlay--active .board-move-piece--move{transform:translateY(0) rotate(var(--piece-tilt,0deg)) scale(var(--piece-scale,1))}.board-captured-piece{filter:drop-shadow(0 5px 7px #00000059);width:42px;height:42px;margin-top:-21px;margin-left:-21px;position:absolute}.board-captured-piece.board-hand-piece--text{margin-top:-21px;margin-left:-21px}.board-captured-piece--throw{opacity:0;transform:translateY(0) rotate(var(--piece-tilt,0deg)) scale(.98);top:0;left:0}.board-captured-piece--active{animation:.58s cubic-bezier(.16,.9,.24,1) .8s forwards captured-throw-side}@keyframes hand-idle{0%{transform:translate(0,0)rotate(-7deg)}to{transform:translate(2px,-2px)rotate(-3deg)}}@keyframes hand-piece-idle{0%{transform:translate(0,0)scale(1.02)}to{transform:translate(2px,-1px)scale(1.03)}}@keyframes captured-throw-side{0%{transform:translate3d(0, 0, 0) rotate(var(--piece-tilt,0deg)) scale(.98);opacity:0}8%{opacity:1}22%{transform:translate3d(10px, calc((var(--carry-lift,10px) + 14px) * -1), 0) rotate(12deg) scale(1.04);opacity:1}to{transform:translate3d(var(--drop-x), var(--drop-y), 0) rotate(26deg) scale(.74);opacity:0}}@media (width<=520px){.board-surface{max-width:100%}.piece-image{width:90%;height:90%}.file-label,.rank-label{font-size:7px}}.left-bg-art{opacity:.08;pointer-events:none;z-index:0;background:url(/riderchess.png) 50%/contain no-repeat;width:calc(50vw - 580px);position:fixed;top:0;bottom:0;left:0}.season-decor{pointer-events:none;z-index:1;position:fixed;inset:60px 0 0;overflow:hidden}.season-decor__item{opacity:0;transform:translate3d(0, 0, 0) scale(var(--season-scale,1));place-items:center;font-size:1.15rem;animation-name:seasonal-fall;animation-timing-function:linear;animation-iteration-count:infinite;display:inline-grid;position:absolute;top:-10%}.season-decor--winter .season-decor__item{color:#e6f2ffb3;text-shadow:0 0 10px #c8e6ff40}.season-decor--spring .season-decor__item{color:#ffc4df99;text-shadow:0 0 12px #ffc4df33}.season-decor--summer .season-decor__item{color:#ffe27880;text-shadow:0 0 14px #ffe27847}.season-decor--autumn .season-decor__item{color:#e6a25480;text-shadow:0 0 12px #e6a25433}@keyframes seasonal-fall{0%{transform:translate3d(0, -6vh, 0) rotate(0deg) scale(var(--season-scale,1));opacity:0}10%{opacity:1}85%{opacity:.75}to{transform:translate3d(var(--season-drift,0px), 112vh, 0) rotate(220deg) scale(var(--season-scale,1));opacity:0}}.top-bar{background:var(--bg-header);border-bottom:1px solid var(--border-subtle);z-index:100;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;display:flex}.brand-text{flex-direction:column;gap:2px;display:flex}.brand h1{color:var(--text-white);letter-spacing:-.04em;margin:0;font-size:1.35rem;font-weight:800;line-height:1.1}.brand-subtitle{color:var(--accent-bright);letter-spacing:.01em;margin:0;font-size:.7rem;font-weight:500;line-height:1}.brand-logo{border-radius:var(--radius-sm);width:auto;height:30px;transition:box-shadow var(--transition-base)}.brand-logo:hover{box-shadow:0 0 0 2px var(--accent)}.auth-panel{align-items:center;gap:10px;display:flex}.auth-actions{gap:8px;display:flex}.auth-form{flex-direction:column;gap:8px;min-width:min(420px,48vw);display:flex}.auth-mode-toggle{gap:6px;display:inline-flex}.auth-mode-btn{border:1px solid var(--border);background:var(--bg-panel);color:var(--text-dim);cursor:pointer;border-radius:999px;padding:5px 10px;font-size:.74rem;font-weight:700}.auth-mode-btn.active{border-color:var(--accent);color:var(--accent-bright);background:var(--accent-glow)}.auth-form-row{gap:8px;display:flex}.auth-input{flex:1;min-width:0}.auth-error{color:#ff8f8f;font-size:.75rem}.signin-page{place-items:center;min-height:calc(100vh - 60px);padding:28px 16px;display:grid}.signin-card{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:linear-gradient(#ffffff08,#ffffff03);width:min(560px,100%);padding:28px;box-shadow:0 20px 48px #0000003d}.signin-back-btn,.signin-hero{margin-bottom:18px}.signin-hero h2{color:var(--text-bright);margin:0 0 8px;font-size:1.5rem}.signin-hero p{color:var(--text-dim);margin:0;line-height:1.55}.signin-form{min-width:0}.page-loading{place-items:center;min-height:calc(100vh - 60px);padding:24px;display:grid}.home-page{background:radial-gradient(80% 40% at 50% 0,#4a90d90f,#0000 70%),0 0;width:min(1080px,100%);margin:0 auto;padding:56px 28px 60px}.home-hero{grid-template-columns:1fr;align-items:start;gap:28px;display:grid}.home-hero--signed-in{grid-template-columns:minmax(0,1.15fr) minmax(320px,380px);gap:48px}.home-hero-copy{text-align:left;flex-direction:column;gap:18px;display:flex}.home-hero-eyebrow{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--accent-bright);align-items:center;gap:10px;font-size:.72rem;display:inline-flex}.home-hero-eyebrow:before{content:"";background:var(--accent-bright);opacity:.7;width:22px;height:1px}.home-hero h2{letter-spacing:-.02em;max-width:18ch;color:var(--text-bright);margin:0;font-size:clamp(2rem,4.2vw,3.2rem);font-weight:800;line-height:1.05}.home-hero h2 em{color:var(--accent-bright);font-style:normal}.home-summary{max-width:56ch;color:var(--text-muted);margin:0;font-size:1.05rem;line-height:1.55}.home-actions{flex-wrap:wrap;gap:10px;margin-top:4px;display:flex}.home-cta{padding:12px 22px;font-size:.95rem}.home-hero-status{font-family:var(--font-mono);letter-spacing:.02em;color:var(--text-dim);align-items:center;gap:10px;margin-top:4px;font-size:.76rem;display:inline-flex}.home-dot{background:var(--text-dim);border-radius:50%;width:7px;height:7px;display:inline-block}.home-dot.is-on{background:var(--accent-bright);animation:2.4s ease-in-out infinite home-pulse;box-shadow:0 0 0 3px #7dc4352e}@keyframes home-pulse{0%,to{opacity:.55}50%{opacity:1}}.home-hero-art{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:radial-gradient(#4a90d914,#0000 65%),linear-gradient(#ffffff04,#0003);place-items:center;padding:18px;display:grid}.home-hero-card{border-radius:var(--radius-lg);background:var(--bg-panel);border:1px solid var(--border);flex-direction:column;gap:18px;padding:22px;display:flex;box-shadow:0 4px 16px #00000080}.home-account-card__header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:flex-start;gap:12px;padding-bottom:16px;display:flex}.home-account-card__header h3{color:var(--text-bright);letter-spacing:-.005em;margin:4px 0 0;font-size:1.15rem;font-weight:700}.home-account-handle{font-family:var(--font-mono);color:var(--text-dim);margin-top:2px;font-size:.76rem;display:block}.home-card-label{font-family:var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim);margin:0;font-size:.66rem;font-weight:600}.home-rating-pill{color:var(--accent-bright);font-family:var(--font-mono);letter-spacing:.04em;white-space:nowrap;background:#7dc4351a;border:1px solid #7dc43542;border-radius:999px;padding:5px 11px;font-size:.74rem;font-weight:600}.home-rating-pill--big{letter-spacing:0;padding:8px 16px;font-size:1.15rem}.home-record-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.home-record-tile{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);text-align:center;background:#ffffff06;flex-direction:column;gap:2px;padding:12px 10px;display:flex}.home-record-tile span{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim);font-size:.66rem}.home-record-tile strong{color:var(--text-bright);letter-spacing:-.02em;font-size:1.4rem;font-weight:700}.home-challenge-card{border-radius:var(--radius-md);background:linear-gradient(160deg,#7dc43514,#7dc43505);border:1px solid #7dc43547;flex-direction:column;gap:6px;padding:14px;display:flex}.home-challenge-card strong{color:var(--text-bright);font-size:.9rem}.home-challenge-card__actions{gap:8px;margin-top:6px;display:flex}.home-challenge-card__actions .btn{flex:1;justify-content:center;padding:7px 14px;font-size:.82rem}.home-status-card{border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:#ffffff06;flex-direction:column;gap:4px;padding:14px;display:flex}.home-status-card strong{color:var(--text-bright);font-size:.95rem}.home-status-card span{color:var(--text-dim);font-size:.82rem;line-height:1.5}.home-aura-strip{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:linear-gradient(#ffffff05,#0000002e);grid-template-columns:320px minmax(0,1fr);align-items:center;gap:36px;margin-top:36px;padding:26px;display:grid}.home-aura-strip__diagram{border-radius:var(--radius-md);background:#00000040;place-items:center;padding:14px;display:grid}.home-aura-strip__copy h3{color:var(--text-bright);letter-spacing:-.012em;margin:6px 0 10px;font-size:1.5rem;font-weight:700}.home-aura-strip__copy p{max-width:540px;color:var(--text-muted);margin:0 0 16px;line-height:1.6}.home-aura-strip__cta{display:inline-flex}.home-aura-diagram{border-radius:var(--radius-md);flex-direction:column;gap:0;display:inline-flex;overflow:hidden;box-shadow:0 0 0 1px #0009,0 8px 32px #0006}.home-aura-diagram__row{gap:0;display:flex}.home-aura-diagram__cell{place-items:center;width:44px;height:44px;display:grid;position:relative}.home-aura-diagram__cell.is-light{background:var(--board-light,#ebe1cb)}.home-aura-diagram__cell.is-dark{background:var(--board-dark,#b08762)}.home-aura-diagram__cell.is-source:before{content:"";background:radial-gradient(circle,#4a90d959 0%,#4a90d92e 50%,#0000 75%);position:absolute;inset:0;box-shadow:inset 0 0 0 2px #6aafeb8c}.home-aura-diagram__cell.is-adj:before{content:"";background:#7dc43552;position:absolute;inset:0;box-shadow:inset 0 0 0 1.5px #b4e66e8c}.home-aura-diagram__cell.is-knm:before{content:"";background-image:repeating-linear-gradient(45deg,#c8f08252 0 4px,#7dc4352e 4px 9px);position:absolute;inset:0;box-shadow:inset 0 0 0 1.5px #b4e66e73}.home-aura-diagram__piece{z-index:1;color:#1a1814;text-shadow:0 1px 2px #00000040;font-size:1.7rem;line-height:1;position:relative}.home-dashboard{grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:20px;margin-top:36px;display:grid}.home-panel{border-radius:var(--radius-lg);background:var(--bg-panel);border:1px solid var(--border-subtle);flex-direction:column;gap:16px;padding:22px;display:flex}.home-panel__header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:flex-end;gap:12px;padding-bottom:14px;display:flex}.home-panel__header h3{color:var(--text-bright);letter-spacing:-.005em;margin:4px 0 0;font-size:1.1rem;font-weight:700}.home-panel__muted{color:var(--text-dim);margin:0;font-size:.88rem}.home-recent-list{flex-direction:column;display:flex}.home-recent-row{border-bottom:1px solid var(--border-subtle);grid-template-columns:auto 1fr;align-items:center;gap:14px;padding:12px 0;display:grid}.home-recent-row:last-child{border-bottom:none}.home-recent-result{text-align:center;width:56px;font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;border-radius:4px;padding:5px 0;font-size:.7rem;font-weight:700}.home-recent-result--win{color:var(--accent-bright);background:#7dc43524}.home-recent-result--loss{color:#ff8a8a;background:#c0303024}.home-recent-result--draw{color:var(--text-muted);background:#ffffff0f}.home-recent-copy{flex-direction:column;gap:2px;min-width:0;display:flex}.home-recent-copy strong{color:var(--text-bright);font-size:.92rem;font-weight:600}.home-recent-copy span{font-family:var(--font-mono);color:var(--text-dim);letter-spacing:.01em;font-size:.74rem}.home-lane-list{flex-direction:column;gap:8px;display:flex}.home-lane{border-radius:var(--radius-md);border:1px solid var(--border-subtle);width:100%;color:inherit;font:inherit;text-align:left;cursor:pointer;background:#ffffff05;grid-template-columns:36px 1fr auto;align-items:center;gap:14px;padding:14px 14px 14px 12px;transition:background .15s,border-color .15s;display:grid}.home-lane:hover{border-color:var(--border);background:#ffffff0d}.home-lane:hover .home-lane__arrow{color:var(--accent-bright);transform:translate(3px)}.home-lane__mark{width:36px;height:36px;font-family:var(--font-mono);color:var(--accent-bright);background:#7dc4351a;border:1px solid #7dc4353d;border-radius:8px;place-items:center;font-size:.95rem;font-weight:700;display:grid}.home-lane__body{flex-direction:column;gap:2px;display:flex}.home-lane__body strong{color:var(--text-bright);font-size:.96rem;font-weight:600}.home-lane__body span{color:var(--text-dim);font-size:.82rem;line-height:1.4}.home-lane__arrow{color:var(--text-dim);font-size:1.05rem;transition:color .15s,transform .15s}.home-highlights{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:36px;display:grid}.home-highlight{border-radius:var(--radius-lg);background:var(--bg-panel);border:1px solid var(--border-subtle);flex-direction:column;gap:10px;padding:22px;display:flex}.home-highlight__mark{width:36px;height:36px;color:var(--accent-bright);background:#7dc4351a;border:1px solid #7dc4353d;border-radius:8px;place-items:center;font-size:1.1rem;display:grid}.home-highlight h3{color:var(--text-bright);letter-spacing:-.005em;margin:0;font-size:1.05rem;font-weight:700}.home-highlight p{color:var(--text-muted);margin:0;font-size:.86rem;line-height:1.55}.home-highlight__hint{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.02em;margin-top:auto;padding-top:6px;font-size:.78rem;font-weight:600}.home-outro{border-top:1px solid var(--border-subtle);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:18px;margin-top:36px;padding-top:32px;display:flex}.home-outro__text{color:var(--text-dim);font-size:.9rem}.home-outro__text strong{color:var(--text-bright)}.home-outro__actions{gap:8px;display:flex}@media (width<=960px){.home-hero,.home-hero--signed-in{grid-template-columns:1fr;gap:28px}.home-aura-strip,.home-dashboard{grid-template-columns:1fr}}@media (width<=900px){.auth-form{width:100%;min-width:0}.auth-form-row{flex-wrap:wrap}.auth-input{min-width:140px}.signin-card{padding:20px}.home-page{padding:28px 16px 40px}.home-highlights{grid-template-columns:1fr}}.auth-user{align-items:center;gap:8px;display:flex}.auth-user-chip{background:var(--bg-panel);border:1px solid var(--border);cursor:pointer;transition:background var(--transition-base), border-color var(--transition-base);border-radius:999px;align-items:center;gap:8px;padding:4px 12px 4px 5px;display:flex}.auth-user-chip:hover{background:var(--bg-panel-hover);border-color:var(--border)}.auth-avatar-mini{background:var(--accent-soft);border:1.5px solid var(--accent);width:26px;height:26px;color:var(--accent-bright);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.7rem;font-weight:700;display:flex;overflow:hidden}.auth-avatar-mini img{object-fit:cover;width:100%;height:100%}.auth-name{color:var(--text-bright);font-size:.88rem;font-weight:600}.auth-meta,.auth-status{color:var(--accent);font-size:.78rem;font-family:var(--font-mono);font-weight:600}.app{background:var(--bg-body);min-height:100vh;color:var(--text-primary);flex-direction:column;display:flex}.layout{grid-template-columns:1fr 340px;align-items:start;gap:0 24px;width:100%;max-width:1160px;margin:0 auto;padding:24px 24px 32px;display:grid}.board-section{flex-direction:column;align-items:center;padding:0 8px;display:flex}.board-header{justify-content:space-between;align-items:center;gap:12px;width:100%;max-width:580px;margin-bottom:10px;padding:0 2px;display:flex}.game-mode-badge{text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);align-items:center;gap:7px;font-size:.72rem;font-weight:700;display:flex}.game-mode-dot{background:var(--text-dim);border-radius:50%;flex-shrink:0;width:7px;height:7px}.game-mode-dot--live{background:#4caf50;animation:2s ease-in-out infinite livePulse;box-shadow:0 0 6px #4caf50b3}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.45}}.game-status-text{color:var(--text-muted);font-size:.85rem;font-weight:500}.connection-chip{text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--border);color:var(--text-dim);border-radius:999px;padding:3px 8px;font-size:.68rem}.connection-chip--live{color:#a9e278;background:#5a902024;border-color:#5a902073}.connection-chip--reconnecting,.connection-chip--connecting{color:#ffdfa6;background:#c6923224;border-color:#c692326b}.connection-chip--offline{color:#ffc1c1;background:#c0303021;border-color:#c030305c}.player-bar{border:1px solid var(--border-subtle);width:auto;max-width:min(420px,100%);min-height:40px;transition:border-color var(--transition-slow), background var(--transition-slow), transform var(--transition-base), box-shadow var(--transition-base);background:linear-gradient(#ffffff0a,#ffffff04);border-radius:999px;justify-content:space-between;align-items:center;gap:10px;padding:7px 12px;display:inline-flex;position:relative;overflow:hidden;box-shadow:0 10px 18px #00000024}.player-bar--top{align-self:flex-start;margin-bottom:8px}.player-bar--bottom{align-self:flex-start;margin-top:8px}.board-section--3d .player-bar{background:linear-gradient(#ffffff0d,#ffffff04);transition:filter .5s,transform .35s}.board-section--3d .player-bar:before{content:none}.board-section--3d .player-bar--bottom{margin-top:20px;transform:translateY(10px)}.board-section--3d .board-actions{margin-top:26px}.board-section--3d .player-bar__info,.board-section--3d .player-bar__clock{z-index:1;position:relative}.board-section--3d .player-bar--active-turn{background:linear-gradient(90deg,#5a902024 0%,#ffffff0a 72%)}.player-bar--active-turn{background:linear-gradient(90deg,#5a90201f 0%,#ffffff08 70%);border-color:#78be3485;box-shadow:0 12px 22px #00000029,0 0 0 1px #78be3414}.board-section--realistic .player-bar{background:linear-gradient(#ffffff14,#ffffff03),linear-gradient(90deg,#57391c29,#1e1812e6 40%);box-shadow:0 12px 26px #00000061}.board-section--realistic .player-bar--bottom{background:linear-gradient(#ffffff1f,#ffffff05),linear-gradient(90deg,#623f1f4d,#1a140ef0 40%);border-color:#fff1d733;box-shadow:0 14px 28px #0000006b}.board-section--realistic .player-bar__name{color:#f6ebd3;text-shadow:0 1px #00000080;font-weight:700}.board-section--realistic .player-bar__rating{color:#f6e6bf;background:#2d1f128c;border:1px solid #ffecc23d}.board-section--realistic .player-bar__clock{color:#f3e4bd;letter-spacing:.07em;text-shadow:0 1px #0000008c;background:radial-gradient(circle at 22% 30%,#ffffff1f,#0000 28%),linear-gradient(#442f1ef0,#1a120cfa);border:1px solid #ffffff14;border-radius:999px;min-width:94px;padding:6px 14px 6px 34px;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff14,inset 0 -1px #00000061,0 8px 14px #0000003d}.board-section--realistic .player-bar__clock:before{content:"";background:radial-gradient(circle,#ffffffb8 0 1px,#0000 1px),linear-gradient(135deg,#ffffff3d,#00000024),#dac79d;border-radius:50%;width:18px;height:18px;position:absolute;top:50%;left:10px;transform:translateY(-50%);box-shadow:inset 0 0 0 1px #482e1757,0 1px 2px #00000047}.board-section--realistic .player-bar__clock:after{content:"";transform-origin:0;background:#482e17d9;border-radius:999px;width:8px;height:2px;position:absolute;top:50%;left:18px;transform:translateY(-50%)rotate(40deg);box-shadow:-4px -3px #482e17d9}.board-section--realistic .player-bar__clock-value{z-index:1;display:inline-block;position:relative}[data-theme=light] .board-section--realistic .player-bar__clock{color:#5b4226;text-shadow:0 1px #ffffffa8;background:radial-gradient(circle at 22% 30%,#fffc,#0000 28%),linear-gradient(#fcf8effa,#ddcfb5f5);border:1px solid #7e5b273d;box-shadow:inset 0 1px #ffffffeb,inset 0 -1px #664b2924,0 8px 14px #6d56342e}[data-theme=light] .board-section--realistic .player-bar__name{color:#fff2d6;text-shadow:0 1px #0000008c}[data-theme=light] .board-section--realistic .player-bar__rating{color:#ffe9ba;background:#2a1d1199;border-color:#ffecc247}[data-theme=light] .board-section--realistic .player-bar__clock:before{background:radial-gradient(circle,#fffffff2 0 1px,#0000 1px),linear-gradient(135deg,#ffffffb8,#aa844929),#f0d8a4;box-shadow:inset 0 0 0 1px #7e5b2747,0 1px 2px #70562d29}[data-theme=light] .board-section--realistic .player-bar__clock:after{background:#6e4f28db;box-shadow:-4px -3px #6e4f28db}.board-section:not(.board-section--3d) .player-bar{box-shadow:0 10px 18px #0000001f}.player-bar__info{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.player-bar__color-indicator{border:2px solid #ffffff2e;border-radius:50%;flex-shrink:0;width:13px;height:13px}.player-bar__color-indicator--white{background:#f0ede8;border-color:#ffffff40}.player-bar__color-indicator--black{background:#2a2826;border-color:#ffffff38}.player-bar__name{color:var(--text-bright);text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:600;overflow:hidden}.player-bar__rating{color:var(--text-dim);font-size:.72rem;font-family:var(--font-mono);background:#ffffff0d;border-radius:999px;flex-shrink:0;padding:2px 7px}.player-bar__clock{font-family:var(--font-mono);color:var(--text-bright);background:var(--bg-input);text-align:center;letter-spacing:.02em;min-width:68px;transition:background var(--transition-base), color var(--transition-base), box-shadow var(--transition-base);border-radius:999px;padding:4px 10px;font-size:.96rem;font-weight:700;position:relative}.player-bar__clock-value{display:inline-block}.player-bar__clock--active{color:#fff;background:var(--accent);box-shadow:0 0 14px #5a902066}.player-bar__clock--low{animation:1s ease-in-out infinite clock-pulse;color:#fff!important;background:var(--danger)!important;box-shadow:0 0 14px #c0303080!important}@keyframes clock-pulse{0%,to{opacity:1}50%{opacity:.65}}.player-chip{background:var(--accent-soft);color:var(--accent-bright);letter-spacing:.02em;border:1px solid #5a902066;border-radius:999px;flex-shrink:0;padding:3px 11px;font-size:.78rem;font-weight:700}.promotion-picker{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);text-align:center;background:radial-gradient(circle at 0 0,#5a90201f,#0000 40%),linear-gradient(#ffffff08,#ffffff04);width:min(580px,100%);margin-top:12px;padding:14px;box-shadow:0 16px 28px #0003}.promotion-picker__title{color:var(--text-bright);margin:0 0 10px;font-size:.9rem;font-weight:700}.promotion-picker__options{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.promotion-picker__option,.promotion-picker__cancel{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-panel);color:var(--text-bright);font:inherit;cursor:pointer;transition:border-color var(--transition-base), background var(--transition-base), transform var(--transition-base)}.promotion-picker__option{flex-direction:column;justify-content:center;align-items:center;gap:6px;min-height:42px;padding:10px 8px;font-weight:700;display:flex}.promotion-picker__icon{object-fit:contain;filter:drop-shadow(0 4px 10px #00000038);width:34px;height:34px}.promotion-picker__label{font-size:.78rem;line-height:1}.promotion-picker__option:hover,.promotion-picker__cancel:hover{border-color:var(--accent);background:var(--bg-panel-hover);transform:translateY(-1px)}.promotion-picker__cancel{margin-top:10px;padding:8px 14px}.ai-opponent-badge{background:#5a90201a;border:1px solid #5a902059;border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:.78rem;display:flex}.badge-icon{font-size:1rem}.badge-content{align-items:center;gap:4px;display:flex}.badge-label{color:var(--accent-bright);margin:0;font-size:.78rem;font-weight:700}.badge-difficulty{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;font-size:.7rem;font-family:var(--font-mono);margin:0}.board-actions{gap:6px;width:100%;max-width:580px;margin-top:10px;display:flex}.board-actions .btn{flex:1;padding:7px 10px;font-size:.8rem}.check-alert{border-radius:var(--radius-sm);background:var(--danger-soft);color:#ff9b85;text-align:center;border:1px solid #c0303066;width:100%;max-width:580px;margin:0 0 8px;padding:8px 16px;font-size:.88rem;font-weight:700;animation:.35s checkShake}@keyframes checkShake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.victory-banner{border-radius:var(--radius-md);color:#a8d96a;text-transform:uppercase;letter-spacing:.06em;text-align:center;background:linear-gradient(135deg,#5a902038 0%,#5a90200f 100%);border:1px solid #5a902080;width:100%;max-width:580px;margin:0 0 10px;padding:14px 20px;font-size:.95rem;font-weight:800;animation:.4s cubic-bezier(.34,1.56,.64,1) victoryEntry}@keyframes victoryEntry{0%{opacity:0;transform:scale(.92)translateY(-6px)}to{opacity:1;transform:scale(1)translateY(0)}}.challenge-toast{border-radius:var(--radius-md);background:linear-gradient(135deg,#5a90202e 0%,#5a90200d 100%);border:1px solid #5a902073;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;width:100%;max-width:580px;margin:0 0 10px;padding:12px 16px;animation:.25s slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.challenge-toast-text{color:var(--text-bright);margin:0;font-size:.88rem}.challenge-toast-actions{gap:6px;display:flex}.ai-thinking-indicator{border-radius:var(--radius-md);background:#5a902012;border:1px solid #5a902033;align-items:center;gap:10px;width:100%;max-width:580px;margin:8px 0;padding:9px 14px;display:flex}.thinking-spinner{border:2px solid #5a90204d;border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:15px;height:15px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.thinking-text{color:var(--accent-hover);font-size:.83rem;font-weight:500;animation:1.6s ease-in-out infinite textPulse}@keyframes textPulse{0%,to{opacity:1}50%{opacity:.5}}.sidebar{background:var(--bg-panel);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);flex-direction:column;height:calc(100vh - 100px);display:flex;position:sticky;top:76px;overflow:hidden}.tab-navigation{border-bottom:1px solid var(--border);scrollbar-width:none;background:var(--bg-panel);flex-shrink:0;display:flex;overflow-x:auto}.tab-navigation::-webkit-scrollbar{display:none}.tab-btn{color:var(--text-dim);cursor:pointer;transition:color var(--transition-base), border-color var(--transition-base), background var(--transition-base);white-space:nowrap;text-align:center;background:0 0;border:none;border-bottom:2px solid #0000;flex-direction:column;flex:1;align-items:center;gap:3px;min-width:0;padding:12px 22px 10px;font-size:.74rem;font-weight:600;display:flex;position:relative}.tab-icon-wrap{justify-content:center;align-items:center;display:inline-flex;position:relative}.tab-icon{transition:transform var(--transition-base);font-size:1rem;line-height:1}.tab-btn:hover .tab-icon{transform:translateY(-1px)}.tab-label{letter-spacing:.04em;text-transform:uppercase;font-size:.63rem;line-height:1}.tab-btn:hover{color:var(--text-bright);background:#ffffff08}.tab-btn.active{color:var(--accent-bright);border-bottom-color:var(--accent);background:#5a902012}.tab-btn.active .tab-icon{filter:drop-shadow(0 0 3px #5a902099)}.tab-badge{color:#fff;text-align:center;pointer-events:none;background:#e53935;border-radius:999px;min-width:16px;height:16px;padding:0 3px;font-size:.6rem;font-weight:700;line-height:16px;animation:.3s cubic-bezier(.34,1.56,.64,1) badgePop;position:absolute;top:-5px;right:-9px}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}.tab-content{flex:1;overflow:hidden auto}.tab-panel{padding:16px 18px;animation:.15s ease-out tabReveal}@keyframes tabReveal{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tab-panel>h3{color:var(--text-dim);text-transform:uppercase;letter-spacing:.09em;margin:0 0 14px;font-size:.72rem;font-weight:700}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-base), color var(--transition-base), transform var(--transition-fast), box-shadow var(--transition-base);font-size:.85rem;font-weight:600;font-family:var(--font-body);border:none;justify-content:center;align-items:center;gap:6px;padding:8px 16px;display:inline-flex}.btn:disabled{opacity:.38;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.97)}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-primary{background:var(--accent);color:#fff;letter-spacing:.01em}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 3px 10px #5a90204d}.btn-ghost{color:var(--text-primary);border:1px solid var(--border);background:#ffffff0e}.btn-ghost:hover:not(:disabled){color:var(--text-bright);border-color:var(--border);background:#ffffff17}.btn-danger{color:#e88;background:#c0303024;border:1px solid #c0303047}.btn-danger:hover:not(:disabled){background:#c030303d}.theme-select{flex-direction:column;gap:5px;margin:8px 0;display:flex}.select,input.select,select.select,textarea.select{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-sm);font-size:.85rem;font-family:var(--font-body);transition:border-color var(--transition-base), box-shadow var(--transition-base);width:100%;padding:8px 12px;display:block}.select:focus{border-color:var(--border-focus);outline:none;box-shadow:0 0 0 3px #5a902024}.select::placeholder{color:var(--text-dim)}.select option{background:var(--bg-panel);color:var(--text-primary)}.match-state{margin:0 0 6px;font-size:.85rem}.play-section{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.play-section-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.07em;margin-bottom:2px;font-size:.68rem;font-weight:700}.play-action-btn{border-radius:var(--radius-md);width:100%;transition:background var(--transition-base), transform var(--transition-fast), box-shadow var(--transition-base);cursor:pointer;font-size:.92rem;font-weight:700;font-family:var(--font-body);border:none;justify-content:center;align-items:center;gap:8px;padding:11px 16px;display:flex}.play-action-btn--primary{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-hover) 100%);color:#fff;box-shadow:0 2px 10px #5a902047}.play-action-btn--primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 18px #5a90206b}.play-action-btn--primary:active:not(:disabled){transform:scale(.98);box-shadow:0 1px 6px #5a902033}.play-action-btn--secondary{background:var(--bg-panel-raised);color:var(--text-muted);border:1px solid var(--border)}.play-action-btn--secondary:hover:not(:disabled){background:var(--bg-panel-hover);color:var(--text-bright)}.play-action-btn:disabled{opacity:.38;cursor:not-allowed}.difficulty-grid{grid-template-columns:repeat(4,1fr);gap:5px;margin:4px 0;display:grid}.difficulty-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-dim);cursor:pointer;text-align:center;transition:all var(--transition-base);font-size:.72rem;font-weight:600;font-family:var(--font-body);padding:7px 4px}.difficulty-btn:hover{color:var(--text-bright);border-color:var(--border);background:var(--bg-panel-hover)}.difficulty-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-bright);font-weight:700}.time-control-grid{grid-template-columns:repeat(3,1fr);gap:5px;margin:4px 0;display:grid}.time-control-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-dim);cursor:pointer;text-align:center;transition:all var(--transition-base);font-size:.72rem;font-weight:600;font-family:var(--font-mono);padding:7px 4px}.time-control-btn:hover{color:var(--text-bright);background:var(--bg-panel-hover)}.time-control-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-bright);font-weight:700}.sidebar-clocks{background:var(--bg-panel-raised);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;gap:4px;margin:10px 0;padding:10px 12px;display:flex}.sidebar-clock-row{border-radius:var(--radius-sm);transition:background var(--transition-base);justify-content:space-between;align-items:center;padding:5px 8px;display:flex}.sidebar-clock-row--active{background:var(--accent-soft);border:1px solid var(--accent)}.sidebar-clock-label{color:var(--text-muted);font-size:.8rem;font-weight:500}.sidebar-clock-val{font-family:var(--font-mono);color:var(--text-bright);letter-spacing:.04em;font-size:1.2rem;font-weight:700}.sidebar-clock-val--low{color:var(--danger);animation:1s ease-in-out infinite clock-pulse}.ready-row{justify-content:space-between;align-items:center;gap:8px;font-size:.85rem;display:flex}.ready-chip{border:1px solid var(--border);color:var(--text-dim);letter-spacing:.02em;border-radius:999px;padding:3px 10px;font-size:.7rem;font-weight:700}.ready-chip--on{border-color:var(--accent);color:var(--accent-bright);background:var(--accent-soft)}.ai-mode-status{border-radius:var(--radius-md);background:var(--accent-glow);border:1px solid #5a902040;margin-top:10px;padding:10px 12px}.ai-status-text{color:var(--accent-bright);margin:0 0 2px;font-size:.82rem;font-weight:700}.ai-status-difficulty{color:var(--accent);font-size:.75rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;margin:0}.waiting-list ul{flex-direction:column;gap:6px;margin:8px 0 0;padding:0;list-style:none;display:flex}.waiting-list li{background:var(--bg-panel-raised);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:border-color var(--transition-base), background var(--transition-base);justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.waiting-list li:hover{border-color:var(--border);background:var(--bg-panel-hover)}.waiting-meta{flex-direction:column;gap:2px;display:flex}.waiting-meta strong{color:var(--text-bright);font-size:.88rem}.waiting-list button{flex-shrink:0;padding:5px 12px;font-size:.78rem}.game-id-input-group{align-items:stretch;gap:6px;display:flex}.game-id-input-group .select{flex:1}.game-id-input-group .btn{flex-shrink:0;padding:6px 14px}.settings-panel{position:relative}.settings-hero{background:radial-gradient(circle at 0 0,#76b03038,#0000 42%),linear-gradient(135deg,#ffffff0a,#ffffff03);border:1px solid #5a90202e;border-radius:18px;grid-template-columns:1fr auto;align-items:center;gap:14px;margin-bottom:18px;padding:14px 16px;display:grid;box-shadow:inset 0 1px #ffffff0a,0 12px 30px #00000029}.settings-hero__eyebrow{color:var(--accent-bright);letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px;font-size:.65rem;font-weight:700;display:inline-block}.settings-hero__title{color:var(--text-bright);margin:0;font-size:.86rem;line-height:1.55}.settings-hero__preview{background:#0a0c0c47;border-radius:18px;grid-template-columns:1fr 1fr;gap:4px;width:62px;height:62px;padding:4px;display:grid;transform:rotate(8deg);box-shadow:inset 0 0 0 1px #ffffff0d}.settings-hero__preview-cell{border-radius:10px;position:relative;overflow:hidden}.settings-hero__preview-cell:after{content:"";background:linear-gradient(135deg,#ffffff2e,#0000 60%);position:absolute;inset:0}.settings-hero__preview-cell--light{background:#e7d4b2}.settings-hero__preview-cell--dark{background:#8f6546}.settings-hero__preview-cell--accent{box-shadow:inset 0 0 0 2px #84cb37cc,0 0 16px #84cb3740}.settings-section{background:linear-gradient(#ffffff08,#ffffff04),#00000014;border:1px solid #ffffff0f;border-radius:16px;margin-bottom:16px;padding:14px;box-shadow:inset 0 1px #ffffff08}.settings-section-heading{align-items:center;gap:10px;margin-bottom:10px;display:flex}.settings-section-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.07em;margin:0;font-size:.68rem;font-weight:700;display:block}.settings-section-rail{background:linear-gradient(90deg,#ffffff0f,#ffffff04);border-radius:999px;flex:1;height:8px;position:relative;overflow:hidden}.settings-section-rail:before{content:"";border-radius:inherit;background:linear-gradient(90deg,#76b030e6,#b6db6659);width:clamp(58px,28%,112px);position:absolute;inset:1px;box-shadow:0 0 16px #76b03040}.settings-section-rail:after{content:"";border-radius:inherit;opacity:.5;background:linear-gradient(90deg,#ffffff3d,#0000);width:32%;position:absolute;top:1px;bottom:1px;left:12px}.settings-slider{flex-direction:column;gap:8px;display:flex}.settings-slider__input{width:100%;accent-color:var(--accent);cursor:pointer}.settings-slider__meta{color:var(--text-dim);justify-content:space-between;align-items:center;gap:10px;font-size:.72rem;display:flex}.settings-slider__meta strong{color:var(--text-bright);font-family:var(--font-mono);font-size:.78rem}.theme-swatches{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.theme-swatch{border-radius:var(--radius-md);border:2px solid var(--border-subtle);background:var(--bg-panel-raised);cursor:pointer;transition:border-color var(--transition-base), background var(--transition-base), transform var(--transition-fast), box-shadow var(--transition-base);color:var(--text-dim);font-size:.7rem;font-weight:600;font-family:var(--font-body);flex-direction:column;align-items:center;gap:7px;padding:10px 6px 8px;display:flex}.theme-swatch:hover{border-color:var(--border);color:var(--text-bright);transform:translateY(-1px);box-shadow:0 12px 20px #00000029}.theme-swatch.active{border-color:var(--accent);color:var(--accent-bright);background:var(--accent-glow);box-shadow:0 0 0 1px #76b03040,0 14px 24px #253d1047}.theme-swatch-preview{border-radius:var(--radius-xs);width:36px;height:36px;box-shadow:var(--shadow-sm);grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;display:grid;overflow:hidden}.theme-swatch-preview span{display:block}.swatch-classic-light{background:#f0d9b5}.swatch-classic-dark{background:#b58863}.swatch-slate-light{background:#dee3e6}.swatch-slate-dark{background:#8ca2ad}.swatch-rosewood-light{background:#f0d2b4}.swatch-rosewood-dark{background:#b06040}.piece-set-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.piece-set-btn{border-radius:var(--radius-md);border:2px solid var(--border-subtle);background:var(--bg-panel-raised);cursor:pointer;transition:border-color var(--transition-base), transform var(--transition-fast), box-shadow var(--transition-base), background var(--transition-base);color:var(--text-dim);font-size:.72rem;font-weight:600;font-family:var(--font-body);flex-direction:column;align-items:center;gap:6px;padding:12px 8px;display:flex}.piece-set-btn:hover{border-color:var(--border);color:var(--text-bright);transform:translateY(-1px);box-shadow:0 12px 20px #00000024}.piece-set-btn.active{border-color:var(--accent);color:var(--accent-bright);background:var(--accent-glow);box-shadow:0 0 0 1px #76b03040,inset 0 1px #ffffff0f}.piece-set-preview{font-size:1.6rem;line-height:1}.piece-set-note{color:var(--text-dim);font-size:.64rem;font-weight:500}.piece-set-btn.active .piece-set-note{color:var(--accent)}.theme-swatch--custom{position:relative}.theme-swatch-delete{color:#fff;cursor:pointer;opacity:0;z-index:2;background:#c03030cc;border-radius:50%;place-items:center;width:16px;height:16px;font-size:.75rem;line-height:1;transition:opacity .15s;display:grid;position:absolute;top:4px;right:4px}.theme-swatch--custom:hover .theme-swatch-delete{opacity:1}.theme-swatch--add .theme-swatch-preview--add{color:var(--text-dim);background:var(--bg-panel);border:2px dashed var(--border);border-radius:var(--radius-xs);place-items:center;width:36px;height:36px;margin:0 auto;padding:0;font-size:0;display:grid;position:relative}.theme-swatch--add .theme-swatch-preview--add:before{content:"+";color:var(--text-dim);place-items:center;font-size:1.5rem;font-weight:300;line-height:1;display:grid;position:absolute;inset:0;transform:translateY(-1px)}.theme-creator{background:var(--bg-panel-raised);border-radius:var(--radius-md);border:1px solid var(--border-subtle);flex-direction:column;gap:10px;margin-top:12px;padding:12px;display:flex}.theme-creator__pickers{flex-direction:column;gap:6px;display:flex}.theme-creator__color-row{cursor:pointer;justify-content:space-between;align-items:center;display:flex}.theme-creator__color-label{color:var(--text-muted);font-size:.75rem;font-weight:500}.theme-creator__color-input{border:1px solid var(--border);border-radius:var(--radius-xs);cursor:pointer;background:0 0;width:36px;height:24px;padding:1px}.theme-creator__preview{border-radius:var(--radius-xs);width:80px;height:80px;box-shadow:var(--shadow-sm);grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(4,1fr);align-self:center;display:grid;overflow:hidden}.theme-creator__preview-sq{width:100%;height:100%}.theme-creator__actions{gap:8px;display:flex}.theme-creator__actions .btn{flex:1;padding:7px 10px;font-size:.8rem}.game-chat{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-panel);flex-direction:column;width:100%;max-width:580px;margin-top:10px;display:flex;overflow:hidden}.game-chat__header{text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;padding:7px 14px;font-size:.68rem;font-weight:700;display:flex}.game-chat__mode{color:var(--accent-bright)}.game-chat__voice-panel{border-bottom:1px solid var(--border-subtle);background:linear-gradient(#5a902014,#5a902005);flex-direction:column;gap:8px;padding:10px 12px;display:flex}.game-chat__voice-meta{color:var(--text-muted);align-items:center;gap:8px;font-size:.8rem;display:flex}.game-chat__voice-dot{background:#fff3;border-radius:999px;width:9px;height:9px;box-shadow:0 0 0 1px #ffffff14}.game-chat__voice-dot--live{background:#49c05f;box-shadow:0 0 10px #49c05f99}.game-chat__voice-actions{gap:8px;display:flex}.game-chat__voice-diagnostics{grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:8px;display:grid}.game-chat__voice-diagnostic{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:#ffffff0a;flex-direction:column;gap:3px;padding:8px 9px;display:flex}.game-chat__voice-diagnostic-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-size:.66rem;font-weight:700}.game-chat__voice-diagnostic-value{color:var(--text-bright);font-size:.8rem;font-weight:600}.game-chat__messages{flex-direction:column;gap:4px;height:150px;padding:8px 14px;display:flex;overflow-y:auto}.game-chat__empty{color:var(--text-dim);font-size:.78rem;font-style:italic}.game-chat__message{color:var(--text-primary);word-break:break-word;font-size:.82rem;line-height:1.4}.game-chat__message--own .game-chat__message-name{color:var(--accent-bright)}.game-chat__message-name{color:var(--text-bright);margin-right:5px;font-weight:700}.game-chat__input-row{border-top:1px solid var(--border-subtle);flex-shrink:0;gap:6px;padding:8px 10px;display:flex}.game-chat__input-row .select{flex:1;padding:6px 10px;font-size:.82rem}.game-chat__input-row .btn{flex-shrink:0;padding:6px 14px;font-size:.8rem}.game-chat__voice-btn{min-width:84px}.game-chat__voice-btn--live{color:#fff;background:var(--accent);border-color:var(--accent)}.game-chat__speech-status{border-radius:var(--radius-sm);color:#ffc3c3;background:#c0303014;border:1px solid #c0303038;padding:9px 10px;font-size:.76rem}.moves-list{padding:0;overflow-y:visible}.move-table{width:100%}.move-table-row{border-radius:var(--radius-xs);transition:background var(--transition-fast);grid-template-columns:28px 1fr 1fr;display:grid}.move-table-row:nth-child(odd){background:#ffffff04}.move-table-row:hover{background:#ffffff0d}.move-number-cell{color:var(--text-dim);text-align:right;font-size:.72rem;font-weight:500;font-family:var(--font-mono);padding:4px 6px}.move-cell{font-family:var(--font-mono);color:var(--text-primary);border-radius:var(--radius-xs);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);padding:4px 8px;font-size:.85rem;font-weight:500}.move-cell:hover{color:var(--text-bright);background:#ffffff14}.move-cell--empty{cursor:default}.move-cell--empty:hover{background:0 0}.time-summary{background:var(--bg-panel-raised);border-radius:var(--radius-md);border:1px solid var(--border-subtle);grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;padding:10px 12px;display:grid}.summary-item{flex-direction:column;gap:2px;display:flex}.summary-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;font-size:.68rem;font-weight:700}.summary-time{font-family:var(--font-mono);color:var(--text-bright);font-size:1.05rem;font-weight:700}.review-timeline{border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-panel-raised);margin-top:12px;padding:10px}.review-timeline__header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.review-timeline__header h4{text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim);margin:0;font-size:.75rem}.review-timeline__result{color:var(--accent-bright);font-size:.72rem}.review-timeline__list{flex-direction:column;gap:6px;display:flex}.review-timeline__row{border-radius:var(--radius-xs);background:#ffffff05;grid-template-columns:34px 52px 1fr;align-items:center;gap:8px;padding:6px 8px;display:grid}.review-timeline__idx{color:var(--text-dim);font-size:.69rem;font-family:var(--font-mono)}.review-timeline__san{font-family:var(--font-mono);color:var(--text-bright);font-size:.82rem;font-weight:700}.review-timeline__tags{flex-wrap:wrap;gap:4px;display:flex}.review-tag{color:var(--text-dim);border:1px solid var(--border);text-transform:uppercase;letter-spacing:.03em;border-radius:999px;padding:3px 7px;font-size:.63rem;line-height:1}.review-tag--alert{color:#ffb7a8;background:#c0303024;border-color:#c0303059}.coach-hints{border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:#5a902012;margin-top:12px;padding:10px}.coach-hints__header{justify-content:space-between;align-items:center;gap:8px;display:flex}.coach-hints__header h4{letter-spacing:.07em;text-transform:uppercase;color:var(--text-dim);margin:0;font-size:.75rem}.coach-hints__badge{text-transform:uppercase;letter-spacing:.05em;color:var(--accent-bright);border:1px solid #5a902059;border-radius:999px;padding:3px 6px;font-size:.62rem}.coach-hints__list{flex-direction:column;gap:7px;margin-top:8px;display:flex}.coach-hints__item strong{color:var(--text-bright);font-size:.78rem}.coach-hints__item p{color:var(--text-dim);margin:4px 0 0;font-size:.74rem;line-height:1.45}.muted{color:var(--text-dim);font-size:.82rem}.error-text{color:#e88;margin-top:6px;font-size:.83rem}.footer{border-top:1px solid var(--border-subtle);color:var(--text-dim);background:var(--bg-header);justify-content:space-between;align-items:center;margin-top:auto;padding:14px 24px;font-size:.75rem;display:flex}.footer-brand{color:var(--text-muted);letter-spacing:-.01em;align-items:center;gap:8px;font-size:.82rem;font-weight:700;display:flex}.footer-brand-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:6px;height:6px}.footer-meta{color:var(--text-dim);font-size:.72rem}@media (width<=1100px){.layout{grid-template-columns:1fr 300px;gap:0 16px;padding:16px}}@media (width<=900px){.layout{grid-template-columns:1fr;gap:14px;padding:12px}.sidebar{height:auto;max-height:none;position:static;top:auto}.tab-content{max-height:420px}.board-section{padding:0}}@media (width<=640px){.top-bar{height:48px;padding:0 14px}.brand h1{font-size:.95rem}.brand-subtitle,.auth-name,.auth-meta{display:none}@media (width<=480px){.auth-user .btn{display:none}}.layout{gap:12px;padding:10px}.tab-btn{min-width:40px;padding:10px 4px 8px}.tab-label{font-size:.58rem}.player-bar{min-height:36px;padding:6px 10px}.player-bar__name{font-size:.85rem}.player-bar__clock{min-width:62px;padding:2px 8px;font-size:.92rem}.board-actions .btn{padding:6px 8px;font-size:.75rem}.footer{text-align:center;flex-direction:column;gap:6px;padding:12px}}@media (width<=480px){.tab-label{display:none}.tab-btn{padding:12px 0}.tab-icon{font-size:1.2rem}}.leaderboard-panel{background:var(--bg-panel);border-right:1px solid var(--border-subtle);flex-direction:column;height:calc(100vh - 80px);display:flex;position:sticky;top:64px;overflow:hidden}.leaderboard-panel[data-embedded]{background:0 0;border-right:none;height:auto;position:static;top:auto;overflow-y:visible}.leaderboard-header{border-bottom:1px solid var(--border-subtle);flex-shrink:0;padding:12px 14px 8px}.leaderboard-panel[data-embedded] .leaderboard-header{border-bottom:1px solid var(--border-subtle);margin-bottom:4px;padding:0 0 10px}.leaderboard-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin:0;font-size:.72rem;font-weight:700}.leaderboard-list{flex:1;padding:4px 0;overflow-y:auto}.leaderboard-empty{padding:12px 4px;font-size:.82rem}.lb-row{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;transition:background var(--transition-fast);border-radius:var(--radius-sm);background:0 0;border:none;border-left:3px solid #0000;align-items:center;gap:9px;margin:1px 0;padding:7px 10px;font-family:inherit;font-size:.83rem;display:flex}.lb-row:hover{background:#ffffff0d}.lb-row--self{background:var(--accent-glow);border-left-color:var(--accent)}.lb-row--self:hover{background:#5a90201a}.lb-rank{color:var(--text-dim);text-align:right;min-width:26px;font-size:.7rem;font-family:var(--font-mono);flex-shrink:0;font-weight:600}.lb-row:first-child .lb-rank{color:gold}.lb-row:nth-child(2) .lb-rank{color:silver}.lb-row:nth-child(3) .lb-rank{color:#cd7f32}.lb-avatar{background:var(--accent-soft);border:1.5px solid var(--border);width:27px;height:27px;color:var(--accent-bright);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:flex;overflow:hidden}.lb-avatar img{object-fit:cover;width:100%;height:100%}.lb-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.lb-name{text-overflow:ellipsis;white-space:nowrap;color:var(--text-bright);font-size:.84rem;font-weight:600;overflow:hidden}.lb-rating{color:var(--text-dim);font-size:.72rem;font-family:var(--font-mono)}.avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.avatar--md{width:44px;height:44px;font-size:1rem}.avatar--lg{width:72px;height:72px;font-size:1.7rem}.avatar--initials{background:var(--accent-soft);color:var(--accent-bright);border:2px solid #5a902059;font-weight:800}.avatar img{object-fit:cover;width:100%;height:100%}.modal-overlay{-webkit-backdrop-filter:blur(6px);z-index:200;background:#000000bf;justify-content:center;align-items:center;padding:16px;animation:.15s overlayFade;display:flex;position:fixed;inset:0}@keyframes overlayFade{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:430px;max-height:90vh;box-shadow:var(--shadow-lg), 0 0 0 1px #ffffff0a;padding:0;animation:.22s cubic-bezier(.34,1.56,.64,1) modalEntry;position:relative;overflow:hidden}@keyframes modalEntry{0%{opacity:0;transform:scale(.93)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-close{color:var(--text-dim);cursor:pointer;width:28px;height:28px;transition:background var(--transition-base), color var(--transition-base);z-index:2;background:#ffffff14;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;line-height:1;display:flex;position:absolute;top:12px;right:14px}.modal-close:hover{color:var(--text-bright);background:#ffffff26}.setup-modal{max-width:540px}.setup-modal__content{padding:20px}.setup-modal__content h3{color:var(--text-bright);margin:0 0 6px}.setup-modal__section{margin-top:16px}.setup-modal__actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:18px;display:grid}.runtime-error{border-radius:var(--radius-lg);background:linear-gradient(#c030301f,#c030300a);border:1px solid #c030304d;width:min(720px,100% - 32px);margin:18px auto;padding:22px}.runtime-error h2{color:var(--text-bright);margin:0 0 8px;font-size:1.1rem}.runtime-error__actions{gap:8px;margin-top:12px;display:flex}.toast-stack{z-index:220;flex-direction:column;gap:8px;max-width:min(360px,100vw - 32px);display:flex;position:fixed;bottom:16px;right:16px}.toast{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:var(--bg-panel-raised);color:var(--text-primary);padding:10px 12px;font-size:.8rem;box-shadow:0 8px 20px #00000038}.toast--error{color:#ffc7c7;background:#c0303029;border-color:#c0303059}.profile-modal{max-height:90vh;padding:0;overflow-y:auto}.profile-header-band{background:linear-gradient(135deg,#5a902038 0%,#5a90200d 100%);border-bottom:1px solid #5a90202e;align-items:flex-start;gap:18px;padding:24px 22px 20px;display:flex;position:relative}.profile-meta{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.profile-name{letter-spacing:-.025em;color:var(--text-bright);margin:0;font-size:1.25rem;font-weight:800}.profile-rating-badge{background:var(--accent-soft);color:var(--accent-bright);font-size:.8rem;font-weight:700;font-family:var(--font-mono);border:1px solid #5a902066;border-radius:999px;align-items:center;gap:4px;width:fit-content;padding:3px 10px;display:inline-flex}.profile-anon-tag{color:var(--text-dim);font-size:.72rem;font-style:italic}.profile-wld{align-items:center;gap:5px;margin-top:2px;display:flex}.wld-item{font-size:.78rem;font-weight:700;font-family:var(--font-mono)}.wld-win{color:#4caf50}.wld-loss{color:#e57373}.wld-draw{color:var(--text-dim)}.wld-sep{color:var(--text-dim);font-size:.7rem}.profile-body{padding:18px 22px 6px}.profile-intro{color:var(--text-muted);background:var(--bg-panel-raised);border-radius:var(--radius-sm);border-left:3px solid var(--border);margin:0 0 16px;padding:10px 12px;font-size:.88rem;line-height:1.6}.profile-intro-empty{color:var(--text-dim);margin:0 0 14px;font-size:.83rem;font-style:italic}.profile-actions{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.profile-actions .btn{flex:1;min-width:100px}.profile-edit-form{flex-direction:column;gap:14px;padding:22px;display:flex}.profile-edit-form h3{color:var(--text-bright);margin:0 0 4px;font-size:.95rem;font-weight:700}.edit-label{color:var(--text-dim);flex-direction:column;gap:6px;font-size:.82rem;font-weight:600;display:flex}.edit-textarea{resize:vertical;min-height:80px;font-family:inherit}.profile-history{border-top:1px solid var(--border-subtle);margin-top:2px;padding:16px 22px 22px}.profile-history-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin:0 0 10px;font-size:.68rem;font-weight:700}.history-row{border-radius:var(--radius-xs);transition:background var(--transition-fast);border-bottom:1px solid #ffffff0a;grid-template-columns:44px 1fr auto auto;align-items:center;gap:8px;padding:6px 4px;font-size:.82rem;display:grid}.history-row:hover{background:#ffffff08}.history-row:last-child{border-bottom:none}.history-result{text-align:center;letter-spacing:.04em;border-radius:999px;padding:3px 7px;font-size:.68rem;font-weight:800}.result-win{color:#4caf50;background:#4caf502e}.result-loss{color:#e57373;background:#e573732e}.result-draw{color:var(--text-dim);background:#ffffff12}.history-opponent{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.history-delta{font-family:var(--font-mono);white-space:nowrap;font-size:.76rem;font-weight:700}.delta-pos{color:#4caf50}.delta-neg{color:#e57373}.history-date{color:var(--text-dim);white-space:nowrap;font-size:.7rem}.social-tab{flex-direction:column;display:flex;padding:0!important}.social-subtabs{border-bottom:1px solid var(--border);flex-shrink:0;margin-bottom:0;display:flex}.social-subtab-btn{color:var(--text-dim);cursor:pointer;transition:color var(--transition-base), border-color var(--transition-base);letter-spacing:.03em;font-size:.75rem;font-weight:600;font-family:var(--font-body);background:0 0;border:none;border-bottom:2px solid #0000;border-radius:0;flex:1;padding:11px 0}.social-subtab-btn:hover{color:var(--text-bright)}.social-subtab-btn.active{color:var(--accent-bright);border-bottom-color:var(--accent)}.social-section{flex-direction:column;gap:8px;padding:16px 18px;display:flex}.social-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin:0 0 6px;font-size:.68rem;font-weight:700}.announcements-list{flex-direction:column;gap:6px;max-height:280px;padding-right:2px;display:flex;overflow-y:auto}.ann-item{border-radius:var(--radius-md);transition:background var(--transition-fast);background:#ffffff09;border:1px solid #ffffff0f;padding:9px 11px}.ann-item--own{background:var(--accent-glow);border-color:#5a902047}.ann-row{justify-content:space-between;align-items:baseline;gap:6px;margin-bottom:3px;display:flex}.ann-author{color:var(--accent-bright);font-size:.78rem;font-weight:700}.ann-time{color:var(--text-dim);font-size:.7rem;font-family:var(--font-mono)}.ann-text{word-break:break-word;color:var(--text-primary);margin:0;font-size:.84rem;line-height:1.4}.ann-input-row{gap:6px;margin-top:6px;display:flex}.ann-input{flex:1;min-width:0;padding:7px 10px;font-size:.85rem}.ann-send-btn{white-space:nowrap;flex-shrink:0;padding:6px 14px;font-size:.82rem}.dm-conversation{flex-direction:column;height:100%;min-height:360px;padding:14px 18px 16px;display:flex}.dm-header{border-bottom:1px solid var(--border-subtle);align-items:center;gap:10px;margin-bottom:12px;padding-bottom:10px;display:flex}.dm-back-btn{padding:4px 10px;font-size:.8rem}.dm-partner-name{color:var(--text-bright);font-size:.92rem;font-weight:700}.dm-messages{flex-direction:column;flex:1;gap:6px;max-height:300px;padding:4px 0;display:flex;overflow-y:auto}.dm-empty{text-align:center;color:var(--text-dim);padding:20px 0;font-size:.85rem}.dm-message{flex-direction:column;align-items:flex-start;gap:2px;max-width:86%;display:flex}.dm-message--own{align-self:flex-end;align-items:flex-end}.dm-sender{color:var(--text-dim);padding:0 4px;font-size:.7rem}.dm-bubble{word-break:break-word;background:#ffffff12;border:1px solid #ffffff17;border-radius:12px;padding:7px 12px;font-size:.85rem;line-height:1.45}.dm-message--own .dm-bubble{background:var(--accent-soft);color:var(--text-bright);border-color:#5a90204d}.dm-input-row{border-top:1px solid var(--border-subtle);gap:6px;margin-top:10px;padding-top:10px;display:flex}.dm-input{flex:1;min-width:0;padding:7px 10px;font-size:.85rem}.dm-send-btn{white-space:nowrap;flex-shrink:0;padding:6px 14px;font-size:.82rem}.friend-requests-inbox{border-radius:var(--radius-md);background:#5a90200f;border:1px solid #5a90202e;margin-bottom:6px;padding:10px 12px}.friend-request-item{justify-content:space-between;align-items:center;gap:8px;padding:5px 0;display:flex}.friend-request-name{color:var(--text-bright);font-size:.88rem;font-weight:600}.friend-item{border-radius:var(--radius-md);background:var(--bg-panel-raised);border:1px solid var(--border-subtle);transition:border-color var(--transition-fast), background var(--transition-fast);align-items:center;gap:8px;padding:7px 10px;display:flex}.friend-item:hover{background:var(--bg-panel-hover);border-color:var(--border)}.friend-name-btn{color:var(--text-bright);cursor:pointer;text-align:left;text-overflow:ellipsis;white-space:nowrap;background:0 0;border:none;flex:1;min-width:0;padding:0;font-family:inherit;font-size:.88rem;font-weight:600;overflow:hidden}.friend-name-btn:hover{color:var(--accent-bright)}.friend-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.friend-remove-btn{line-height:1;color:var(--text-dim)!important;background:0 0!important;border-color:#0000!important;padding:.2rem .45rem!important;font-size:.72rem!important}.friend-remove-btn:hover{color:#e88!important;background:#c030301a!important;border-color:#0000!important}.presence-dot{background:#ffffff1a;border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.presence-dot--online{background:#4caf50;animation:2.5s ease-in-out infinite presencePulse}@keyframes presencePulse{0%,to{box-shadow:0 0 3px #4caf5080}50%{box-shadow:0 0 7px #4caf50d9}}.lb-row .presence-dot{flex-shrink:0}.waiting-list{margin-top:4px}.ready-panel{border-radius:var(--radius-md);background:var(--bg-panel-raised);border:1px solid var(--border-subtle);flex-direction:column;gap:8px;margin:10px 0;padding:12px 14px;display:flex}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-body:#0f0e0d;--bg-page:#141210;--bg-panel:#1c1a17;--bg-panel-raised:#232119;--bg-panel-hover:#272420;--bg-input:#161410;--bg-header:#0f0e0d;--text-primary:#c4c1bc;--text-bright:#edeae6;--text-white:#fff;--text-dim:#6a6865;--text-muted:#9a9794;--text-link:#7eb6d8;--accent:#5a9020;--accent-hover:#6aaa28;--accent-bright:#7dc435;--accent-soft:#5a90202e;--accent-glow:#5a902012;--danger:#c03030;--danger-soft:#c0303026;--success:#4a9a4a;--border:#2e2c29;--border-subtle:#222018;--border-focus:var(--accent);--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 16px #00000080;--shadow-lg:0 12px 40px #000000a6;--shadow-board:0 0 0 1px #00000080, 0 8px 48px #000000b3;--radius-xs:3px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--font-body:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "SF Mono", "Fira Code", monospace;--transition-fast:.1s ease;--transition-base:.18s ease;--transition-slow:.28s ease}[data-theme=light]{--bg-body:#f5f4f2;--bg-page:#fff;--bg-panel:#f0ede9;--bg-panel-raised:#e8e4df;--bg-panel-hover:#e2ddd8;--bg-input:#faf9f7;--bg-header:#f5f4f2;--text-primary:#2c2a27;--text-bright:#111009;--text-white:#1a1814;--text-dim:#9a9592;--text-muted:#6a6865;--text-link:#2e7ab0;--border:#d0cdc9;--border-subtle:#e0ddd8;--shadow-sm:0 1px 3px #0000001f;--shadow-md:0 4px 16px #00000026;--shadow-lg:0 12px 40px #0003;--shadow-board:0 0 0 1px #00000026, 0 8px 48px #0003}[data-theme=light] ::-webkit-scrollbar-thumb{background:#c8c5c1}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#b0ada9}body{font-family:var(--font-body);background:var(--bg-body);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-size:14px;line-height:1.5}#root{min-height:100vh}button{cursor:pointer;font-family:inherit}a{color:var(--text-link);text-decoration:none}a:hover{text-decoration:underline}::selection{background:var(--accent);color:#fff}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#2e2c29;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#403e3b}
