:root{color:#1f2937;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at top,#bfdbfea6,#0000 42%),linear-gradient(#eff6ff 0%,#fff7ed 100%);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;font-weight:400;line-height:1.5}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;min-height:100vh;margin:0}body,button,input,textarea,select{font:inherit}button{font-family:inherit}h1,h2,h3,p{margin:0}a{color:inherit}code{font-family:SFMono-Regular,ui-monospace,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}#root{--root-pad-y:3rem;width:100%;margin:0 auto;padding:1.5rem 2rem}@media (width<=720px){#root{--root-pad-y:2rem;padding:1rem}}.welcome-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a8c;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.welcome-modal{background:#fffffff7;border:1px solid #94a3b82e;border-radius:2rem;flex-direction:column;gap:1.5rem;width:min(680px,100%);max-height:90vh;padding:2.5rem;display:flex;position:relative;overflow-y:auto;box-shadow:0 32px 64px #0f172a38}.welcome-close{color:#475569;cursor:pointer;background:#f8fafc;border:1px solid #94a3b84d;border-radius:999px;justify-content:center;align-items:center;width:2.2rem;height:2.2rem;font-size:.85rem;transition:background .12s,color .12s,border-color .12s;display:flex;position:absolute;top:1.1rem;right:1.1rem}.welcome-close:hover{color:#b91c1c;background:#fee2e2;border-color:#ef44444d}.welcome-start{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:999px;align-self:flex-start;padding:.85rem 1.6rem;font-size:1rem;font-weight:700;transition:transform .12s,box-shadow .12s}.welcome-start:hover{transform:translateY(-2px);box-shadow:0 12px 28px #2563eb4d}.app-shell{flex-direction:column;gap:1.5rem;display:flex}.board-card,.detail-card,.metric-card,.sidebar-card{background:#ffffffeb;border:1px solid #94a3b82e;box-shadow:0 20px 45px #0f172a14}.profile-bar-wrapper{position:relative}.profile-bar-toggle{cursor:pointer;text-align:left;background:#ffffffeb;border:1px solid #94a3b82e;border-radius:1.4rem;align-items:center;gap:.9rem;width:100%;padding:.9rem 1.4rem;transition:background .12s,box-shadow .12s;display:flex;box-shadow:0 20px 45px #0f172a14}.profile-bar-toggle:hover{background:#eff6fff2;box-shadow:0 20px 45px #2563eb1a}.profile-bar-name{color:#0f172a;font-size:1.1rem}.profile-drawer{z-index:50;background:#fffffffa;border:1px solid #94a3b833;border-radius:1.4rem;padding:1.4rem 1.6rem;animation:.15s drawerSlide;position:absolute;top:calc(100% + .4rem);left:0;right:0;box-shadow:0 28px 56px #0f172a24}@keyframes drawerSlide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.drawer-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem;margin-top:.9rem;display:grid}.drawer-section h3{color:#0f172a;margin:0 0 .5rem;font-size:.95rem}.drawer-section ul{color:#475569;flex-direction:column;gap:.4rem;margin:0;padding-left:1.1rem;display:flex}.drawer-section .move-line{margin:0}.content-grid{grid-template-columns:minmax(240px,18%) minmax(0,1fr) minmax(280px,22%);align-items:stretch;gap:1.5rem;display:grid}.left-sidebar{flex-direction:column;gap:1.25rem;height:100%;display:flex}.sidebar-card{border-radius:1.6rem;flex-direction:column;flex:1;gap:1.25rem;padding:1.2rem;display:flex;overflow-y:auto}.sidebar-group{flex-direction:column;gap:.75rem;display:flex}.opening-select{color:#0f172a;cursor:pointer;appearance:none;background:#f8fafc url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") right .85rem center no-repeat;border:1px solid #94a3b859;border-radius:999px;width:100%;padding:.65rem 2.2rem .65rem .85rem;font-size:.93rem;font-weight:600;transition:border-color .12s,box-shadow .12s}.opening-select:focus{border-color:#2563eb73;outline:none;box-shadow:0 0 0 3px #2563eb1a}.piece-btn{padding:.5rem .9rem;font-size:1.9rem;line-height:1}.board-column{height:calc(100dvh - var(--profile-bar-h,4.75rem) - var(--root-pad-y,3rem));grid-template-rows:1fr auto;align-self:start;place-items:stretch center;gap:.75rem;min-height:0;display:grid}.board-card{border-radius:1.6rem;flex-direction:column;align-items:center;width:100%;max-width:clamp(440px,85vmin,980px);height:100%;min-height:0;padding:1.4rem;display:flex;overflow:auto}.detail-column{flex-direction:column;gap:1.25rem;display:flex}.detail-card{border-radius:1.6rem;padding:1.4rem}.eyebrow{color:#2563eb;letter-spacing:.14em;text-transform:uppercase;margin:0;font-size:.82rem;font-weight:700}.hero-description,.toolbar-description,.detail-copy,.metric-card p,.detail-group li,.inspector li,.continuation-card li,.status-panel li{color:#475569}.toolbar-loading-note{color:#64748b;letter-spacing:.01em;margin:-.25rem 0 0;font-size:.78rem}.highlight-label,.toolbar-label,.metric-label{letter-spacing:.06em;text-transform:uppercase;color:#64748b;font-size:.82rem;font-weight:700}.hero-highlights{gap:1rem;display:grid}.highlight-card{background:linear-gradient(#eff6ffe6,#fff7ede0);border:1px solid #3b82f62e;border-radius:1.25rem;flex-direction:column;gap:.35rem;padding:1rem 1.1rem;display:flex}.highlight-card strong,.metric-card strong,.inspector strong,.detail-badge{color:#111827}.chip-list,.mode-toggle,.suggestion-toggle{flex-wrap:wrap;gap:.65rem;display:flex}.chip,.mode-button{color:#0f172a;cursor:pointer;background:#f8fafc;border:1px solid #94a3b859;border-radius:999px;padding:.62rem .9rem;font-size:.93rem;font-weight:600;transition:transform .12s,border-color .12s,background .12s,color .12s,box-shadow .12s}.sidebar-group .mode-toggle{flex-direction:column;gap:.5rem}.sidebar-group .mode-toggle .mode-button{text-align:center;width:100%}.sidebar-group .mode-toggle.piece-toggle{flex-direction:row;gap:.5rem}.chip:hover,.mode-button:hover{border-color:#2563eb73;transform:translateY(-1px);box-shadow:0 12px 24px #2563eb1f}.chip.active,.mode-button.active{color:#eff6ff;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-color:#0000}.board-actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;width:100%;max-width:100%;margin-top:1rem;display:flex}.section-heading{flex-wrap:wrap;justify-content:space-between;align-items:start;gap:.6rem;margin-bottom:1rem;display:flex}.section-heading h2{margin:.2rem 0 0;font-size:1.45rem}.detail-badge{white-space:normal;word-break:break-word;text-align:center;max-width:12rem}.fen-block{text-align:right;color:#64748b;flex-direction:column;align-items:flex-end;gap:.35rem;max-width:16rem;display:flex}.fen-block code{overflow-wrap:anywhere;color:#0f172a;background:#eff6ff;border-radius:.9rem;max-width:100%;padding:.55rem .7rem;font-size:.76rem;display:block}.chess-heatmap-board{background:linear-gradient(#fafaf9,#f5f5f4);border-radius:1.5rem;width:100%;max-width:100%;height:auto}.legend{grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem;width:100%;max-width:100%;margin-top:1rem;display:grid}.legend-ramp{border-radius:999px;height:.85rem}.legend-ramp-blue{background:linear-gradient(90deg,#dbeafe,#1d4ed8)}.legend-ramp-neutral{background:linear-gradient(90deg,#f5f5f4,#d6d3d1)}.legend-ramp-orange{background:linear-gradient(90deg,#fed7aa,#ea580c)}.legend-labels{color:#64748b;grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem;width:100%;max-width:100%;margin-top:.5rem;font-size:.85rem;display:grid}.metric-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;width:100%;display:grid}.metric-grid.metric-grid-stacked{grid-template-columns:1fr}.metric-card{border-radius:1.4rem;flex-direction:column;gap:.45rem;padding:1.15rem;display:flex}.detail-badge{white-space:nowrap;background:#f8fafc;border:1px solid #94a3b840;border-radius:999px;padding:.45rem .8rem;font-size:.85rem;font-weight:700}.detail-badge.subtle{color:#475569;font-weight:600}.detail-badge.in-book{color:#166534;background:#dcfce7e6;border-color:#22c55e33}.detail-badge.out-of-book{color:#9a3412;background:#ffedd5eb;border-color:#f9731633}.detail-group+.detail-group{margin-top:1.1rem}.detail-group-header{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.6rem;display:flex}.detail-group h3,.attacker-columns h3{color:#0f172a;margin:0 0 .6rem;font-size:1rem}.detail-group ul,.attacker-columns ul{flex-direction:column;gap:.5rem;margin:0;padding-left:1.1rem;display:flex}.move-line{color:#0f172a;background:#f8fafc;border-radius:1rem;padding:.8rem .95rem;line-height:1.6}.inspector{flex-direction:column;gap:1.1rem;display:flex}.inspector-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;display:grid}.inspector-metrics div{background:#f8fafc;border-radius:1rem;flex-direction:column;gap:.35rem;padding:.9rem;display:flex}.inspector-metrics span{color:#64748b;font-size:.85rem}.attacker-columns{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.continuation-list,.analysis-list{flex-direction:column;gap:.85rem;display:flex}.engine-mode-note{background:#ffedd58c;border:1px solid #f973162e;border-radius:1rem;margin-bottom:1rem;padding:.95rem 1rem}.engine-mode-note strong{color:#9a3412;margin-bottom:.3rem;display:block}.engine-mode-note.partial{background:#eff6ffb3;border-color:#2563eb2e}.engine-mode-note.partial strong,.engine-mode-note.partial .source-label{color:#1d4ed8}.source-label,.engine-source-label{color:#9a3412;background:#ffffffe6;border:1px solid #f9731629;border-radius:999px;align-items:center;margin-top:.6rem;padding:.32rem .58rem;font-size:.78rem;font-weight:700;display:inline-flex}.source-label.blue{color:#1d4ed8;border-color:#2563eb29}.continuation-card,.analysis-card,.status-panel{background:#f8fafc;border:1px solid #94a3b82e;border-radius:1.1rem;padding:1rem}.continuation-card.active{border-color:#2563eb59;box-shadow:0 12px 24px #2563eb1a}.analysis-card.selected{border-color:#f9731659;box-shadow:0 12px 24px #f973161f}.card-row,.line-row{justify-content:space-between;align-items:center;gap:.8rem;display:flex}.continuation-card h3,.analysis-card h3,.status-panel h3{color:#0f172a;margin:0;font-size:1rem}.subline-list{flex-direction:column;gap:.45rem;margin:.75rem 0 0;padding-left:1rem;display:flex}.percentage-pill,.eval-pill{color:#1d4ed8;white-space:nowrap;background:#2563eb14;border-radius:999px;padding:.35rem .6rem;font-size:.82rem;font-weight:700}.eval-pill{color:#c2410c;background:#f973161f}.move-buttons{flex-wrap:wrap;gap:.75rem;display:flex}.action-button{color:#0f172a;cursor:pointer;background:#fff;border:1px solid #94a3b84d;border-radius:999px;padding:.65rem .95rem;font-weight:600;transition:transform .12s,box-shadow .12s,border-color .12s}.action-button:hover:not(:disabled){border-color:#2563eb59;transform:translateY(-1px);box-shadow:0 10px 20px #2563eb14}.action-button:disabled{opacity:.45;cursor:not-allowed}.dropdown-toggle-header{cursor:pointer;text-align:left;background:0 0;border:none;width:100%;margin-bottom:1rem;padding:0 1rem 0 0;display:block}.dropdown-toggle-header:hover .dropdown-chevron{color:#2563eb}.dropdown-chevron{color:#94a3b8;flex-shrink:0;font-size:.75rem;transition:color .12s}.small-note{color:#64748b;font-size:.88rem}.move-log{flex-wrap:wrap;gap:.55rem;display:flex}.move-log span{color:#334155;background:#ffffffe6;border:1px solid #94a3b829;border-radius:999px;padding:.4rem .65rem;font-size:.9rem}.loading-text,.error-text{color:#64748b}.error-text{color:#b91c1c}input[type=file]{color:#334155;font-size:.9rem}.opening-tree-canvas{background:#f8fafc;border:1px solid #94a3b833;border-radius:1rem;width:100%;min-height:360px}.pgn-tree-card{width:100%;min-width:0}.opening-tree-wrap{width:100%;position:relative;overflow:auto}.opening-tree-tooltip{z-index:100;pointer-events:none;color:#1a1a1a;background:#fffef9;border:1px solid #d8d0c4;border-radius:.5rem;min-width:160px;max-width:240px;padding:.5rem .65rem;font-family:DM Mono,ui-monospace,monospace;font-size:.72rem;position:fixed;box-shadow:0 4px 14px #0000001a}.opening-tree-tooltip-move{color:#1a1a1a;margin-bottom:.2rem;font-weight:600}.opening-tree-tooltip-name{color:#8b8078;margin-bottom:.15rem}.opening-tree-tooltip-stats{color:#a89e94;margin-bottom:.35rem}.version2-tree .version2-tree-node-rect{filter:drop-shadow(0 1px 3px #0000001a)}.decision-tree-button{color:#1c1000;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:14px;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:0;padding:.95rem 1.5rem;font-size:1rem;font-weight:800;transition:transform .12s,box-shadow .12s;display:flex;box-shadow:0 4px #b45309,0 8px 24px #d9770659}.decision-tree-row{justify-content:center;align-items:stretch;width:100%;max-width:clamp(440px,85vmin,980px);min-height:clamp(64px,15dvh,110px);padding-top:.5rem;padding-bottom:.25rem;display:flex}.decision-tree-button:before{content:"♟";font-size:1.2rem}.decision-tree-button:hover{transform:translateY(-2px);box-shadow:0 6px #b45309,0 14px 32px #d9770666}.decision-tree-button:active{transform:translateY(2px);box-shadow:0 2px #b45309,0 4px 12px #d977064d}.decision-tree-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172ab8;justify-content:center;align-items:stretch;animation:.18s dtFadeIn;display:flex;position:fixed;inset:0}@keyframes dtFadeIn{0%{opacity:0}to{opacity:1}}.decision-tree-page{background:#faf9f7;flex-direction:column;width:100%;max-width:1400px;animation:.22s dtSlideUp;display:flex;overflow:hidden}@keyframes dtSlideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.decision-tree-header{color:#fff;background:#1e3a5f;flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.decision-tree-header .eyebrow{text-transform:uppercase;letter-spacing:.08em;color:#93c5fd;margin:0 0 .2rem;font-size:.7rem}.decision-tree-header h2{color:#fff;margin:0;font-size:1.15rem;font-weight:700}.decision-tree-close{color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #ffffff38;border-radius:8px;padding:.45rem 1rem;font-size:.85rem;font-weight:600;transition:background .15s}.decision-tree-close:hover{background:#ffffff38}.decision-tree-body{flex:1;display:flex;overflow:hidden}.decision-tree-left{border-right:1px solid #e5e1da;flex:1;min-width:0;padding:1rem .5rem 1rem 1rem;overflow:auto}.decision-tree-right{background:#fff;flex-shrink:0;justify-content:center;align-items:flex-start;width:520px;padding:1.5rem 1.25rem;display:flex;overflow-y:auto}.decision-tree-board-wrap{flex-direction:column;align-items:center;width:100%;display:flex}.decision-tree-board-wrap .move-line{text-align:center;word-break:break-word;color:#6b7280;max-width:440px}.score-pill{color:#1d4ed8;background:#2563eb14;border-radius:999px;justify-content:center;align-items:center;min-width:4rem;padding:.35rem .6rem;font-size:.82rem;font-weight:700;display:inline-flex}@media (width<=1200px){.content-grid{grid-template-columns:minmax(200px,20%) minmax(0,1fr) minmax(240px,24%)}}@media (width<=960px){.content-grid,.drawer-grid,.metric-grid{grid-template-columns:1fr}}@media (width<=720px){.board-card,.detail-card,.sidebar-card{border-radius:1.25rem;padding:1rem}.section-heading,.inspector-metrics,.attacker-columns{grid-template-columns:1fr}.section-heading{display:grid}.board-actions,.card-row,.line-row{flex-direction:column;align-items:flex-start}.fen-block{text-align:left;align-items:flex-start}.legend,.legend-labels{grid-template-columns:1fr}}@media (height<=820px){.board-column{gap:.6rem}.board-card{padding:1.05rem}.board-actions{gap:.65rem;margin-top:.65rem}.legend{margin-top:.65rem}.legend-labels{margin-top:.35rem}.small-note{font-size:.82rem}}@media (height<=720px){.board-column{gap:.5rem}.board-card{padding:.95rem}.board-actions{gap:.55rem;margin-top:.55rem}.legend{gap:.65rem;margin-top:.55rem}.legend-labels{margin-top:.3rem;font-size:.8rem}.small-note{font-size:.78rem}}@media (width<=860px){.decision-tree-body{flex-direction:column}.decision-tree-left{border-bottom:1px solid #e5e1da;border-right:none;max-height:50vh}.decision-tree-right{width:100%}}.opening-winrate{flex-direction:column;gap:.55rem;margin-top:.25rem;display:flex}.opening-winrate-bar{border:1px solid #94a3b833;border-radius:6px;width:100%;height:26px;display:flex;overflow:hidden}.opening-winrate-segment{white-space:nowrap;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;transition:width .4s;display:flex;overflow:hidden}.opening-winrate-white{color:#1e293b;background:#e2e8f0}.opening-winrate-draw{color:#fff;background:#94a3b8}.opening-winrate-black{color:#e2e8f0;background:#1e293b}.opening-winrate-legend{flex-wrap:wrap;gap:1rem;display:flex}.opening-winrate-legend-item{color:#475569;align-items:center;gap:.35rem;font-size:.82rem;display:flex}.opening-winrate-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.opening-winrate-dot-white{background:#e2e8f0;border:1px solid #94a3b8}.opening-winrate-dot-draw{background:#94a3b8}.opening-winrate-dot-black{background:#1e293b}
