@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&display=swap";.card{background:var(--bg);border:.5px solid var(--border);border-radius:var(--radius);padding:16px}.card-sm{padding:12px 14px}.card-title{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:600}.metric-card{background:var(--bg);border:.5px solid var(--border);border-radius:var(--radius);padding:16px}.metric-label{color:var(--text3);margin-bottom:6px;font-size:11.5px;font-weight:500}.metric-value{color:var(--text);letter-spacing:-.5px;font-size:24px;font-weight:700;line-height:1}.metric-sub{color:var(--text3);margin-top:4px;font-size:12px}.metric-trend-up{color:var(--green)}.metric-trend-down{color:var(--red)}.progress-wrap{margin-bottom:4px}.progress-label-row{color:var(--text2);justify-content:space-between;margin-bottom:6px;font-size:12.5px;display:flex}.progress-track{background:var(--bg3);border-radius:999px;height:6px;overflow:hidden}.progress-fill{background:var(--blue);border-radius:999px;height:100%;transition:width .4s}.badge{border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-blue{background:var(--blue-light);color:var(--blue)}.badge-green{background:var(--green-light);color:var(--green)}.badge-red{background:var(--red-light);color:var(--red)}.badge-amber{background:var(--amber-light);color:var(--amber)}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 14px;font-size:13.5px;font-weight:500;transition:opacity .15s;display:inline-flex}.btn:hover{opacity:.88}.btn-primary{background:var(--blue);color:#fff}.btn-secondary{background:var(--bg3);color:var(--text2)}.btn-ghost{color:var(--text2);background:0 0}.btn-danger{background:var(--red-light);color:var(--red)}.btn-sm{padding:5px 10px;font-size:12.5px}.btn-icon{color:var(--text3);background:0 0;border-radius:6px;padding:6px}.btn-icon:hover{background:var(--bg3);color:var(--text)}.input{border:.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:var(--bg);outline:none;width:100%;padding:8px 12px;font-size:13.5px;transition:border-color .15s}.input:focus{border-color:var(--blue)}.input::placeholder{color:var(--text3)}textarea.input{resize:vertical;min-height:80px}.modal-overlay{z-index:200;background:#00000059;justify-content:center;align-items:center;padding:16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg);border-radius:var(--radius);border:.5px solid var(--border);width:100%;max-width:480px;max-height:90vh;padding:24px;overflow-y:auto}.modal-title{color:var(--text);margin-bottom:20px;font-size:16px;font-weight:600}.modal-footer{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.form-group{margin-bottom:14px}.form-label{color:var(--text2);text-transform:uppercase;letter-spacing:.4px;margin-bottom:5px;font-size:12px;font-weight:600;display:block}.banner{border-radius:var(--radius);align-items:center;gap:12px;padding:14px 16px;font-size:13.5px;font-weight:500;display:flex}.banner-green{background:var(--green-light);color:var(--green);border:.5px solid #b8e8d8}.banner-blue{background:var(--blue-light);color:var(--blue);border:.5px solid var(--blue-mid)}.banner-amber{background:var(--amber-light);color:var(--amber);border:.5px solid #f0d890}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}@media (width<=768px){.grid-3,.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=480px){.grid-2,.grid-3,.grid-4{grid-template-columns:minmax(0,1fr)}}.section-title{color:var(--text2);text-transform:uppercase;letter-spacing:.5px;border-bottom:.5px solid var(--border);margin-bottom:12px;padding-bottom:8px;font-size:13px;font-weight:600}.score-selector{flex-wrap:wrap;gap:4px;display:flex}.score-btn{border:.5px solid var(--border);background:var(--bg);width:32px;height:32px;color:var(--text2);cursor:pointer;border-radius:6px;font-size:13px;font-weight:600;transition:all .12s}.score-btn:hover{border-color:var(--blue);color:var(--blue)}.score-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}.star-rating{gap:4px;display:flex}.star-btn{cursor:pointer;background:0 0;border:none;padding:2px;transition:transform .1s}.star-btn:hover{transform:scale(1.15)}.toast-container{z-index:999;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:80px;left:50%;transform:translate(-50%)}.toast{background:var(--text);color:#fff;border-radius:var(--radius-sm);white-space:nowrap;padding:10px 16px;font-size:13.5px;font-weight:500;animation:.2s slideUp,.3s 2.5s forwards fadeOut}.habit-row{border-bottom:.5px solid var(--border);align-items:center;gap:10px;padding:10px 0;display:flex}.habit-row:last-child{border-bottom:none}.habit-check{border:1.5px solid var(--border2);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;transition:all .15s;display:flex}.habit-check.checked{background:var(--blue);border-color:var(--blue)}.habit-name{flex:1;font-size:13.5px;font-weight:500}.habit-name.done{color:var(--text3);text-decoration:line-through}.habit-streak{color:var(--amber);align-items:center;gap:3px;font-size:12px;font-weight:600;display:flex}.habit-pts{color:var(--text3);margin-left:4px;font-size:12px;font-weight:500}.empty-state{color:var(--text3);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 24px;display:flex}.empty-state p{font-size:14px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes confettiFall{to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.tabs{border-bottom:.5px solid var(--border);gap:4px;margin-bottom:20px;display:flex}.tab-btn{color:var(--text2);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-.5px;padding:8px 14px;font-size:13.5px;font-weight:500;transition:color .12s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--blue);border-bottom-color:var(--blue)}.divider{background:var(--border);height:.5px;margin:16px 0}.inline-edit-wrap{align-items:center;gap:6px;display:flex}.inline-edit-val{cursor:pointer;border-bottom:1px dashed var(--border2);font-size:14px;font-weight:600}.inline-edit-val:hover{border-bottom-color:var(--blue);color:var(--blue)}*{box-sizing:border-box;margin:0;padding:0}:root{--blue:#1a56db;--blue-light:#e8f0fd;--blue-mid:#c3d5f8;--blue-dark:#0c447c;--bg:#fff;--bg2:#f7f8fa;--bg3:#f0f1f4;--text:#0f1117;--text2:#5a6272;--text3:#9aa0ac;--border:#e4e6ea;--border2:#d0d4dc;--green:#0d9f6e;--green-light:#e6f7f2;--red:#e02424;--red-light:#fdf2f2;--amber:#c27803;--amber-light:#fdf6e3;--radius:12px;--radius-sm:8px;--sidebar-w:220px;--topbar-h:56px;--bottom-nav-h:64px}body{background:var(--bg2);color:var(--text);-webkit-font-smoothing:antialiased;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}#root{width:100%;min-height:100vh;display:flex}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}.sidebar{width:var(--sidebar-w);background:var(--bg);border-right:.5px solid var(--border);z-index:100;flex-direction:column;min-height:100vh;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-logo{border-bottom:.5px solid var(--border);padding:20px 16px 16px}.sidebar-logo h1{color:var(--blue);letter-spacing:-.5px;font-size:20px;font-weight:700}.sidebar-logo p{color:var(--text3);margin-top:2px;font-size:11px}.sidebar-nav{flex:1;padding:8px}.nav-item{border-radius:var(--radius-sm);color:var(--text2);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 10px;font-size:13.5px;font-weight:500;transition:background .12s,color .12s;display:flex;position:relative}.nav-item:hover{background:var(--bg2);color:var(--text)}.nav-item.active{background:var(--blue-light);color:var(--blue)}.nav-badge{background:var(--red);color:#fff;border-radius:999px;margin-left:auto;padding:1px 5px;font-size:10px;font-weight:700}.main-wrap{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{height:var(--topbar-h);background:var(--bg);border-bottom:.5px solid var(--border);z-index:50;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.topbar-title{color:var(--text);font-size:16px;font-weight:600}.topbar-points{background:var(--blue-light);border-radius:999px;align-items:center;gap:8px;padding:6px 12px;display:flex}.topbar-points span{color:var(--blue);font-size:13px;font-weight:600}.page-content{flex:1;padding:24px}.hamburger-btn{border-radius:var(--radius-sm);border:.5px solid var(--border);background:var(--bg);cursor:pointer;width:36px;height:36px;color:var(--text2);flex-shrink:0;justify-content:center;align-items:center;display:none;position:relative}.hamburger-btn:hover{background:var(--bg2)}.hamburger-badge{background:var(--red);border:1.5px solid var(--bg);border-radius:50%;width:7px;height:7px;position:absolute;top:4px;right:4px}.drawer{background:var(--bg);border-right:.5px solid var(--border);z-index:300;flex-direction:column;width:260px;transition:transform .22s;display:none;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-100%)}.drawer-open{transform:translate(0)}.drawer-overlay{z-index:299;background:#0000004d;animation:.2s fadeIn;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar{display:none}.main-wrap{margin-left:0}.hamburger-btn,.drawer{display:flex}.drawer-overlay{display:block}.page-content{padding:16px}.topbar{height:var(--topbar-h);padding:0 16px}}
