*{box-sizing:border-box}:root{color-scheme:light;font-family:Poppins,Segoe UI,Tahoma,sans-serif}body{margin:0;background:radial-gradient(circle at top,#fef6e4,#f1f4f8 55%,#e9eef5);color:#1f2937}button,input,select{font-family:inherit}.page{min-height:100vh;display:grid;place-items:center;padding:24px 16px 88px}.page.auth{padding-bottom:24px}.shell{width:min(720px,100%)}.card{background:#fff;border-radius:20px;padding:24px;box-shadow:0 18px 40px #0f172a1f}.allowance-card{margin:16px 0}.allowance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.value{margin:6px 0 0;font-size:1.2rem;font-weight:600}.card-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.today-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.btn.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border-radius:999px}.btn.icon-btn svg{width:18px;height:18px}.card h1{font-size:1.4rem;margin:0}.card h2{font-size:1.1rem;margin:0 0 8px}.muted{color:#6b7280;margin:8px 0 0}.help{color:#6b7280;font-size:.85rem;margin:0}.error{color:#b91c1c;margin:12px 0}.list{display:grid;gap:12px}.month-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:12px 0 16px}.calendar{display:grid;gap:8px}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.calendar-label{font-size:.75rem;text-align:center;color:#64748b}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.calendar-cell{min-height:64px;border-radius:12px;padding:6px;display:flex;flex-direction:column;justify-content:space-between;border:1px solid #e2e8f0;cursor:pointer}.calendar-cell.blank{background:transparent;border:none;cursor:default}.calendar-cell .day{font-size:.85rem;font-weight:600}.calendar-cell .points{font-size:.75rem;color:#1f2937}.progress-wrap{display:flex;justify-content:center;margin:12px 0 16px}.progress-ring{position:relative;width:140px;height:140px}.progress-ring svg{transform:rotate(-90deg)}.ring-bg{fill:none;stroke:#e2e8f0}.ring-fg{fill:none;stroke:#0f172a;stroke-linecap:round;transition:stroke-dashoffset .2s ease}.progress-ring__text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.progress-ring__percent{font-size:1.2rem;font-weight:600}.progress-ring__label{font-size:.85rem;color:#64748b}.progress-ring__sublabel{font-size:.75rem;color:#94a3b8}.heatmap.neutral{background:#f1f5f9}.heatmap.red{background:#fecaca}.heatmap.yellow{background:#fde68a}.heatmap.light{background:#bbf7d0}.heatmap.perfect{background:#4ade80;color:#0f172a}.heatmap.gold{background:#a78bfa;color:#0f172a}.list-item{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-radius:14px;background:#f8fafc;border:1px solid #e2e8f0}.goal-item{position:relative;display:block;padding:18px 18px 16px;background:#f8fafc;border:1px solid #e2e8f0}.goal-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center}.goal-main .meta{margin-top:6px}.goal-center{display:flex;justify-content:center}.goal-side{text-align:right;display:flex;flex-direction:column;gap:6px;align-items:flex-end}.goal-points{margin:0;font-weight:600;color:#0f172a}.goal-type{margin:0;font-size:.85rem;color:#1f2937}.goal-menu-trigger{position:absolute;top:8px;right:8px;border:none;background:transparent;font-size:1.2rem;line-height:1;padding:0;cursor:pointer;color:#0f172a}.goal-menu{position:absolute;top:36px;right:10px;background:#fff;border:1px solid #1f2937;border-radius:10px;padding:6px;display:grid;gap:4px;min-width:120px;z-index:2}.goal-menu-item{background:transparent;border:none;text-align:left;padding:6px 8px;font-size:.9rem;cursor:pointer;border-radius:8px}.goal-menu-item:hover{background:#f1f5f9}.goal-menu-item.danger{color:#b91c1c}.goal-error{margin-top:10px}.habit-content{flex:1}.habit-content.centered{display:flex;flex-direction:column;justify-content:center;gap:8px}.habit-meta{display:flex;flex-direction:column;align-items:flex-end;align-self:stretch;padding-top:6px;gap:6px}.habit-meta .meta{margin:0 0 6px}.habit-meta .tag{margin-top:auto;margin-bottom:auto}.title{margin:0;font-weight:600}.habit-title{display:flex;flex-direction:column;align-items:flex-start;gap:4px;flex-wrap:nowrap}.streak-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:999px;background:#fef3c7;color:#92400e;font-size:.75rem;font-weight:600;white-space:nowrap}.meta{margin:4px 0 0;font-size:.85rem;color:#64748b}.tag{background:#0f172a;color:#fff;padding:6px 10px;border-radius:999px;font-size:.85rem}.btn{background:#0f172a;color:#fff;border:none;border-radius:999px;padding:10px 16px;font-size:.9rem;cursor:pointer}.btn.secondary{background:#fff;color:#0f172a;border:1px solid #0f172a}.btn.ghost{background:transparent;color:#475569;border:1px dashed #cbd5f5}.goal-actions{display:inline-flex;align-items:center;gap:6px}.goal-actions .btn{padding:6px 10px}.goal-actions svg{width:16px;height:16px}.btn.danger{background:#ef4444}.btn:disabled{opacity:.6;cursor:not-allowed}.input{width:100%;border:1px solid #e2e8f0;border-radius:12px;padding:10px 12px;font-size:.95rem;background:#fff}.input.compact{width:140px}.form{display:grid;gap:16px}.field{display:grid;gap:8px;font-size:.9rem}.field.compact-field{justify-items:center}.row{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px;align-items:center}.row.align-end{grid-template-columns:1fr auto}.conversion-line{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}.row.headers{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:#64748b}.stack{display:grid;gap:10px}.spacer{height:28px}.unit{align-self:center;color:#64748b;font-size:.9rem}.actions{display:flex;justify-content:flex-end;gap:12px;margin-top:16px}.nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;display:grid;grid-template-columns:repeat(3,1fr);padding:10px 8px 14px;gap:8px}.nav-btn{border:none;background:transparent;padding:10px 12px;border-radius:12px;font-size:.9rem;font-weight:600;color:#475569}.nav-btn.icon-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 12px}.nav-btn.icon-btn svg{width:18px;height:18px}.nav-btn.active{background:#0f172a;color:#fff}.nav-spacer{min-height:40px}.details-summary{display:flex;align-items:center;justify-content:space-between;cursor:pointer;list-style:none}.details-summary::-webkit-details-marker{display:none}.details-summary:after{content:"▾";font-size:1rem;color:#475569}details[open] .details-summary:after{content:"▴"}@media (min-width: 768px){.page{padding:32px 24px 24px}.nav{position:static;margin-top:16px;border-radius:18px}}@media (max-width: 640px){.today-card{padding-bottom:96px}}.calendar-cell.selected{outline:2px solid #0f172a;outline-offset:2px}.banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;background:#fef3c7;color:#92400e;margin:8px 0 12px;font-size:.9rem}.toggle-group{display:inline-flex;gap:8px;align-items:center;justify-content:center;width:100%}.btn.secondary.active{background:#0f172a;color:#fff;border-color:#0f172a}
