*{box-sizing:border-box;margin:0;padding:0}:root{--pu50:#eeedfe;--pu800:#3c3489;--pu600:#534ab7;--pu200:#afa9ec;--te50:#e1f5ee;--te800:#085041;--te600:#0f6e56;--te200:#5dcaa5;--am50:#faeeda;--am800:#633806;--am600:#854f0b;--am200:#ef9f27;--co50:#faece7;--co800:#712b13;--co600:#993c1d;--co200:#f0997b;--gr50:#eaf3de;--gr800:#27500a;--gr600:#3b6d11;--bl50:#e6f1fb;--bl800:#0c447c;--bl600:#185fa5;--gy100:#d3d1c7;--gy50:#f1efe8;--gy600:#5f5e5a;--color-text-primary:#222;--color-text-secondary:#666;--color-text-tertiary:#999;--color-background-primary:#fff;--color-background-secondary:#f5f5f5;--color-background-tertiary:#e8e8e8;--color-border-primary:#ddd;--color-border-secondary:#e5e5e5;--color-border-tertiary:#efefef;--border-radius-md:6px;--font-sans:system-ui, sans-serif}body{font-family:var(--font-sans);color:var(--color-text-primary);font-size:13px}.app{max-width:960px;margin:0 auto;padding:1rem}.tabs{border-bottom:.5px solid var(--color-border-tertiary);gap:0;display:flex}.tab{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 16px;font-size:13px;font-weight:500}.tab.active{color:var(--color-text-primary);border-bottom-color:var(--color-text-primary)}.panel{display:none}.panel.active{display:block}.week-nav{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:1rem;display:flex}.week-nav button{border:.5px solid var(--color-border-secondary);background:var(--color-background-secondary);border-radius:var(--border-radius-md);cursor:pointer;color:var(--color-text-primary);padding:5px 12px;font-size:12px}.week-nav button:hover{background:var(--color-background-tertiary)}.week-label{flex:1;font-size:14px;font-weight:500}.mode-badge{border-radius:10px;padding:3px 10px;font-size:11px;font-weight:500}.mode-normal{background:var(--te50);color:var(--te800)}.mode-travel{background:var(--am50);color:var(--am800)}.mode-hard{background:var(--co50);color:var(--co800)}.grid-wrap{position:relative;overflow:auto visible}.week-grid{z-index:1;grid-template-columns:68px repeat(7,minmax(0,1fr));gap:2px;min-width:560px;display:grid;position:relative}.day-header{text-align:center;color:var(--color-text-secondary);padding:6px 2px;font-size:12px;font-weight:500}.day-header.today{color:var(--color-text-primary);font-weight:500}.time-label{color:var(--color-text-tertiary);justify-content:flex-end;align-items:center;height:32px;padding-right:6px;font-size:10px;display:flex}.slot{text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:4px;justify-content:center;align-items:center;height:32px;padding:2px 3px;font-size:9px;font-weight:500;line-height:1.2;transition:opacity .1s;display:flex;position:relative}.slot:hover{opacity:.8}.slot.free{background:var(--color-background-secondary);color:var(--color-text-tertiary)}.slot.blocked{background:var(--color-background-tertiary);color:var(--color-text-tertiary);cursor:default}.slot.coding{background:var(--pu50);color:var(--pu800)}.slot.depth{background:var(--te50);color:var(--te800)}.slot.project{background:var(--am50);color:var(--am800)}.slot.stories{background:var(--co50);color:var(--co800)}.slot.workout{background:var(--gr50);color:var(--gr800)}.slot.flex{background:var(--bl50);color:var(--bl800)}.slot.review{background:var(--gy50);color:var(--gy600)}.slot.stretch-coding{border:1.5px dashed var(--pu600);color:var(--pu600);background:0 0}.slot.stretch-depth{border:1.5px dashed var(--te600);color:var(--te600);background:0 0}.slot.stretch-project{border:1.5px dashed var(--am600);color:var(--am600);background:0 0}.slot.stretch-stories{border:1.5px dashed var(--co600);color:var(--co600);background:0 0}.slot.stretch-workout{border:1.5px dashed var(--gr600);color:var(--gr600);background:0 0}.slot.stretch-flex{border:1.5px dashed var(--bl600);color:var(--bl600);background:0 0}.legend{flex-wrap:wrap;gap:6px;margin:10px 0 4px;display:flex}.leg{color:var(--color-text-secondary);align-items:center;gap:5px;font-size:11px;display:flex}.leg-dot{border-radius:2px;flex-shrink:0;width:11px;height:11px}.leg-dot.stretch{border:1.5px dashed var(--gy600);background:0 0}.hours-bar{background:var(--color-background-secondary);border-radius:var(--border-radius-md);align-items:center;gap:10px;margin:10px 0;padding:10px 12px;display:flex}.hours-label{color:var(--color-text-secondary);min-width:80px;font-size:12px}.bar-bg{background:var(--color-background-tertiary);border-radius:4px;flex:1;height:8px;position:relative;overflow:hidden}.bar-fill{border-radius:4px;height:100%;transition:width .3s}.bar-core{background:var(--te600)}.bar-stretch{background:var(--pu200)}.hours-num{text-align:right;min-width:70px;color:var(--color-text-primary);font-size:13px;font-weight:500}.note-row{background:var(--color-background-secondary);border-radius:var(--border-radius-md);color:var(--color-text-secondary);margin-top:8px;padding:10px 12px;font-size:12px;line-height:1.7}.type-picker{z-index:1000;background:var(--color-background-primary);border:.5px solid var(--color-border-secondary);border-radius:var(--border-radius-md);min-width:130px;padding:6px;display:none;position:absolute;top:34px;left:0;box-shadow:0 2px 8px #00000026}.type-opt{cursor:pointer;color:var(--color-text-primary);border-radius:4px;align-items:center;gap:6px;padding:5px 10px;font-size:12px;display:flex}.type-opt:hover{background:var(--color-background-secondary)}.type-dot{border-radius:2px;flex-shrink:0;width:10px;height:10px}.week-mode-row{flex-wrap:wrap;gap:8px;margin-bottom:10px;display:flex}.mode-btn{border-radius:var(--border-radius-md);border:.5px solid var(--color-border-secondary);background:var(--color-background-secondary);cursor:pointer;color:var(--color-text-secondary);padding:5px 12px;font-size:12px}.mode-btn.active{border-color:var(--color-border-primary);color:var(--color-text-primary);font-weight:500}.mode-btn:hover{background:var(--color-background-tertiary)}.kanban{grid-template-columns:repeat(4,minmax(0,1fr));align-items:start;gap:10px;display:grid}.col-head{color:var(--color-text-secondary);border-radius:var(--border-radius-md);text-align:center;margin-bottom:6px;padding:6px 10px;font-size:11px;font-weight:500}.kcard{background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);margin-bottom:7px;padding:9px 11px}.kcard-title{color:var(--color-text-primary);margin-bottom:3px;font-size:12px;font-weight:500}.ktag{border-radius:10px;margin-bottom:3px;padding:2px 7px;font-size:10px;display:inline-block}.knote{color:var(--color-text-secondary);font-size:11px;line-height:1.4}.kmove{cursor:pointer;border:.5px solid var(--color-border-tertiary);color:var(--color-text-tertiary);background:0 0;border-radius:3px;margin-top:5px;margin-right:3px;padding:2px 5px;font-size:10px}.kmove:hover{background:var(--color-background-secondary)}.prog-row{align-items:center;gap:10px;margin-bottom:9px;display:flex}.prog-label{min-width:170px;color:var(--color-text-secondary);font-size:12px}.prog-bar-bg{background:var(--color-background-tertiary);border-radius:4px;flex:1;height:7px;overflow:hidden}.prog-bar{border-radius:4px;height:100%}.cnt-row{align-items:center;gap:7px;margin-bottom:7px;display:flex}.cnt-btn{border:.5px solid var(--color-border-secondary);background:var(--color-background-secondary);cursor:pointer;width:26px;height:26px;color:var(--color-text-primary);border-radius:50%;justify-content:center;align-items:center;font-size:15px;display:flex}.cnt-val{text-align:center;min-width:28px;color:var(--color-text-primary);font-size:14px;font-weight:500}.note-area{border:.5px solid var(--color-border-secondary);border-radius:var(--border-radius-md);width:100%;min-height:70px;font-size:12px;font-family:var(--font-sans);color:var(--color-text-primary);background:var(--color-background-primary);resize:vertical;padding:9px}.save-btn{border:.5px solid var(--color-border-secondary);background:var(--color-background-secondary);border-radius:var(--border-radius-md);cursor:pointer;color:var(--color-text-primary);margin-top:5px;padding:5px 13px;font-size:12px}.save-btn:hover{background:var(--color-background-tertiary)}.win-chip{background:var(--gr50);color:var(--gr800);border-radius:10px;margin:3px;padding:4px 10px;font-size:12px;display:inline-block}.add-win{gap:7px;margin-top:7px;display:flex}.add-win input{border:.5px solid var(--color-border-secondary);border-radius:var(--border-radius-md);font-size:12px;font-family:var(--font-sans);background:var(--color-background-primary);color:var(--color-text-primary);flex:1;padding:5px 9px}.sec-title{color:var(--color-text-primary);margin-bottom:10px;font-size:14px;font-weight:500}.tip{color:var(--color-text-secondary);margin-bottom:12px;font-size:12px}
