@import"https://fonts.googleapis.com/css2?family=Newsreader:opsz,wght@6..72,500;6..72,600&family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--ink: #1b1b1f;--muted: #6b6b73;--line: #e5e2da;--surface: #fffdf8;--accent: #0e7490;--accent-strong: #0b5b70;--accent-soft: #d9f0f3;--font-body: "Space Grotesk", system-ui, sans-serif;--font-display: "Newsreader", serif;--shadow-soft: 0 10px 30px rgba(20, 20, 30, .08);--shadow-strong: 0 18px 50px rgba(20, 20, 30, .12);font-family:var(--font-body);line-height:1.5;font-weight:400;color:var(--ink);background-color:#f7f2e8;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-height:100vh;background-image:radial-gradient(circle at 10% 10%,#fff4da 0%,transparent 50%),radial-gradient(circle at 90% 0%,#dff1f5 0%,transparent 45%),linear-gradient(135deg,#f8f0e1,#f4f7f2)}a{color:inherit;text-decoration:none}button{font-family:inherit}#root{width:100%}.page{min-height:100vh;padding:32px 24px 64px;color:var(--ink)}.topbar{display:grid;grid-template-columns:1.2fr auto 1fr;align-items:center;gap:24px;max-width:1200px;margin:0 auto 32px}.brand{display:flex;flex-direction:column;gap:6px}.brand-mark{font-family:var(--font-display);font-weight:600;font-size:1.4rem;letter-spacing:-.02em}.brand-sub{color:var(--muted);font-size:.9rem}.nav{display:flex;justify-content:center;gap:12px}.nav-link{background:transparent;border:1px solid transparent;color:var(--muted);padding:8px 14px;border-radius:999px;font-weight:500;transition:all .2s ease}.nav-link:hover{border-color:var(--line);color:var(--ink)}.top-actions{display:flex;justify-content:flex-end;align-items:center;gap:12px}.user-pill{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid var(--line);background:var(--surface);font-size:.9rem;cursor:pointer}.user-dot{width:10px;height:10px;border-radius:999px;background:var(--accent)}.content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.auth-card{background:var(--surface);border-radius:24px;padding:24px;display:flex;align-items:center;justify-content:space-between;gap:24px;box-shadow:var(--shadow-strong)}.auth-card h2{margin:0 0 8px;font-family:var(--font-display);font-size:1.5rem}.auth-card p{margin:0;color:var(--muted)}.auth-form{display:grid;gap:12px;min-width:320px}.auth-form label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--muted)}.auth-form input{border-radius:12px;border:1px solid var(--line);padding:10px 12px;font-size:.95rem;background:#fff;color:var(--ink)}.auth-actions{display:flex;gap:10px;flex-wrap:wrap}.banner{background:#f5f0e8;border-radius:12px;padding:10px 14px;color:var(--muted);font-size:.9rem}.banner.error{background:#fdeaea;color:#a33d3d}.calendar-controls{display:flex;align-items:center;justify-content:space-between;gap:16px}.month-switcher{display:flex;align-items:center;gap:12px;background:var(--surface);padding:10px 16px;border-radius:999px;box-shadow:var(--shadow-soft)}.month-label{font-weight:600;letter-spacing:-.01em}.icon-button{width:32px;height:32px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--ink);font-size:1.2rem;cursor:pointer;transition:all .2s ease}.icon-button:hover{border-color:var(--accent);color:var(--accent)}.mode-toggle{display:flex;align-items:center;border-radius:999px;border:1px solid var(--line);background:var(--surface);overflow:hidden}.toggle{background:transparent;border:none;padding:10px 16px;cursor:pointer;font-weight:500;color:var(--muted)}.toggle.active{background:var(--accent-soft);color:var(--ink)}.habits-card{background:var(--surface);border-radius:24px;padding:20px;box-shadow:var(--shadow-strong);animation:rise .6s ease both}.grid-scroll{overflow-x:auto;padding-bottom:12px}.empty-state{padding:16px 8px;color:var(--muted)}.habits-grid{display:grid;grid-auto-rows:44px;gap:1px;background:var(--line);border-radius:16px;min-width:900px}.grid-head,.grid-cell{background:var(--surface);display:flex;align-items:center;justify-content:center;padding:0 10px;font-size:.85rem}.grid-head{font-weight:600;color:var(--muted)}.grid-head.weekday{text-transform:uppercase;font-size:.7rem;letter-spacing:.08em}.grid-head.date{font-size:.85rem;color:var(--ink)}.grid-head.subhead{color:transparent}.grid-head.today{color:var(--accent);border-bottom:2px solid var(--accent)}.grid-row{display:contents}.grid-cell{position:relative;font-weight:500}.habit-name{justify-content:space-between;gap:12px;font-size:.95rem}.row-action{background:transparent;border:none;color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;cursor:pointer}.row-action:hover{color:var(--accent)}.day-cell{padding:0;border:none;cursor:pointer;background:var(--surface);font-size:.9rem;transition:background .2s ease,transform .2s ease}.day-cell:hover{background:var(--accent-soft)}.day-cell.done{background:var(--accent);color:#fff;font-weight:600}.day-cell.done:hover{background:var(--accent-strong)}.stat{font-weight:600;color:var(--ink)}.sticky-left{position:sticky;left:0;z-index:2;background:var(--surface)}.button{border:none;border-radius:999px;padding:10px 18px;font-weight:600;cursor:pointer;background:var(--accent);color:#fff;transition:transform .2s ease,box-shadow .2s ease}.button:hover{transform:translateY(-1px);box-shadow:0 10px 20px #0e749033}.button.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}.add-habit{margin-top:16px}.habit-form{margin-top:16px;display:flex;flex-direction:column;gap:12px}.habit-fields{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.habit-fields label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--muted)}.habit-fields input{border-radius:12px;border:1px solid var(--line);padding:10px 12px;font-size:.95rem;background:#fff;color:var(--ink)}.notes-card{background:var(--surface);border-radius:20px;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px;box-shadow:var(--shadow-soft)}.notes-card h2{margin:0 0 8px;font-family:var(--font-display);font-size:1.2rem}.notes-card p{margin:0;color:var(--muted)}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 960px){.topbar{grid-template-columns:1fr;justify-items:start}.nav{justify-content:flex-start}.top-actions{justify-content:flex-start;flex-wrap:wrap}.calendar-controls{flex-direction:column;align-items:flex-start}.auth-card{flex-direction:column;align-items:stretch}.auth-form{width:100%}.habit-fields{grid-template-columns:1fr}}@media (max-width: 720px){.page{padding:24px 16px 48px}.habits-grid{min-width:740px}.notes-card{flex-direction:column;align-items:flex-start}}
