*{box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}h1,h2,h3,p{margin-top:0}h1{font-size:34px;line-height:1.15;margin-bottom:0}button{align-items:center;background:#1f2933;border:0;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;justify-content:center;line-height:1.2;min-height:42px;padding:10px 14px}button:disabled{cursor:not-allowed;opacity:.45}button.secondary{background:#e5e7eb;color:#1f2933}button.google-login{background:#fff;border:1px solid #d7dce2;color:#1f2933;gap:10px}button.google-login span{align-items:center;background:#4285f4;border-radius:50%;color:#fff;display:inline-flex;font-size:14px;height:22px;justify-content:center;width:22px}input,select{color:#1f2933;font:inherit;font-size:16px;font-weight:400;min-height:42px}input{background:#fff;border:1px solid #d7dce2;border-radius:6px;color:#1f2933;font:inherit;line-height:1.2;min-width:0;padding:10px}input::placeholder{color:#6b7280;font-weight:400;opacity:1}input[type=date],input[type=number]{font-size:16px;font-weight:400}input[type=date].date--empty{color:#6b7280;font-weight:400}select{background:#fff;border:1px solid #d7dce2;border-radius:6px;color:#1f2933;padding:9px 10px}select:invalid{color:#6b7280;font-weight:400}.shell{background:#f5f2eb;color:#1f2933;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:0}.app-menu{align-items:center;background:#fff;border:0;border-bottom:1px solid #d7dce2;border-radius:0;box-shadow:0 1px 2px #1f29330f;display:flex;flex:0 0 auto;gap:12px;justify-content:space-between;margin:0;max-width:none;min-height:58px;padding:8px 32px;width:100%}.app-menu__item{background:transparent;color:#1f2933;min-height:42px}.app-menu__nav{display:flex;gap:4px}.app-menu__item--active{background:#eef2f6}.app-menu__auth{align-items:center;display:flex;gap:10px;min-width:0}.app-menu__user{font-size:14px;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-backdrop{align-items:center;background:#1f293361;display:flex;justify-content:center;inset:0;padding:24px;position:fixed;z-index:100}.settings-modal{background:#fff;border:1px solid #d7dce2;box-shadow:0 18px 50px #1f29333d;max-width:520px;width:min(100%,520px)}.settings-modal__header{align-items:center;border-bottom:1px solid #e4e7eb;display:flex;justify-content:space-between;padding:14px 16px}.settings-modal__header h2{font-size:20px;margin:0}.settings-modal__close{font-size:18px;height:34px;min-height:34px;padding:0;width:34px}.settings-modal__body{display:grid;gap:0}.settings-tabs{border-bottom:1px solid #e4e7eb;display:flex;gap:4px;padding:0 16px}.settings-tabs button{background:transparent;border-bottom:3px solid transparent;border-radius:0;color:#4b5563;font-size:15px;font-weight:700;min-height:42px;padding:10px 12px}.settings-tabs__button--active{border-bottom-color:#1f2933!important;color:#1f2933!important}.settings-row{align-items:center;border-bottom:1px solid #e4e7eb;display:flex;gap:16px;justify-content:space-between;padding:14px 16px}.settings-row:last-child{border-bottom:0}.settings-row span{font-weight:700}.profile-summary{align-items:center;border-bottom:1px solid #e4e7eb;display:flex;gap:14px;padding:16px}.profile-summary img,.profile-summary__avatar{align-items:center;background:#eef2f6;border:1px solid #d7dce2;border-radius:50%;color:#1f2933;display:flex;flex:0 0 auto;font-size:18px;font-weight:700;height:48px;justify-content:center;object-fit:cover;width:48px}.profile-summary div:last-child{display:grid;gap:4px;min-width:0}.profile-summary strong,.profile-summary span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-summary span{color:#6b7280}.topbar{align-items:center;display:flex;gap:24px;justify-content:space-between;margin:0 auto 28px;max-width:1180px}.eyebrow{color:#6b7280;font-size:13px;font-weight:700;margin:0 0 6px;text-transform:uppercase}.status{align-items:center;background:#fff;border:1px solid #d7dce2;border-radius:8px;display:inline-flex;font-weight:700;gap:8px;padding:10px 14px;text-transform:uppercase}.status span{background:#dc2626;border-radius:50%;display:block;height:9px;width:9px}.status--ok span{background:#15803d}.overview,.workspace{display:grid;gap:16px;margin:0 auto 16px;max-width:1180px}.workspace{flex:1 1 auto;margin:0;max-width:none;min-height:0;overflow:hidden;padding:0;width:100%}.overview{flex:0 0 auto}.overview{grid-template-columns:repeat(3,minmax(0,1fr))}.workspace{grid-template-columns:1.4fr 1fr}.workspace--single{grid-template-columns:1fr}.workspace--analysis{grid-template-columns:1fr;max-width:none}.overview article,.panel{background:#fff;border:1px solid #d7dce2;border-radius:0;box-shadow:0 1px 2px #1f29330f}.overview article{padding:20px}.overview span{color:#6b7280;display:block;font-size:13px;font-weight:700;margin-bottom:8px;text-transform:uppercase}.overview strong{display:block;font-size:24px;margin-bottom:8px}.overview p,.muted{color:#4b5563}.overview p{line-height:1.5;margin-bottom:0}.panel{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden;padding:0}.data-view{display:flex;flex:1 1 auto;flex-direction:column;height:100%;min-height:0;overflow:hidden}.analysis-workspace{background:#fff;border:1px solid #d7dce2;border-radius:0;box-shadow:0 1px 2px #1f29330f;display:grid;grid-template-columns:minmax(180px,260px) 8px minmax(320px,1fr) 8px minmax(180px,260px);min-height:0;overflow:hidden;height:100%;width:100%}.analysis-panel{background:#f8fafc;min-width:0;overflow:hidden}.analysis-panel--left{border-right:1px solid #e4e7eb}.analysis-panel--right{border-left:1px solid #e4e7eb}.splitter{background:linear-gradient(90deg,transparent 0 3px,#cbd5e1 3px 5px,transparent 5px 8px),#eef2f6;cursor:col-resize}.splitter--horizontal{background:linear-gradient(180deg,transparent 0 3px,#cbd5e1 3px 5px,transparent 5px 8px),#eef2f6;cursor:row-resize}.analysis-main{align-items:center;background:#eef2f6;display:flex;justify-content:center;min-height:0;min-width:0;padding:20px}.chessboard{aspect-ratio:1;flex:0 0 auto}.analysis-game-actions,.analysis-move-actions{border-bottom:1px solid #e4e7eb;display:grid;gap:0}.analysis-game-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.analysis-move-actions{grid-template-columns:repeat(3,minmax(0,1fr))}.analysis-game-actions button,.analysis-move-actions button{background:transparent;border-right:1px solid #e4e7eb;border-radius:0;color:#1f2933;font-size:13px;font-weight:700;min-height:40px;padding:8px 6px}.analysis-game-actions button:last-child,.analysis-move-actions button:last-child{border-right:0}.analysis-game-actions button:not(:disabled):hover,.analysis-move-actions button:not(:disabled):hover{background:#eef2f6}.analysis-navigation{border-bottom:1px solid #e4e7eb;display:grid;gap:0;grid-template-columns:repeat(4,minmax(0,1fr))}.analysis-navigation button{background:transparent;border-right:1px solid #e4e7eb;border-radius:0;color:#1f2933;font-size:16px;font-weight:700;min-height:42px;padding:8px 6px}.analysis-navigation button:last-child{border-right:0}.analysis-navigation button:not(:disabled):hover{background:#eef2f6}.analysis-side-block{border-bottom:1px solid #e4e7eb;min-height:0}.analysis-comment{background:#fff;border:0;border-radius:0;display:block;font:inherit;min-height:120px;padding:12px 14px;resize:vertical;width:100%}.analysis-comment:disabled{background:#f8fafc;color:#6b7280}.analysis-variations{display:grid;gap:0;max-height:220px;overflow:auto}.analysis-variation{align-items:center;background:transparent;border-bottom:1px solid #e4e7eb;border-radius:0;color:#1f2933;display:grid;gap:4px;justify-content:stretch;min-height:48px;padding:8px 14px;text-align:left}.analysis-variation span{color:#6b7280;font-size:12px;font-weight:700;text-transform:uppercase}.analysis-variation strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analysis-variation--selected,.analysis-variation:not(:disabled):hover{background:#eef2f6}.analysis-variation-actions{display:grid;gap:8px;grid-template-columns:1fr 1fr;padding:10px}.analysis-variation-actions button{border-radius:0;font-size:13px;min-height:36px;padding:8px}.analysis-side-split{display:grid;grid-template-rows:minmax(120px,.6fr) 8px minmax(160px,.4fr);height:100%;min-height:0}.move-list{display:flex;flex-direction:column;height:100%;min-height:0}.move-list__header{border-bottom:1px solid #e4e7eb;color:#1f2933;flex:0 0 auto;font-size:13px;font-weight:700;padding:12px 14px;text-transform:uppercase}.move-list__body{flex:1 1 auto;min-height:0;overflow:auto}.move-list__notation,.move-list__empty{color:#6b7280;margin:0;padding:12px 14px}.move-list__notation{color:#1f2933;font:inherit;line-height:1.6;white-space:pre-wrap}.pgn-tree{color:#1f2933;display:block;line-height:1.8;padding:12px 14px}.pgn-token,.pgn-variation{display:inline}.pgn-token{margin-right:6px}.pgn-token__prefix{font-weight:700;margin-right:4px}.pgn-token__move{background:transparent;border-radius:0;color:#1f2933;display:inline;font:inherit;font-weight:500;min-height:0;padding:1px 3px;vertical-align:baseline}.pgn-token__move--main{font-weight:700}.pgn-token__move--current{background:#f1c40f;color:#111}.pgn-token__comment{color:#15803d;font-style:italic;margin-left:4px}.pgn-variation{color:#4b5563;margin-right:6px}.pgn-variation__paren{color:#6b7280;font-weight:700;margin:0 3px}.candidate-moves{display:flex;flex-direction:column;min-height:0}.candidate-moves__body{flex:1 1 auto;min-height:0;overflow:auto}.candidate-moves__row{align-items:center;background:transparent;border-bottom:1px solid #e4e7eb;border-radius:0;color:inherit;display:grid;gap:12px;grid-template-columns:minmax(52px,.8fr) minmax(52px,auto) minmax(120px,2fr);justify-content:stretch;min-height:38px;padding:8px 14px;text-align:left;width:100%}.candidate-moves__row--header{background:#f8fafc;color:#6b7280;font-size:12px;font-weight:700;min-height:32px;position:sticky;text-transform:uppercase;top:0;z-index:1}.candidate-moves__row:not(.candidate-moves__row--header):hover{background:#eef2f6}.candidate-moves__row--running{background:#eef2f6}.candidate-moves__move{color:#1f2933;font-weight:700;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.candidate-moves__score{color:#4b5563;font-variant-numeric:tabular-nums;min-width:52px;text-align:right}.candidate-moves__pv{color:#4b5563;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tabs{border-bottom:1px solid #e4e7eb;flex:0 0 auto;display:flex;gap:4px;margin:0;padding:0 16px}.tabs button{background:transparent;border-bottom:3px solid transparent;border-radius:0;color:#4b5563;font-size:20px;font-weight:700;min-height:42px;padding:10px 14px}.tabs button,.tabs__button--active{border-radius:0}.tabs__button--active{border-bottom-color:#1f2933!important;color:#1f2933!important}.panel__meta{color:#6b7280;font-size:13px;margin:4px 0 0}.notice{background:#fff7ed;border:1px solid #fed7aa;border-radius:8px;color:#9a3412;margin-bottom:16px;padding:10px 12px}.filter-bar{align-items:end;border-bottom:1px solid #e4e7eb;display:grid;flex:0 0 auto;gap:12px;grid-template-columns:minmax(180px,1.2fr) 120px 130px 130px auto;margin:0;padding:12px 16px}.filter-bar--players{grid-template-columns:140px minmax(180px,1.2fr) 120px 130px 130px auto}.filter-bar--imports{grid-template-columns:150px 180px 140px 140px minmax(240px,1fr)}.filter-bar label{color:#4b5563;display:grid;font-size:13px;font-weight:700;gap:6px}.filter-bar__actions{display:flex;gap:8px;justify-content:flex-end}.filter-bar__refresh{margin-left:0}.export-bar{align-items:start;border-bottom:1px solid #e4e7eb;display:flex;flex:0 0 auto;gap:12px;margin:0;overflow-x:auto;padding:12px 16px;white-space:nowrap}.export-bar label{display:grid;flex:0 0 auto;gap:6px}.export-bar label:nth-child(1){width:140px}.export-bar label:nth-child(2),.export-bar label:nth-child(3){flex-basis:240px}.export-bar label:nth-child(4),.export-bar label:nth-child(5),.export-bar label:nth-child(6),.export-bar label:nth-child(7){width:120px}.export-bar button{flex:0 0 auto}.combo{position:relative}.combo__trigger,.combo__search{background:#fff;border:1px solid #d7dce2;border-radius:6px;color:#1f2933;font:inherit;font-size:16px;font-weight:400;line-height:1.2;min-height:42px;min-width:0;text-align:left;width:100%}.combo__trigger{display:block;padding-right:34px;padding-left:10px;width:100%}.combo__trigger span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.combo__trigger--placeholder{color:#6b7280;font-weight:400}.combo__clear{align-items:center;background:transparent;color:#6b7280;display:flex;font-size:18px;height:28px;justify-content:center;padding:0;position:absolute;right:4px;top:5px;width:28px}.combo__menu{background:#fff;border:1px solid #d7dce2;border-radius:6px;box-shadow:0 8px 20px #1f293324;left:0;position:absolute;right:0;top:calc(100% + 4px);z-index:200}.combo__search{border:0;border-bottom:1px solid #e4e7eb;border-radius:6px 6px 0 0;padding:10px}.combo__options{max-height:200px;overflow-y:auto}.combo__option{background:transparent;border-radius:0;color:#1f2933;display:block;font:inherit;font-weight:400;overflow:hidden;padding:9px 10px;text-align:left;text-overflow:ellipsis;white-space:nowrap;width:100%}.combo__option:hover{background:#eef2f7}.combo__empty{color:#6b7280;padding:9px 10px}.pager{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.pager--bottom{border-top:1px solid #e4e7eb;flex:0 0 auto;justify-content:space-between;margin-top:0;padding:12px 16px}.pager__controls{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.pager label{align-items:center;color:#4b5563;display:flex;font-size:13px;font-weight:700;gap:8px}.table{flex:1 1 auto;min-height:0;overflow:auto}.table__row{border-top:1px solid #e4e7eb;display:grid;gap:12px;grid-template-columns:70px minmax(220px,1fr) 100px 100px 120px;min-width:700px;padding:10px 16px}.table__row--head{background:#fff;border-top:0;color:#6b7280;font-size:13px;font-weight:700;position:sticky;top:0;text-transform:uppercase;z-index:5}.table__row--button{background:transparent;border-left:0;border-right:0;border-bottom:0;color:inherit;cursor:pointer;font:inherit;text-align:left;width:100%}.table__row--button:hover,.table__row--button:focus-visible{background:#f4f6f8}.table__sort{background:transparent;border-radius:4px;color:inherit;display:inline-flex;font:inherit;font-size:inherit;gap:6px;justify-content:flex-start;min-height:28px;min-width:0;padding:4px 0;text-align:left;text-transform:inherit}.table__sort:hover,.table__sort--active{color:#1f2933}.table__row--games{grid-template-columns:110px minmax(180px,1fr) minmax(180px,1fr) 70px minmax(200px,1.4fr);min-width:780px}.table__row--imports{grid-template-columns:60px 90px 100px minmax(260px,1.4fr) 90px 80px 80px minmax(180px,1fr) minmax(180px,1fr);min-width:1280px}@media(max-width:860px){.app-menu{align-items:stretch;flex-direction:column;padding:8px 20px}.app-menu__auth{justify-content:space-between}.app-menu__nav{flex-wrap:wrap}.topbar{align-items:flex-start;flex-direction:column}.overview,.workspace{grid-template-columns:1fr;padding-left:0;padding-right:0}.overview{padding-left:20px;padding-right:20px}.export-bar{align-items:start}.filter-bar{grid-template-columns:1fr}.filter-bar__actions{flex-wrap:wrap}.analysis-workspace{grid-template-columns:1fr!important;min-height:auto}.analysis-panel,.splitter{display:none}.analysis-main{min-height:calc(100vh - 280px);padding:12px}.chessboard{max-width:100%}}
