@import url(https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:wght@300;400;500&display=swap);.auth-wrapper.dark[data-v-ecc12d04]{--bg:#050508;--bg-card:rgba(10,12,25,.85);--border:rgba(79,142,247,.18);--border-tab:rgba(79,142,247,.15);--text:#fff;--text-sub:hsla(0,0%,100%,.35);--text-label:hsla(0,0%,100%,.35);--input-bg:hsla(0,0%,100%,.04);--input-border:hsla(0,0%,100%,.08);--tab-bg:hsla(0,0%,100%,.04);--tab-inactive:hsla(0,0%,100%,.4);--toggle-bg:hsla(0,0%,100%,.08);--toggle-color:hsla(0,0%,100%,.6);--orb-opacity:0.18;--grid-color:rgba(79,142,247,.04);--shadow:0 24px 60px rgba(0,0,0,.5)}.auth-wrapper.light[data-v-ecc12d04]{--bg:#f0f4ff;--bg-card:hsla(0,0%,100%,.95);--border:rgba(79,142,247,.25);--border-tab:rgba(79,142,247,.2);--text:#0f1729;--text-sub:rgba(15,23,41,.45);--text-label:rgba(15,23,41,.45);--input-bg:rgba(79,142,247,.04);--input-border:rgba(79,142,247,.15);--tab-bg:rgba(79,142,247,.06);--tab-inactive:rgba(15,23,41,.4);--toggle-bg:rgba(79,142,247,.1);--toggle-color:#4f8ef7;--orb-opacity:0.1;--grid-color:rgba(79,142,247,.06);--shadow:0 24px 60px rgba(79,142,247,.12)}[data-v-ecc12d04]{box-sizing:border-box;margin:0;padding:0}.auth-wrapper[data-v-ecc12d04]{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;font-family:DM Sans,sans-serif;overflow:hidden;position:relative;transition:background .4s ease}.bg-grid[data-v-ecc12d04]{position:fixed;inset:0;background-image:linear-gradient(var(--grid-color) 1px,transparent 1px),linear-gradient(90deg,var(--grid-color) 1px,transparent 1px);background-size:48px 48px;animation:gridShift-ecc12d04 20s linear infinite;transition:opacity .4s}@keyframes gridShift-ecc12d04{0%{transform:translateY(0)}to{transform:translateY(48px)}}.bg-orb[data-v-ecc12d04]{position:fixed;border-radius:50%;filter:blur(80px);opacity:var(--orb-opacity);animation:orbFloat-ecc12d04 12s ease-in-out infinite;transition:opacity .4s}.orb-1[data-v-ecc12d04]{width:500px;height:500px;background:radial-gradient(circle,#4f8ef7,transparent 70%);top:-150px;left:-100px}.orb-2[data-v-ecc12d04]{width:400px;height:400px;background:radial-gradient(circle,#a855f7,transparent 70%);bottom:-100px;right:-80px;animation-delay:-4s}.orb-3[data-v-ecc12d04]{width:300px;height:300px;background:radial-gradient(circle,#3b82f6,transparent 70%);top:50%;left:60%;animation-delay:-8s}@keyframes orbFloat-ecc12d04{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-20px) scale(1.05)}66%{transform:translate(-20px,30px) scale(.95)}}.theme-toggle[data-v-ecc12d04]{position:fixed;top:20px;right:20px;z-index:100;width:40px;height:40px;border-radius:10px;background:var(--toggle-bg);border:1px solid var(--border);color:var(--toggle-color);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;backdrop-filter:blur(10px)}.theme-toggle[data-v-ecc12d04]:hover{transform:scale(1.1)}.auth-container[data-v-ecc12d04]{position:relative;z-index:10;width:100%;max-width:420px;padding:0 20px;display:flex;flex-direction:column;align-items:center;gap:24px}.brand[data-v-ecc12d04]{display:flex;align-items:center;gap:12px;opacity:0;transform:translateY(-20px);transition:all .6s cubic-bezier(.34,1.56,.64,1)}.brand.brand-visible[data-v-ecc12d04]{opacity:1;transform:translateY(0)}.brand-icon[data-v-ecc12d04]{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:rgba(79,142,247,.1);border:1px solid rgba(79,142,247,.2)}.brand-name[data-v-ecc12d04]{font-family:Syne,sans-serif;font-size:24px;font-weight:800;background:linear-gradient(135deg,#4f8ef7,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px}.tab-switcher[data-v-ecc12d04]{position:relative;display:flex;background:var(--tab-bg);border:1px solid var(--border-tab);border-radius:12px;padding:4px;width:100%;opacity:0;transform:translateY(-10px);transition:all .6s cubic-bezier(.34,1.56,.64,1) .15s}.tab-switcher.tabs-visible[data-v-ecc12d04]{opacity:1;transform:translateY(0)}.tab-btn[data-v-ecc12d04]{flex:1;padding:10px;border:none;background:transparent;color:var(--tab-inactive);font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;cursor:pointer;border-radius:9px;position:relative;z-index:2;transition:color .3s}.tab-btn.active[data-v-ecc12d04]{color:var(--text)}.tab-indicator[data-v-ecc12d04]{position:absolute;top:4px;left:4px;width:calc(50% - 4px);height:calc(100% - 8px);background:linear-gradient(135deg,rgba(79,142,247,.3),rgba(168,85,247,.3));border:1px solid rgba(79,142,247,.4);border-radius:9px;transition:transform .35s cubic-bezier(.34,1.4,.64,1);backdrop-filter:blur(4px)}.tab-indicator.tab-right[data-v-ecc12d04]{transform:translateX(100%)}.card[data-v-ecc12d04]{width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:24px;padding:36px 32px;backdrop-filter:blur(20px);box-shadow:var(--shadow);opacity:0;transform:translateY(20px);transition:all .7s cubic-bezier(.34,1.2,.64,1) .25s,background .4s,border-color .4s;min-height:360px}.card.card-visible[data-v-ecc12d04]{opacity:1;transform:translateY(0)}.form-section[data-v-ecc12d04]{width:100%}.form-title[data-v-ecc12d04]{font-family:Syne,sans-serif;font-size:26px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:-.5px}.form-subtitle[data-v-ecc12d04]{font-size:14px;color:var(--text-sub);margin-bottom:28px}.field[data-v-ecc12d04]{position:relative;margin-bottom:22px}.field label[data-v-ecc12d04]{display:block;font-size:11px;font-weight:600;color:var(--text-label);margin-bottom:8px;letter-spacing:.8px;text-transform:uppercase;transition:color .3s}.field.filled label[data-v-ecc12d04],.field.focused label[data-v-ecc12d04]{color:#4f8ef7}.field input[data-v-ecc12d04]{width:100%;background:var(--input-bg);border:1px solid var(--input-border);border-radius:10px;padding:13px 40px 13px 16px;color:var(--text);font-family:DM Sans,sans-serif;font-size:15px;outline:none;transition:all .3s}.field input[data-v-ecc12d04]::-moz-placeholder{color:var(--text-sub)}.field input[data-v-ecc12d04]::placeholder{color:var(--text-sub)}.field.focused input[data-v-ecc12d04]{border-color:rgba(79,142,247,.5);background:rgba(79,142,247,.06);box-shadow:0 0 0 3px rgba(79,142,247,.1)}.field-line[data-v-ecc12d04]{position:absolute;bottom:0;left:16px;right:16px;height:2px;background:linear-gradient(90deg,#4f8ef7,#a855f7);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.34,1.2,.64,1);border-radius:2px}.field.focused .field-line[data-v-ecc12d04]{transform:scaleX(1)}.input-hint[data-v-ecc12d04]{margin-top:8px;font-size:12px;color:var(--text-sub);line-height:1.35}.eye-btn[data-v-ecc12d04]{position:absolute;right:12px;top:50%;transform:translateY(8%);background:none;border:none;cursor:pointer;color:var(--text-sub);opacity:.6;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.eye-btn[data-v-ecc12d04]:hover{opacity:1}.submit-btn[data-v-ecc12d04]{width:100%;padding:14px;border:none;border-radius:12px;background:linear-gradient(135deg,#4f8ef7,#a855f7);color:#fff;font-family:DM Sans,sans-serif;font-size:15px;font-weight:600;cursor:pointer;margin-top:8px;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px rgba(79,142,247,.3)}.submit-btn[data-v-ecc12d04]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px rgba(79,142,247,.4)}.submit-btn[data-v-ecc12d04]:active:not(:disabled){transform:translateY(0)}.submit-btn[data-v-ecc12d04]:disabled{opacity:.6;cursor:not-allowed}.spinner[data-v-ecc12d04]{display:inline-block;width:18px;height:18px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin-ecc12d04 .7s linear infinite;vertical-align:middle}@keyframes spin-ecc12d04{to{transform:rotate(1turn)}}.error-msg[data-v-ecc12d04]{color:#f87171;font-size:13px;margin-bottom:12px;padding:10px 12px;background:hsla(0,91%,71%,.08);border:1px solid hsla(0,91%,71%,.2);border-radius:8px;animation:shake-ecc12d04 .4s ease}@keyframes shake-ecc12d04{0%,to{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}.success-msg[data-v-ecc12d04]{color:#4ade80;font-size:13px;margin-bottom:12px;padding:10px 12px;background:rgba(74,222,128,.08);border:1px solid rgba(74,222,128,.2);border-radius:8px}.switch-hint[data-v-ecc12d04]{text-align:center;margin-top:20px;font-size:13px;color:var(--text-sub)}.link-btn[data-v-ecc12d04]{background:none;border:none;color:#4f8ef7;cursor:pointer;font-size:13px;font-family:DM Sans,sans-serif;font-weight:500;transition:color .2s;padding:0}.link-btn[data-v-ecc12d04]:hover{color:#a855f7}.slide-fade-enter-active[data-v-ecc12d04]{transition:all .35s cubic-bezier(.34,1.2,.64,1)}.slide-fade-leave-active[data-v-ecc12d04]{transition:all .2s ease}.slide-fade-enter-from[data-v-ecc12d04]{opacity:0;transform:translateX(24px)}.slide-fade-leave-to[data-v-ecc12d04]{opacity:0;transform:translateX(-24px)}@media (max-width:480px){.auth-container[data-v-ecc12d04]{padding:0 16px;gap:20px}.card[data-v-ecc12d04]{padding:28px 20px;min-height:auto}.form-title[data-v-ecc12d04]{font-size:22px}.brand-name[data-v-ecc12d04]{font-size:20px}.theme-toggle[data-v-ecc12d04]{top:16px;right:16px}}.dashboard.dark[data-v-79ecf873]{--bg:#050508;--sidebar-bg:rgba(8,10,22,.97);--card-bg:rgba(10,12,25,.8);--border:rgba(79,142,247,.15);--text:#fff;--text-sub:hsla(0,0%,100%,.4);--text-label:hsla(0,0%,100%,.35);--input-bg:hsla(0,0%,100%,.04);--input-border:hsla(0,0%,100%,.1);--nav-hover:rgba(79,142,247,.08);--nav-active:rgba(79,142,247,.15);--topbar-bg:rgba(5,5,8,.9);--shadow:0 8px 32px rgba(0,0,0,.4);--day-bg:hsla(0,0%,100%,.04);--day-border:hsla(0,0%,100%,.08);--orb-opacity:0.12}.dashboard.light[data-v-79ecf873]{--bg:#f0f4ff;--sidebar-bg:hsla(0,0%,100%,.98);--card-bg:hsla(0,0%,100%,.9);--border:rgba(79,142,247,.2);--text:#0f1729;--text-sub:rgba(15,23,41,.45);--text-label:rgba(15,23,41,.5);--input-bg:rgba(79,142,247,.04);--input-border:rgba(79,142,247,.18);--nav-hover:rgba(79,142,247,.06);--nav-active:rgba(79,142,247,.12);--topbar-bg:rgba(240,244,255,.95);--shadow:0 8px 32px rgba(79,142,247,.1);--day-bg:rgba(79,142,247,.04);--day-border:rgba(79,142,247,.15);--orb-opacity:0.07}[data-v-79ecf873]{box-sizing:border-box;margin:0;padding:0}.dashboard[data-v-79ecf873]{display:flex;min-height:100vh;background:var(--bg);font-family:DM Sans,sans-serif;position:relative;transition:background .4s}.bg-orb[data-v-79ecf873]{position:fixed;border-radius:50%;filter:blur(100px);opacity:var(--orb-opacity);pointer-events:none;z-index:0;transition:opacity .4s}.orb-1[data-v-79ecf873]{width:600px;height:600px;background:radial-gradient(circle,#4f8ef7,transparent 70%);top:-200px;left:-200px}.orb-2[data-v-79ecf873]{width:500px;height:500px;background:radial-gradient(circle,#a855f7,transparent 70%);bottom:-150px;right:-150px}.sidebar[data-v-79ecf873]{width:240px;flex-shrink:0;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 16px;position:sticky;top:0;height:100vh;z-index:50;backdrop-filter:blur(20px);transition:background .4s,border-color .4s}.sidebar-header[data-v-79ecf873]{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;padding:0 8px}.brand[data-v-79ecf873]{display:flex;align-items:center;gap:10px}.brand-icon[data-v-79ecf873]{width:36px;height:36px;border-radius:10px;background:rgba(79,142,247,.1);border:1px solid rgba(79,142,247,.2);display:flex;align-items:center;justify-content:center}.brand-name[data-v-79ecf873]{font-family:Syne,sans-serif;font-size:16px;font-weight:800;background:linear-gradient(135deg,#4f8ef7,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-close[data-v-79ecf873]{display:none;background:none;border:none;color:var(--text-sub);cursor:pointer;padding:4px}.sidebar-nav[data-v-79ecf873]{flex:1;display:flex;flex-direction:column;gap:4px}.nav-item[data-v-79ecf873]{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;border:none;background:transparent;color:var(--text-sub);font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;cursor:pointer;text-align:left;width:100%;transition:all .2s}.nav-item[data-v-79ecf873]:hover{background:var(--nav-hover);color:var(--text)}.nav-item.active[data-v-79ecf873]{background:var(--nav-active);color:#4f8ef7}.sidebar-footer[data-v-79ecf873]{display:flex;flex-direction:column;gap:4px}.logout-btn[data-v-79ecf873],.theme-btn[data-v-79ecf873]{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;border:none;background:transparent;font-family:DM Sans,sans-serif;font-size:14px;cursor:pointer;width:100%;text-align:left;transition:all .2s}.theme-btn[data-v-79ecf873]{color:var(--text-sub)}.theme-btn[data-v-79ecf873]:hover{background:var(--nav-hover);color:var(--text)}.logout-btn[data-v-79ecf873]{color:#f87171}.logout-btn[data-v-79ecf873]:hover{background:hsla(0,91%,71%,.08)}.overlay[data-v-79ecf873]{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:40;backdrop-filter:blur(2px)}.main[data-v-79ecf873]{flex:1;display:flex;flex-direction:column;min-height:100vh;position:relative;z-index:1;overflow-x:hidden}.topbar[data-v-79ecf873]{position:sticky;top:0;z-index:30;background:var(--topbar-bg);border-bottom:1px solid var(--border);backdrop-filter:blur(16px);padding:0 24px;height:60px;display:flex;align-items:center;gap:16px;transition:background .4s,border-color .4s}.burger[data-v-79ecf873]{display:none;background:none;border:none;color:var(--text-sub);cursor:pointer;padding:4px}.topbar-title[data-v-79ecf873]{flex:1;font-family:Syne,sans-serif;font-size:18px;font-weight:700;color:var(--text)}.topbar-avatar[data-v-79ecf873]{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#4f8ef7,#a855f7);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;cursor:pointer;transition:transform .2s;box-shadow:0 0 20px rgba(79,142,247,.3)}.topbar-avatar[data-v-79ecf873]:hover{transform:scale(1.08)}.page[data-v-79ecf873]{padding:28px 24px;max-width:780px}.page.page-habits[data-v-79ecf873]{max-width:100%}.add-card[data-v-79ecf873],.section-card[data-v-79ecf873]{background:var(--card-bg);border:1px solid var(--border);border-radius:20px;padding:24px;backdrop-filter:blur(16px);box-shadow:var(--shadow);margin-bottom:24px;transition:background .4s,border-color .4s}.section-title[data-v-79ecf873]{font-family:Syne,sans-serif;font-size:15px;font-weight:700;color:var(--text);margin-bottom:16px;display:flex;align-items:center;gap:8px}.count-badge[data-v-79ecf873]{background:rgba(79,142,247,.15);color:#4f8ef7;font-size:12px;font-weight:600;padding:2px 8px;border-radius:20px;font-family:DM Sans,sans-serif}.add-form[data-v-79ecf873]{display:flex;gap:10px;align-items:flex-end}.add-inputs[data-v-79ecf873]{display:flex;gap:10px;flex:1;flex-wrap:wrap}.input[data-v-79ecf873]{background:var(--input-bg);border:1px solid var(--input-border);border-radius:10px;padding:11px 14px;color:var(--text);font-family:DM Sans,sans-serif;font-size:14px;outline:none;width:100%;transition:all .3s}.input[data-v-79ecf873]::-moz-placeholder{color:var(--text-sub)}.input[data-v-79ecf873]::placeholder{color:var(--text-sub)}.input[data-v-79ecf873]:focus{border-color:rgba(79,142,247,.5);box-shadow:0 0 0 3px rgba(79,142,247,.1)}.select[data-v-79ecf873]{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-color:rgba(79,142,247,.3);background:linear-gradient(135deg,rgba(79,142,247,.1),rgba(168,85,247,.06)),url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%234f8ef7' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat,no-repeat;background-position:0 0,right 12px center;background-size:auto,12px 12px;padding-right:34px;font-weight:600}.select[data-v-79ecf873]:hover{border-color:rgba(79,142,247,.45)}.select[data-v-79ecf873]:focus{border-color:rgba(79,142,247,.6);box-shadow:0 0 0 3px rgba(79,142,247,.14)}.select option[data-v-79ecf873]{color:#0f1729;background:#fff}.add-inputs .input[data-v-79ecf873]:first-child{flex:2;min-width:160px}.add-inputs .input[data-v-79ecf873]:last-child{flex:1;min-width:140px}.add-btn[data-v-79ecf873]{padding:11px 18px;border:none;border-radius:10px;background:linear-gradient(135deg,#4f8ef7,#a855f7);color:#fff;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;white-space:nowrap;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 16px rgba(79,142,247,.3);flex-shrink:0}.add-btn[data-v-79ecf873]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px rgba(79,142,247,.4)}.add-btn[data-v-79ecf873]:disabled{opacity:.6;cursor:not-allowed}.habits-list[data-v-79ecf873]{display:flex;flex-direction:column;gap:12px}.habits-layout[data-v-79ecf873]{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:start;width:100%}.habits-tables[data-v-79ecf873]{display:flex;flex-direction:column;gap:12px;min-width:0}.month-title[data-v-79ecf873]{font-family:Syne,sans-serif;font-size:16px;font-weight:700;color:var(--text)}.frequency-section[data-v-79ecf873]{display:flex;flex-direction:column;gap:8px}.frequency-title[data-v-79ecf873]{font-family:Syne,sans-serif;font-size:14px;font-weight:700;color:var(--text-sub)}.progress-cards[data-v-79ecf873]{display:flex;gap:12px;position:sticky;top:74px;margin-top:28px;align-self:start;justify-self:end}.progress-card[data-v-79ecf873]{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:14px 12px;width:188px;display:flex;flex-direction:column;align-items:center;gap:10px}.progress-title[data-v-79ecf873]{font-family:Syne,sans-serif;font-size:13px;font-weight:700;color:var(--text);text-align:center}.progress-ring-wrap[data-v-79ecf873]{position:relative;width:122px;height:122px;display:flex;align-items:center;justify-content:center}.progress-ring[data-v-79ecf873]{width:116px;height:116px;transform:rotate(-90deg)}.progress-bg[data-v-79ecf873]{fill:none;stroke:var(--day-border);stroke-width:10}.progress-value[data-v-79ecf873]{fill:none;stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset .35s ease,stroke .35s ease}.progress-center[data-v-79ecf873]{position:absolute;inset:14px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(79,142,247,.06);border:1px solid var(--border)}.progress-percent[data-v-79ecf873]{font-family:Syne,sans-serif;font-size:19px;font-weight:700;line-height:1;letter-spacing:.2px;font-variant-numeric:tabular-nums}.progress-meta[data-v-79ecf873]{color:var(--text-sub);font-size:12px;font-weight:600;letter-spacing:.15px}.month-table-wrap[data-v-79ecf873]{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;overflow-x:auto;overflow-y:hidden;box-shadow:var(--shadow);scrollbar-width:none;-ms-overflow-style:none}.month-table-wrap[data-v-79ecf873]::-webkit-scrollbar{width:0;height:0}.month-table[data-v-79ecf873]{width:100%;border-collapse:collapse;min-width:900px}.month-table td[data-v-79ecf873],.month-table th[data-v-79ecf873]{border-bottom:1px solid var(--border)}.month-table tbody tr:last-child td[data-v-79ecf873]{border-bottom:none}.month-table tbody tr:last-child td[data-v-79ecf873]:first-child{border-bottom-left-radius:14px}.month-table tbody tr:last-child td[data-v-79ecf873]:last-child{border-bottom-right-radius:14px}.action-col[data-v-79ecf873],.day-col[data-v-79ecf873],.habit-col[data-v-79ecf873]{font-size:12px;font-weight:700;color:var(--text-sub);background:rgba(79,142,247,.08);padding:10px 8px;text-align:center}.action-col[data-v-79ecf873]{min-width:84px}.habit-col[data-v-79ecf873]{text-align:left;min-width:240px}.day-col.today[data-v-79ecf873]{color:#4f8ef7}.habit-cell[data-v-79ecf873]{background:var(--card-bg);min-width:240px}.habit-cell-content[data-v-79ecf873]{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;min-height:52px}.habit-main[data-v-79ecf873]{min-width:0}.edit-btn[data-v-79ecf873]{background:rgba(79,142,247,.12);border:1px solid rgba(79,142,247,.35);color:#4f8ef7;border-radius:8px;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.edit-btn[data-v-79ecf873]:hover{background:rgba(79,142,247,.2);transform:translateY(-1px)}.action-cell[data-v-79ecf873]{width:84px;min-width:84px;text-align:center;background:var(--card-bg)}.status-cell[data-v-79ecf873]{position:relative;width:38px;min-width:38px;text-align:center;font-size:15px;font-weight:700;color:#f87171;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background .2s,color .2s;vertical-align:middle}.status-mark[data-v-79ecf873]{display:flex;align-items:center;justify-content:center;min-height:44px;padding:2px 14px 10px 2px}.comment-chip[data-v-79ecf873]{position:absolute;bottom:3px;right:2px;width:16px;height:16px;padding:0;border:none;border-radius:5px;background:rgba(79,142,247,.12);color:var(--text-sub);cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:0;transition:background .2s,color .2s,transform .15s;z-index:2}.comment-chip[data-v-79ecf873]:hover{background:rgba(79,142,247,.22);color:#4f8ef7;transform:scale(1.06)}.comment-chip.active[data-v-79ecf873]{background:rgba(79,142,247,.28);color:#4f8ef7}.status-cell.has-comment:not(.done) .comment-chip[data-v-79ecf873]{color:#4f8ef7}.status-cell[data-v-79ecf873]:hover{background:rgba(79,142,247,.08)}.status-cell.done[data-v-79ecf873]{color:#4ade80}.status-cell.today[data-v-79ecf873]{background:rgba(79,142,247,.08)}.empty-state[data-v-79ecf873],.loading-state[data-v-79ecf873]{padding:48px;text-align:center;color:var(--text-sub);font-size:14px;display:flex;flex-direction:column;align-items:center;gap:12px}.habit-name[data-v-79ecf873]{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.delete-btn[data-v-79ecf873]{background:none;border:none;cursor:pointer;color:var(--text-sub);padding:6px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;margin:0 auto}.delete-btn[data-v-79ecf873]:hover{color:#f87171;background:hsla(0,91%,71%,.1)}.delete-btn.solid[data-v-79ecf873]{background:hsla(0,91%,71%,.12);border:1px solid hsla(0,91%,71%,.35);color:#f87171}.habit-delete-modal-backdrop[data-v-79ecf873]{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;z-index:120;padding:16px}.habit-delete-modal[data-v-79ecf873]{width:min(440px,100%);background:var(--card-bg);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:18px}.habit-delete-modal h4[data-v-79ecf873]{font-family:Syne,sans-serif;font-size:18px;color:var(--text);margin-bottom:10px}.habit-delete-modal p[data-v-79ecf873]{color:var(--text-sub);font-size:14px;margin-bottom:16px}.comment-modal[data-v-79ecf873]{width:min(440px,100%);background:var(--card-bg);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:18px}.comment-modal h4[data-v-79ecf873]{font-family:Syne,sans-serif;font-size:18px;color:var(--text);margin-bottom:8px}.comment-modal-sub[data-v-79ecf873]{color:var(--text-sub);font-size:14px;margin-bottom:14px;line-height:1.45}.comment-modal-sub strong[data-v-79ecf873]{color:var(--text);font-weight:600}.comment-textarea[data-v-79ecf873]{resize:vertical;min-height:100px;font-family:DM Sans,sans-serif;line-height:1.45;margin-bottom:10px}.comment-modal-hint[data-v-79ecf873]{font-size:12px;color:var(--text-sub);line-height:1.4;margin-bottom:14px;margin-top:-4px}.comment-save-btn[data-v-79ecf873]{padding:10px 20px;border:none;border-radius:10px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#5b6ef5;background-image:linear-gradient(135deg,#4f8ef7,#9333ea);color:#fff;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s,filter .2s;box-shadow:0 4px 14px rgba(79,142,247,.45);display:inline-flex;align-items:center;justify-content:center;min-width:120px;opacity:1}.comment-save-btn[data-v-79ecf873]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px rgba(79,142,247,.55);filter:brightness(1.03)}.comment-save-btn[data-v-79ecf873]:disabled{opacity:.85;cursor:not-allowed;filter:grayscale(.08) brightness(.95)}.comment-save-btn .spinner[data-v-79ecf873]{border-color:hsla(0,0%,100%,.35);border-top-color:#fff}.habit-delete-actions[data-v-79ecf873]{display:flex;justify-content:flex-end;gap:10px}.profile-card[data-v-79ecf873]{background:var(--card-bg);border:1px solid var(--border);border-radius:20px;padding:28px 24px;display:flex;align-items:center;gap:20px;margin-bottom:20px;box-shadow:var(--shadow);backdrop-filter:blur(16px);transition:background .4s,border-color .4s}.profile-avatar[data-v-79ecf873]{width:64px;height:64px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,#4f8ef7,#a855f7);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff;box-shadow:0 0 30px rgba(79,142,247,.3)}.profile-name[data-v-79ecf873]{font-family:Syne,sans-serif;font-size:20px;font-weight:700;color:var(--text)}.profile-email[data-v-79ecf873]{font-size:14px;color:var(--text-sub);margin-top:2px}.edit-form[data-v-79ecf873]{display:flex;flex-direction:column;gap:16px}.field-row[data-v-79ecf873]{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field[data-v-79ecf873]{display:flex;flex-direction:column;gap:6px}.field label[data-v-79ecf873]{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-label)}.optional[data-v-79ecf873]{font-size:10px;text-transform:none;letter-spacing:0;color:var(--text-sub);font-weight:400}.required[data-v-79ecf873]{color:#f87171}.save-btn[data-v-79ecf873]{padding:12px;border:none;border-radius:12px;background:linear-gradient(135deg,#4f8ef7,#a855f7);color:#fff;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 16px rgba(79,142,247,.3);margin-top:4px}.save-btn[data-v-79ecf873]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px rgba(79,142,247,.4)}.save-btn[data-v-79ecf873]:disabled{opacity:.6;cursor:not-allowed}.danger-card[data-v-79ecf873]{border-color:hsla(0,91%,71%,.2)}.danger-title[data-v-79ecf873]{color:#f87171}.danger-desc[data-v-79ecf873]{font-size:13px;color:var(--text-sub);margin-bottom:16px;margin-top:-8px}.danger-btn[data-v-79ecf873]{padding:10px 20px;border:1px solid hsla(0,91%,71%,.4);border-radius:10px;background:hsla(0,91%,71%,.08);color:#f87171;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.danger-btn[data-v-79ecf873]:hover:not(:disabled){background:hsla(0,91%,71%,.15);border-color:hsla(0,91%,71%,.6)}.danger-btn[data-v-79ecf873]:disabled{opacity:.6;cursor:not-allowed}.delete-confirm[data-v-79ecf873]{display:flex;flex-direction:column;gap:12px}.confirm-actions[data-v-79ecf873]{display:flex;gap:10px}.cancel-btn[data-v-79ecf873]{padding:10px 20px;border:1px solid var(--border);border-radius:10px;background:var(--input-bg);color:var(--text-sub);font-family:DM Sans,sans-serif;font-size:14px;cursor:pointer;transition:all .2s}.cancel-btn[data-v-79ecf873]:hover{color:var(--text)}.error-msg[data-v-79ecf873]{color:#f87171;font-size:13px;padding:10px 12px;background:hsla(0,91%,71%,.08);border:1px solid hsla(0,91%,71%,.2);border-radius:8px;animation:shake-79ecf873 .4s ease}@keyframes shake-79ecf873{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.success-msg[data-v-79ecf873]{color:#4ade80;font-size:13px;padding:10px 12px;background:rgba(74,222,128,.08);border:1px solid rgba(74,222,128,.2);border-radius:8px}.spinner[data-v-79ecf873]{display:inline-block;width:16px;height:16px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin-79ecf873 .7s linear infinite;vertical-align:middle}.spinner.big[data-v-79ecf873]{width:32px;height:32px;border-width:3px;border-color:var(--input-border);border-top-color:#4f8ef7}@keyframes spin-79ecf873{to{transform:rotate(1turn)}}.page-fade-enter-active[data-v-79ecf873]{transition:all .3s ease}.page-fade-leave-active[data-v-79ecf873]{transition:all .2s ease}.page-fade-enter-from[data-v-79ecf873]{opacity:0;transform:translateY(12px)}.page-fade-leave-to[data-v-79ecf873]{opacity:0;transform:translateY(-8px)}.habit-item-enter-active[data-v-79ecf873]{transition:all .35s cubic-bezier(.34,1.2,.64,1)}.habit-item-leave-active[data-v-79ecf873]{transition:all .2s ease}.habit-item-enter-from[data-v-79ecf873]{opacity:0;transform:translateY(16px)}.habit-item-leave-to[data-v-79ecf873]{opacity:0;transform:translateX(-16px)}@media (max-width:768px){.sidebar[data-v-79ecf873]{position:fixed;left:-260px;top:0;height:100vh;width:240px;transition:left .3s cubic-bezier(.34,1.2,.64,1);box-shadow:none}.sidebar.open[data-v-79ecf873]{left:0;box-shadow:4px 0 40px rgba(0,0,0,.3)}.sidebar-close[data-v-79ecf873]{display:flex}.overlay[data-v-79ecf873]{display:block}.burger[data-v-79ecf873]{display:flex}.main[data-v-79ecf873]{width:100%}.page[data-v-79ecf873]{padding:20px 16px}.add-form[data-v-79ecf873]{flex-direction:column}.add-btn[data-v-79ecf873]{width:100%;justify-content:center}.habit-cell[data-v-79ecf873],.habit-col[data-v-79ecf873]{min-width:180px}.month-table[data-v-79ecf873]{min-width:760px}.habits-layout[data-v-79ecf873]{grid-template-columns:1fr}.progress-cards[data-v-79ecf873]{position:static;margin-top:0;width:100%;justify-content:center;gap:10px;flex-wrap:wrap}.progress-card[data-v-79ecf873]{width:min(260px,100%);flex-direction:row;justify-content:center;gap:14px}.progress-title[data-v-79ecf873]{display:none}.progress-ring-wrap[data-v-79ecf873]{width:88px;height:88px}.progress-ring[data-v-79ecf873]{width:84px;height:84px}.progress-percent[data-v-79ecf873]{font-size:15px}.field-row[data-v-79ecf873]{grid-template-columns:1fr}}@media (max-width:480px){.topbar[data-v-79ecf873]{padding:0 16px}.profile-card[data-v-79ecf873]{flex-direction:column;text-align:center}}*{box-sizing:border-box;margin:0;padding:0}#app,body{min-height:100vh}#app{font-family:DM Sans,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background .4s ease}#app.dark{background:#050508}#app.light{background:#f0f4ff}