*{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=relent]{--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}[data-theme=cherry]{--bg-app:#ffc0e8;--bg-subtle:#ffade1;--nav-bg:#ff8fcf;--text-main:#520a3e;--text-muted:#9b2c69;--text-subtle:#b2528e;--panel-bg:#fff0f9;--panel-bg-subtle:#ffe9f4;--panel-border:#ff3c9670;--panel-border-strong:#ff3c96ad;--panel-shadow:0 12px 28px #0000001a;--accent:#ff2c9f;--accent-muted:#ff2c9b85;--accent-border:#ff2c9bb3;--accent-text:#5b0c34;--accent-hover-bg:#ff2c9b52;--nav-item-color:#ce2f8f;--nav-item-hover-bg:#ff2c9b47;--nav-item-active-bg:#ff2c9b6b;--nav-item-active-color:#5b0c34;--btn-bg:#ffd1ed;--btn-bg-hover:#ffb0dc;--btn-border:#ff2c9b85;--btn-color:#5b0c34;--btn-primary-bg:#ff2c9b9e;--btn-primary-border:#ff2c9bc7;--btn-primary-color:#3a0329;--btn-primary-hover-bg:#ff2c9b94;--input-bg:#ffe9f5;--input-bg-focus:#ffdaef;--input-border:#ff2c9b85;--input-border-focus:#ff2c9bb3;--input-color:#5b0c34;--input-placeholder:#d36aac;--panel-popup-bg:#ffe4f2;--color-gameover:#f159bf;--color-success:#ffaddf;--color-warning:#ff7ab9;--color-danger:#ff3f9f;--color-pos-eval:#5b0c34;--color-neg-eval:#b5548f}[data-theme=ocean]{--bg-app:#0f75c3;--bg-subtle:#4b8fc0;--nav-bg:#043358;--text-main:#f4fbff;--text-muted:#c0e9ff;--text-subtle:#a4d9ee;--panel-bg:#073459e6;--panel-bg-subtle:#093a68f5;--panel-border:#7bd7ff52;--panel-border-strong:#7bd7ff80;--panel-shadow:0 12px 28px #00000047;--accent:#7bd7ff;--accent-muted:#7bd7ff57;--accent-border:#7bd7ff8f;--accent-text:#eefcff;--accent-hover-bg:#7bd7ff4d;--nav-item-color:#cdf1ff;--nav-item-hover-bg:#7bd7ff2e;--nav-item-active-bg:#7bd7ff4d;--nav-item-active-color:#f3fdff;--btn-bg:#073459b8;--btn-bg-hover:#073459d1;--btn-border:#7bd7ff61;--btn-color:#eefcff;--btn-primary-bg:#7bd7ff47;--btn-primary-border:#7bd7ff80;--btn-primary-color:#eefcff;--btn-primary-hover-bg:#7bd7ff6b;--input-bg:#073459bd;--input-bg-focus:#093a68e6;--input-border:#7bd7ff61;--input-border-focus:#7bd7ff8f;--input-color:#effcff;--input-placeholder:#b3d8ee;--panel-popup-bg:#0a2e52f5;--color-gameover:#aadeff;--color-success:#82f1d1;--color-warning:#9bdfff;--color-danger:#e79cb8;--color-pos-eval:#f3fdff;--color-neg-eval:#abdcf0;--review-btn-success-text:#0d1e24}[data-theme=gold]{--bg-app:#222;--bg-subtle:#050503;--nav-bg:#000;--text-main:#f3e8af;--text-muted:#b79f69;--text-subtle:#7f7257;--panel-bg:#141414f2;--panel-bg-subtle:#0c0904eb;--panel-border:#ffc35024;--panel-border-strong:#ffc35038;--panel-shadow:0 12px 30px #00000073;--accent:#c69f37;--accent-muted:#c69f3724;--accent-border:#c69f373d;--accent-text:#f6e4ab;--accent-hover-bg:#c69f371f;--nav-item-color:#c9b481;--nav-item-hover-bg:#c69f371a;--nav-item-active-bg:#c69f3729;--nav-item-active-color:#f6e4ab;--btn-bg:#ffffff0f;--btn-bg-hover:#ffffff1f;--btn-border:#ffffff1f;--btn-color:#f7e7b9;--btn-primary-bg:#c69f372e;--btn-primary-border:#c69f3747;--btn-primary-color:#241703;--btn-primary-hover-bg:#c69f373d;--input-bg:#ffffff0d;--input-bg-focus:#ffffff24;--input-border:#c69f3738;--input-border-focus:#c69f3757;--input-color:#f7e7b9;--input-placeholder:#b49f7a;--panel-popup-bg:#0a0804f5;--color-gameover:#f1d780;--color-success:#ebd5a5;--color-warning:#dab548;--color-danger:#c69b55;--color-pos-eval:#f7e5af;--color-neg-eval:#b59c61;--review-btn-success-text:#2b2722}[data-theme=pixelcursor]{--bg-app:linear-gradient(135deg, #020617 0%, #2e1065 50%, #082f49 100%);--bg-subtle:#0f2a60;--nav-bg:#000;--text-main:#f4faff;--text-muted:#c2e7ff;--text-subtle:#9ecfff;--panel-bg:#08102afa;--panel-bg-subtle:#0a1230fa;--panel-border:#42d7ff5c;--panel-border-strong:#42d7ff8f;--panel-shadow:0 12px 30px #00000061;--accent:#57e1ff;--accent-muted:#42d7ff7a;--accent-border:#42d7ffad;--accent-text:#eef7ff;--accent-hover-bg:#42d7ff52;--nav-item-color:#b6f0ff;--nav-item-hover-bg:#42d7ff38;--nav-item-active-bg:#42d7ff57;--nav-item-active-color:#eef7ff;--btn-bg:#ffffff2e;--btn-bg-hover:#ffffff42;--btn-border:#42d7ff85;--btn-color:#eef7ff;--btn-primary-bg:#42d7ff8a;--btn-primary-border:#42d7ffb8;--btn-primary-color:#eef7ff;--btn-primary-hover-bg:#42d7ff8f;--input-bg:#ffffff29;--input-bg-focus:#ffffff3d;--input-border:#42d7ff7a;--input-border-focus:#42d7ffb3;--input-color:#eef7ff;--input-placeholder:#b7e1ff;--panel-popup-bg:#08102afa;--color-gameover:#4cdfef;--color-success:#b7f4ff;--color-warning:#8be5ff;--color-danger:#ff99bf;--color-pos-eval:#deefff;--color-neg-eval:#a7c9ff;--review-btn-success-text:#111417}[data-theme=stone]{--bg-app:#2f2f2f;--bg-subtle:#3a3a3a;--nav-bg:#2f3030;--text-main:#e8e8e8;--text-muted:#b0b0b0;--text-subtle:#8e8e8e;--panel-bg:#585858f0;--panel-bg-subtle:#3a3a3af5;--panel-border:#d8d8d829;--panel-border-strong:#d8d8d83d;--panel-shadow:0 12px 30px #0000006b;--accent:silver;--accent-muted:#dcdcdc29;--accent-border:#dcdcdc47;--accent-text:#f1f1f1;--accent-hover-bg:#dcdcdc29;--nav-item-color:#c6c6c6;--nav-item-hover-bg:#dcdcdc1a;--nav-item-active-bg:#dcdcdc2e;--nav-item-active-color:#f1f1f1;--btn-bg:#ffffff1f;--btn-bg-hover:#fff3;--btn-border:#dcdcdc2e;--btn-color:#ededed;--btn-primary-bg:#dcdcdc29;--btn-primary-border:#dcdcdc47;--btn-primary-color:#222;--btn-primary-hover-bg:#dcdcdc3d;--input-bg:#ffffff1a;--input-bg-focus:#ffffff2e;--input-border:#dcdcdc33;--input-border-focus:#dcdcdc52;--input-color:#f0f0f0;--input-placeholder:#a8a8a8;--panel-popup-bg:#3c3c3cfa;--color-gameover:#d4d4d4;--color-success:#c8c8c8;--color-warning:#b8b9bb;--color-danger:#b0b0b0;--color-pos-eval:#f2f2f2;--color-neg-eval:#a2a2a2;--review-btn-success-text:#111}[data-theme=dark-alt]{--bg-app:#080808;--bg-subtle:#111;--nav-bg:#080808;--text-main:#f4f4f4;--text-muted:#9a9a9a;--text-subtle:#707070;--panel-bg:#121212f0;--panel-bg-subtle:#0e0e0ee6;--panel-border:#ffffff14;--panel-border-strong:#ffffff24;--panel-shadow:0 12px 30px #00000080;--accent:#7f8692;--accent-muted:#ffffff1a;--accent-border:#ffffff2e;--accent-text:#dfe3eb;--accent-hover-bg:#ffffff1f;--nav-item-color:#b6b6b6;--nav-item-hover-bg:#ffffff0f;--nav-item-active-bg:#ffffff24;--nav-item-active-color:#dfe3eb;--btn-bg:#ffffff0f;--btn-bg-hover:#ffffff1a;--btn-border:#ffffff1a;--btn-color:#f2f2f2;--btn-primary-bg:#ffffff1a;--btn-primary-border:#ffffff2e;--btn-primary-color:#f2f2f2;--btn-primary-hover-bg:#ffffff24;--input-bg:#ffffff0d;--input-bg-focus:#ffffff1a;--input-border:#ffffff1f;--input-border-focus:#ffffff2e;--input-color:#f4f4f4;--input-placeholder:#7e7e7e;--panel-popup-bg:#141414;--color-gameover:#f1c56f;--color-success:#8fbf8f;--color-warning:#9a8f67;--color-danger:#ce7d80;--color-pos-eval:#f4f4f4;--color-neg-eval:#a1a9b5}.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;--control-panel-w:280px;--review-panel-w:0px;--review-reserve-h: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(--control-panel-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) - var(--review-reserve-h)) / 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));--review-reserve-h:clamp(280px, 30dvh, 420px)}.board-layout.with-review.review-below{--review-panel-w:0px;--review-reserve-h:0px}.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%;min-width:0;display:flex}.board-layout{align-items:stretch;gap:var(--col-gap);width:100%;min-width:0;height:auto;min-height:var(--board-size);flex-flow:row;justify-content:center;display:flex}.board-layout>.board-area-outer{flex:none}.control-panel{--control-panel-gap:8px;flex:1 1 var(--control-panel-w);min-width:min(100%,220px);height:var(--board-size);gap:var(--control-panel-gap);scrollbar-width:thin;scrollbar-color:#ffffff26 transparent;flex-direction:column;min-height:0;display:flex;overflow:hidden auto}.board-layout.with-review .control-panel{flex:320px;min-width:min(100%,260px)}.engine-controls-slot{opacity:0;max-height:0;margin-bottom:calc(-1 * var(--control-panel-gap));pointer-events:none;will-change:max-height, opacity, transform;transition:max-height .42s cubic-bezier(.22,1,.36,1),opacity .28s,transform .42s cubic-bezier(.22,1,.36,1),margin-bottom .42s cubic-bezier(.22,1,.36,1);overflow:hidden;transform:translateY(-10px)}.engine-controls-slot.visible{opacity:1;pointer-events:auto;max-height:220px;margin-bottom:0;transform:translateY(0)}.engine-controls-slot.hidden{pointer-events:none}.control-panel .move-list{max-height:none}.analysis-panel{opacity:0;pointer-events:none;will-change:max-width, opacity, transform;flex-direction:column;flex:0 1 0;min-width:0;max-width:0;min-height:0;transition:max-width .62s cubic-bezier(.22,1,.36,1),opacity .54s,transform .62s cubic-bezier(.22,1,.36,1);display:flex;overflow:hidden;transform:translate(20px)}.analysis-panel .game-review{opacity:0;min-width:0;transition:opacity .52s,transform .66s cubic-bezier(.22,1,.36,1);overflow:hidden;transform:translateY(8px)}.analysis-panel.visible{opacity:1;pointer-events:auto;flex:320px;min-width:min(100%,260px);max-width:50%;transform:translate(0)}.analysis-panel.visible .game-review{opacity:1;width:100%;height:auto;max-height:none;transform:translateY(0)}.analysis-panel.hidden .game-review{opacity:0;transform:translateY(10px)}.board-layout.review-below{flex-wrap:wrap;align-items:flex-start;height:auto;min-height:0}.board-layout.review-below .control-panel{height:var(--board-size);max-height:var(--board-size);overflow-y:auto}.board-layout.review-below .control-panel .move-history{flex:auto;min-height:0}.board-layout.review-below .control-panel .move-list{min-height:0;max-height:none}.board-layout.review-below .analysis-panel{flex:0 0 100%;width:100%;min-width:0;max-width:100%;height:auto;max-height:0;transition:max-height .62s cubic-bezier(.22,1,.36,1),opacity .44s;overflow:hidden;transform:none}.board-layout.review-below .analysis-panel.visible{max-height:4000px;overflow:visible}.board-layout.review-below .analysis-panel.visible .game-review{flex:none;width:100%;height:auto;max-height:none;overflow-y:visible}@media (width>=1441px){.board-layout.with-review{--review-reserve-h:clamp(220px, 24dvh, 320px)}}@media (width>=1281px) and (width<=1440px){.board-layout.with-review{--review-reserve-h:clamp(220px, 22dvh, 300px)}}@media (width>=1201px) and (width<=1280px){.board-layout.with-review{--review-reserve-h:clamp(240px, 24dvh, 320px)}}@media (width>=1081px) and (width<=1200px){.board-layout.with-review{--review-reserve-h:clamp(280px, 26dvh, 340px)}}@media (width>=961px) and (width<=1080px){.board-layout.with-review{--review-reserve-h:clamp(300px, 28dvh, 380px)}}@media (width>=841px) and (width<=960px){.board-layout.with-review{--review-reserve-h:clamp(320px, 30dvh, 400px)}}@media (width>=801px) and (width<=840px){.board-layout.with-review{--review-reserve-h:clamp(340px, 32dvh, 420px)}}@media (width>=801px) and (width<=1440px) and (height<=920px){.board-layout.with-review{--review-reserve-h:clamp(360px, 34dvh, 460px)}}@media (orientation:landscape) and (width>=801px) and (height<=820px){.board-layout.with-review{--review-reserve-h:clamp(380px, 36dvh, 500px)}}@media (width<=1200px){:root{--control-panel-w:240px}.board-layout.with-review{--review-panel-w:0px}.board-layout{flex-wrap:wrap;align-items:flex-start;height:auto;min-height:0}.control-panel{height:var(--board-size);max-height:var(--board-size);overflow-y:auto}.control-panel .move-history{flex:auto;min-height:0}.control-panel .move-list{min-height:0;max-height:none}.analysis-panel{flex:0 0 100%;width:100%;min-width:0;max-width:100%;height:auto;max-height:0;transition:max-height .62s cubic-bezier(.22,1,.36,1),opacity .44s;overflow:hidden;transform:none}.analysis-panel.visible{max-height:4000px;overflow:visible}.analysis-panel.visible .game-review{flex:none;width:100%;height:auto;max-height:none;overflow-y:visible}}@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:stretch}.board-layout{flex-direction:column;align-items:stretch;gap:12px;height:auto;min-height:0}.board-layout>.board-area-outer{width:100%}.control-panel{width:100%;height:auto;min-height:unset;flex:none;gap:8px;max-height:none;padding:0;overflow:hidden visible}.analysis-panel{flex:none;width:100%;min-width:0;max-width:100%;height:auto;max-height:0;padding:0;transition:max-height .62s cubic-bezier(.22,1,.36,1),opacity .44s;overflow:hidden;transform:none}.analysis-panel.visible{max-height:4000px;overflow:visible}.analysis-panel.visible .game-review{flex:none;width:100%;height:auto;max-height:none;overflow-y: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}.control-panel{--control-panel-gap:0;width:100%;height:auto;min-height:unset;gap:var(--control-panel-gap);max-height:none;padding:0 8px;overflow:hidden visible}.analysis-panel{width:100%;min-width:0;max-width:100%;height:auto;max-height:0;padding:0;transition:max-height .62s cubic-bezier(.22,1,.36,1),opacity .44s;overflow:hidden;transform:none}.analysis-panel.visible{max-height:4000px;overflow:visible}.analysis-panel.visible .game-review{flex:none;width:100%;height:auto;max-height:none;overflow-y:visible}.control-panel .game-actions,.control-panel .engine-controls,.control-panel .engine-lines,.control-panel .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}.control-panel .engine-lines,.control-panel .move-history,.analysis-panel .game-review{border-top:1px solid var(--panel-border)!important}.move-list{max-height:none}}:root{--board-light:#f0d9b5;--board-dark:#b58863}.board-area-outer{touch-action:none;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:visible}.board-grid .square:first-child{border-top-left-radius:2px}.board-grid .square:nth-child(8){border-top-right-radius:2px}.board-grid .square:nth-child(57){border-bottom-left-radius:2px}.board-grid .square:nth-child(64){border-bottom-right-radius:2px}.square{width:var(--sq);height:var(--sq);isolation:isolate;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:before{content:"";z-index:3;pointer-events:none;background:#50be6480;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:#58b85a94!important}.square.best-to:after{content:"";z-index:0;pointer-events:none;background:#58b85a80;border-radius:2px;position:absolute;inset:0}.square.last-move-from{background:#dcba46ad!important}.square.dark.last-move-from{background:#b7952ab3!important}.square.last-move-to{background:#e4c455b8!important}.square.dark.last-move-to{background:#c4a032bf!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:0;position:absolute;inset:0}.move-annotation-icon{object-fit:contain;pointer-events:none;z-index:5;filter:drop-shadow(0 1px 3px #000000b3);width:34%;height:34%;position:absolute;top:4%;right:4%}.king-outcome-icon{object-fit:contain;pointer-events:none;z-index:6;filter:drop-shadow(0 1px 3px #000000b3);width:34%;height:34%;position:absolute;top:4%;right:4%}.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:6%;right:6%}@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}.eval-bar.flipped{flex-direction:column-reverse}.eval-bar.flipped .eval-score-white{top:6px;bottom:auto}.eval-bar.flipped .eval-score-black{top:auto;bottom:6px}@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%)}.eval-bar.flipped{flex-direction:row}.eval-bar.flipped .eval-score-white{left:auto;right:6px}.eval-bar.flipped .eval-score-black{left:6px;right:auto}}.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}.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;gap:.65rem;display:flex}.el-title-meta{align-items:center;gap:.4rem;display:flex}.el-depth-badge{color:var(--text-subtle);font-variant-numeric:tabular-nums;letter-spacing:.02em;font-size:.66rem}.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{opacity:1;align-items:center;gap:.3rem;max-height:2rem;transition:max-height .28s cubic-bezier(.22,1,.36,1),opacity .22s,transform .28s cubic-bezier(.22,1,.36,1);display:flex;overflow:hidden;transform:translateY(0)}.el-controls.hidden{opacity:0;pointer-events:none;max-height:0;transform:translateY(-6px)}.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-lines-btn:disabled{opacity:.45;cursor:default}.el-thinking{color:var(--accent);align-items:center;font-size:.72rem;display:inline-flex}.el-thinking:not(.el-thinking-idle){animation:.8s ease-in-out infinite el-pulse}.el-thinking-idle{opacity:.35}@keyframes el-pulse{0%,to{opacity:1}50%{opacity:.2}}.el-body{opacity:1;flex-direction:column;gap:0;max-height:320px;transition:max-height .34s cubic-bezier(.22,1,.36,1),opacity .24s,transform .34s cubic-bezier(.22,1,.36,1);display:flex;overflow:hidden;transform:translateY(0)}.el-body.hidden{opacity:0;pointer-events:none;max-height:0;transform:translateY(-8px)}.el-line-slot{opacity:1;max-height:2.4rem;margin-top:.3rem;transition:max-height .22s cubic-bezier(.22,1,.36,1),opacity .18s,transform .22s cubic-bezier(.22,1,.36,1),margin-top .22s cubic-bezier(.22,1,.36,1);overflow:hidden;transform:translateY(0)}.el-line-slot:first-child{margin-top:0}.el-line-slot.visible{animation:.22s el-slot-fade-in}.el-line-slot.hidden{opacity:0;pointer-events:none;max-height:0;margin-top:0;transform:translateY(-6px)}.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 .14s,border-color .2s;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-empty{pointer-events:none;opacity:.62}.el-line-empty:hover{background:var(--panel-bg-subtle)}.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-great{color:#5b8aba}.el-eval.line-brilliant{color:#69c7ff}.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-empty{background:var(--panel-border);opacity:.45;border-radius:4px;flex-shrink:0;width:3.2em;height:.72em;display:inline-block}.el-moves-empty{background:var(--panel-border);opacity:.35;border-radius:4px;flex:1;width:60%;height:.68em;display:inline-block}@keyframes el-slot-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.game-actions{background:var(--panel-bg);border:1px solid var(--panel-border);width:100%;box-shadow:var(--panel-shadow);z-index:2;border-radius:10px;flex-direction:column;gap:.4rem;padding:.6rem .75rem;display:flex;position:sticky;bottom:0}.status-controls{grid-template-columns:repeat(4,minmax(0,1fr));gap:.4rem;display:grid}.reset-btn,.engine-toggle-btn,.review-btn,.editor-btn{border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--btn-color);cursor:pointer;text-align:center;border-radius:8px;padding:.4rem .55rem;font-size:.78rem;font-weight:600;transition:transform .15s,background .15s,color .15s,border-color .15s,box-shadow .15s;position:relative}.review-btn:hover:not(:disabled){transform:none}.action-label{white-space:nowrap;text-overflow:ellipsis;vertical-align:middle;display:inline-block;overflow:hidden}.trailing-icon{vertical-align:middle;width:1rem;height:1rem;margin-left:.35rem;transition:filter .15s,opacity .15s}.measure-label{visibility:hidden;pointer-events:none;white-space:nowrap;height:0;position:absolute;overflow:hidden}.reset-btn:hover,.engine-toggle-btn:hover,.review-btn:hover:not(:disabled){background:var(--btn-bg-hover);color:var(--text-main)}.engine-toggle-btn.active{background:var(--btn-primary-bg);border-color:var(--btn-primary-border);color:var(--btn-primary-color)}.review-btn.active{background:var(--btn-bg);border-color:var(--btn-border);color:var(--text-main);box-shadow:none}.review-btn.ready:not(.active){background:var(--color-success);border-color:var(--color-success);color:var(--review-btn-success-text,#111)}.review-btn.ready:not(.active) .trailing-icon{filter:none;opacity:1}.review-btn.ready:not(.active):hover{background:var(--color-success);color:var(--review-btn-success-text,#111);box-shadow:0 0 0 2px #fffc}.review-btn.active .trailing-icon{filter:grayscale();opacity:.55}.review-btn:disabled .trailing-icon{filter:grayscale();opacity:.35}.review-btn:disabled{opacity:.45;cursor:default;box-shadow:none}.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{border:1px solid var(--panel-border);background:color-mix(in srgb, var(--panel-bg-subtle) 82%, transparent);border-radius:8px;flex-direction:column;gap:5px;padding:.48rem .58rem;display:flex}.gr-progress-track{background:color-mix(in srgb, var(--panel-border) 76%, transparent);border-radius:999px;height:8px;position:relative;overflow:hidden}.gr-progress-bar{background:linear-gradient(90deg, color-mix(in srgb, var(--accent) 74%, #fff 8%) 0%, var(--accent) 100%);height:100%;box-shadow:0 0 0 1px color-mix(in srgb, var(--accent) 42%, transparent);border-radius:999px;transition:width .22s;position:relative}.gr-progress-text{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:.71rem;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-update-btn,.gr-stop-btn{background:var(--btn-bg);border:1px solid var(--btn-border);color:var(--btn-color);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;gap:.35rem;padding:5px 12px;font-family:inherit;font-size:.8rem;transition:background .12s,color .12s;display:inline-flex}.gr-update-icon{width:1rem;height:1rem;transition:filter .15s,opacity .15s}.gr-update-btn:hover,.gr-stop-btn:hover{background:var(--btn-bg-hover);color:var(--text-main)}.gr-update-btn.active{background:var(--btn-bg);border-color:var(--btn-border);color:var(--text-main);box-shadow:none}.gr-update-btn.active .gr-update-icon{filter:grayscale();opacity:.55}.gr-update-btn.ready:not(.active){background:var(--color-success);border-color:var(--color-success);color:var(--review-btn-success-text,#111)}.gr-update-btn.ready:not(.active) .gr-update-icon{filter:none;opacity:1}.gr-update-btn.ready:not(.active):hover{background:var(--color-success);color:var(--review-btn-success-text,#111);box-shadow:0 0 0 2px #fffc}.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)}: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%;height:100%;margin:0;padding:0;list-style:none;display:flex}.app-nav-li{justify-content:center;width:100%;display:flex}.app-nav-li.settings-slot{margin-top:auto}.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:stretch;align-items:stretch;gap:0;width:100%;height:100%}.app-nav-li{flex:1 1 0;min-width:0;height:100%}.app-nav-li.settings-slot{margin-top:0}.app-nav-item{border-radius:0;flex:none;width:100%;height:100%;padding:6px 4px}.app-nav-item.active{background:color-mix(in srgb, var(--nav-item-active-bg) 92%, transparent)}.app-nav-label{font-size:.53rem}}
