:root{--bg:#0c0d12;--bg-elevated:#13141c;--border:#252836;--text:#c4c8d4;--text-muted:#7a8194;--text-heading:#f4f5f7;--accent:#22d3ee;--accent-dim:#22d3ee26;--success:#4ade80;--warning:#fbbf24;--danger:#f87171;--cell:12px;--radius:12px;--font:"DM Sans", system-ui, sans-serif;--streak-at-risk:#fbbf24;--bg-input:#0f1118;--transition-fast:.15s ease;--transition-std:.25s ease;--z-modal:50;--z-fab:40;--z-toast:60;--shadow-modal:0 24px 80px #00000073}*,:before,:after{box-sizing:border-box}html{font-size:16px}body{min-height:100svh;font-family:var(--font);background:var(--bg);color:var(--text);margin:0;line-height:1.5}#root{min-height:100svh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2{color:var(--text-heading);letter-spacing:-.02em;font-weight:700}.app{max-width:960px;margin:0 auto;padding:0 1.25rem 3rem}.hero{padding:3rem 0 2rem}.hero-inner{text-align:left}.eyebrow{text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin:0 0 .5rem;font-size:.75rem}.hero h1{margin:0 0 .5rem;font-size:clamp(1.75rem,4vw,2.35rem)}.sub{color:var(--text-muted);max-width:36rem;margin:0 0 1.25rem}.hero-actions{flex-wrap:wrap;gap:.75rem;display:flex}.container{flex-direction:column;gap:1.5rem;display:flex}.banner{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-elevated);padding:.75rem 1rem}.banner.error{color:#fecaca;border-color:#f8717166}.muted{color:var(--text-muted)}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;display:grid}.stat-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.stat-card.accent{background:linear-gradient(145deg, var(--accent-dim), var(--bg-elevated));border-color:#22d3ee59}.stat-card.wide{grid-column:1/-1}.stat-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 .25rem;font-size:.75rem}.stat-value{color:var(--text-heading);margin:0;font-size:1.5rem;font-weight:700}.stat-inline{flex-wrap:wrap;gap:.75rem;margin:0;font-weight:600;display:flex}.diff-easy{color:#4ade80}.diff-med{color:#fbbf24}.diff-hard{color:#f87171}.diff-unk{color:var(--text-muted)}.milestone-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.milestone-copy h2{margin:0 0 .25rem;font-size:1.1rem}.milestone-copy p{color:var(--text-muted);margin:0 0 1rem}.milestone-track{background:#1f2330;border-radius:999px;height:10px;overflow:hidden}.milestone-fill{background:linear-gradient(90deg,#22d3ee,#a78bfa);border-radius:999px;height:100%;transition:width .4s}.milestone-foot{color:var(--text-muted);margin:.75rem 0 0;font-size:.85rem}.section-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.section-head h2{margin:0;font-size:1.1rem}.segmented{border:1px solid var(--border);border-radius:999px;display:inline-flex;overflow:hidden}.seg{color:var(--text-muted);font:inherit;cursor:pointer;background:0 0;border:none;padding:.4rem .85rem}.seg.active{background:var(--accent-dim);color:var(--text-heading)}.heatmap-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.heatmap-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.heatmap-header h2{margin:0;font-size:1.1rem}.heatmap-header-right{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.heatmap-month-labels{gap:3px;margin-bottom:2px;display:flex}.month-label{color:var(--text-muted);white-space:nowrap;text-align:left;font-size:.6rem;line-height:1}.heatmap-legend{color:var(--text-muted);align-items:center;gap:.35rem;font-size:.75rem;display:inline-flex}.legend-swatch{border-radius:3px;width:12px;height:12px}.heatmap-wrap{align-items:stretch;gap:.5rem;display:flex}.heatmap-dow{grid-template-rows:repeat(7, var(--cell));gap:3px;padding-top:0;display:grid}.dow-label{color:var(--text-muted);font-size:.65rem;line-height:var(--cell);text-align:right;padding-right:.25rem}.heatmap-scroll{flex:1;padding-bottom:.25rem;overflow-x:auto}.heatmap-columns{flex-direction:row;gap:3px;min-width:min-content;display:flex}.week-col{flex-direction:column;gap:3px;display:flex}.heat-cell{width:var(--cell);height:var(--cell);background:#1f2330;border-radius:3px}.heat-cell.empty{opacity:.2}.heat-cell.lvl0{background:#1f2330}.heat-cell.lvl1{background:#22d3ee40}.heat-cell.lvl2{background:#22d3ee73}.heat-cell.lvl3{background:#22d3eea6}.heat-cell.lvl4{background:#22d3eee6}.legend-swatch.lvl0{background:#1f2330}.legend-swatch.lvl1{background:#22d3ee40}.legend-swatch.lvl2{background:#22d3ee73}.legend-swatch.lvl3{background:#22d3eea6}.legend-swatch.lvl4{background:#22d3eee6}.heatmap-empty{color:var(--text-muted);margin:1rem 0 0;font-size:.9rem}.month-calendar-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.mc-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.mc-nav-btn{border:1px solid var(--border);cursor:pointer;width:32px;height:32px;color:var(--text-muted);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.mc-nav-btn:hover:not(:disabled){color:var(--text-heading);background:#ffffff0f}.mc-nav-btn:disabled{opacity:.25;cursor:default}.mc-month-label{color:var(--text-heading);letter-spacing:-.01em;font-size:1rem;font-weight:700}.mc-dow-row{grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px;display:grid}.mc-dow-label{text-align:center;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding-bottom:.4rem;font-size:.65rem;font-weight:600}.mc-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.mc-cell{cursor:default;min-height:64px;transition:border-color var(--transition-fast), background var(--transition-fast);border:1px solid #0000;border-radius:8px;flex-direction:column;justify-content:flex-start;gap:2px;padding:5px 5px 4px;display:flex;position:relative}.mc-cell--null{pointer-events:none;background:0 0;border-color:#0000}.mc-cell--future{border-color:var(--border);opacity:.35;pointer-events:none;background:0 0}.mc-cell--empty{border-color:var(--border);background:0 0}.mc-cell--lvl1{cursor:pointer;background:#22d3ee14;border-color:#22d3ee33}.mc-cell--lvl2{cursor:pointer;background:#22d3ee2e;border-color:#22d3ee66}.mc-cell--lvl3{cursor:pointer;background:#22d3ee52;border-color:#22d3eea6}.mc-cell--lvl1:hover,.mc-cell--lvl2:hover,.mc-cell--lvl3:hover{filter:brightness(1.12)}.mc-cell--today{box-shadow:inset 0 0 0 2px var(--accent)}.mc-cell--selected{box-shadow:inset 0 0 0 2px var(--accent);filter:brightness(1.12)}.mc-day-num{color:var(--text-muted);align-self:flex-start;font-size:.7rem;font-weight:600;line-height:1}.mc-cell--lvl1 .mc-day-num,.mc-cell--lvl2 .mc-day-num,.mc-cell--lvl3 .mc-day-num{color:var(--text-heading)}.mc-cell--today .mc-day-num{color:var(--accent)}.mc-cell--today.mc-cell--lvl1 .mc-day-num,.mc-cell--today.mc-cell--lvl2 .mc-day-num,.mc-cell--today.mc-cell--lvl3 .mc-day-num{color:var(--text-heading)}.mc-event-row{white-space:nowrap;text-overflow:ellipsis;border-radius:2px;align-items:center;width:100%;min-width:0;padding:1px 3px;font-size:.6rem;font-weight:500;line-height:1.4;display:flex;overflow:hidden}.mc-event-row.easy{color:var(--text-heading);background:#4ade8014;border-left:3px solid #4ade80}.mc-event-row.medium{color:var(--text-heading);background:#fbbf2414;border-left:3px solid #fbbf24}.mc-event-row.hard{color:var(--text-heading);background:#f8717114;border-left:3px solid #f87171}.mc-event-row.unknown{border-left:3px solid var(--text-muted);color:var(--text-muted);background:#7a819414}.mc-overflow-label{color:var(--text-muted);padding-left:4px;font-size:.6rem;line-height:1.4}.mc-empty{text-align:center;color:var(--text-muted);grid-column:1/-1;padding:2rem 0;font-size:.9rem}.mc-legend{flex-wrap:wrap;gap:1rem;margin-top:.875rem;display:flex}.mc-legend-item{color:var(--text-muted);letter-spacing:.02em;align-items:center;gap:.3rem;font-size:.65rem;display:flex}.mc-legend-swatch{border-radius:3px;flex-shrink:0;width:10px;height:10px}.mc-legend-swatch--lvl1{background:#22d3ee14;border:1px solid #22d3ee33}.mc-legend-swatch--lvl2{background:#22d3ee2e;border:1px solid #22d3ee66}.mc-legend-swatch--lvl3{background:#22d3ee52;border:1px solid #22d3eea6}@media (width>=640px){.mc-cell{min-height:88px;padding:7px 7px 5px}.mc-day-num{font-size:.75rem}}@media (width<=360px){.mc-grid,.mc-dow-row{gap:2px}.mc-cell{padding:4px 3px 3px}.mc-day-num{font-size:.6rem}}.cdd-placeholder{min-height:0;transition:min-height .2s}.cdd-placeholder:has(.cdd-card){min-height:160px}.cdd-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;animation:.2s forwards cdd-in}@keyframes cdd-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cdd-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.cdd-date{color:var(--text-heading);letter-spacing:-.02em;margin:0;font-size:1.1rem;font-weight:700}.cdd-count{color:var(--text-muted);margin:.2rem 0 0;font-size:.8rem}.cdd-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.cdd-item{flex-direction:column;gap:.25rem;display:flex}.cdd-item+.cdd-item{border-top:1px solid var(--border);padding-top:.75rem}.cdd-item-top{flex-wrap:wrap;align-items:baseline;gap:.5rem;display:flex}.cdd-item-title{color:var(--text-heading);font-size:.925rem;font-weight:600;text-decoration:none}.cdd-item-title:hover{color:var(--accent);text-decoration:underline}.cdd-item-notes{color:var(--text-muted);white-space:pre-wrap;word-break:break-word;margin:0;font-size:.85rem;line-height:1.5}.recent-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.recent-card h2{margin:0;font-size:1.1rem}.solve-history-head{justify-content:space-between;align-items:baseline;margin-bottom:1rem;display:flex}.history-empty{text-align:center;color:var(--text-muted);padding:2rem 0;font-size:.9rem}.load-more-row{text-align:center;margin-top:1rem}.recent-title-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.recent-note{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:480px;font-size:.8rem;overflow:hidden}@media (hover:none){.recent-item .edit-btn{opacity:1;position:static;transform:none}.recent-item{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.recent-main{padding-right:0!important}}.recent-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.recent-item{background:var(--bg-input);transition:background var(--transition-fast);border:1px solid #1e2230;border-radius:8px;padding:.65rem .75rem;list-style:none;position:relative}.recent-item:hover{background:color-mix(in srgb, var(--bg-input), white 3%)}.recent-item .edit-btn{opacity:0;transition:opacity var(--transition-fast);position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.recent-item:hover .edit-btn{opacity:1}.recent-main{flex-direction:column;gap:.15rem;min-width:0;padding-right:3rem;display:flex}.recent-title{color:var(--text-heading);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.recent-meta{color:var(--text-muted);font-size:.8rem}.recent-date{color:var(--text-muted);font-size:.75rem}.pill{border-radius:999px;padding:.1rem .45rem;font-size:.7rem;font-weight:600;display:inline-block}.pill.diff-easy{color:#4ade80;background:#4ade8026}.pill.diff-medium{color:#fbbf24;background:#fbbf2426}.pill.diff-hard{color:#f87171;background:#f8717126}.pill.diff-unknown{color:var(--text-muted);background:#7a819433}.metrics-row{grid-template-columns:1fr 1fr 2fr;gap:.75rem;display:grid}.metric-cell{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem}.metric-value{color:var(--text-heading);letter-spacing:-.02em;font-size:1.75rem;font-weight:700;line-height:1.1}.metric-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-top:.25rem;font-size:.7rem;font-weight:400}.metric-top-row{justify-content:space-between;align-items:baseline;gap:.5rem;display:flex}.range-toggle{gap:.2rem;display:flex}.range-toggle button{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;border-radius:4px;padding:.15rem .35rem;font-size:.65rem;font-weight:600}.range-toggle button.active{background:var(--accent-dim);color:var(--accent)}.difficulty-cell{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;justify-content:center;padding:1rem 1.25rem;display:flex}.diff-cell-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.5rem;font-size:.7rem;font-weight:400}.diff-bar-track{background:var(--border);border-radius:999px;height:8px;display:flex;overflow:hidden}.diff-segment{height:100%;transition:width .4s}.diff-segment.easy{background:#4ade80}.diff-segment.medium{background:#fbbf24}.diff-segment.hard{background:#f87171}.diff-dot.easy{background:#4ade80}.diff-dot.medium{background:#fbbf24}.diff-dot.hard{background:#f87171}.diff-dot.unknown{background:var(--text-muted)}.diff-legend{flex-wrap:wrap;gap:.75rem;margin-top:.5rem;display:flex}.diff-legend-item{color:var(--text-muted);align-items:center;gap:.3rem;font-size:.72rem;display:flex}.diff-dot{border-radius:999px;width:6px;height:6px}@media (width<=520px){.metrics-row{grid-template-columns:1fr 1fr}.difficulty-cell{grid-column:1/-1}}@media (width<=380px){.metrics-row{grid-template-columns:1fr}.difficulty-cell{grid-column:auto}}.top-bar{justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-top:1.5rem;display:flex}.app-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:.8rem;font-weight:600}.streak-block{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem 1.5rem 1.75rem}.streak-number{letter-spacing:-.04em;color:var(--text-heading);margin-bottom:.2rem;font-size:3.5rem;font-weight:800;line-height:1}.streak-label{color:var(--text-muted);margin-bottom:.35rem;font-size:.85rem}.streak-message{color:var(--text);margin-top:.75rem;font-size:1rem}.streak-warning{color:var(--streak-at-risk);margin-top:.5rem;font-size:.85rem}.streak-number--at-risk{color:var(--streak-at-risk)}.streak-warning--amplified{color:var(--text-heading);background:#fbbf241f;border:1px solid #fbbf2440;border-radius:999px;align-items:center;gap:.35rem;margin-top:.75rem;padding:.3rem .75rem;font-size:1rem;font-weight:600;display:inline-flex}.streak-today-ack{color:var(--success);margin-top:.5rem;font-size:.85rem}@media (width<=639px){.hide-mobile{display:none!important}}.week-strip{justify-content:space-between;gap:.25rem;margin-top:1rem;display:flex}.week-strip-day{flex-direction:column;flex:1;align-items:center;gap:.3rem;display:flex}.week-strip-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-size:.65rem;font-weight:600;line-height:1}.week-strip-circle{border:2px solid var(--border);width:28px;height:28px;transition:background var(--transition-fast), border-color var(--transition-fast);background:0 0;border-radius:50%;flex-shrink:0}.week-strip-circle--filled{background:var(--accent);border-color:var(--accent)}.week-strip-circle--today{box-shadow:0 0 0 2px var(--bg-elevated), 0 0 0 4px var(--accent)}@media (width<=639px){.week-strip-circle{width:24px;height:24px}}.log-fab{z-index:var(--z-fab);cursor:pointer;color:#0c0d12;width:52px;height:52px;transition:filter var(--transition-fast), transform .1s ease;background:linear-gradient(135deg,#22d3ee,#7dd3fc);border:none;border-radius:999px;justify-content:center;align-items:center;font-size:1.5rem;font-weight:300;line-height:1;display:none;position:fixed;bottom:1.5rem;right:1.25rem;box-shadow:0 4px 20px #22d3ee4d}.log-fab:hover{filter:brightness(1.08)}.log-fab:active{transform:scale(.95)}@keyframes fab-pulse{0%,to{box-shadow:0 4px 20px #22d3ee4d}50%{box-shadow:0 4px 28px #fbbf248c,0 0 0 6px #fbbf241f}}.log-fab--at-risk{animation:2s ease-in-out infinite fab-pulse}@media (width<=639px){.log-fab{display:flex}}.toast{background:var(--bg-elevated);color:var(--text-heading);z-index:var(--z-toast);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--transition-fast), transform var(--transition-fast);border:1px solid #22d3ee4d;border-radius:999px;padding:.6rem 1.25rem;font-size:.875rem;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)translateY(8px);box-shadow:0 8px 32px #0006}.toast.visible{opacity:1;transform:translate(-50%)translateY(0)}@media (width<=639px){.toast{bottom:5rem}}.footer{text-align:center;color:var(--text-muted);margin-top:2rem;padding:1rem 0;font-size:.85rem}.btn-primary{font:inherit;cursor:pointer;color:#0c0d12;background:linear-gradient(135deg,#22d3ee,#7dd3fc);border:none;border-radius:999px;padding:.55rem 1.1rem;font-weight:600}.btn-primary:hover{filter:brightness(1.05)}.btn-ghost{border:1px solid var(--border);color:var(--text-heading);cursor:pointer;font:inherit;background:0 0;border-radius:8px;padding:.35rem .6rem}.btn-ghost.small{font-size:.8rem}.btn-danger{color:#fecaca;cursor:pointer;font:inherit;background:#f871711a;border:1px solid #f8717180;border-radius:8px;padding:.55rem .9rem}.modal-backdrop{z-index:var(--z-modal);background:#000000a6;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;width:min(480px,100%);box-shadow:0 24px 80px #00000073}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.modal-head h2{margin:0;font-size:1.1rem}.modal-form{flex-direction:column;gap:.85rem;padding:1.25rem;display:flex}.field{color:var(--text-muted);flex-direction:column;gap:.35rem;font-size:.85rem;display:flex}.field span{color:var(--text-heading);font-weight:600}.field input,.field select,.field textarea{font:inherit;border:1px solid var(--border);background:var(--bg-input);color:var(--text-heading);border-radius:8px;padding:.5rem .65rem}.field textarea{resize:vertical}.field-hint{color:var(--text-muted);font-size:.75rem}.field-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}@media (width<=520px){.field-row{grid-template-columns:1fr}}.form-error{color:#fecaca;margin:0;font-size:.85rem}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:.25rem;display:flex}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-ghost:hover{background:#ffffff0d}@media (width<=639px){.app{padding-bottom:5rem}}
