*{box-sizing:border-box}:root{--bg:#eef2ff;--bg-alt:linear-gradient(145deg,#f1f5ff,#fbf8ff 45%,#f0f9ff);--surface:hsla(0,0%,100%,.9);--surface-soft:#f8fafe;--text:#101828;--muted:#4b5563;--line:#e3e9ff;--primary:#2563eb;--primary-press:#1d4ed8;--danger:#dc2626;--shadow:0 18px 38px rgba(15,23,42,.15);--radius-lg:18px;--radius-md:12px;--radius-sm:10px;--ring:0 0 0 3px rgba(37,99,235,.2);--font-ui:"Poppins","Inter","Avenir Next",sans-serif;font-family:var(--font-ui);background:var(--bg);color:var(--text)}:root[data-theme=dark]{--bg:#0f172a;--bg-alt:#0f172a;--surface:rgba(30,41,59,.88);--surface-soft:#111827;--text:#f8fafc;--muted:#94a3b8;--line:#334155;--primary:#22d3ee;--primary-press:#06b6d4;--danger:#f87171;--shadow:0 16px 38px rgba(15,23,42,.45)}@font-face{font-family:Poppins;src:local("Poppins")}body{margin:0;min-height:100vh}.shell-root{min-height:100vh;background:var(--bg-alt)}.content-shell{min-height:100vh;padding:1.4rem}.top-bar{position:-webkit-sticky;position:sticky;z-index:4;top:0;display:flex;align-items:center;gap:.75rem;padding:.8rem 1rem;margin:0 auto;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--surface),transparent 20%);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.top-bar nav{display:flex;flex-wrap:wrap;gap:.45rem;margin-left:.75rem;flex:1 1}.top-bar a{color:var(--text);text-decoration:none;border:1px solid var(--line);padding:.42rem .75rem;border-radius:999px}.top-bar a.active{background:var(--primary);color:#fff;border-color:transparent}.brand{font-weight:700;display:flex;align-items:center;gap:.45rem}.brand-mark{width:28px;height:28px;display:inline-grid;place-items:center;border-radius:50%;background:var(--primary);color:#fff}.page,.page-calendar,.page-habits{min-height:calc(100vh - 66px)}.card{width:min(1100px,100%);margin:0 auto;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--line);padding:1.2rem;box-shadow:var(--shadow)}h1{margin:0 0 .45rem;letter-spacing:.01em}h2,h3{margin:0}.page-heading{justify-content:space-between;align-items:center;gap:1rem}.compact-row,.page-heading{display:flex;flex-wrap:wrap}.compact-row{gap:.6rem;margin:.65rem 0 .9rem}.toggle-row{display:flex;gap:.5rem;margin-bottom:.9rem}.toggle-row button{background:#1e293b;color:#fff}.toggle-row .active{background:var(--primary)}.compact-row label,label{display:grid;grid-gap:.35rem;gap:.35rem;color:var(--muted);font-size:.92rem}.form{display:grid;grid-gap:.7rem;gap:.7rem;margin-bottom:1rem;margin-top:.8rem}.form-inline{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.form input,.form select,.form textarea,.form-inline input,.form-inline select,.form-inline textarea{border:1px solid var(--line);border-radius:var(--radius-sm);padding:.66rem .7rem;background:var(--surface-soft);color:var(--text);font:inherit}.form textarea{resize:vertical;min-height:110px}button{border:none;border-radius:var(--radius-sm);background:var(--primary);color:#fff;font-weight:600;padding:.65rem .85rem;cursor:pointer}button:disabled{opacity:.5;cursor:not-allowed}button:hover{filter:brightness(1.02)}button.secondary{background:#334155}button.danger{background:var(--danger)}button.tiny{padding:.4rem .6rem;font-size:.82rem}button.theme-toggle{background:transparent;color:var(--text);border:1px solid var(--line)}.muted{color:var(--muted);margin-top:0}.error{color:#dc2626;margin:.5rem 0}.toast{margin-top:.5rem;border:1px solid;border-radius:10px;padding:.6rem .75rem;background:color-mix(in srgb,var(--surface),transparent 18%)}.toast.success{color:#047857;border-color:#34d399}.toast.error{color:#b91c1c;border-color:#fca5a5}.habits{list-style:none;padding:0;margin:0;display:grid;grid-gap:.75rem;gap:.75rem}.habit-row{border:1px solid var(--line);background:var(--surface-soft);border-radius:var(--radius-md);padding:.85rem;display:grid;grid-gap:.5rem;gap:.5rem}.habit-row h2{font-size:1.05rem;margin-bottom:.3rem}.habit-row p{margin:.05rem 0}.habit-main{display:grid;grid-gap:.35rem;gap:.35rem}.habit-title-row{display:flex;align-items:center;gap:.7rem}.habit-mark{width:34px;height:34px}.habit-controls{display:flex;gap:.45rem;flex-wrap:wrap}.habit-controls button{flex:1 1 auto}.done-btn.done{background:#059669}.edit-panel{margin-top:.8rem;border-top:1px dashed var(--line);padding-top:.75rem;display:grid;grid-gap:.45rem;gap:.45rem}.edit-panel .actions{display:flex;gap:.5rem}.checkbox-group{border:1px dashed var(--line);border-radius:10px;padding:.45rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(70px,1fr));grid-gap:.45rem;gap:.45rem;margin-bottom:.25rem}.checkbox-group.compact{grid-template-columns:repeat(auto-fit,minmax(60px,1fr))}.checkbox-group label{display:flex;align-items:center;gap:.35rem}.chips{display:flex;flex-wrap:wrap;gap:.42rem;margin-top:.35rem}.chip{border-radius:999px;border:1px solid var(--line);padding:.25rem .56rem;font-size:.8rem}.habit-history{margin-top:.55rem;border:1px dashed var(--line);border-radius:10px;padding:.55rem;background:color-mix(in srgb,var(--surface-soft),transparent 8%)}.habit-history h3{margin:0 0 .4rem;font-size:.9rem}.history-list{list-style:none;margin:0;padding:0;display:grid;grid-gap:.3rem;gap:.3rem;font-size:.86rem}.chip.tag{background:color-mix(in srgb,var(--surface),transparent 60%)}.chip-good{color:#b45309;border-color:#f59e0b}.empty{padding:1rem;border:1px dashed var(--line);border-radius:10px;color:var(--muted)}.skeleton-row{animation:pulse 1.5s ease-in-out infinite}.skeleton{border-radius:10px;background:linear-gradient(90deg,color-mix(in srgb,var(--surface-soft),var(--line)),color-mix(in srgb,var(--surface-soft),transparent 20%),color-mix(in srgb,var(--surface-soft),var(--line)));animation:pulse 1.35s ease-in-out infinite}.calendar-grid{margin-top:.75rem;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:6px;gap:6px}.calendar-header{text-align:center;color:var(--muted);font-size:.84rem;padding:.35rem;border-radius:8px;border:1px solid var(--line)}.calendar-cell{min-height:90px;border:1px solid var(--line);border-radius:10px;padding:.5rem;display:grid;align-content:start;grid-gap:.35rem;gap:.35rem;background:var(--surface-soft);cursor:pointer}.calendar-cell.empty-slot{background:transparent;border-style:dashed;cursor:default}.calendar-cell.day-all{background:color-mix(in srgb,#22c55e,transparent 88%)}.calendar-cell.day-partial{background:color-mix(in srgb,#f59e0b,transparent 88%)}.calendar-cell.day-none{background:color-mix(in srgb,#ef4444,transparent 90%)}.calendar-cell.selected{outline:2px solid var(--primary)}.calendar-cell span{font-weight:600}.calendar-dots{display:flex;flex-wrap:wrap;gap:.17rem}.calendar-dots span{width:15px;height:15px;border-radius:50%;display:inline-grid;place-items:center;color:#fff;font-size:.62rem}.day-details{margin-top:1rem}.day-details ul{list-style:none;margin:.5rem 0 0;padding:0;display:grid;grid-gap:.42rem;gap:.42rem}.day-details li{display:flex;gap:.5rem;align-items:center}.dot{width:13px;height:13px;border-radius:50%;display:inline-block}.chart-card,.settings-block{margin-top:1rem;border:1px solid var(--line);border-radius:12px;padding:.9rem;background:var(--surface-soft)}.line-chart{width:100%;height:170px}.bars{display:grid;grid-gap:.5rem;gap:.5rem}.bar-row{display:grid;grid-gap:.3rem;gap:.3rem}.bar-row span{font-size:.88rem;color:var(--muted)}.bar-shell{border-radius:99px;border:1px solid var(--line);padding:.08rem;background:color-mix(in srgb,var(--surface),transparent 80%)}.bar-fill{min-width:35px;border-radius:99px;background:var(--primary);color:#fff;font-size:.72rem;padding:.12rem .5rem}.stats-grid{margin-top:.9rem;display:grid;grid-gap:.6rem;gap:.6rem;grid-template-columns:repeat(auto-fit,minmax(165px,1fr))}.stat{padding:.8rem;border:1px solid var(--line);border-radius:11px;background:var(--surface-soft)}.stat h3{font-size:.95rem;margin-bottom:.45rem}.stat-main{font-size:1.2rem;margin:0}.simple-table{width:100%;margin-top:1rem;border-collapse:collapse;overflow-x:auto}.simple-table td,.simple-table th{border-bottom:1px solid var(--line);text-align:left;padding:.55rem .45rem}.small-muted{font-size:.74rem;color:var(--muted)}@keyframes pulse{0%,to{opacity:.9}50%{opacity:.45}}@media (max-width:880px){.top-bar{align-items:flex-start;flex-wrap:wrap}.top-bar nav{width:100%;margin-left:0}.content-shell{padding:.9rem}.habit-controls button{width:100%}.calendar-cell{min-height:66px}}.habit-layout{margin-top:1rem;display:grid;grid-template-columns:220px minmax(0,1fr);grid-gap:.85rem;gap:.85rem;align-items:start}.category-sidebar{display:grid;grid-gap:.45rem;gap:.45rem;background:var(--surface-soft);border:1px solid var(--line);border-radius:12px;padding:.65rem}.category-sidebar h3{margin:0 0 .25rem;font-size:.94rem}.category-sidebar button{border:1px solid var(--line);background:transparent;color:var(--text);width:100%;text-align:left;padding:.5rem .6rem;border-radius:10px}.category-sidebar button.active{border-color:var(--primary);background:color-mix(in srgb,var(--primary),transparent 82%)}.habit-main-content{min-width:0}.habit-card{background:var(--surface-soft);border:1px solid var(--line);border-left:5px solid var(--habit-color);border-radius:var(--radius-md);padding:.8rem;display:grid;grid-gap:.5rem;gap:.5rem}.habit-card-header{display:flex;align-items:flex-start;gap:.65rem}.habit-card h2{margin:0;font-size:1.03rem}.habit-card p{margin-top:.2rem;margin-bottom:0}.habit-mark{width:36px;height:36px;display:inline-grid;place-items:center;border-radius:50%;color:#fff}.habit-check{display:inline-flex;align-items:center;gap:.45rem;font-size:.88rem}.habit-check input{width:16px;height:16px}.modal-backdrop{position:fixed;z-index:30;inset:0;background:color-mix(in srgb,#000,transparent 55%);display:grid;place-items:center;padding:1rem}.modal-card{width:min(620px,100%);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1rem;box-shadow:var(--shadow)}.modal-card header{margin-bottom:.7rem}.modal-card .actions{display:flex;justify-content:flex-end;gap:.45rem}.stats-summary{margin-top:.85rem}.stats-summary .stat-main{font-size:1.6rem}.heatmap-shell{margin-top:.7rem}.heatmap-grid{margin-top:.55rem;display:grid;grid-gap:4px;gap:4px;grid-auto-flow:column;grid-template-rows:repeat(7,18px);overflow-x:auto;padding-bottom:.55rem}.heat-cell{width:18px;border:none;border-radius:4px;color:transparent;cursor:pointer;padding:0;font-size:0}.heat-cell.selected{outline:2px solid var(--primary)}.heat-cell span{color:transparent;font-size:8px}.heat-cell.level-0{background:#e5e7eb}.heat-cell.level-1{background:#bbf7d0}.heat-cell.level-2{background:#4ade80}.heat-cell.level-3{background:#16a34a}.heat-cell.level-4{background:#15803d}.heat-legend{display:inline-flex;gap:.35rem;align-items:center;margin-top:.45rem;font-size:.82rem}.heat-dot{width:12px;height:12px;border-radius:3px}.heat-dot.level-0{background:#e5e7eb}.heat-dot.level-1{background:#bbf7d0}.heat-dot.level-2{background:#4ade80}.heat-dot.level-3{background:#16a34a}.heat-dot.level-4{background:#15803d}@media (max-width:1020px){.habit-layout{grid-template-columns:1fr}.category-sidebar{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));display:grid}.habit-card-header,.habit-controls,.habit-controls .actions{flex-direction:column}.heatmap-grid{grid-template-rows:repeat(7,16px)}.heat-cell{width:14px;height:14px}}