.login-page[data-v-35514438]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.login-card[data-v-35514438]{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:48px 40px;width:100%;max-width:380px;display:flex;flex-direction:column;gap:8px}.brand[data-v-35514438]{display:flex;align-items:center;gap:8px;margin-bottom:16px}.brand-icon[data-v-35514438]{font-size:24px}.brand-name[data-v-35514438]{font-size:18px;font-weight:800;color:var(--text)}.title[data-v-35514438]{font-size:22px;font-weight:700;color:var(--text);margin-top:4px}.subtitle[data-v-35514438]{font-size:13px;color:var(--text-muted);margin-bottom:16px}.form[data-v-35514438]{display:flex;flex-direction:column;gap:12px;margin-top:8px}.field[data-v-35514438]{position:relative}.input[data-v-35514438]{width:100%;background:var(--surface-2);border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-size:14px;font-family:inherit;padding:12px 44px 12px 14px;outline:none;transition:border-color .15s}.input[data-v-35514438]:focus{border-color:var(--accent)}.input.error[data-v-35514438]{border-color:#ef4444}.toggle-visibility[data-v-35514438]{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:16px;padding:4px;line-height:1;opacity:.6;transition:opacity .12s}.toggle-visibility[data-v-35514438]:hover{opacity:1}.error-msg[data-v-35514438]{font-size:12px;color:#ef4444;margin-top:-4px}.submit-btn[data-v-35514438]{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:13px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s,opacity .15s;display:flex;align-items:center;justify-content:center;margin-top:4px}.submit-btn[data-v-35514438]:hover:not(:disabled){background:var(--accent-hover)}.submit-btn[data-v-35514438]:disabled{opacity:.6;cursor:not-allowed}.spinner[data-v-35514438]{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-35514438 .7s linear infinite}@keyframes spin-35514438{to{transform:rotate(360deg)}}.grid-wrapper[data-v-32b54ca3]{background:var(--surface);border-radius:16px;padding:20px;overflow:hidden}.month-nav[data-v-32b54ca3]{display:flex;align-items:center;gap:16px;margin-bottom:16px}.month-nav button[data-v-32b54ca3]{background:var(--surface-2);border:none;color:var(--text);width:32px;height:32px;border-radius:8px;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.month-nav button[data-v-32b54ca3]:hover{background:var(--border)}.month-label[data-v-32b54ca3]{font-size:18px;font-weight:700;color:var(--text)}.scroll-container[data-v-32b54ca3]{overflow-x:auto;overflow-y:visible}.habit-table[data-v-32b54ca3]{border-collapse:collapse;width:100%;min-width:900px}.habit-col[data-v-32b54ca3]{min-width:160px;text-align:left;padding:6px 12px;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.day-col[data-v-32b54ca3]{width:32px;min-width:32px;text-align:center;font-size:11px;font-weight:600;color:var(--text-muted);padding:4px 2px}.day-col.today[data-v-32b54ca3],.check-cell.today[data-v-32b54ca3],.pct-cell.today[data-v-32b54ca3]{background:#6366f110}.habit-row:hover td[data-v-32b54ca3]{background:var(--surface-2)}.habit-row:hover td.today[data-v-32b54ca3]{background:#6366f120}.habit-name[data-v-32b54ca3]{padding:6px 12px;font-size:13px;color:var(--text);white-space:nowrap;border-right:1px solid var(--border)}.icon[data-v-32b54ca3]{margin-right:6px}.check-cell[data-v-32b54ca3]{text-align:center;padding:4px 2px}.check-btn[data-v-32b54ca3]{width:22px;height:22px;border-radius:6px;border:1.5px solid var(--border);background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .12s;color:#fff}.check-btn[data-v-32b54ca3]:hover{border-color:var(--accent)}.check-btn.checked[data-v-32b54ca3]{background:var(--accent);border-color:var(--accent)}.check-btn svg[data-v-32b54ca3]{width:12px;height:12px}.percentage-row td[data-v-32b54ca3]{border-top:1px solid var(--border);padding-top:8px}.pct-label[data-v-32b54ca3]{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.pct-cell[data-v-32b54ca3]{text-align:center;padding:6px 2px}.pct-badge[data-v-32b54ca3]{font-size:10px;font-weight:700;padding:2px 3px;border-radius:4px;color:var(--text);display:inline-block}.chart-wrapper[data-v-1527a833]{background:var(--surface);border-radius:16px;padding:20px;height:220px;display:flex;flex-direction:column}.chart-title[data-v-1527a833]{font-size:14px;font-weight:600;color:var(--text-muted);margin:0 0 12px;text-transform:uppercase;letter-spacing:.05em}canvas[data-v-1527a833]{flex:1}.stats-bar[data-v-93fe47f8]{display:flex;gap:16px}.stat[data-v-93fe47f8]{background:var(--surface);border-radius:12px;padding:16px 24px;flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.stat-value[data-v-93fe47f8]{font-size:28px;font-weight:800;color:var(--accent)}.stat-label[data-v-93fe47f8]{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}@media(max-width:767px){.stats-bar[data-v-93fe47f8]{flex-wrap:wrap}.stat[data-v-93fe47f8]{flex:1 1 calc(50% - 8px);min-width:calc(50% - 8px);padding:14px 12px}.stat-value[data-v-93fe47f8]{font-size:24px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100vh;display:flex;flex-direction:column}:root{--bg: #0f1117;--surface: #1a1d27;--surface-2: #22263a;--border: #2e3349;--text: #e2e8f0;--text-muted: #64748b;--accent: #6366f1;--accent-hover: #818cf8}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,sans-serif;min-height:100vh}.app{display:flex;min-height:100vh}.sidebar{width:220px;min-width:220px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 0;gap:24px;overflow-y:auto}.logo{display:flex;align-items:center;gap:10px;padding:0 20px;font-size:20px;font-weight:800;color:var(--text)}.logo-icon{font-size:24px}.nav{display:flex;flex-direction:column;gap:2px;padding:0 12px}.nav-item{display:flex;align-items:center;gap:10px;background:none;border:none;color:var(--text-muted);font-size:13px;font-weight:500;padding:9px 12px;border-radius:8px;cursor:pointer;text-align:left;transition:all .12s}.nav-item:hover,.nav-item.active{background:var(--surface-2);color:var(--text)}.nav-item.active{color:var(--accent);font-weight:600}.section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:0 20px;margin-bottom:8px}.habit-list{flex:1;overflow-y:auto}.habit-item{display:flex;align-items:center;gap:8px;padding:6px 20px;font-size:12px;color:var(--text-muted);transition:color .12s}.habit-item:hover{color:var(--text)}.logout-btn{display:flex;align-items:center;gap:10px;background:none;border:none;color:var(--text-muted);font-size:13px;font-weight:500;padding:9px 24px;cursor:pointer;text-align:left;transition:color .12s;margin-top:auto}.logout-btn:hover{color:#ef4444}.main{flex:1;overflow-y:auto;padding:28px 32px;display:flex;flex-direction:column;gap:20px}.topbar{display:flex;align-items:flex-start;justify-content:space-between}.page-title{font-size:26px;font-weight:800;color:var(--text)}.page-sub{font-size:13px;color:var(--text-muted);margin-top:2px}.loading{color:var(--text-muted);font-size:14px;padding:40px 0;text-align:center}.today-badge{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:8px 16px;font-size:13px;font-weight:600;color:var(--accent)}.mobile-topbar{display:none}.mobile-logout-btn{background:none;border:none;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;font-family:inherit;transition:color .12s}.mobile-logout-btn:hover{color:#ef4444}@media(max-width:767px){.mobile-topbar{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border-bottom:1px solid var(--border);padding:12px 16px;position:sticky;top:0;z-index:10}.sidebar{display:none}.main{padding:16px;gap:16px}.topbar{flex-direction:column;align-items:flex-start;gap:8px}.page-title{font-size:20px}.today-badge{font-size:12px;padding:6px 12px}}
