:root{--bg-root:#0A0A0A;--bg-header:#111;--bg-input:#1A1A1A;--bg-card:#0A0A0A;--bg-sidebar:#111;--bg-panel:#111;--border-main:#222;--border-sub:#1A1A1A;--border-btn:#333;--text-primary:#fff;--text-secondary:#E5E5E5;--text-muted:#888;--text-dim:#555;--text-faint:#444;--text-ghost:#333;--bc-bg:#0F0F0F;--edit-bg:#1A1700;--empty-bg:#0D0D0D;--empty-border:#555;--drive-bg:#1A1A2E;--drive-border:#4A4A8A;--result-bad:#FCA5A5;--result-ok:#93C5FD;--result-good:#86EFAC}[data-theme=light]{--bg-root:#F0F0F0;--bg-header:#E0E0E0;--bg-input:#D4D4D4;--bg-card:#E8E8E8;--bg-sidebar:#E4E4E4;--bg-panel:#E0E0E0;--border-main:#C0C0C0;--border-sub:#CCC;--border-btn:#AAA;--text-primary:#111;--text-secondary:#222;--text-muted:#555;--text-dim:#777;--text-faint:#888;--text-ghost:#AAA;--bc-bg:#E8E8E8;--edit-bg:#FFF8E0;--empty-bg:#D8D8D8;--empty-border:#999;--drive-bg:#D8D8F0;--drive-border:#8888BB;--result-bad:#DC2626;--result-ok:#1E40AF;--result-good:#166534}*{margin:0;padding:0;box-sizing:border-box}body{font-family:JetBrains Mono,SF Mono,monospace;background:var(--bg-root);color:var(--text-secondary);min-height:100vh;min-height:100dvh;user-select:none;-webkit-user-select:none;touch-action:manipulation;overflow:hidden;transition:background .25s,color .25s}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .08s}button:active{transform:scale(.96)}.header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-header);border-bottom:2px solid var(--border-main);flex-shrink:0}.header-left{display:flex;align-items:center;gap:12px}.header-title{font-size:18px;font-weight:800;letter-spacing:2px;color:var(--text-primary)}.badge{font-size:12px;background:var(--bg-input);padding:3px 8px;border-radius:4px;color:var(--text-muted)}.header-right{display:flex;align-items:center;gap:6px}.q-group{display:flex;gap:1px}.q-btn{width:36px;height:34px;font-size:13px;font-weight:700;border:1px solid var(--border-btn);background:var(--bg-input);color:var(--text-faint)}.q-btn.active{background:var(--text-primary);color:var(--bg-root);border-color:var(--text-primary)}.q-btn:first-child{border-radius:5px 0 0 5px}.q-btn:last-child{border-radius:0 5px 5px 0}.hdr-btn{padding:5px 12px;height:34px;font-size:11px;font-weight:700;letter-spacing:1px;border-radius:5px;border:1px solid var(--border-btn);background:var(--bg-input);color:var(--text-muted)}.hdr-btn.on-analyse{background:#f59e0b;color:#000;border-color:#f59e0b}.hdr-btn.on-export{background:#8b5cf6;color:#fff;border-color:#8b5cf6}.theme-btn{width:34px;height:34px;font-size:16px;background:var(--bg-input);border:1px solid var(--border-btn);border-radius:5px;display:flex;align-items:center;justify-content:center}.progress{display:flex;height:4px;background:var(--bg-header);flex-shrink:0}.progress-seg{flex:1;transition:background .2s}.edit-bar{height:4px;background:#f59e0b;flex-shrink:0}.breadcrumb{display:flex;align-items:center;gap:5px;padding:8px 14px;background:var(--bc-bg);border-bottom:1px solid var(--border-sub);min-height:40px;flex-shrink:0;overflow-x:auto}.breadcrumb.editing{background:var(--edit-bg)}.bc-item{font-size:11px;font-weight:600;letter-spacing:1px;color:var(--text-faint);padding:2px 3px;white-space:nowrap}.bc-item.active{font-weight:800}.bc-item.filled{color:var(--text-primary)}.bc-item.clickable{text-decoration:underline;text-decoration-color:var(--border-btn);text-underline-offset:3px;cursor:pointer}.bc-color-badge{padding:2px 8px;border-radius:4px}.bc-sep{color:var(--text-ghost);font-size:11px}.edit-label{font-size:12px;font-weight:800;letter-spacing:1px;color:#f59e0b;white-space:nowrap}.undo-btn{padding:5px 14px;background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border-btn);border-radius:5px;font-size:11px;font-weight:700;letter-spacing:1px;margin-left:auto;flex-shrink:0}.main-area{flex:1;display:flex;overflow:hidden}.input-area{flex:1;padding:14px;overflow-y:auto}.step-title{font-size:10px;color:var(--text-dim);font-weight:700;letter-spacing:3px;margin-bottom:12px}.play-confirm{background:var(--bg-input);border:1px solid var(--border-btn);border-radius:6px;padding:8px 12px;margin-bottom:14px;font-size:11px;color:var(--text-muted);line-height:1.6}.play-confirm strong{color:var(--text-primary);font-weight:700;font-size:13px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.btn-color{height:88px;border:none;border-radius:10px;font-size:20px;font-weight:800;letter-spacing:2px}.btn-number{height:68px;background:var(--bg-input);color:var(--text-primary);border-radius:8px;font-size:16px;font-weight:700;border:2px solid var(--border-btn);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;padding:4px 2px}.btn-number .num-label{font-size:8px;color:var(--text-dim);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;padding:0 2px}.btn-number.not-in-book{opacity:.35}.btn-hash{height:88px;background:var(--bg-input);color:var(--text-primary);border-radius:10px;font-size:34px;font-weight:800;letter-spacing:3px;border:2px solid var(--border-btn)}.btn-down{height:88px;background:var(--bg-input);color:var(--text-primary);border-radius:10px;font-size:34px;font-weight:800;border:2px solid var(--border-btn);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.btn-sub{font-size:9px;font-weight:600;opacity:.5;letter-spacing:1px}.btn-dist{height:88px;background:var(--bg-input);color:var(--text-primary);border-radius:10px;font-size:18px;font-weight:800;letter-spacing:1px;border:2px solid var(--border-btn);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.btn-outcome{height:82px;border:none;border-radius:10px;font-size:22px;font-weight:800;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}.btn-result{height:88px;border:none;border-radius:10px;font-size:38px;font-weight:800;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}.btn-desc{font-size:9px;font-weight:600;opacity:.7;letter-spacing:1px}.skip-btn{width:100%;height:56px;background:var(--bg-input);color:var(--text-muted);border:2px solid var(--border-btn);border-radius:10px;font-size:16px;font-weight:800;letter-spacing:2px;margin-bottom:12px}.flag-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.btn-flag{height:64px;background:var(--bg-input);color:var(--text-primary);border:2px solid var(--border-btn);border-radius:8px;font-size:13px;font-weight:700;letter-spacing:1px}.note-row{display:flex;gap:6px}.note-input{flex:1;height:44px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-btn);border-radius:6px;padding:0 12px;font-size:13px;font-family:inherit;outline:none}.note-input:focus{border-color:var(--text-muted)}.note-submit{height:44px;padding:0 16px;background:#8b5cf6;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:700;letter-spacing:1px}.sidebar{width:340px;background:var(--bg-sidebar);border-left:1px solid var(--border-sub);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:8px 12px;border-bottom:1px solid var(--border-sub);display:flex;justify-content:space-between;align-items:center}.sidebar-title{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--text-dim)}.sidebar-btns{display:flex;gap:3px}.sb-btn{font-size:9px;font-weight:700;letter-spacing:1px;background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border-btn);border-radius:4px;padding:3px 7px}.sb-btn.on{background:#f59e0b;color:#000;border-color:#f59e0b}.sb-btn-drive{background:#1e1e3a;color:#88c;border-color:#4a4a8a}.play-log{flex:1;overflow-y:auto;padding:5px 8px;-webkit-overflow-scrolling:touch}.play-row{display:flex;align-items:center;gap:3px;padding:6px 8px;margin-bottom:2px;background:var(--bg-card);border-radius:4px;font-size:11px;border-left:3px solid var(--border-btn);min-height:34px}.play-row.empty{background:var(--empty-bg)}.play-row.editing{background:var(--edit-bg);outline:1px solid #F59E0B44}.play-row.dragging{opacity:.5}.drive-row{display:flex;align-items:center;gap:6px;padding:5px 8px;margin:6px 0 3px;background:var(--drive-bg);border-radius:4px;font-size:10px;font-weight:700;letter-spacing:2px;color:var(--drive-border);border-left:3px solid var(--drive-border);min-height:28px}.cell{flex-shrink:0;text-align:center;border-radius:2px;padding:1px 2px}.cell.editable{outline:1px dashed #55555566;cursor:pointer}.cell-num{color:var(--text-dim);font-weight:600;width:16px;font-size:10px}.cell-color{padding:1px 5px;border-radius:3px;font-size:9px;font-weight:700;min-width:18px}.cell-number{color:var(--text-primary);font-weight:700;width:24px}.cell-hash{color:var(--text-muted);width:14px}.cell-down{color:var(--text-muted);width:14px;font-weight:700}.cell-dist{color:var(--text-dim);width:26px;font-size:9px;font-weight:600}.cell-outcome{font-weight:700;width:26px;font-size:9px}.cell-result{font-weight:800;width:18px}.cell-name{color:var(--text-dim);font-size:8px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-left:2px}.cell-flag{font-size:10px;width:16px;cursor:pointer;text-align:center;flex-shrink:0}.drag-handle{cursor:grab;color:var(--text-ghost);font-size:12px;width:16px;flex-shrink:0;text-align:center}.drag-handle:active{cursor:grabbing}.del-btn{margin-left:auto;background:#dc2626;color:#fff;border:none;border-radius:3px;width:20px;height:20px;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.empty-msg{color:var(--text-ghost);font-size:11px;text-align:center;margin-top:40px}.panel{padding:14px;background:var(--bg-panel);flex-shrink:0;overflow-x:auto}.panel-export{border-bottom:2px solid #8B5CF6}.panel-analyse{border-bottom:2px solid #F59E0B}.copy-btn{padding:9px 20px;background:#8b5cf6;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:700;transition:background .2s}.copy-btn.copied{background:#16a34a}.export-hint{color:var(--text-faint);font-size:11px;margin-left:8px}.export-cols{font-size:9px;color:var(--text-dim);letter-spacing:1px;margin:8px 0 6px}.export-pre{background:var(--bg-card);padding:10px;border-radius:5px;font-size:10px;color:var(--text-muted);overflow:auto;max-height:100px;border:1px solid var(--border-main);white-space:pre}.clear-btn{padding:5px 12px;background:#dc262644;color:#fca5a5;border:1px solid #DC262666;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:1px}.a-row{display:flex;gap:16px;flex-wrap:wrap}.a-section-title{font-size:10px;color:#f59e0b;font-weight:700;letter-spacing:2px;margin-bottom:7px}.a-cards{display:flex;gap:5px;flex-wrap:wrap}.a-card{background:var(--bg-card);border-radius:5px;padding:6px 10px;border:1px solid var(--border-btn);min-width:70px}.a-card-title{font-size:11px;font-weight:700}.a-card-count{font-size:16px;font-weight:800;color:var(--text-primary)}.a-card-bd{font-size:10px;color:var(--text-faint);margin-top:2px}.flag-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center}.flag-modal{background:var(--bg-header);border:1px solid var(--border-main);border-radius:12px;padding:20px;width:360px;max-width:90vw}.flag-modal h3{font-size:14px;font-weight:800;letter-spacing:1px;color:var(--text-primary);margin-bottom:14px}.flag-modal-btns{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.flag-modal-btn{padding:8px 16px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-btn);border-radius:6px;font-size:12px;font-weight:700}.flag-modal-close{width:100%;padding:10px;background:var(--border-btn);color:var(--text-muted);border:none;border-radius:6px;font-size:12px;font-weight:700;margin-top:8px}.back-btn{background:var(--bg-input);border:1px solid var(--border-btn);color:var(--text-muted);border-radius:5px;width:34px;height:34px;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.exp-btn{padding:5px 12px;height:34px;font-size:11px;font-weight:700;letter-spacing:1px;border-radius:5px;border:1px solid var(--border-btn);background:var(--bg-input);color:var(--text-muted)}.import-preview{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid #F59E0B55;border-radius:6px;padding:8px 12px;margin-bottom:10px;flex-wrap:wrap}.import-preview-txt{font-size:11px;color:#f59e0b;font-weight:700;flex:1}.import-confirm-btn{padding:5px 14px;background:#f59e0b;color:#000;border:none;border-radius:5px;font-size:11px;font-weight:800}.import-cancel-btn{padding:5px 12px;background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border-btn);border-radius:5px;font-size:11px;font-weight:700}.pin-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-root)}.pin-box{display:flex;flex-direction:column;align-items:center;gap:14px;padding:40px 32px;background:var(--bg-header);border:1px solid var(--border-main);border-radius:12px;min-width:260px}.pin-logo{font-size:22px;font-weight:800;letter-spacing:4px;color:var(--text-primary)}.pin-subtitle{font-size:11px;font-weight:600;letter-spacing:3px;color:var(--text-muted);margin-top:-8px}.pin-input{width:100%;height:48px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-btn);border-radius:8px;padding:0 16px;font-size:20px;font-family:inherit;text-align:center;letter-spacing:8px;outline:none}.pin-input:focus{border-color:var(--text-muted)}.pin-btn{width:100%;height:44px;background:var(--text-primary);color:var(--bg-root);border:none;border-radius:8px;font-size:14px;font-weight:800;letter-spacing:2px}.pin-error{font-size:11px;color:#fca5a5;font-weight:700;letter-spacing:1px}.gm-body{flex:1;overflow-y:auto;padding:16px}.gm-list{display:flex;flex-direction:column;gap:8px}.gm-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-header);border:1px solid var(--border-main);border-radius:8px;cursor:pointer;transition:border-color .15s;position:relative}.gm-card:active{transform:scale(.99)}.gm-card:hover{border-color:var(--border-btn)}.gm-card-date{font-size:10px;color:var(--text-muted);font-weight:600;letter-spacing:1px;flex-shrink:0}.gm-card-title{font-size:15px;font-weight:800;color:var(--text-primary);letter-spacing:1px;flex:1}.gm-card-opp{font-size:11px;color:var(--text-muted);flex-shrink:0}.gm-card-del{background:transparent;border:none;color:var(--text-faint);font-size:20px;line-height:1;padding:0 4px;flex-shrink:0}.gm-card-del:hover{color:#fca5a5}.gm-form-wrap{margin-bottom:16px}.gm-form{background:var(--bg-header);border:1px solid #F59E0B55;border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:10px}.gm-form-title{font-size:11px;font-weight:800;letter-spacing:2px;color:#f59e0b}.gm-input{height:42px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-btn);border-radius:6px;padding:0 12px;font-size:14px;font-family:inherit;outline:none;width:100%}.gm-input:focus{border-color:var(--text-muted)}.gm-form-btns{display:flex;gap:8px}.gm-btn-create{flex:1;height:42px;background:var(--text-primary);color:var(--bg-root);border:none;border-radius:6px;font-size:13px;font-weight:800;letter-spacing:1px}.gm-btn-cancel{padding:0 20px;height:42px;background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border-btn);border-radius:6px;font-size:12px;font-weight:700}.flash{position:fixed;top:0;right:0;bottom:0;left:0;background:#16a34a22;pointer-events:none;z-index:100;animation:flash .35s ease-out forwards}.save-ind{position:fixed;bottom:12px;left:12px;font-size:10px;color:var(--text-dim);letter-spacing:1px;background:var(--bg-header);padding:4px 10px;border-radius:4px;border:1px solid var(--border-sub);z-index:50;animation:fadeOut 2s ease-out forwards}@keyframes flash{0%{opacity:1}to{opacity:0}}@keyframes slideIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1}70%{opacity:1}to{opacity:0;pointer-events:none}}@media (max-width:700px){.sidebar{width:100%;border-left:none;border-top:1px solid var(--border-sub);max-height:240px}.main-area{flex-direction:column}}
