*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{background:var(--bg-app);color:var(--text-main);margin:0;font-family:Inter,Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif}button{font:inherit}img{-webkit-user-drag:none;user-drag:none;draggable:false;-webkit-user-select:none;user-select:none}html,body{-webkit-user-select:none;user-select:none}input,textarea,select{-webkit-user-select:text;user-select:text}@media (pointer:coarse){body{-webkit-user-select:none;user-select:none}input[type=text],input[type=search],input[type=email],input[type=password],textarea{-webkit-user-select:text;user-select:text}input[type=range]{touch-action:none}}body{margin:0}html,body,#root{height:100%}:root{--bg-app:#f0ece6;--bg-subtle:#e8e3db;--nav-bg:#e3ddd4;--text-main:#2b2722;--text-muted:#7d7570;--text-subtle:#a39d98;--panel-bg:#ffffffe0;--panel-bg-subtle:#ffffff8c;--panel-border:#00000012;--panel-border-strong:#0000001f;--panel-shadow:0 1px 3px #0000000d, 0 4px 18px #0000000a;--accent:#5e8d7b;--accent-muted:#5e8d7b24;--accent-border:#5e8d7b47;--accent-text:#3a6b59;--accent-hover-bg:#5e8d7b38;--nav-item-color:#8a8078;--nav-item-hover-bg:#0000000d;--nav-item-active-bg:#5e8d7b21;--nav-item-active-color:#3a6b59;--btn-bg:#0000000d;--btn-bg-hover:#00000017;--btn-border:#0000001c;--btn-color:#4a4540;--btn-primary-bg:#5e8d7b21;--btn-primary-border:#5e8d7b47;--btn-primary-color:#3a6b59;--btn-primary-hover-bg:#5e8d7b38;--input-bg:#0000000a;--input-bg-focus:#00000012;--input-border:#0000001f;--input-border-focus:#5e8d7b73;--input-color:#2b2722;--input-placeholder:#a39d98;--panel-popup-bg:#faf8f4;--color-gameover:#b87840;--color-success:#4a9060;--color-warning:#a88040;--color-danger:#b05050;--color-pos-eval:#2b2722;--color-neg-eval:#7090a8;--board-light:#f0d9b5;--board-dark:#b58863}[data-theme=dark]{--bg-app:#1c1917;--bg-subtle:#171512;--nav-bg:#141210;--text-main:#e8e3da;--text-muted:#9e9890;--text-subtle:#6e6860;--panel-bg:#ffffff0f;--panel-bg-subtle:#ffffff08;--panel-border:#ffffff14;--panel-border-strong:#ffffff26;--panel-shadow:0 1px 4px #0003, 0 4px 18px #00000024;--accent:#8ab5a0;--accent-muted:#8ab5a024;--accent-border:#8ab5a047;--accent-text:#8ab5a0;--accent-hover-bg:#8ab5a038;--nav-item-color:#726c64;--nav-item-hover-bg:#ffffff0d;--nav-item-active-bg:#8ab5a026;--nav-item-active-color:#8ab5a0;--btn-bg:#ffffff12;--btn-bg-hover:#ffffff1c;--btn-border:#ffffff1f;--btn-color:#c8c0b8;--btn-primary-bg:#8ab5a024;--btn-primary-border:#8ab5a047;--btn-primary-color:#8ab5a0;--btn-primary-hover-bg:#8ab5a038;--input-bg:#ffffff12;--input-bg-focus:#ffffff1a;--input-border:#ffffff1f;--input-border-focus:#8ab5a073;--input-color:#e8e3da;--input-placeholder:#6e6860;--panel-popup-bg:#201e1a;--color-gameover:#d4a870;--color-success:#72b882;--color-warning:#d4a870;--color-danger:#d08078;--color-pos-eval:#e8e3da;--color-neg-eval:#8da8be}[data-theme=light]{--bg-app:#f0ece6;--bg-subtle:#e8e3db;--nav-bg:#e3ddd4;--text-main:#2b2722;--text-muted:#7d7570;--text-subtle:#a39d98;--panel-bg:#ffffffe0;--panel-bg-subtle:#ffffff8c;--panel-border:#00000012;--panel-border-strong:#0000001f;--panel-shadow:0 1px 3px #0000000d, 0 4px 18px #0000000a;--accent:#5e8d7b;--accent-muted:#5e8d7b24;--accent-border:#5e8d7b47;--accent-text:#3a6b59;--accent-hover-bg:#5e8d7b38;--nav-item-color:#8a8078;--nav-item-hover-bg:#0000000d;--nav-item-active-bg:#5e8d7b21;--nav-item-active-color:#3a6b59;--btn-bg:#0000000d;--btn-bg-hover:#00000017;--btn-border:#0000001c;--btn-color:#4a4540;--btn-primary-bg:#5e8d7b21;--btn-primary-border:#5e8d7b47;--btn-primary-color:#3a6b59;--btn-primary-hover-bg:#5e8d7b38;--input-bg:#0000000a;--input-bg-focus:#00000012;--input-border:#0000001f;--input-border-focus:#5e8d7b73;--input-color:#2b2722;--input-placeholder:#a39d98;--panel-popup-bg:#faf8f4;--color-gameover:#b87840;--color-success:#4a9060;--color-warning:#a88040;--color-danger:#b05050;--color-pos-eval:#2b2722;--color-neg-eval:#7090a8}.app-shell{background:var(--bg-app);min-height:100dvh;color:var(--text-main);flex-direction:row;display:flex}.app-content{min-height:100dvh;margin-left:var(--nav-w,72px);flex-direction:column;flex:1;display:flex;overflow-x:hidden}.home-page{flex-direction:column;flex:1;width:100%;display:flex}@media (width<=640px){.app-content{margin-left:0;margin-bottom:var(--nav-h-mobile,62px);min-height:calc(100dvh - var(--nav-h-mobile,62px))}.home-page{min-height:calc(100dvh - var(--nav-h-mobile,62px))}}:root{--nav-w:72px;--nav-h-mobile:60px;--layout-pad:12px;--col-gap:12px;--eval-bar-w:26px;--sidebar-w:280px;--review-panel-w:0px;--board-border:16px;--move-list-mobile-max-h:180px;--mobile-gutter:16px;--h-chrome:calc(var(--nav-w) + var(--layout-pad) * 2 + var(--eval-bar-w) + var(--col-gap) + var(--col-gap) + var(--sidebar-w) + var(--review-panel-w) + var(--board-border));--v-chrome:calc(var(--layout-pad) * 2 + var(--board-border));--sq:max(44px, min(calc((100dvh - var(--v-chrome)) / 8), calc((100vw - var(--h-chrome)) / 8)));--board-size:calc(var(--sq) * 8 + var(--board-border))}.board-layout.with-review{--review-panel-w:calc(320px + var(--col-gap))}.chess-container{padding:var(--layout-pad);box-sizing:border-box;-webkit-user-select:none;user-select:none;flex-direction:column;flex:auto;justify-content:flex-start;align-items:center;width:100%;display:flex}.board-layout{align-items:stretch;gap:var(--col-gap);height:var(--board-size);flex-direction:row;justify-content:center;display:flex}.sidebar{width:var(--sidebar-w);scrollbar-width:thin;scrollbar-color:#ffffff26 transparent;flex-direction:column;flex-shrink:0;gap:8px;min-height:0;display:flex;overflow:hidden auto}.analysis-panel{opacity:0;pointer-events:none;flex-direction:column;flex-shrink:0;width:0;max-width:0;min-height:0;transition:width .45s cubic-bezier(.22,1,.36,1),max-width .45s cubic-bezier(.22,1,.36,1),opacity .32s,transform .45s cubic-bezier(.22,1,.36,1);display:flex;overflow:hidden;transform:translate(20px)}.analysis-panel.visible{opacity:1;pointer-events:auto;width:320px;max-width:320px;transform:translate(0)}@media (width<=960px){:root{--sidebar-w:240px}.analysis-panel.visible{width:260px;max-width:260px}.board-layout.with-review{--review-panel-w:calc(260px + var(--col-gap))}}@media (width<=820px){:root{--sq:max(44px, calc(( 100vw - var(--nav-w) - var(--layout-pad) * 2 - var(--mobile-gutter) - var(--board-border) ) / 8))}.chess-container{align-items:center}.board-layout{flex-direction:column;align-items:center;gap:12px;height:auto}.sidebar{width:100%;height:auto;min-height:unset;gap:8px;max-height:none;padding:0 8px;overflow:hidden visible}.analysis-panel{width:100%;max-width:100%;height:auto;max-height:0;padding:0 8px;transition:max-height .45s cubic-bezier(.22,1,.36,1),opacity .32s;overflow:hidden;transform:none}.analysis-panel.visible{width:100%;max-width:100%;max-height:2000px;overflow:visible}}@media (width<=640px){:root{--sq:calc((100vw - var(--mobile-gutter)) / 8)}.chess-container{align-items:stretch;padding:0}.board-layout{flex-direction:column;align-items:stretch;gap:0;height:auto}.sidebar{width:100%;height:auto;min-height:unset;gap:0;max-height:none;padding:0 8px;overflow:hidden visible}.analysis-panel{width:100%;max-width:100%;height:auto;max-height:0;padding:0 8px;transition:max-height .45s cubic-bezier(.22,1,.36,1),opacity .32s;overflow:hidden;transform:none}.analysis-panel.visible{width:100%;max-width:100%;max-height:2000px;overflow:visible}.sidebar .game-status,.sidebar .engine-controls,.sidebar .engine-lines,.sidebar .move-history,.analysis-panel .game-review{box-shadow:none!important;background:0 0!important;border:none!important;border-radius:0!important;margin:0!important;padding:10px 0!important}.sidebar .engine-lines,.sidebar .move-history,.analysis-panel .game-review{border-top:1px solid var(--panel-border)!important}.move-list{max-height:var(--move-list-mobile-max-h)}}:root{--board-light:#f0d9b5;--board-dark:#b58863}.board-area-outer{flex-direction:row;flex-shrink:0;align-items:stretch;display:flex}.eval-slot{opacity:0;flex-direction:column;flex-shrink:0;width:0;margin-right:0;transition:width .45s cubic-bezier(.22,1,.36,1),opacity .28s,margin-right .45s cubic-bezier(.22,1,.36,1);display:flex;overflow:hidden}.eval-slot.visible{width:var(--eval-bar-w,26px);opacity:1;margin-right:8px}.eval-slot.hidden{pointer-events:none}.board-with-eval{flex-shrink:0;align-items:stretch;display:flex}.board-area{align-items:stretch;display:flex}.board-column{flex-direction:column;align-items:stretch;display:flex}.board-grid{grid-template-columns:repeat(8, var(--sq));grid-template-rows:repeat(8, var(--sq));touch-action:none;border:8px solid #333;border-radius:10px;flex-shrink:0;display:grid;position:relative;overflow:hidden}.square{width:var(--sq);height:var(--sq);cursor:pointer;box-sizing:border-box;justify-content:center;align-items:center;display:flex;position:relative}.square.light{background:var(--board-light)}.square.dark{background:var(--board-dark)}.square.light.selected{background:#f6f669}.square.dark.selected{background:#d3d34c}.square.hovered:before{content:"";pointer-events:none;z-index:0;background:#ffffff21;position:absolute;inset:0}.square.drag-over{filter:brightness(1.25)}.square.drag-over:before{content:"";z-index:3;pointer-events:none;background:#50be6459;position:absolute;inset:0}.square.legal-empty:after{content:"";z-index:4;pointer-events:none;background:#00000038;border-radius:50%;width:32%;height:32%;position:absolute}.square.legal-capture{box-shadow:inset 0 0 0 4px #d22d2dd9}.square.best-from{background:#64c86473!important}.square.best-to:after{content:"";z-index:4;pointer-events:none;background:#64c86466;border-radius:2px;position:absolute;inset:0}.square.last-move-from{background:#cdb95080!important}.square.dark.last-move-from{background:#aa94288c!important}.square.last-move-to{background:#cdb9508c!important}.square.dark.last-move-to{background:#aa942899!important}.piece{object-fit:contain;pointer-events:none;z-index:1;width:100%;height:100%;position:relative}.move-annotation-tint{pointer-events:none;z-index:2;position:absolute;inset:0}.move-annotation-icon{object-fit:contain;pointer-events:none;z-index:5;filter:drop-shadow(0 1px 3px #000000b3);width:40%;height:40%;position:absolute;top:-16%;right:-16%}.move-annotation-spinner{pointer-events:none;z-index:5;border:2.5px solid #ffffff38;border-top-color:#ffffffd9;border-radius:50%;width:34%;height:34%;animation:.75s linear infinite annotation-spin;position:absolute;top:-14%;right:-14%}@keyframes annotation-spin{to{transform:rotate(360deg)}}.drag-ghost{pointer-events:none;z-index:9000;object-fit:contain;filter:drop-shadow(0 6px 12px #0009);transform-origin:50%;position:fixed}.promotion-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1200;background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.promotion-modal{border:1px solid var(--panel-border);background:var(--panel-popup-bg);border-radius:16px;flex-direction:column;gap:12px;width:min(320px,100vw - 24px);padding:16px;display:flex;box-shadow:0 8px 40px #0000002e}.promotion-modal h3{color:var(--text-main);margin:0;font-size:1rem}.promotion-modal p{color:var(--text-muted);margin:0;font-size:.82rem}.promotion-choices{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.promotion-choice{border:1px solid var(--panel-border);background:var(--btn-bg);cursor:pointer;border-radius:11px;padding:6px;transition:background .15s,border-color .15s}.promotion-choice:hover{background:var(--accent-muted);border-color:var(--accent-border)}.promotion-choice img{aspect-ratio:1;object-fit:contain;width:100%}.promotion-cancel{border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--btn-color);cursor:pointer;border-radius:9px;padding:8px 12px;font-family:inherit;font-size:.85rem;transition:background .15s,color .15s}.promotion-cancel:hover{background:var(--btn-bg-hover);color:var(--text-main)}.coord{opacity:.75;z-index:5;pointer-events:none;font-size:.62rem;font-weight:700;line-height:1;position:absolute}.rank-coord{top:2px;left:2px}.file-coord{bottom:2px;right:3px}.square.light .coord{color:var(--board-dark)}.square.dark .coord{color:var(--board-light)}@media (width<=820px){.board-area-outer{flex-direction:column;width:100%;padding:0 8px}.eval-slot{flex-direction:row;align-items:center;width:100%;height:0;max-height:0;margin-right:0;transition:height .38s cubic-bezier(.22,1,.36,1),max-height .38s cubic-bezier(.22,1,.36,1),opacity .26s;transform:none}.eval-slot.visible{opacity:1;width:100%;height:22px;max-height:22px;margin-bottom:6px;margin-right:0;transform:none}.eval-slot.hidden{height:0;max-height:0}.board-with-eval{justify-content:center}}.eval-bar{border:1px solid var(--panel-border-strong);border-radius:4px;flex-direction:column;flex:1 0 0;width:26px;min-height:0;display:flex;position:relative;overflow:hidden}.eval-bar-black{height:var(--eval-black,50%);background:#1e1c19;width:100%;transition:height .4s,width .4s}.eval-bar-white{background:#f5f2ec;flex:1;width:100%;transition:height .4s,width .4s}.eval-score{letter-spacing:-.01em;white-space:nowrap;pointer-events:none;font-size:.63rem;font-weight:700;line-height:1;position:absolute;bottom:6px;left:50%;transform:translate(-50%)}.eval-score-white{color:#1e1c19;top:auto;bottom:6px}.eval-score-black{color:#f5f2ec;top:6px;bottom:auto}@media (width<=820px){.eval-bar{align-self:unset;border-radius:4px;flex-direction:row-reverse;flex:1;width:100%;height:100%}.eval-bar-black{height:100%;width:var(--eval-black,50%);flex:none}.eval-bar-white{height:100%;width:var(--eval-white,50%);flex:none}.eval-score{font-size:.58rem;top:50%;bottom:auto;left:6px;transform:translateY(-50%)}.eval-score-white{inset:50% auto auto 6px;transform:translateY(-50%)}.eval-score-black{inset:50% 6px auto auto;transform:translateY(-50%)}}.engine-controls{background:var(--panel-bg);border:1px solid var(--panel-border);box-shadow:var(--panel-shadow);border-radius:10px;flex-direction:column;gap:.5rem;padding:.6rem .9rem;display:flex}.engine-status-row{align-items:center;gap:.5rem;display:flex}.engine-ready-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.engine-ready-dot.ready{background:var(--color-success);box-shadow:0 0 4px var(--color-success)}.engine-ready-dot.loading{background:var(--color-warning);animation:1s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.engine-label{color:var(--text-muted);font-size:.78rem}.engine-depth-badge{color:var(--accent-text);background:var(--accent-muted);border:1px solid var(--accent-border);border-radius:5px;margin-left:auto;padding:.1rem .4rem;font-size:.7rem}.skill-row{flex-direction:column;gap:.2rem;display:flex}.skill-label{color:var(--text-muted);font-size:.76rem}.skill-label strong{color:var(--text-main)}.skill-slider{width:100%;accent-color:var(--accent);cursor:pointer}.skill-range-labels{color:var(--text-subtle);justify-content:space-between;margin-top:1px;font-size:.67rem;display:flex}.slider-control{flex-direction:column;gap:.4rem;width:100%;display:flex}.slider-title{color:var(--text-muted);font-size:.76rem;font-weight:500}.slider-track-wrap{align-items:center;gap:.7rem;display:flex}.slider-track-container{flex:1;position:relative}.slider-input{cursor:pointer;appearance:none;background:linear-gradient(90deg, var(--accent) var(--percent,0%), var(--panel-border) var(--percent,0%));-webkit-tap-highlight-color:transparent;border-radius:999px;outline:none;width:100%;height:5px;transition:background .1s}.slider-input::-webkit-slider-thumb{appearance:none;border:2.5px solid var(--accent);cursor:pointer;background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .14s cubic-bezier(.34,1.56,.64,1),box-shadow .14s;box-shadow:0 2px 8px #0000002e}.slider-input::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 3px 10px #00000038}.slider-input::-webkit-slider-thumb:active{transform:scale(.95)}.slider-input::-moz-range-thumb{border:2.5px solid var(--accent);cursor:pointer;background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .14s cubic-bezier(.34,1.56,.64,1),box-shadow .14s;box-shadow:0 2px 8px #0000002e}.slider-input::-moz-range-thumb:hover{transform:scale(1.12)}.slider-output{color:var(--text-muted);text-align:right;min-width:44px;font-size:.78rem;font-weight:600}.slider-range-labels{color:var(--text-subtle);justify-content:space-between;font-size:.68rem;display:flex}.shared-switch{cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;display:inline-flex;position:relative}.shared-switch input{opacity:0;width:0;height:0;position:absolute}.shared-switch-track{background:var(--panel-border-strong);border-radius:999px;width:44px;height:24px;transition:background .22s,box-shadow .22s;position:relative;box-shadow:inset 0 1px 2px #0000001a}.shared-switch-track:after{content:"";background:var(--text-subtle);border-radius:50%;width:18px;height:18px;transition:transform .24s cubic-bezier(.34,1.56,.64,1),background .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0003}.shared-switch input:checked+.shared-switch-track{background:var(--accent)}.shared-switch input:checked+.shared-switch-track:after{background:#fff;transform:translate(20px);box-shadow:0 2px 6px #00000040}.shared-switch:hover .shared-switch-track{background:var(--text-subtle)}.shared-switch:hover input:checked+.shared-switch-track{background:var(--accent);opacity:.9}.shared-switch input:disabled+.shared-switch-track{opacity:.4;cursor:not-allowed;pointer-events:none}.engine-lines{background:var(--panel-bg);border:1px solid var(--panel-border);box-shadow:var(--panel-shadow);border-radius:10px;flex-direction:column;gap:.35rem;padding:.6rem .9rem;display:flex}.el-header{flex-direction:column;gap:.35rem;display:flex}.el-title-row{justify-content:space-between;align-items:center;display:flex}.el-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;font-size:.72rem;font-weight:600}.el-toggle{cursor:pointer;align-items:center;display:inline-flex;position:relative}.el-toggle input{opacity:0;width:0;height:0;position:absolute}.el-toggle-track{background:var(--panel-border-strong);border-radius:10px;width:32px;height:18px;transition:background .2s;display:inline-block;position:relative}.el-toggle-track:after{content:"";background:var(--text-subtle);border-radius:50%;width:14px;height:14px;transition:transform .2s,background .2s;position:absolute;top:2px;left:2px}.el-toggle input:checked+.el-toggle-track{background:var(--accent)}.el-toggle input:checked+.el-toggle-track:after{background:#fff;transform:translate(14px)}.el-controls{align-items:center;gap:.3rem;display:flex}.el-lines-label{color:var(--text-subtle);margin-right:2px;font-size:.7rem}.el-lines-btn{background:var(--btn-bg);border:1px solid var(--btn-border);color:var(--text-muted);cursor:pointer;border-radius:5px;padding:2px 7px;font-family:inherit;font-size:.7rem;line-height:1.4;transition:background .12s,color .12s,border-color .12s}.el-lines-btn.active{background:var(--accent-muted);border-color:var(--accent-border);color:var(--accent-text)}.el-lines-btn:hover:not(.active){background:var(--btn-bg-hover);color:var(--text-main)}.el-depth-badge{color:var(--text-subtle);font-variant-numeric:tabular-nums;letter-spacing:.02em;margin-left:auto;font-size:.66rem}.el-thinking{color:var(--accent);font-size:.6rem;animation:.8s ease-in-out infinite el-pulse}@keyframes el-pulse{0%,to{opacity:1}50%{opacity:.2}}.el-body{flex-direction:column;gap:.3rem;display:flex}.el-status{color:var(--text-subtle);font-size:.75rem}.el-loading{color:var(--accent-text);align-items:center;gap:.45rem;font-size:.74rem;display:flex}.el-spinner{border:2px solid var(--accent-muted);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:.7s linear infinite el-spin;display:inline-block}@keyframes el-spin{to{transform:rotate(360deg)}}.el-line{background:var(--panel-bg-subtle);border:1px solid var(--panel-border);border-radius:7px;align-items:center;gap:.5rem;min-height:1.9rem;padding:.3rem .55rem;font-size:.78rem;line-height:1.4;transition:background .1s;display:flex;overflow:hidden}.el-line:hover{background:var(--nav-item-hover-bg)}.el-line-clickable{cursor:pointer}.el-line-clickable:hover{background:var(--accent-muted);border-color:var(--accent-border)}.el-line-skeleton{pointer-events:none}.el-eval{flex-shrink:0;min-width:3.8em;font-size:.8rem;font-weight:700}.el-eval.pos{color:var(--color-pos-eval)}.el-eval.neg{color:var(--color-neg-eval)}.el-moves{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.76rem;overflow:hidden}.el-eval.line-best{color:var(--color-success)}.el-eval.line-good{color:#9aaa44}.el-eval.line-inaccuracy{color:var(--color-warning)}.el-eval.line-mistake{color:#c07a30}.el-eval.line-blunder{color:var(--color-danger)}.el-eval-ph{background:var(--panel-border);border-radius:4px;flex-shrink:0;width:3.2em;height:.72em;animation:1.4s ease-in-out infinite el-shimmer;display:inline-block}.el-moves-ph{background:var(--panel-border);opacity:.7;border-radius:4px;flex:1;width:60%;height:.68em;animation:1.4s ease-in-out .2s infinite el-shimmer;display:inline-block}@keyframes el-shimmer{0%,to{opacity:.5}50%{opacity:.2}}.game-status{flex-direction:column;gap:.5rem;width:100%;display:flex}.turn-info{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.92rem;font-weight:500;display:flex}.turn-info.gameover{color:var(--color-gameover);font-weight:700}.opening-info{color:var(--text-muted);opacity:.92;font-size:.8rem}.status-controls{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.turn-dot{border:2px solid var(--panel-border-strong);border-radius:50%;flex-shrink:0;width:12px;height:12px}.dot-white{background:#f8f8f4}.dot-black{background:#1e1c19}.reset-btn,.engine-toggle-btn,.review-btn{border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--btn-color);cursor:pointer;border-radius:8px;padding:.32rem .7rem;font-size:.82rem;transition:background .15s,color .15s,border-color .15s}.reset-btn:hover,.engine-toggle-btn:hover,.review-btn:hover{background:var(--btn-bg-hover);color:var(--text-main)}.engine-toggle-btn.active,.review-btn.active{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-color)}.move-history{background:var(--panel-bg);border:1px solid var(--panel-border);min-height:0;box-shadow:var(--panel-shadow);border-radius:10px;flex-direction:column;flex:1;gap:.5rem;padding:.6rem .75rem;display:flex}.move-history-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.move-history-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.7rem;font-weight:600}.move-history-nav{gap:2px;display:flex}.nav-btn{background:var(--btn-bg);border:1px solid var(--btn-border);color:var(--btn-color);cursor:pointer;border-radius:5px;padding:3px 7px;font-size:.7rem;line-height:1;transition:background .12s,color .12s}.nav-btn:hover:not(:disabled){background:var(--btn-bg-hover);color:var(--text-main)}.nav-btn:disabled{opacity:.3;cursor:default}.move-list{scrollbar-width:thin;scrollbar-color:var(--panel-border-strong) transparent;flex-direction:column;flex:auto;gap:2px;min-height:0;display:flex;overflow-y:auto}.move-row{grid-template-columns:26px 1fr 1fr;align-items:center;gap:4px;display:grid}.move-num{color:var(--text-subtle);text-align:right;flex-shrink:0;font-size:.76rem}.move-btn{background:var(--btn-bg);border:1px solid var(--btn-border);color:var(--btn-color);cursor:pointer;text-align:center;white-space:nowrap;text-overflow:ellipsis;border-radius:5px;padding:3px 6px;font-family:inherit;font-size:.8rem;transition:background .1s,color .1s,border-color .1s;overflow:hidden}.move-btn:hover{background:var(--btn-bg-hover);color:var(--text-main);border-color:var(--panel-border-strong)}.move-btn.active{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-color);font-weight:600}.move-btn-placeholder{cursor:default;background:0 0;border-color:#0000}.no-moves{color:var(--text-subtle);font-size:.8rem}.move-row-group{flex-direction:column;gap:2px;display:flex}.variation-line{border-left:2px solid var(--panel-border-strong);color:var(--text-muted);flex-wrap:wrap;align-items:baseline;gap:2px;margin-left:4px;padding:2px 4px 2px 10px;font-size:.78rem;display:flex}.variation-depth-2{border-left-color:var(--panel-border);margin-left:16px;font-size:.74rem}.variation-depth-3{border-left-color:var(--panel-border);opacity:.8;margin-left:24px;font-size:.7rem}.var-move-wrapper{flex-wrap:wrap;align-items:baseline;gap:2px;display:inline-flex}.var-move-num{color:var(--text-subtle);white-space:nowrap;padding:0 2px;font-size:.8em}.variation-line .move-btn{background:var(--btn-bg);border-color:var(--btn-border);color:var(--text-muted);padding:2px 5px;font-size:.8em}.variation-line .move-btn:hover{background:var(--btn-bg-hover);color:var(--text-main)}.variation-line .move-btn.active{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-color);font-weight:600}.game-review{background:var(--panel-bg);border:1px solid var(--panel-border);width:100%;box-shadow:var(--panel-shadow);border-radius:10px;flex-direction:column;flex:1;gap:.75rem;padding:.85rem .95rem;display:flex;overflow-y:auto}.game-review-header{justify-content:space-between;align-items:center;display:flex}.game-review-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.7rem;font-weight:600}.gr-close-btn{color:var(--text-subtle);cursor:pointer;background:0 0;border:none;border-radius:5px;padding:2px 6px;font-size:.8rem;line-height:1;transition:color .12s,background .12s}.gr-close-btn:hover{color:var(--text-main);background:var(--nav-item-hover-bg)}.gr-setup{flex-direction:column;gap:.45rem;display:flex}.gr-depth-label{color:var(--text-muted);font-size:.8rem}.gr-depth-row{align-items:center;gap:.5rem;display:flex}.gr-depth-input{background:var(--input-bg);border:1px solid var(--input-border);width:64px;color:var(--input-color);text-align:center;border-radius:6px;padding:4px 8px;font-family:inherit;font-size:.88rem}.gr-depth-input:focus{border-color:var(--input-border-focus);background:var(--input-bg-focus);outline:none}.gr-start-btn{background:var(--btn-primary-bg);border:1px solid var(--btn-primary-border);color:var(--btn-primary-color);cursor:pointer;border-radius:7px;flex:1;padding:6px 12px;font-family:inherit;font-size:.85rem;transition:background .15s}.gr-start-btn:hover:not(:disabled){background:var(--btn-primary-hover-bg)}.gr-start-btn:disabled{opacity:.45;cursor:default}.gr-hint{color:var(--text-subtle);margin:0;font-size:.74rem;line-height:1.4}.gr-loading{min-height:240px;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.gr-results{flex-direction:column;gap:.55rem;display:flex}.gr-player-stats{background:var(--panel-bg-subtle);border:1px solid var(--panel-border);border-radius:8px;padding:.75rem .85rem}.gr-stats-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.gr-player-stat{flex-direction:column;gap:.5rem;display:flex}.gr-stat-header{align-items:center;gap:.4rem;margin-bottom:.2rem;display:flex}.gr-player-color{font-size:.9rem;line-height:1}.gr-player-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:90px;font-size:.73rem;font-weight:600;overflow:hidden}.gr-player-pgn-elo{color:var(--text-subtle);white-space:nowrap;margin-left:2px;font-size:.67rem}.gr-game-info{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.45rem;display:flex}.gr-game-event{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:.7rem;overflow:hidden}.gr-game-date{color:var(--text-subtle);white-space:nowrap;font-size:.67rem}.gr-stat-values{flex-direction:column;gap:.35rem;display:flex}.gr-stat-item{justify-content:space-between;align-items:baseline;display:flex}.gr-stat-label{color:var(--text-subtle);font-size:.72rem}.gr-stat-value{color:var(--accent-text);font-size:.82rem;font-weight:600}@media (width<=640px){.gr-stats-row{grid-template-columns:1fr;gap:.8rem}}.gr-progress-wrap{background:var(--panel-border);border-radius:3px;height:5px;position:relative;overflow:hidden}.gr-progress-bar{background:var(--accent);border-radius:3px;height:100%;transition:width .2s;position:absolute;top:0;left:0}.gr-progress-text{color:var(--text-subtle);margin-top:4px;font-size:.7rem;display:block}.gr-graph-wrap{flex-direction:column;gap:4px;display:flex}.eval-graph-svg{border:1px solid var(--panel-border);cursor:crosshair;border-radius:6px;width:100%;height:200px;display:block}.gr-graph-labels{color:var(--text-subtle);justify-content:space-between;font-size:.64rem;display:flex}.gr-current-eval{align-items:baseline;gap:.5rem;font-size:.82rem;display:flex}.gr-eval-label{color:var(--text-subtle)}.gr-eval-value{font-size:.95rem;font-weight:700}.gr-eval-value.pos{color:var(--color-pos-eval)}.gr-eval-value.neg{color:var(--color-neg-eval)}.gr-eval-depth{color:var(--text-subtle);font-size:.7rem}.gr-controls{gap:.5rem;display:flex}.gr-restart-btn,.gr-stop-btn{background:var(--btn-bg);border:1px solid var(--btn-border);color:var(--btn-color);cursor:pointer;border-radius:6px;padding:5px 12px;font-family:inherit;font-size:.8rem;transition:background .12s,color .12s}.gr-restart-btn:hover,.gr-stop-btn:hover{background:var(--btn-bg-hover);color:var(--text-main)}.gr-move-summary{background:var(--panel-bg-subtle);border:1px solid var(--panel-border);border-radius:7px;flex-direction:column;gap:.22rem;padding:.55rem .7rem;display:flex}.gr-move-summary-header{grid-template-columns:1fr 1.8rem 1.8rem;align-items:center;margin-bottom:.2rem;display:grid}.gr-move-summary-row{grid-template-columns:1fr 1.8rem 1.8rem;align-items:center;gap:.2rem;display:grid}.gr-move-summary-label{color:var(--text-muted);align-items:center;gap:.35rem;font-size:.73rem;display:flex}.gr-move-summary-icon{object-fit:contain;flex-shrink:0;width:14px;height:14px}.gr-move-summary-player{text-align:center;color:var(--text-subtle);font-size:.8rem}.gr-move-summary-count{color:var(--text-subtle);text-align:center;font-size:.73rem;font-weight:600}.gr-move-summary-count.has-count{color:var(--accent-text)}.tab-bar{background:var(--panel-bg);border:1px solid var(--panel-border);box-shadow:var(--panel-shadow);border-radius:12px;gap:2px;max-width:460px;margin-bottom:24px;margin-left:auto;margin-right:auto;padding:3px;display:flex}.tab-bar-item{color:var(--text-muted);cursor:pointer;letter-spacing:.02em;background:0 0;border:none;border-radius:10px;flex:1;padding:8px 12px;font-family:inherit;font-size:.82rem;font-weight:600;transition:color .15s,background .15s}.tab-bar-item:hover{color:var(--text-main);background:var(--nav-item-hover-bg)}.tab-bar-item.active{background:var(--accent-muted);color:var(--accent-text);border:1px solid var(--accent-border)}.game-card{background:var(--panel-bg);border:1px solid var(--panel-border);box-shadow:var(--panel-shadow);border-radius:12px;flex-direction:column;gap:10px;padding:14px 18px;transition:border-color .18s,box-shadow .18s;display:flex}.game-card:hover{border-color:var(--accent-border);box-shadow:var(--panel-shadow), 0 0 0 1px var(--accent-border)}.game-card-players{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.game-card-player{color:var(--text-main);font-size:.88rem;font-weight:600}.game-card-player--white{color:var(--text-main)}.game-card-player--black{color:var(--text-muted)}.game-card-vs{color:var(--text-subtle);text-transform:uppercase;letter-spacing:.07em;font-size:.7rem;font-weight:500}.game-card-meta{flex-wrap:wrap;gap:6px;display:flex}.game-card-badge{background:var(--btn-bg);border:1px solid var(--btn-border);color:var(--text-muted);white-space:nowrap;border-radius:5px;padding:2px 7px;font-size:.7rem;display:inline-block}.game-card-badge--opening{color:var(--accent-text);background:var(--accent-muted);border-color:var(--accent-border);text-overflow:ellipsis;max-width:260px;overflow:hidden}.game-card-badge--platform{font-weight:600}.game-card-badge--chesscom{color:#4a8c5c;background:#4a8c5c1a;border-color:#4a8c5c40}.game-card-badge--lichess{color:#b07040;background:#b070401a;border-color:#b0704040}.game-card-badge--depth{color:var(--accent-text);background:var(--accent-muted);border-color:var(--accent-border)}.game-card-analyze-btn{background:var(--btn-primary-bg);border:1px solid var(--btn-primary-border);color:var(--btn-primary-color);cursor:pointer;border-radius:8px;align-self:flex-end;padding:7px 16px;font-family:inherit;font-size:.82rem;font-weight:600;transition:background .15s,border-color .15s}.game-card-analyze-btn:hover{background:var(--btn-primary-hover-bg);border-color:var(--accent)}.account-connect-platform-row{gap:8px;margin-bottom:16px;display:flex}.account-connect-platform-btn{background:var(--btn-bg);border:1px solid var(--btn-border);color:var(--text-muted);cursor:pointer;border-radius:9px;padding:8px 20px;font-family:inherit;font-size:.84rem;font-weight:600;transition:background .15s,color .15s,border-color .15s}.account-connect-platform-btn:hover{color:var(--text-main);background:var(--btn-bg-hover)}.account-connect-platform-btn.active{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-color)}.account-connect-row{flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:14px;display:flex}.account-connect-input-wrap{flex:1;min-width:180px}.account-connect-count-wrap{flex-shrink:0;width:80px}.account-connect-label{color:var(--text-muted);margin-bottom:5px;font-size:.75rem;display:block}.account-connect-input,.account-connect-select{background:var(--input-bg);border:1px solid var(--input-border);width:100%;color:var(--input-color);box-sizing:border-box;border-radius:7px;outline:none;padding:8px 12px;font-family:inherit;font-size:.85rem;transition:border-color .18s,background .18s}.account-connect-input:focus,.account-connect-select:focus{background:var(--input-bg-focus);border-color:var(--input-border-focus)}.account-connect-select{cursor:pointer;appearance:none;text-align:center}.account-connect-fetch-btn{background:var(--btn-primary-bg);border:1px solid var(--btn-primary-border);color:var(--btn-primary-color);cursor:pointer;white-space:nowrap;border-radius:8px;align-self:flex-end;padding:8px 20px;font-family:inherit;font-size:.85rem;font-weight:600;transition:background .15s,border-color .15s}.account-connect-fetch-btn:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--accent)}.account-connect-fetch-btn:disabled{background:var(--btn-bg);border-color:var(--btn-border);color:var(--text-subtle);cursor:not-allowed}.account-connect-error{color:var(--color-danger);background:#b050501a;border:1px solid #b0505047;border-radius:7px;margin-bottom:14px;padding:10px 14px;font-size:.82rem}.account-connect-empty{color:var(--text-subtle);text-align:center;padding:20px 0;font-size:.84rem}.account-connect-games{flex-direction:column;gap:10px;display:flex}.board-editor-input-group{margin-bottom:12px}.board-editor-label{color:var(--text-muted);margin-bottom:5px;font-size:.76rem;display:block}.board-editor-text-input{background:var(--input-bg);border:1px solid var(--input-border);width:100%;color:var(--input-color);box-sizing:border-box;resize:none;border-radius:7px;outline:none;padding:8px 12px;font-family:Fira Mono,Consolas,monospace;font-size:.85rem;transition:border-color .18s,background .18s}.board-editor-text-input:focus{background:var(--input-bg-focus);border-color:var(--input-border-focus)}.board-editor-textarea{resize:vertical;min-height:80px}.board-editor-error{color:var(--color-danger);background:#b050501a;border:1px solid #b0505047;border-radius:7px;margin:12px 0;padding:10px 14px;font-size:.82rem}.board-editor-btn-group{flex-wrap:wrap;gap:10px;margin:16px 0;display:flex}.board-editor-btn{background:var(--btn-primary-bg);border:1px solid var(--btn-primary-border);color:var(--btn-primary-color);cursor:pointer;border-radius:8px;padding:9px 18px;font-family:inherit;font-size:.85rem;font-weight:500;transition:background .18s,border-color .18s}.board-editor-btn:hover:not(:disabled){background:var(--btn-primary-hover-bg);border-color:var(--accent)}.board-editor-btn:disabled{background:var(--btn-bg);border:1px solid var(--btn-border);color:var(--text-subtle);cursor:not-allowed;opacity:.6}.board-editor-btn--secondary{background:var(--btn-bg);border-color:var(--btn-border);color:var(--btn-color)}.board-editor-btn--secondary:hover:not(:disabled){background:var(--btn-bg-hover);border-color:var(--panel-border-strong);color:var(--text-main)}.board-editor-btn--ghost{border-color:var(--btn-border);color:var(--text-muted);background:0 0}.board-editor-btn--ghost:hover:not(:disabled){background:var(--btn-bg);color:var(--text-main)}.board-editor-hint{background:var(--panel-bg-subtle);border:1px solid var(--panel-border);border-radius:9px;margin-top:20px;padding:14px 16px}.board-editor-hint p{color:var(--text-muted);margin:0 0 8px;font-size:.84rem}.board-editor-hint strong{color:var(--text-main)}.board-editor-hint ul{color:var(--text-muted);margin:0;padding-left:20px;font-size:.8rem;line-height:1.6}.board-editor-hint li{margin-bottom:4px}.analysis-history-empty{text-align:center;color:var(--text-subtle);padding:36px 0;font-size:.88rem}.analysis-history-empty p{margin:0 0 6px}.analysis-history-empty-hint{color:var(--text-subtle);max-width:340px;font-size:.8rem;line-height:1.5;margin:0 auto!important}.analysis-history-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.analysis-history-count{color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;font-size:.74rem;font-weight:600}.analysis-history-clear-btn{border:1px solid var(--btn-border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:7px;padding:4px 12px;font-family:inherit;font-size:.78rem;transition:color .15s,border-color .15s,background .15s}.analysis-history-clear-btn:hover{color:var(--color-danger);background:#b0505012;border-color:#b0505059}.analysis-history-list{flex-direction:column;gap:10px;display:flex}.analysis-page{box-sizing:border-box;width:100%;max-width:640px;margin:0 auto;padding:40px 24px 64px}.analysis-header{text-align:center;margin-bottom:24px}.analysis-title{color:var(--text-main);letter-spacing:-.02em;margin:0 0 6px;font-size:1.75rem;font-weight:700}.analysis-subtitle{color:var(--text-muted);margin:0;font-size:.875rem}@media (width<=480px){.analysis-page{padding:20px 14px 40px}}.sp-overlay{z-index:900;-webkit-backdrop-filter:blur();backdrop-filter:blur();background:0 0;justify-content:center;align-items:center;padding:12px;transition:background .22s,-webkit-backdrop-filter .22s,backdrop-filter .22s;display:flex;position:fixed;inset:0}.sp-overlay--visible{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#00000059}.sp-panel{background:var(--panel-popup-bg);border:1px solid var(--panel-border);opacity:0;border-radius:16px;width:min(100%,320px);max-height:80dvh;padding:8px 0 12px;transition:transform .26s cubic-bezier(.22,1,.36,1),opacity .2s;overflow-y:auto;transform:translateY(12px)scale(.97);box-shadow:0 8px 40px #00000024}.sp-overlay--visible .sp-panel{opacity:1;transform:translateY(0)scale(1)}.sp-title{letter-spacing:.1em;text-transform:uppercase;color:var(--accent-text);border-bottom:1px solid var(--panel-border);margin-bottom:4px;padding:10px 20px 8px;font-size:.66rem;font-weight:700}.sp-options{flex-direction:column;display:flex}.sp-option{color:var(--text-muted);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:0 0;border:none;justify-content:space-between;align-items:center;gap:12px;padding:13px 20px;font-family:inherit;font-size:.9rem;transition:background .12s,color .12s;display:flex}.sp-option:hover{background:var(--nav-item-hover-bg);color:var(--text-main)}.sp-option:active{background:var(--accent-muted)}.sp-option--active{color:var(--text-main);font-weight:600}.sp-option--disabled{opacity:.38;cursor:not-allowed;pointer-events:none}.sp-option-label{flex:1}.sp-check{width:18px;height:18px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sp-check svg{width:100%;height:100%}.settings-page{box-sizing:border-box;width:100%;max-width:640px;margin:0 auto;padding:40px 24px}.settings-header{text-align:center;margin-bottom:24px}.settings-title{color:var(--text-main);letter-spacing:-.02em;margin:0 0 6px;font-size:1.75rem;font-weight:700}.settings-subtitle{color:var(--text-muted);margin:0;font-size:.875rem}.settings-tab-bar{background:var(--panel-bg);border:1px solid var(--panel-border);box-shadow:var(--panel-shadow);border-radius:12px;gap:2px;max-width:460px;margin-bottom:24px;margin-left:auto;margin-right:auto;padding:3px;display:flex}.settings-tab-item{color:var(--text-muted);cursor:pointer;letter-spacing:.02em;background:0 0;border:none;border-radius:10px;flex:1;padding:8px 12px;font-family:inherit;font-size:.82rem;font-weight:600;transition:color .15s,background .15s}.settings-tab-item:hover{color:var(--text-main);background:var(--nav-item-hover-bg)}.settings-tab-item.active{background:var(--accent-muted);color:var(--accent-text);border:1px solid var(--accent-border)}.setting-section{margin-bottom:28px}.setting-section-title{text-transform:uppercase;letter-spacing:.1em;color:var(--accent-text);margin:0 0 10px;font-size:.66rem;font-weight:700}.setting-section-body{background:var(--panel-bg);border:1px solid var(--panel-border);box-shadow:var(--panel-shadow);border-radius:14px;overflow:hidden}.setting-row{border-bottom:1px solid var(--panel-border);justify-content:space-between;align-items:center;gap:16px;padding:14px 18px;transition:background .12s;display:flex}.setting-row:last-child{border-bottom:none}.setting-row:hover{background:var(--nav-item-hover-bg)}.setting-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.setting-label{color:var(--text-main);font-size:.9rem;font-weight:500}.setting-desc{color:var(--text-subtle);font-size:.76rem}.setting-control{flex-shrink:0}.select-trigger{background:var(--btn-bg);border:1px solid var(--btn-border);color:var(--btn-color);cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;border-radius:9px;justify-content:space-between;align-items:center;gap:6px;min-width:130px;padding:7px 10px 7px 13px;font-family:inherit;font-size:.85rem;transition:background .14s,border-color .14s,color .14s;display:inline-flex}.select-trigger:hover{background:var(--btn-bg-hover);border-color:var(--panel-border-strong);color:var(--text-main)}.select-trigger:active{background:var(--accent-muted)}.select-trigger--disabled{opacity:.38;cursor:not-allowed}.select-trigger-value{flex:1}.select-trigger-chevron{opacity:.55;flex-shrink:0;justify-content:center;align-items:center;width:14px;height:14px;display:flex}.select-trigger-chevron svg{width:100%;height:100%}.setting-row .slider-control{width:200px}.appearance-preview-wrap{flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:18px;padding:22px 20px 24px;display:flex}.board-preview{aspect-ratio:1;border:1px solid var(--panel-border);border-radius:16px;flex-shrink:0;grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(4,1fr);width:min(100%,400px);display:grid;overflow:hidden;box-shadow:0 14px 32px #0000003d}.board-preview-sq{justify-content:center;align-items:center;display:flex;position:relative}.board-preview-sq.sq-light{background:var(--board-light)}.board-preview-sq.sq-dark{background:var(--board-dark)}.board-preview-piece{object-fit:contain;pointer-events:none;filter:drop-shadow(0 1px 3px #00000059);width:92%;height:92%}.appearance-preview-controls{background:var(--panel-bg);border:1px solid var(--panel-border);width:min(100%,280px);box-shadow:var(--panel-shadow);border-radius:18px;flex-direction:column;align-items:center;gap:16px;padding:16px;display:flex}.appearance-preview-control-item{text-align:center;flex-direction:column;align-items:center;gap:4px;width:100%;display:flex}.appearance-preview-control-label{letter-spacing:.05em;text-transform:uppercase;color:var(--text-subtle);text-align:center;font-size:.72rem;font-weight:600}.appearance-preview-control-item .select-trigger{width:min(100%,240px);min-width:0}.custom-board-colors{grid-template-columns:1fr 1fr;gap:12px;width:100%;display:grid}.custom-color-item{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:14px;flex-direction:column;align-items:center;gap:8px;padding:10px;display:flex}.custom-color-label{color:var(--text-subtle);text-transform:uppercase;letter-spacing:.06em;font-size:.76rem}.custom-color-picker{cursor:pointer;border:none;border-radius:12px;width:100%;height:42px;padding:0}.engine-presets{gap:8px;padding:14px 16px;display:flex}.engine-preset-btn{background:var(--btn-bg);border:1px solid var(--btn-border);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:12px 8px;font-family:inherit;transition:background .15s,border-color .15s,transform .1s;display:flex;position:relative}.engine-preset-btn:hover{background:var(--btn-bg-hover);border-color:var(--panel-border-strong);transform:translateY(-1px)}.engine-preset-btn:active{transform:translateY(0)}.engine-preset-btn.active{background:var(--accent-muted);border-color:var(--accent-border)}.engine-preset-icon{font-size:1.4rem;line-height:1}.engine-preset-label{color:var(--text-main);font-size:.82rem;font-weight:700}.engine-preset-check{color:var(--accent);font-size:.92rem;line-height:1;position:absolute;top:10px;right:10px}.engine-preset-desc{color:var(--text-subtle);font-size:.7rem}@media (width<=640px){.appearance-preview-wrap{flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:14px 12px}.board-preview{width:min(100%,340px)}.appearance-preview-controls{width:100%;max-width:340px;padding:12px}}@media (width<=480px){.settings-page{padding:20px 14px 30px}.setting-section{margin-bottom:18px}.setting-row{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:12px 14px}.setting-row .setting-info{align-items:center}.setting-row .slider-control{width:100%}.setting-control{justify-content:center;width:100%;display:flex}.select-trigger{width:100%;max-width:320px}.appearance-preview-wrap{gap:8px;padding:10px}.board-preview{width:min(100%,320px)}.appearance-preview-controls{max-width:260px}.custom-board-colors{grid-template-columns:1fr}.engine-presets{flex-direction:column;align-items:center;gap:6px;padding:10px 12px}.engine-preset-btn{width:100%;max-width:320px;padding:10px 8px}}:root{--nav-w:72px;--nav-h-mobile:62px}.app-nav{width:var(--nav-w);background:var(--nav-bg);border-right:1px solid var(--panel-border);z-index:200;flex-direction:column;align-items:center;gap:6px;height:100dvh;padding:16px 0 24px;display:flex;position:fixed;top:0;left:0}.app-nav-logo{opacity:.7;flex-shrink:0;width:32px;height:32px;margin-bottom:20px}.app-nav-logo svg{width:100%;height:100%}.app-nav-list{flex-direction:column;align-items:center;gap:2px;width:100%;margin:0;padding:0;list-style:none;display:flex}.app-nav-item{width:52px;color:var(--nav-item-color);cursor:pointer;background:0 0;border:none;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:9px 0;font-family:inherit;text-decoration:none;transition:color .18s,background .18s;display:flex}.app-nav-item:hover{color:var(--text-muted);background:var(--nav-item-hover-bg)}.app-nav-item.active{color:var(--nav-item-active-color);background:var(--nav-item-active-bg)}.app-nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.app-nav-icon svg{width:100%;height:100%}.app-nav-label{letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;font-size:.56rem;font-weight:600;line-height:1}@media (width<=640px){.app-nav{width:100%;height:var(--nav-h-mobile);padding:0 8px env(safe-area-inset-bottom,0);border-right:none;border-top:1px solid var(--panel-border);flex-direction:row;justify-content:space-around;align-items:center;gap:0;inset:auto 0 0}.app-nav-logo{display:none}.app-nav-list{flex-direction:row;justify-content:space-around;gap:0;width:100%}.app-nav-item{border-radius:10px;flex:1;width:auto;padding:8px 4px}.app-nav-label{font-size:.53rem}}
