:root{--bg: #09090b;--panel: #101013;--line: #1f1f25;--empty: #17171c;--text: #e7e7ea;--muted: #8b8b94;--cell: 11px;--gap: 3px;--pitch: 14px;--label-w: 26px;--label-gap: 6px}*{box-sizing:border-box}html,body{margin:0;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased}#app{max-width:860px;margin:0 auto;padding:26px 18px 80px}.topbar{display:flex;align-items:center;justify-content:space-between}.topbar h1{margin:0;font-size:20px;font-weight:650;letter-spacing:-.02em}.hint{margin:6px 0 18px;font-size:12px;color:var(--muted)}.hint b{color:var(--text);font-weight:600}.add{background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:7px 12px;font-size:13px;cursor:pointer}.add:hover{border-color:#33333b}.strip{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;margin-bottom:18px;scrollbar-width:thin}.chip{display:inline-flex;align-items:center;gap:6px;flex-shrink:0;padding:7px 11px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 45%,transparent);background:color-mix(in srgb,var(--accent) 10%,transparent);color:var(--text);font-size:13px;cursor:pointer;line-height:1}.chip:hover{border-color:var(--accent)}.chip.on{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}.chip-ico{font-size:14px}.chip-val{font-weight:600;font-variant-numeric:tabular-nums}.cards{display:flex;flex-direction:column;gap:14px}.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px 16px 16px}.card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.title{display:flex;align-items:center;gap:9px;min-width:0}.title .icon{font-size:18px}.title h2{margin:0;font-size:15px;font-weight:600;color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.status{font-size:12.5px;color:var(--muted);white-space:nowrap}.logbtn{width:30px;height:30px;border-radius:8px;border:1px solid var(--accent);background:transparent;color:var(--accent);font-size:16px;line-height:1;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center}.logbtn:hover{background:color-mix(in srgb,var(--accent) 18%,transparent)}.logbtn.done{background:var(--accent);color:#0a0a0a}.edit{background:transparent;border:none;color:var(--muted);font-size:18px;line-height:1;cursor:pointer;padding:2px 6px;border-radius:6px}.edit:hover{color:var(--text);background:var(--line)}.graph{overflow-x:auto;padding-bottom:4px}.months{display:grid;grid-template-columns:repeat(53,var(--pitch));height:13px;margin-bottom:4px;margin-left:calc(var(--label-w) + var(--label-gap))}.mlabel{font-size:10px;color:var(--muted);white-space:nowrap}.graph-body{display:flex}.daylabels{display:grid;grid-template-rows:repeat(7,var(--cell));gap:var(--gap);width:var(--label-w);margin-right:var(--label-gap)}.daylabels span{font-size:9px;line-height:var(--cell);color:var(--muted);text-align:right}.cells{display:grid;grid-template-rows:repeat(7,var(--cell));grid-auto-flow:column;grid-auto-columns:var(--cell);gap:var(--gap)}.cell{width:var(--cell);height:var(--cell);border-radius:2px;background:var(--empty);border:1px solid rgba(255,255,255,.04);cursor:pointer}.cell.future{background:transparent;border-color:transparent;cursor:default;pointer-events:none}.cell:hover{outline:1px solid rgba(255,255,255,.28)}.spark{position:relative;height:78px;margin-top:2px}.spark-svg{width:100%;height:76px;display:block;overflow:visible}.spark-lbl{position:absolute;left:0;font-size:10px;color:var(--muted);font-variant-numeric:tabular-nums;pointer-events:none}.spark-hi{top:0}.spark-lo{bottom:6px}.spark-empty{display:flex;align-items:center;justify-content:center;height:100%;font-size:12.5px;color:var(--muted)}.spark-empty b{color:var(--text);font-weight:600}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:16px;background:#0000009e;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{width:100%;max-width:392px;background:#0e0e12;border:1px solid var(--line);border-radius:16px;padding:20px}.modal.mini{max-width:320px}.modal h3{margin:0 0 16px;font-size:16px}.unit-suffix{font-size:13px;color:var(--muted)}.row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.row>span:first-child{width:46px;flex-shrink:0;font-size:12px;color:var(--muted)}.modal input,.modal select{background:#16161c;border:1px solid var(--line);color:var(--text);border-radius:8px;padding:8px 10px;font-size:13px}.modal input:focus,.modal select:focus{outline:none;border-color:var(--accent)}.icon-input{width:44px;text-align:center;font-size:16px}.name-input,.unit-input,.modal select,#me-val{flex:1;min-width:0}#m-goal{width:64px}.swatches{display:flex;flex-wrap:wrap;gap:7px;flex:1}.swatch{width:22px;height:22px;padding:0;border-radius:50%;border:2px solid transparent;cursor:pointer}.swatch.sel{border-color:#fff}.modal-actions{display:flex;align-items:center;justify-content:space-between;margin-top:18px}.modal-actions>div{display:flex;gap:8px}.primary{background:var(--accent);color:#0a0a0a;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer}.ghost{background:transparent;color:var(--text);border:1px solid var(--line);border-radius:8px;padding:8px 14px;font-size:13px;cursor:pointer}.del{background:transparent;color:#f87171;border:1px solid #3a2222;border-radius:8px;padding:8px 14px;font-size:13px;cursor:pointer}@media(max-width:560px){#app{padding:22px 14px 64px}.card{padding:12px 12px 14px}.status{font-size:12px}}
