.shiny-text{color:#b5b5b5a4;background:linear-gradient(120deg,#fff0 40%,#fffc 50%,#fff0 60%) 0 0/200% 100%;-webkit-background-clip:text;background-clip:text;animation:5s linear infinite shiny-text-shine;display:inline-block}@keyframes shiny-text-shine{0%{background-position:100%}to{background-position:-100%}}.shiny-text.disabled{animation:none}.magic-rings-container{width:100%;height:100%}.login-aurora-bg{z-index:-1;pointer-events:none;position:fixed;inset:0;overflow:hidden}.login-aurora-bg:before,.login-aurora-bg:after{content:"";will-change:transform;border-radius:50%;position:absolute}.login-aurora-bg:before{filter:blur(40px);background:radial-gradient(circle,#ff7a302e,#0000 60%);width:600px;height:600px;animation:12s ease-in-out infinite login-aura-drift-top;top:-200px;left:50%;transform:translate(-50%)}.login-aurora-bg:after{filter:blur(60px);background:radial-gradient(circle,#60a5fa1f,#0000 60%);width:500px;height:500px;animation:15s ease-in-out infinite reverse login-aura-drift-bot;bottom:-200px;right:10%}@keyframes login-aura-drift-top{0%,to{transform:translate(-50%)scale(1)}50%{transform:translate(-50%,30px)scale(1.05)}}@keyframes login-aura-drift-bot{0%,to{transform:translate(0)scale(1)}50%{transform:translate(-20px,-30px)scale(1.04)}}html[data-theme=light] .login-aurora-bg:before{background:radial-gradient(circle,#ff7a301a,#0000 60%)}html[data-theme=light] .login-aurora-bg:after{background:radial-gradient(circle,#60a5fa14,#0000 60%)}@media (prefers-reduced-motion:reduce){.login-aurora-bg:before,.login-aurora-bg:after{animation:none}}.login-page{z-index:0;position:relative}.login-page .login-logo{margin-left:auto;margin-right:auto;display:block}.login-logo-wrap{justify-content:center;align-items:center;width:260px;height:260px;margin:0 auto -48px;display:flex;position:relative}.login-logo-magic-rings{pointer-events:none;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle closest-side,#000 50%,#0000 100%);mask-image:radial-gradient(circle closest-side,#000 50%,#0000 100%)}.login-logo-wrap .login-logo{z-index:1;width:96px;height:96px;margin:0;position:relative}@media (width>=768px){.login-logo-wrap{width:300px;height:300px}.login-logo-wrap .login-logo{width:112px;height:112px}}@media (prefers-reduced-motion:reduce){.login-logo-magic-rings{display:none}}.login-title-animated{gap:.02em;display:inline-flex}.login-title-letter{opacity:0;animation:.9s cubic-bezier(.16,1,.3,1) forwards loginTitleReveal;animation-delay:calc(var(--letter-index,0) * 80ms);will-change:transform, opacity;display:inline-block;transform:translateY(24px)}@keyframes loginTitleReveal{0%{opacity:0;filter:blur(6px);transform:translateY(24px)}60%{opacity:1;filter:blur()}to{opacity:1;filter:blur();transform:translateY(0)}}.login-page .shiny-text{color:#ffe3a8d4;background:linear-gradient(120deg,#ffecb300 40%,#ffdf80f2 50%,#ffecb300 60%);-webkit-background-clip:text;background-clip:text}.login-page .login-card,.login-page .pwa-install-card,.login-page .feature-card{box-shadow:0 18px 50px -12px #00000059}@media (prefers-reduced-motion:reduce){.login-title-letter{opacity:1;animation:none;transform:none}}.habit-progress-btn{cursor:pointer;border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--text-primary);border-radius:20px;justify-content:center;align-items:center;min-width:80px;padding:8px 14px;font-family:inherit;font-size:13px;line-height:1;transition:border-color .25s,color .25s;display:inline-flex;position:relative;overflow:hidden}.habit-progress-btn.complete{color:#4caf50;border-color:#4caf5073}.habit-progress-btn.partial{color:#4caf50;border-color:#4caf5040}.habit-progress-btn:hover{border-color:#4caf5059}.habit-progress-btn:active{transform:scale(.97)}.habit-progress-fill{pointer-events:none;border-radius:inherit;gap:2px;padding:2px;display:flex;position:absolute;inset:0}.habit-progress-bar{height:100%;width:var(--progress-percent,0%);background:#4caf5038;border-radius:999px;transition:width .35s cubic-bezier(.16,1,.3,1)}.habit-progress-label{z-index:1;white-space:nowrap;align-items:center;gap:6px;display:inline-flex;position:relative}.habit-progress-count{opacity:.75;font-variant-numeric:tabular-nums;letter-spacing:.02em;font-size:11px}@media (prefers-reduced-motion:reduce){.habit-progress-btn,.habit-progress-bar{transition:none!important}.habit-progress-btn:active{transform:none}}.siba-step-indicator-row{align-items:center;width:100%;display:flex}.siba-step-indicator-group{flex:1;align-items:center;min-width:0;display:flex}.siba-step-indicator-group:last-child{flex:none}.siba-step-indicator{outline:none;flex-shrink:0;width:28px;height:28px;position:relative}.siba-step-indicator.clickable{cursor:pointer}.siba-step-indicator.clickable:focus-visible .siba-step-circle-inner{box-shadow:0 0 0 3px var(--accent-glow,#f9731640)}.siba-step-circle-inner{width:100%;height:100%;color:var(--text-secondary,#a3a3a3);border:1.5px solid var(--glass-border,#ffffff1f);background-color:#ffffff0f;border-radius:50%;justify-content:center;align-items:center;font-weight:600;transition:background-color .3s,color .3s,border-color .3s;display:flex}.siba-step-circle-inner[data-status=active]{background-color:var(--accent,#5f8aac);color:var(--accent,#5f8aac);border-color:var(--accent,#5f8aac)}.siba-step-circle-inner[data-status=complete]{background-color:var(--accent,#5f8aac);color:#fff;border-color:var(--accent,#5f8aac)}.siba-step-active-dot{background-color:#fff;border-radius:50%;width:10px;height:10px}.siba-step-check-icon{color:#fff;width:16px;height:16px}.siba-step-number{color:var(--text-secondary,#a3a3a3);font-size:12px;line-height:1}.siba-step-connector{background-color:var(--glass-border,#ffffff1f);border-radius:2px;flex:1;min-width:12px;height:2px;margin:0 6px;position:relative;overflow:hidden}.siba-step-connector-fill{background-color:var(--accent,#5f8aac);border-radius:2px;height:100%;position:absolute;top:0;left:0}@media (prefers-reduced-motion:reduce){.siba-step-circle-inner,.siba-step-connector-fill{transition:none!important}}.animated-card{will-change:transform, opacity}@media (prefers-reduced-motion:reduce){.animated-card{opacity:1!important;transform:none!important}}.onboarding-aurora-bg{z-index:-1;pointer-events:none;position:fixed;inset:0;overflow:hidden}.onboarding-aurora-bg:before,.onboarding-aurora-bg:after{content:"";will-change:transform;border-radius:50%;position:absolute}.onboarding-aurora-bg:before{filter:blur(40px);background:radial-gradient(circle,#ff7a302e,#0000 60%);width:600px;height:600px;animation:12s ease-in-out infinite onboarding-aura-drift-top;top:-200px;left:50%;transform:translate(-50%)}.onboarding-aurora-bg:after{filter:blur(60px);background:radial-gradient(circle,#60a5fa1f,#0000 60%);width:500px;height:500px;animation:15s ease-in-out infinite reverse onboarding-aura-drift-bot;bottom:-200px;right:10%}@keyframes onboarding-aura-drift-top{0%,to{transform:translate(-50%)scale(1)}50%{transform:translate(-50%,30px)scale(1.05)}}@keyframes onboarding-aura-drift-bot{0%,to{transform:translate(0)scale(1)}50%{transform:translate(-20px,-30px)scale(1.04)}}html[data-theme=light] .onboarding-aurora-bg:before{background:radial-gradient(circle,#ff7a301a,#0000 60%)}html[data-theme=light] .onboarding-aurora-bg:after{background:radial-gradient(circle,#60a5fa14,#0000 60%)}@media (prefers-reduced-motion:reduce){.onboarding-aurora-bg:before,.onboarding-aurora-bg:after{animation:none}}.onboarding-page{z-index:0;position:relative}.onboarding-welcome-logo-wrap{justify-content:center;align-items:center;width:220px;height:220px;margin:0 auto -36px;display:flex;position:relative}.onboarding-welcome-rings{pointer-events:none;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle closest-side,#000 50%,#0000 100%);mask-image:radial-gradient(circle closest-side,#000 50%,#0000 100%)}.onboarding-welcome-logo-wrap .onboarding-welcome-logo{z-index:1;position:relative}@media (width>=768px){.onboarding-welcome-logo-wrap{width:260px;height:260px}}.onboarding-loading-logo-wrap{justify-content:center;align-items:center;width:200px;height:200px;margin:0 auto;display:flex;position:relative}.onboarding-loading-rings{pointer-events:none;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle closest-side,#000 50%,#0000 100%);mask-image:radial-gradient(circle closest-side,#000 50%,#0000 100%)}.onboarding-loading-logo-wrap .onboarding-loading-logo{z-index:1;position:relative}@media (prefers-reduced-motion:reduce){.onboarding-welcome-rings,.onboarding-loading-rings{display:none}}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-ext-wght-normal-BOeWTOD4.woff2)format("woff2-variations");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-wght-normal-DqGufNeO.woff2)format("woff2-variations");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-ext-wght-normal-DlzME5K_.woff2)format("woff2-variations");unicode-range:U+1F??}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-wght-normal-CkhJZR-_.woff2)format("woff2-variations");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-vietnamese-wght-normal-CBcvBZtf.woff2)format("woff2-variations");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-ext-wght-normal-DO1Apj_S.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-wght-normal-Dx4kXJAl.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg-primary:#0b0b0e;--bg-secondary:#111115;--bg-card:#17171c;--text-primary:#fffffff5;--text-secondary:#fff9;--text-tertiary:#ffffff61;--accent:#ff7a30;--accent-hover:#ff8c4c;--accent-press:#e86916;--accent-glow:#ff7a3047;--accent-soft:#ff7a301f;--accent-ghost:#ff7a300f;--success:#4ade80;--success-soft:#4ade801f;--warning:#fbbf24;--warning-soft:#fbbf241f;--danger:#f87171;--danger-soft:#f871711f;--info:#60a5fa;--info-soft:#60a5fa1f;--border:#ffffff0f;--radius:16px;--radius-sm:12px;--aura-1:#ff7a3014;--aura-2:#60a5fa0a;--scroll-thumb:#ffffff14;--scroll-thumb-hover:#ffffff2e;--text-grad-from:#fff;--text-grad-to:#ffffff8c;--font-sans:"Inter Variable", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", "SF Mono", ui-monospace, monospace;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-io:cubic-bezier(.4, 0, .2, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--d-fast:.15s;--d-base:.25s;--d-slow:.5s;--bg-0:#0b0b0e;--bg-1:#111115;--bg-2:#17171c;--surface:#ffffff09;--surface-hover:#ffffff0f;--surface-strong:#ffffff14;--border-strong:#ffffff1a;--text-1:var(--text-primary);--text-2:var(--text-secondary);--text-3:var(--text-tertiary);--shadow-xs:0 1px 2px #0006;--shadow-sm:0 1px 2px #0000004d, 0 4px 12px #0000002e, inset 0 1px 0 #ffffff0a;--shadow-md:0 1px 2px #0000004d, 0 8px 24px #00000038, inset 0 1px 0 #ffffff0f;--shadow-lg:0 1px 2px #0000004d, 0 24px 48px #00000052, inset 0 1px 0 #ffffff14;--shadow-accent:0 0 0 1px #ff7a3040, 0 8px 24px #ff7a3040, inset 0 1px 0 #ffffff40;--shadow-glow:0 10px 40px var(--accent-glow);--r-xs:8px;--r-sm:12px;--r-md:16px;--r-lg:20px;--r-xl:28px;--r-full:999px;--s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;--s-8:32px;--s-10:40px;--s-12:48px;--s-16:64px;--glass-bg:#ffffff0a;--glass-border:#ffffff14;--glass-shadow:var(--shadow-lg);--glass-shadow-sm:var(--shadow-sm);--glass-shadow-md:var(--shadow-md);--glass-hover:#ffffff0f;--glass-bg-alt:#ffffff0d;--nav-bg:#0b0b0eb3;--nav-border:#ffffff0f;--nav-shadow:var(--shadow-lg);--modal-bg:#17171ce0;--modal-shadow:0 -2px 8px #0003, 0 -12px 48px #00000059, inset 0 1px 0 #ffffff14;--hover-overlay:#ffffff0d;--chat-time:#ffffff80}[data-theme=light]{--bg-primary:#f8f8f6;--bg-secondary:#f2f2ee;--bg-card:#fff;--text-primary:#121216f5;--text-secondary:#12121699;--text-tertiary:#1212166b;--accent:#ff7a30;--accent-hover:#e86916;--accent-glow:#ff7a3038;--accent-soft:#ff7a301a;--accent-ghost:#ff7a300d;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--border:#14141914;--aura-1:#ff7a301f;--aura-2:#60a5fa12;--scroll-thumb:#1414192e;--scroll-thumb-hover:#1414194d;--text-grad-from:#1a1a1f;--text-grad-to:#1a1a1f8c;--nav-bg:#ffffffeb;--glass-bg:#ffffffd9;--glass-border:#0000001f;--glass-shadow:var(--shadow-lg);--glass-shadow-sm:var(--shadow-sm);--glass-shadow-md:var(--shadow-md);--glass-hover:#0000000a;--glass-bg-alt:#0000000a;--nav-border:#00000014;--nav-shadow:0 -1px 8px #0000000f;--modal-bg:#fffffff2;--modal-shadow:0 -4px 24px #0000001a;--hover-overlay:#0000000a;--chat-time:#0006;scrollbar-color:#00000026 transparent;--bg-0:#f5f5f7;--bg-1:#fff;--bg-2:#fff;--surface:#ffffffd9;--surface-hover:#0000000a;--surface-strong:#0000000f;--border-strong:#00000029;--text-1:var(--text-primary);--text-2:var(--text-secondary);--text-3:#00000070;--shadow-sm:0 1px 2px #0f172a0a, 0 2px 4px #0f172a0a;--shadow-md:0 1px 3px #0f172a0f, 0 4px 12px #0f172a0f;--shadow-lg:0 2px 6px #0f172a14, 0 12px 32px #0f172a1a;--shadow-glow:0 10px 30px var(--accent-glow)}[data-theme=light] ::-webkit-scrollbar-thumb{background:#00000026}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#00000040}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:#ffffff26 transparent;margin:0;padding:0}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}html{overscroll-behavior-x:none}body{font-family:var(--font-sans);font-feature-settings:"ss01", "cv11", "tnum";font-variant-numeric:tabular-nums;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;min-height:100dvh;transition:background var(--d-slow) var(--ease-io), color var(--d-slow) var(--ease-io);line-height:1.45;overflow-x:hidden}body:before{content:"";pointer-events:none;background:radial-gradient(ellipse 900px 600px at 50% -10%, var(--aura-1), transparent 70%), radial-gradient(ellipse 700px 500px at 100% 100%, var(--aura-2), transparent 70%);z-index:0;transition:background var(--d-slow) var(--ease-io);position:fixed;inset:0}body>#root,body>.app,body>main{z-index:1;position:relative}body:has(.login-aurora-bg):before{display:none}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.num{font-variant-numeric:tabular-nums;letter-spacing:-.01em;font-feature-settings:"tnum", "ss01", "cv11"}button{cursor:pointer;font-family:inherit;font-size:inherit;border:none}input,textarea,select{font-family:inherit;font-size:inherit;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;width:100%;padding:12px 16px;transition:border-color .2s}textarea{resize:vertical;max-height:200px}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.btn{border-radius:var(--radius-sm);transition:background var(--d-fast) var(--ease-io), color var(--d-fast) var(--ease-io), border-color var(--d-fast) var(--ease-io), box-shadow var(--d-fast) var(--ease-io), transform var(--d-fast) var(--ease-io);letter-spacing:-.005em;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg, var(--accent-hover), var(--accent));color:#fff;box-shadow:var(--shadow-sm), 0 6px 20px var(--accent-glow)}.btn-primary:after{content:"";transition:transform var(--d-slow) var(--ease-io);pointer-events:none;background:linear-gradient(100deg,#0000 30%,#ffffff38 50%,#0000 70%);position:absolute;inset:0;transform:translate(-100%)}.btn-primary:hover:after{transform:translate(100%)}.btn-primary:hover{box-shadow:var(--shadow-md), 0 12px 32px var(--accent-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)scale(.97)}@media (prefers-reduced-motion:reduce){.btn,.btn-primary,.btn-primary:after{transition:none;transform:none!important}}.btn-danger{color:var(--danger);background:#d56b7026;border:1px solid #d56b7033}.btn-danger:hover{background:#d56b7040}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{color:var(--text-primary);background:var(--hover-overlay)}.back-button{color:var(--accent);background:0 0;align-items:center;gap:4px;margin-bottom:8px;padding:8px 0;font-size:14px;font-weight:500;transition:color .2s;display:inline-flex}.back-button:hover{color:var(--accent-hover)}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);padding:20px;transition:transform .2s,box-shadow .2s;position:relative}.page{padding:max(20px, env(safe-area-inset-top,0px)) max(20px, env(safe-area-inset-right,0px)) calc(90px + env(safe-area-inset-bottom,0px)) max(20px, env(safe-area-inset-left,0px));max-width:600px;animation:fadeIn var(--d-base) var(--ease-out);margin:0 auto;overflow-x:hidden}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-title{letter-spacing:-.022em;margin-bottom:20px;font-size:24px;font-weight:700}.bottom-nav{left:50%;right:auto;bottom:calc(env(safe-area-inset-bottom,0px) + 12px);background:var(--nav-bg);-webkit-backdrop-filter:blur(24px)saturate(180%);border:1px solid var(--border);border-top:1px solid var(--border);border-radius:var(--r-full);box-shadow:var(--shadow-lg);z-index:100;gap:4px;max-width:calc(100vw - 24px);padding:6px;display:flex;position:fixed;transform:translate(-50%)}.nav-item{z-index:1;width:48px;height:48px;color:var(--text-tertiary,var(--text-secondary));border-radius:var(--r-full);transition:color var(--d-base) var(--ease-io);background:0 0;border:none;place-items:center;padding:0;display:grid;position:relative}.nav-item:hover{color:var(--text-primary)}.nav-item.active{color:var(--accent)}.nav-item svg{width:22px;height:22px}.nav-item__label{display:none}.nav-pill{background:var(--accent-soft);border-radius:var(--r-full);opacity:0;pointer-events:none;z-index:0;width:0;height:0;transition:transform var(--d-base) var(--ease-out), width var(--d-base) var(--ease-out), height var(--d-base) var(--ease-out), opacity var(--d-fast) var(--ease-io);will-change:transform, width, height;position:absolute;top:0;left:0}@media (prefers-reduced-motion:reduce){.nav-pill{transition:opacity var(--d-fast) var(--ease-io)}}.task-card{background:var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:background var(--d-base) var(--ease-io), border-color var(--d-base) var(--ease-io), box-shadow var(--d-base) var(--ease-out), transform var(--d-fast) var(--ease-io);box-shadow:var(--shadow-sm);align-items:center;gap:14px;margin-bottom:10px;padding:16px 18px;display:flex}.task-card:hover{background:var(--surface-hover);border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.task-card:active{transform:scale(.985)}.task-card .status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.task-card .status-dot.TODO{background:var(--text-secondary)}.task-card .status-dot.DONE{background:var(--success)}.task-card .status-dot.OVERDUE{background:var(--danger,#ef4444);box-shadow:0 0 0 2px #ef444440}.task-card.overdue .task-name{color:var(--danger,#ef4444)}.task-card .task-info{flex:1;min-width:0}.task-card .task-name{white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.task-card .task-meta{color:var(--text-secondary);margin-top:2px;font-size:12px}.priority-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:6px;padding:3px 8px;font-size:10px;font-weight:600}.priority-badge.LOW{color:var(--text-secondary);background:#94a3b826}.priority-badge.MEDIUM{color:#60a5fa;background:#60a5fa26}.priority-badge.HIGH{color:#f87171;background:#f8717126}.priority-badge.URGENT{color:#fca5a5;background:#fca5a533}.category-section{margin-bottom:24px}.category-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.category-name{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:14px;font-weight:600}.fab{bottom:calc(env(safe-area-inset-bottom,0px) + 88px);border-radius:var(--r-full);background:linear-gradient(180deg, var(--accent-hover) 0%, var(--accent) 100%);color:#fff;z-index:50;width:56px;height:56px;transition:transform var(--d-fast) var(--ease-io), filter var(--d-fast) var(--ease-io), box-shadow var(--d-base) var(--ease-out);justify-content:center;align-items:center;font-size:28px;display:flex;position:fixed;right:20px;box-shadow:inset 0 1px #ffffff4d,inset 0 -1px #0000001f,0 2px 4px #00000052,0 8px 24px #ff7a3057}.fab:hover{filter:brightness(1.06);transform:scale(1.05);box-shadow:inset 0 1px #ffffff4d,0 4px 8px #00000052,0 16px 40px #ff7a3070}.fab:active{filter:brightness(.95);transform:scale(.94)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;padding-bottom:var(--keyboard-inset,0px);background:#0009;justify-content:center;align-items:flex-end;transition:padding-bottom .18s;animation:.2s fadeOverlay;display:flex;position:fixed;inset:0}@keyframes fadeOverlay{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--modal-bg);-webkit-backdrop-filter:blur(24px);border-radius:var(--radius) var(--radius) 0 0;border:1px solid var(--glass-border);box-shadow:var(--modal-shadow);padding:24px;padding-bottom:max(24px, env(safe-area-inset-bottom,0px));width:100%;max-width:600px;max-height:calc(80dvh - var(--keyboard-inset,0px));-webkit-overflow-scrolling:touch;animation:slideUp var(--d-base) var(--ease-out);border-bottom:none;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-title{margin-bottom:16px;font-size:18px;font-weight:700}.modal-field{margin-top:14px}.modal-field label{color:var(--text-secondary);margin-bottom:4px;font-size:13px;display:block}.modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.login-page{text-align:center;flex-direction:column;align-items:center;max-width:100vw;min-height:100dvh;padding:40px 0;animation:.5s fadeIn;display:flex;overflow-x:hidden}.login-hero{margin-bottom:32px;padding:0 24px}.login-logo{object-fit:contain;width:96px;height:96px;margin-bottom:16px;animation:3s ease-in-out infinite logoFloat}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.login-title{letter-spacing:-.035em;background:linear-gradient(180deg, var(--text-grad-from) 30%, var(--text-grad-to) 100%);color:#0000;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:clamp(38px,5vw,52px);font-weight:600;line-height:1.05}.login-subtitle{color:var(--accent);margin-bottom:8px;font-size:15px;font-weight:600}.login-description{color:var(--text-secondary);max-width:300px;font-size:14px;line-height:1.55}.login-features{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;box-sizing:border-box;gap:10px;width:100%;max-width:100%;margin-bottom:24px;padding:0 24px;display:flex;overflow-x:auto}.login-features::-webkit-scrollbar{display:none}.feature-card{background:var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:left;transition:transform var(--d-base) var(--ease-out), background var(--d-base) var(--ease-io), border-color var(--d-base) var(--ease-io), box-shadow var(--d-base) var(--ease-out);scroll-snap-align:start;min-width:200px;box-shadow:var(--shadow-sm,var(--glass-shadow-sm));flex-shrink:0;align-items:flex-start;gap:10px;padding:14px;display:flex}.feature-card:hover{background:var(--surface-hover);border-color:var(--border-strong);box-shadow:var(--shadow-md,var(--glass-shadow));transform:translateY(-2px)}.feature-icon{flex-shrink:0;margin-top:1px;font-size:22px}.feature-title{margin-bottom:2px;font-size:13px;font-weight:600}.feature-desc{color:var(--text-secondary);font-size:11px;line-height:1.4}@media (width>=768px){.login-page{max-width:720px;margin:0 auto;padding:60px 24px}.login-features{scroll-snap-type:none;flex-wrap:wrap;justify-content:center;padding:0;overflow-x:visible}.feature-card{scroll-snap-align:none;flex:200px;min-width:180px;max-width:240px}.login-card,.pwa-install-card,.login-description{max-width:440px}.login-logo{width:112px;height:112px}}.pwa-install-card{background:var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border);border-radius:24px;width:calc(100% - 48px);max-width:420px;margin-bottom:24px;padding:22px;box-shadow:0 1px 2px #00000040,0 12px 32px #0000002e,inset 0 1px #ffffff0a}.pwa-install-header{align-items:center;gap:14px;margin-bottom:14px;display:flex}.pwa-app-icon{object-fit:contain;width:48px;height:48px;box-shadow:0 4px 12px var(--accent-glow);border-radius:12px;flex-shrink:0}.pwa-install-title{margin-bottom:2px;font-size:15px;font-weight:700}.pwa-install-desc{color:var(--text-secondary);font-size:12px;line-height:1.4}.pwa-steps{counter-reset:pwa-step;margin:0 0 12px;padding:0;list-style:none}.pwa-steps li{counter-increment:pwa-step;color:var(--text-primary);padding:6px 0 6px 32px;font-size:13px;line-height:1.4;position:relative}.pwa-steps li:before{content:counter(pwa-step);background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;font-weight:700;display:flex;position:absolute;top:6px;left:0}.pwa-note{color:var(--text-secondary);background:var(--accent-ghost);border:1px solid #ff7a301f;border-radius:8px;padding:8px 12px;font-size:11px;line-height:1.45}.login-card{background:var(--surface);-webkit-backdrop-filter:blur(28px)saturate(180%);border:1px solid var(--border);border-radius:28px;width:calc(100% - 48px);max-width:420px;padding:32px 28px;position:relative;overflow:hidden;box-shadow:0 1px 2px #0000004d,0 24px 48px #00000038,inset 0 1px #ffffff0f}.login-card:before{content:"";background:radial-gradient(circle, var(--accent-soft), transparent 65%);pointer-events:none;z-index:0;width:240px;height:240px;position:absolute;top:-80px;right:-80px}.login-card>*{z-index:1;position:relative}.login-card__title{letter-spacing:-.025em;color:var(--text-primary);margin-bottom:6px;font-size:26px;font-weight:600;line-height:1.15}.login-card__sub{color:var(--text-secondary);margin-bottom:20px;font-size:14.5px;line-height:1.5}.login-form input{margin-bottom:12px}.login-form .btn{width:100%;margin-bottom:8px}.login-form .field{margin-bottom:12px}.login-form .field__input{margin-bottom:0}.login-telegram-btn{color:#fff;box-shadow:var(--shadow-sm);background:#229ed9}.login-telegram-btn:hover:not(:disabled){box-shadow:var(--shadow-md);background:#1e8ac4}.login-telegram-btn:disabled{opacity:.6;cursor:not-allowed}.login-tabs{background:var(--glass-bg-alt);border-radius:10px;gap:4px;margin-bottom:20px;padding:4px;display:flex}.login-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:9px 12px;font-size:13px;font-weight:500;transition:all .2s}.login-tab.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px #6366f166}.login-divider{color:var(--text-secondary);align-items:center;gap:12px;margin:16px 0;font-size:13px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}.google-btn{border-radius:var(--radius-sm);color:#333;background:#fff;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 20px;font-weight:600;transition:background .2s;display:flex}.google-btn:hover{color:#333;background:#f5f5f5}.empty-state{text-align:center;color:var(--text-secondary);padding:40px 20px}.empty-state svg{opacity:.3;width:64px;height:64px;margin-bottom:12px}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;margin:40px auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.sent-msg{color:var(--success);margin-top:12px;font-weight:600}.auth__divider{align-items:center;gap:var(--s-3);margin:var(--s-3) 0;color:var(--text-tertiary);letter-spacing:.08em;text-transform:uppercase;font-size:12px;font-weight:500;display:flex}.auth__divider:before,.auth__divider:after{content:"";background:var(--border);flex:1;height:1px}.login-consent{gap:var(--s-2);margin-top:4px;margin-bottom:var(--s-2);flex-direction:column;width:100%;display:flex}.login-consent__row{align-items:center;gap:var(--s-2);cursor:pointer;font-size:13px;line-height:1;display:flex}.login-consent__check{width:16px;height:16px;accent-color:var(--accent);flex-shrink:0;margin:0}.login-consent__link{color:var(--accent);line-height:1}.login-consent__link:hover{color:var(--accent-hover)}.form-error{color:var(--danger);animation:hero-info-in var(--d-base) var(--ease-out);margin:0;font-size:14px}.login-hint{color:var(--text-secondary);text-align:center;margin-top:-4px;font-size:12px}.login-hint--lg{margin-top:8px;font-size:14px}.login-hint__link{color:var(--accent)}.login-hint__link:hover{color:var(--accent-hover)}.login-toggle{text-align:center;color:var(--text-secondary);margin-top:4px;font-size:14px}.login-toggle__link{color:var(--accent)}.login-toggle__link:hover{color:var(--accent-hover)}.dashboard-stats{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px;display:grid}.dashboard-stats.four-col{grid-template-columns:repeat(4,1fr);gap:8px}.stat-card{background:var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);border-radius:var(--r-md);text-align:center;border:1px solid var(--border);box-shadow:var(--shadow-md);cursor:pointer;transition:background var(--d-base) var(--ease-io), border-color var(--d-base) var(--ease-io), box-shadow var(--d-base) var(--ease-out), transform var(--d-fast) var(--ease-io);padding:18px 14px}.stat-card:hover{background:var(--surface-hover);border-color:var(--border-strong);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.stat-card:active{transform:scale(.98)}.four-col .stat-card{padding:12px 6px}.stat-number{letter-spacing:-.024em;font-variant-numeric:tabular-nums;font-size:28px;font-weight:700}.four-col .stat-number{font-size:24px}.stat-label{color:var(--text-secondary);margin-top:4px;font-size:12px}.four-col .stat-label{font-size:11px}.dashboard-priorities{background:var(--surface);-webkit-backdrop-filter:blur(18px)saturate(170%);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s-4);margin-bottom:var(--s-4);box-shadow:var(--shadow-md)}.priorities-header{letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:var(--s-2);padding-bottom:var(--s-2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;font-size:11px;font-weight:600;display:flex}.priorities-col-labels{gap:0;display:flex}.priorities-col-labels span{text-align:center;letter-spacing:.05em;width:48px;font-size:11px;font-weight:600}.priority-row{border-radius:var(--r-sm);cursor:pointer;transition:background var(--d-fast) var(--ease-io), transform var(--d-fast) var(--ease-io);align-items:center;gap:10px;padding:8px 6px;display:flex}.priority-row:hover{background:var(--surface-hover)}.priority-row:active{transform:scale(.99)}.priority-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 6px}.priority-dot.URGENT{background:var(--danger);color:var(--danger)}.priority-dot.HIGH{color:#f59e0b;background:#f59e0b}.priority-dot.MEDIUM{background:var(--accent);color:var(--accent)}.priority-dot.LOW{color:#6b7280;box-shadow:none;background:#6b7280}.priority-row-label{color:var(--text-primary);flex:1;font-size:13.5px;font-weight:500}.priority-row-count{text-align:center;font-variant-numeric:tabular-nums;width:48px;color:var(--text-secondary);font-size:14px;font-weight:600}.priority-row-count.today{color:var(--accent)}.xp-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--glass-shadow-md);margin-bottom:16px;padding:12px 16px}.xp-card-top{align-items:center;gap:12px;display:flex}.xp-level-badge{background:var(--accent);width:42px;height:42px;box-shadow:0 2px 8px var(--accent-glow);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.xp-level-number{color:#fff;font-size:18px;font-weight:700}.xp-info{flex:1;min-width:0}.xp-points{color:var(--accent);font-size:15px;font-weight:700}.xp-progress-bar{background:var(--bg-card);border-radius:3px;height:6px;margin:4px 0;overflow:hidden}.xp-progress-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .3s}.xp-next-level{color:var(--text-secondary);font-size:11px}.xp-streak{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.xp-streak-fire{font-size:20px;line-height:1}.xp-streak-count{color:var(--warning);font-size:14px;font-weight:700}.filter-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;gap:6px;margin-bottom:20px;display:flex;overflow-x:auto}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{border-radius:var(--r-full);background:var(--surface);border:1px solid var(--border);height:32px;color:var(--text-secondary);white-space:nowrap;transition:background var(--d-fast) var(--ease-io), color var(--d-fast) var(--ease-io), border-color var(--d-fast) var(--ease-io), transform var(--d-fast) var(--ease-io);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;gap:6px;padding:0 14px;font-size:12.5px;font-weight:500;display:inline-flex}.filter-tab:not(.active):hover{background:var(--surface-hover);color:var(--text-primary);border-color:var(--border-strong)}.filter-tab.active{background:var(--accent-soft);color:var(--accent-hover);box-shadow:none;border-color:#ff7a304d}.filter-tab:active{transform:scale(.96)}@media (prefers-reduced-motion:reduce){.filter-tab{transition:none}.filter-tab:active{transform:none}}.filter-select{background:var(--glass-bg);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border-radius:10px;padding:8px 28px 8px 12px;font-family:inherit;font-size:13px}.filter-select.has-value{color:var(--text-primary);border-color:var(--accent);background-color:#f973161a}.checklist-item{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 0;display:flex}.checklist-item:last-of-type{border-bottom:none}.check-btn{border:2px solid var(--border);width:22px;height:22px;color:var(--success);background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex}.check-btn.checked{background:var(--success);border-color:var(--success);color:#fff}.habit-card{background:var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border);border-radius:var(--r-md);transition:background var(--d-base) var(--ease-io), border-color var(--d-base) var(--ease-io), box-shadow var(--d-base) var(--ease-out), transform var(--d-fast) var(--ease-io);box-shadow:var(--shadow-sm);align-items:center;gap:14px;margin-bottom:10px;padding:16px 18px;display:flex}.habit-card:hover{background:var(--surface-hover);border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.habit-check{border:2.5px solid var(--accent);color:#fff;cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;transition:all .2s;display:flex}.habit-check.done{color:#fff}.habit-name{font-size:15px;font-weight:500}.habit-meta{color:var(--text-secondary);margin-top:2px;font-size:12px}.streak-badge{color:#60a5fa;background:#60a5fa26;border-radius:6px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.settings-links{border-radius:var(--radius);overflow:hidden}.settings-link{background:var(--bg-secondary);border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text-primary);cursor:pointer;justify-content:space-between;align-items:center;padding:14px 16px;font-size:15px;transition:background .2s;display:flex}.settings-link:last-child{border-bottom:none}.sphere-grid{grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:380px;display:grid}.sphere-card{background:var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;box-shadow:var(--shadow-sm);transition:background var(--d-base) var(--ease-io), border-color var(--d-base) var(--ease-io), box-shadow var(--d-base) var(--ease-out), transform var(--d-fast) var(--ease-io);flex-direction:column;align-items:center;gap:10px;padding:18px 14px;display:flex}.sphere-card:hover{border-color:var(--sphere-color,var(--border-strong));background:var(--surface-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.sphere-card.selected{border-color:var(--sphere-color,var(--accent));background:var(--accent-soft);box-shadow:0 0 0 1px var(--sphere-color,var(--accent)), 0 8px 24px #ff7a302e}.sphere-icon{font-size:28px}.sphere-label{font-size:13px;font-weight:600}.sphere-card-custom{border-radius:var(--radius-sm);border:2px solid var(--accent);background:var(--accent-glow);box-shadow:0 0 16px var(--accent-glow);flex-direction:column;align-items:center;gap:8px;padding:16px;display:flex;position:relative}.sphere-edit-btn{cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:13px;transition:opacity .15s;position:absolute;top:5px;right:6px}.sphere-edit-btn:hover{opacity:1;background:var(--hover-overlay)}.sphere-card.inactive{opacity:.4;border-color:var(--border);background:var(--bg-secondary);box-shadow:none;filter:grayscale()}.sphere-card.inactive:hover{opacity:.6}.sphere-rating-badge{background:var(--sphere-color,var(--accent));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;margin-top:2px;font-size:11px;font-weight:700;display:inline-flex}.sphere-min-warning{color:var(--danger);text-align:center;margin-bottom:10px;font-size:13px;animation:2s ease-in-out fadeInOut}@keyframes fadeInOut{0%{opacity:0}15%{opacity:1}85%{opacity:1}to{opacity:0}}.onboarding-page{flex-direction:column;align-items:center;min-height:100dvh;padding:24px 16px 40px;display:flex}.onboarding-header{text-align:center;margin-bottom:24px}.onboarding-logo{object-fit:contain;border-radius:14px;width:56px;height:56px;margin-bottom:12px}.onboarding-title{letter-spacing:-.025em;background:linear-gradient(180deg, var(--text-grad-from) 30%, var(--text-grad-to) 100%);color:#0000;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:28px;font-weight:600;line-height:1.15}.onboarding-desc{color:var(--text-secondary);max-width:360px;margin:0 auto 4px;font-size:14.5px;line-height:1.5}.onboarding-desc-sub{color:var(--text-secondary);opacity:.75;max-width:360px;margin:0 auto;font-size:13px;line-height:1.5}.onboarding-list{flex-direction:column;gap:12px;width:100%;max-width:420px;display:flex}.onboarding-sphere-row{background:var(--surface);-webkit-backdrop-filter:blur(16px)saturate(160%);border:1px solid var(--border);border-radius:var(--radius-sm);transition:opacity .2s, background var(--d-fast) var(--ease-io), border-color var(--d-fast) var(--ease-io);padding:14px 16px;box-shadow:0 1px 2px #0003,inset 0 1px #ffffff0a}.onboarding-sphere-row.disabled{opacity:.4;filter:grayscale(.8)}.onboarding-sphere-top{justify-content:space-between;align-items:center;display:flex}.onboarding-checkbox-label{cursor:pointer;flex:1;align-items:center;gap:10px;display:flex}.onboarding-checkbox{width:20px;height:20px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.onboarding-sphere-icon{font-size:22px}.onboarding-sphere-name{font-size:15px;font-weight:600}.onboarding-rating-value{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:inline-flex}.onboarding-slider-wrap{height:42px;margin-top:10px;position:relative}.onboarding-slider-track{background:var(--border);pointer-events:none;border-radius:1px;height:2px;position:absolute;top:8px;left:9px;right:9px}.onboarding-slider-track-fill{height:100%;width:var(--slider-pct,0%);background:var(--slider-color,var(--accent));border-radius:1px;transition:width .15s;position:absolute;top:0;left:0}.onboarding-slider-dot{background:var(--border);border-radius:50%;width:6px;height:6px;transition:background .15s,transform .15s;position:absolute;top:50%;transform:translate(-50%,-50%)}.onboarding-slider-dot.active{background:var(--slider-color,var(--accent))}.onboarding-slider{appearance:none;z-index:2;background:0 0;outline:none;width:100%;height:18px;margin:0;padding:0;position:relative}.onboarding-slider::-webkit-slider-runnable-track{background:0 0;border:none;height:2px}.onboarding-slider::-moz-range-track{background:0 0;border:none;height:2px}.onboarding-slider::-webkit-slider-thumb{appearance:none;background:var(--slider-color,var(--accent));cursor:pointer;border:2.5px solid #fff;border-radius:50%;width:18px;height:18px;margin-top:-8px;box-shadow:0 1px 4px #00000040}.onboarding-slider::-moz-range-thumb{background:var(--slider-color,var(--accent));cursor:pointer;border:2.5px solid #fff;border-radius:50%;width:18px;height:18px;box-shadow:0 1px 4px #00000040}.onboarding-slider-labels{pointer-events:none;-webkit-user-select:none;user-select:none;height:14px;position:absolute;top:26px;left:9px;right:9px}.onboarding-slider-tick{color:var(--text-secondary);opacity:.5;font-size:10px;line-height:1;transition:all .15s;position:absolute;top:0;transform:translate(-50%)}.onboarding-slider-tick.active{color:var(--text-primary);opacity:1;font-weight:700;transform:translate(-50%)scale(1.15)}.onboarding-warning{color:var(--danger);text-align:center;margin-top:12px;font-size:13px}.onboarding-continue{width:100%;max-width:420px;margin-top:20px}.onboarding-stepper{justify-content:center;align-items:center;gap:0;width:100%;max-width:260px;margin-bottom:20px;display:flex}.onboarding-step-dot{background:var(--bg-card);border:2px solid var(--border);width:32px;height:32px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex;position:relative}.onboarding-step-dot:not(:last-child):after{content:"";background:var(--border);width:24px;height:2px;position:absolute;top:50%;left:100%;transform:translateY(-50%)}.onboarding-step-dot.active{background:var(--accent);border-color:var(--accent);color:#fff}.onboarding-step-dot.active:not(:last-child):after{background:var(--accent)}.onboarding-step-dot.current{box-shadow:0 0 0 4px var(--accent-glow)}.onboarding-back-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-self:flex-start;margin-bottom:8px;padding:4px 0;font-size:14px}.onboarding-back-btn:hover{color:var(--text-primary)}.onboarding-suggestions{width:100%;max-width:420px}.onboarding-sphere-group{margin-bottom:16px}.onboarding-group-title{align-items:center;gap:6px;margin-bottom:8px;font-size:15px;font-weight:600;display:flex}.onboarding-section-title{color:var(--text-secondary);margin-bottom:10px;font-size:15px;font-weight:600}.onboarding-suggestion-list{flex-direction:column;gap:6px;display:flex}.onboarding-suggestion-card{background:var(--surface);-webkit-backdrop-filter:blur(16px)saturate(160%);border:1px solid var(--border);cursor:pointer;transition:all var(--d-fast) var(--ease-io);border-radius:12px;align-items:center;gap:10px;padding:12px 14px;display:flex}.onboarding-suggestion-card:active{transform:scale(.98)}.onboarding-suggestion-card.selected{border-color:var(--accent);background:#6366f114}.onboarding-suggestion-check{width:18px;height:18px;accent-color:var(--accent);flex-shrink:0}.onboarding-suggestion-icon{flex-shrink:0;font-size:18px}.onboarding-suggestion-text{font-size:14px;font-weight:500;line-height:1.3}.onboarding-selected-count{text-align:center;color:var(--accent);margin-top:12px;font-size:13px;font-weight:600}.onboarding-buttons{gap:10px;width:100%;max-width:420px;margin-top:20px;display:flex}.onboarding-buttons .btn{flex:1}.btn-ghost{color:var(--text-secondary);border:1.5px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--bg-card);color:var(--text-primary)}.onboarding-skip-btn{min-width:100px;flex:none!important}.onboarding-challenge-scroll{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:12px;padding-bottom:8px;display:flex;overflow-x:auto}.onboarding-challenge-scroll::-webkit-scrollbar{height:4px}.onboarding-challenge-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.onboarding-challenge-card{scroll-snap-align:start;background:var(--surface);-webkit-backdrop-filter:blur(16px)saturate(160%);border:1px solid var(--border);cursor:pointer;min-width:240px;max-width:280px;transition:all var(--d-fast) var(--ease-io);border-radius:14px;flex-shrink:0;padding:14px;position:relative}.onboarding-challenge-card:active{transform:scale(.98)}.onboarding-challenge-card.selected{border-color:var(--accent);background:var(--accent-soft)}.onboarding-challenge-header{justify-content:space-between;align-items:flex-start;margin-bottom:6px;display:flex}.onboarding-challenge-name{flex:1;font-size:14px;font-weight:600;line-height:1.3}.onboarding-challenge-days{color:var(--text-secondary);background:var(--bg-secondary);border-radius:10px;flex-shrink:0;margin-left:8px;padding:2px 8px;font-size:12px}.onboarding-challenge-desc{color:var(--text-secondary);margin-bottom:8px;font-size:12px;line-height:1.4}.onboarding-challenge-habits{flex-wrap:wrap;gap:4px;display:flex}.onboarding-challenge-habit-tag{background:var(--bg-secondary);color:var(--text-secondary);border-radius:8px;padding:3px 8px;font-size:11px}.onboarding-challenge-check-indicator{border:2px solid var(--border);width:24px;height:24px;color:var(--text-secondary);background:var(--bg-card);border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;top:10px;right:10px}.onboarding-challenge-check-indicator.checked{background:var(--accent);border-color:var(--accent);color:#fff}.onboarding-welcome{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:60dvh;padding:60px 24px 40px;display:flex}.onboarding-welcome-logo{object-fit:contain;filter:drop-shadow(0 0 24px #f973164d);border-radius:20px;width:80px;height:80px}.onboarding-welcome-text{color:var(--text-secondary);max-width:360px;font-size:16px;line-height:1.6}.onboarding-welcome-text strong{background:linear-gradient(180deg, var(--text-grad-from) 30%, var(--text-grad-to) 100%);color:#0000;-webkit-background-clip:text;background-clip:text;font-weight:600}.onboarding-loading{z-index:9999;background:var(--bg-secondary);flex-direction:column;justify-content:center;align-items:center;gap:24px;padding:32px;display:flex;position:fixed;inset:0}.onboarding-loading-logo{object-fit:contain;filter:drop-shadow(0 0 20px #f973164d);border-radius:18px;width:72px;height:72px;animation:2s ease-in-out infinite logoPulse}@keyframes logoPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.08)}}.onboarding-loading-title{letter-spacing:-.02em;background:linear-gradient(180deg, var(--text-grad-from) 30%, var(--text-grad-to) 100%);color:#0000;text-align:center;-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:600}.onboarding-progress-wrapper{flex-direction:column;gap:8px;width:100%;max-width:280px;display:flex}.onboarding-progress-bar{background:var(--bg-card);border-radius:4px;width:100%;height:8px;overflow:hidden}.onboarding-progress-fill{background:linear-gradient(90deg, var(--accent-hover), var(--accent));height:100%;box-shadow:0 0 8px var(--accent-glow);border-radius:4px;transition:width .5s;position:relative}.onboarding-progress-fill:after{content:"";background:linear-gradient(90deg,#0000,#ffffff26,#0000);animation:1.5s infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skeleton{background:var(--glass-bg);flex-shrink:0;position:relative;overflow:hidden}.skeleton:after{content:"";background:linear-gradient(90deg, transparent 0%, var(--glass-hover) 50%, transparent 100%);animation:1.4s infinite shimmer;position:absolute;inset:0}.skeleton-row{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px;align-items:center;gap:12px;padding:12px 14px;display:flex}.skeleton-row-tall{align-items:flex-start;min-height:120px;padding:20px}@media (prefers-reduced-motion:reduce){.skeleton:after{animation:none}}::view-transition-old(root){animation-duration:.22s;animation-timing-function:cubic-bezier(.32,.72,0,1)}::view-transition-new(root){animation-duration:.22s;animation-timing-function:cubic-bezier(.32,.72,0,1)}.onboarding-progress-info{justify-content:space-between;align-items:center;display:flex}.onboarding-progress-label{color:var(--text-secondary);font-size:13px}.onboarding-progress-percent{color:var(--accent);font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.spheres-page{padding-bottom:120px}.spheres-list{flex-direction:column;gap:10px;width:100%;max-width:420px;margin:0 auto;display:flex}.spheres-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s-3) var(--s-4);-webkit-backdrop-filter:blur(18px)saturate(160%);box-shadow:var(--shadow-sm);transition:transform var(--d-fast) var(--ease-out), border-color var(--d-fast) var(--ease-out), box-shadow var(--d-fast) var(--ease-out), opacity .2s;justify-content:space-between;align-items:center;display:flex}.spheres-row:hover{border-color:var(--accent-soft,#a78bfa4d);box-shadow:var(--shadow-md);transform:translateY(-2px)}.spheres-row.disabled{opacity:.45;filter:grayscale(.8)}.spheres-left{cursor:pointer;flex:1;align-items:center;gap:10px;min-width:0;display:flex}.spheres-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.spheres-icon-btn{color:var(--text-secondary);cursor:pointer;opacity:.7;background:0 0;border:none;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:8px;font-size:20px;transition:opacity .15s;display:inline-flex}.spheres-icon-btn:hover{opacity:1}.spheres-icon-btn-danger:hover{filter:brightness(1.3)}.spheres-add-btn{max-width:420px;margin:var(--s-4) auto 0;display:block}.spheres-pick-list{gap:var(--s-2);margin-bottom:var(--s-3);flex-direction:column;display:flex}.spheres-pick-row{align-self:stretch;gap:var(--s-3);text-align:left;width:100%;padding:var(--s-2) var(--s-3)!important;justify-content:flex-start!important}.spheres-pick-icon{font-size:20px;line-height:1}.sphere-emoji-grid{grid-template-columns:repeat(5,1fr);gap:8px;display:grid}.sphere-emoji-btn{aspect-ratio:1;border:1px solid var(--border);background:var(--bg-primary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:0;font-size:20px;line-height:1;transition:transform .1s,border-color .15s,background .15s;display:flex}.sphere-emoji-btn:hover{transform:scale(1.08)}.sphere-emoji-btn.active{border-color:var(--accent);background:var(--accent-soft,#a78bfa26);box-shadow:0 0 0 2px var(--accent) inset}@media (width<=420px){.sphere-emoji-grid{grid-template-columns:repeat(4,1fr)}}.sphere-emoji-grid-compact{flex-wrap:wrap;gap:6px;display:flex}.sphere-emoji-grid-compact .sphere-emoji-btn,.sphere-emoji-btn-compact{aspect-ratio:auto;border-radius:6px;width:32px;height:32px;font-size:16px}@media (width<=420px){.sphere-emoji-grid-compact{grid-template-columns:none}}.spheres-edit-rating{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.spheres-rating-btn{border:1px solid var(--border);background:var(--bg-primary);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:8px;font-size:13px;font-weight:600;transition:all .15s}.spheres-rating-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.best-streak-badge{color:#f59e0b;background:#f59e0b26;border-radius:6px;margin-left:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.ai-markdown p{margin:0 0 8px}.ai-markdown p:last-child{margin-bottom:0}.ai-markdown ul,.ai-markdown ol{margin:4px 0;padding-left:20px}.ai-markdown li{margin:2px 0}.ai-markdown strong{font-weight:600}.ai-markdown em{font-style:italic}.ai-markdown code{background:#ffffff1a;border-radius:4px;padding:1px 5px;font-size:.95em}[data-theme=light] .ai-markdown code{background:#00000014}.ai-markdown pre{background:#0000004d;border-radius:8px;margin:8px 0;padding:10px;overflow-x:auto}[data-theme=light] .ai-markdown pre{background:#00000014}.ai-markdown pre code{background:0 0;padding:0}.ai-markdown h1,.ai-markdown h2,.ai-markdown h3{margin:8px 0 4px;font-size:15px;font-weight:600}.ai-markdown blockquote{border-left:3px solid var(--accent);color:var(--text-secondary);margin:8px 0;padding-left:12px}.habit-heatmap-panel{background:var(--bg-secondary);border:1px solid var(--border);border-radius:0 0 var(--radius-sm) var(--radius-sm);border-top:none;margin-top:-8px;margin-bottom:8px;padding:12px 10px}.year-heatmap-container{scrollbar-width:none;overflow-x:auto}.year-heatmap-container::-webkit-scrollbar{display:none}.year-heatmap-months{color:var(--text-secondary);gap:2px;height:14px;margin-bottom:4px;font-size:10px;display:grid}.year-heatmap-month{white-space:nowrap}.year-heatmap-grid{grid-template-rows:repeat(7,10px);grid-auto-flow:column;gap:2px;display:grid}.year-heatmap-cell{background:var(--glass-bg-alt);border-radius:2px;width:10px;height:10px}.year-heatmap-cell.partial{background:var(--accent-glow)}.year-heatmap-cell.done{background:var(--accent)}.year-heatmap-cell.future{border:1px solid var(--border);background:0 0}.year-heatmap-cell.empty,.year-heatmap-cell.missed{background:var(--glass-bg-alt)}.habit-strip-container{margin-bottom:8px}.habit-strip-label{color:var(--text-secondary);letter-spacing:.02em;margin-bottom:4px;font-size:11px}.habit-strip-grid{gap:3px;width:100%;display:flex}.habit-strip-cell{aspect-ratio:1;background:var(--glass-bg-alt);border-radius:3px;flex:1 1 0;min-width:0;max-width:14px;transition:background-color .2s}.habit-strip-cell.partial{background:var(--accent-glow)}.habit-strip-cell.done{background:var(--accent)}.habit-strip-cell.today{outline:1.5px solid var(--accent);outline-offset:1px}.habit-strip-legend{color:var(--text-secondary);opacity:.75;justify-content:space-between;margin-top:4px;font-size:10px;display:flex}.habit-year-toggle{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;margin:4px 0 0;padding:4px 0;font-family:inherit;font-size:12px;transition:color .2s;display:inline-flex}.habit-year-toggle:hover{color:var(--accent)}.habit-year-toggle-arrow{font-size:10px;transition:transform .25s cubic-bezier(.16,1,.3,1);display:inline-block}.habit-year-toggle-arrow.open{transform:rotate(180deg)}.year-heatmap-container{scroll-behavior:smooth;margin-top:8px;animation:.22s ease-out habitYearFadeIn}@keyframes habitYearFadeIn{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion:reduce){.year-heatmap-container,.habit-year-toggle-arrow,.habit-strip-cell{transition:none!important;animation:none!important}}.challenge-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px;padding:16px;transition:border-color .2s}.challenge-card.all-done{border-color:var(--success)}.challenge-card.completed{opacity:.6}.challenge-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:10px;display:flex}.challenge-name{font-size:16px;font-weight:600}.challenge-meta{color:var(--text-secondary);margin-top:2px;font-size:12px}.challenge-progress-bar{background:var(--glass-bg-alt);border-radius:3px;height:6px;margin-bottom:12px;overflow:hidden}.challenge-progress-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .3s}.challenge-habits{flex-direction:column;gap:6px;display:flex}.challenge-habit-row{align-items:center;gap:10px;display:flex}.challenge-habit-name{font-size:14px}.habit-check.small{border-width:2px;width:26px;height:26px;font-size:13px}.challenge-habit-select{flex-direction:column;gap:8px;max-height:200px;margin-top:8px;display:flex;overflow-y:auto}.challenge-habit-option{cursor:pointer;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;align-items:center;gap:10px;padding:8px 10px;font-size:14px;display:flex}.challenge-habit-option input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);flex-shrink:0}.lang-switcher{border-radius:var(--radius-sm);border:1px solid var(--border);display:flex;overflow:hidden}.lang-btn{color:var(--text-secondary);background:0 0;flex:1;padding:10px 16px;font-size:14px;font-weight:500;transition:all .2s}.lang-btn.active{background:var(--accent);color:#fff}.radar-card{padding:var(--s-6);background:var(--surface);-webkit-backdrop-filter:blur(24px)saturate(180%);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-md);margin-bottom:var(--s-4);position:relative;overflow:hidden}.radar-card:before{content:"";background:radial-gradient(circle, var(--accent-soft) 0%, transparent 70%);filter:blur(40px);pointer-events:none;opacity:.9;z-index:0;width:70%;height:70%;position:absolute;top:10%;left:50%;transform:translate(-50%)}.radar-card__head{margin-bottom:var(--s-4);z-index:1;justify-content:space-between;align-items:center;display:flex;position:relative}.radar-card__title{letter-spacing:-.015em;color:var(--text-primary);align-items:center;gap:10px;margin:0;font-size:18px;font-weight:600;display:flex}.radar-card__title--solo{letter-spacing:-.02em;font-size:19px}.radar-card__eyebrow{color:var(--text-tertiary);letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:600}.radar-card__body{z-index:1;position:relative}.info-btn{background:var(--surface);width:28px;height:28px;color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;transition:color var(--d-fast) var(--ease-io), background var(--d-fast) var(--ease-io), border-color var(--d-fast) var(--ease-io);border-radius:50%;place-items:center;padding:0;font-size:12px;font-weight:600;display:grid}.info-btn:hover{color:var(--text-primary);background:var(--surface-hover);border-color:var(--border-strong)}@keyframes radar-stroke-draw{0%{stroke-dashoffset:1400px;opacity:0}40%{opacity:1}to{stroke-dashoffset:0;opacity:1}}@keyframes radar-fade-in{0%{opacity:0}to{opacity:1}}@keyframes radar-dot-pop{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.radar-data-poly{stroke-dasharray:1400;animation:radar-stroke-draw 1.6s var(--ease-out) both;animation-delay:.3s}.radar-data-fill{opacity:0;animation:radar-fade-in .9s var(--ease-out) forwards;animation-delay:1.1s}.radar-dot{opacity:0;transform-origin:50%;animation:radar-dot-pop .45s var(--ease-spring) forwards}.radar-grid{stroke:var(--border);fill:none;transition:stroke var(--d-slow) var(--ease-io)}.radar-grid--outer{stroke:var(--border-strong);stroke-width:1px}.radar-axis{stroke:var(--border);stroke-width:.6px;transition:stroke var(--d-slow) var(--ease-io)}.radar-label{fill:var(--text-secondary);font-family:var(--font-family,var(--font));letter-spacing:.08em;text-transform:uppercase;font-size:10.5px;font-weight:600}.radar-value{fill:var(--text-primary);font-family:var(--font-family,var(--font));letter-spacing:-.01em;font-variant-numeric:tabular-nums;transition:fill var(--d-fast) var(--ease-io);font-size:13px;font-weight:600}.radar-sphere-group{cursor:pointer}.radar-sphere-group:hover .radar-label{fill:var(--text-primary)}.radar-sphere-group:hover .radar-value{fill:var(--accent)}.radar-dot-core{stroke:var(--bg-primary)}.radar-center{fill:var(--accent-soft);stroke:var(--accent-glow);stroke-width:.8px}@media (prefers-reduced-motion:reduce){.radar-data-poly{stroke-dasharray:0;opacity:1;animation:none}.radar-data-fill{opacity:1;animation:none}.radar-dot{opacity:1;animation:none;transform:none}}.radar-card__progress-wrap{margin-top:var(--s-5);padding-top:var(--s-5);border-top:1px solid var(--border);z-index:1;position:relative}.settings-link{background:var(--glass-bg);transition:background .2s}.settings-link:hover{background:var(--glass-hover)}.settings-link-label{align-items:center;gap:8px;display:flex}.friend-add-form{gap:10px;margin-bottom:16px;display:flex}.friend-email-input{border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:10px;flex:1;padding:10px 14px;font-size:14px}.friend-email-input::placeholder{color:var(--text-secondary)}.friend-send-btn{white-space:nowrap;padding:10px 20px;font-size:14px}.friend-status-msg{margin-bottom:12px;font-size:13px}.friend-status-msg.success{color:var(--accent)}.friend-status-msg.error{color:var(--danger)}.friend-section{margin-bottom:20px}.friend-section-title{color:var(--text-secondary);margin-bottom:10px;font-size:15px;font-weight:600}.friend-card{background:var(--bg-card);border-radius:12px;align-items:center;gap:12px;margin-bottom:8px;padding:12px 14px;display:flex}.friend-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:15px;font-weight:600;display:flex}.friend-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.friend-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.friend-email{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.friend-actions{flex-shrink:0;gap:6px;display:flex}.btn-small{border-radius:8px;padding:6px 12px;font-size:12px}.btn-accept{background:var(--accent);color:#fff;cursor:pointer;border:none}.btn-decline{color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;background:0 0}.friend-remove-btn{color:var(--text-secondary);font-size:12px}.friend-empty{color:var(--text-secondary);text-align:center;padding:24px 0;font-size:14px}.friend-badge{background:var(--danger);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:600;display:inline-flex}.friend-request-banner{background:var(--accent);color:#fff;text-align:center;cursor:pointer;border-radius:12px;margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:500;transition:opacity .2s}.friend-request-banner:hover{opacity:.9}.share-sent-badge{color:var(--success);padding:4px 10px;font-size:12px;font-weight:600}.sharing-offer-card .friend-email{color:var(--accent);font-weight:500}.share-friend-list{max-height:300px;overflow-y:auto}.share-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.transfer-badge{background:var(--warning,#f59e0b);color:#fff;border-radius:4px;margin-left:6px;padding:1px 6px;font-size:11px;font-weight:600;display:inline-block}.btn-secondary{background:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.collab-modal{max-height:80vh;overflow-y:auto}.collab-progress{align-items:center;gap:10px;margin-bottom:16px;display:flex}.collab-progress-bar{background:var(--bg-card);border-radius:4px;flex:1;height:8px;overflow:hidden}.collab-progress-fill{background:var(--accent);border-radius:4px;height:100%;transition:width .3s}.collab-progress-text{color:var(--accent);text-align:right;min-width:40px;font-size:14px;font-weight:600}.collab-section-title{color:var(--text-secondary);margin-bottom:8px;font-size:14px;font-weight:600}.collab-members{margin-bottom:12px}.collab-member-card{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 0;display:flex}.collab-member-card:last-child{border-bottom:none}.collab-owner-badge{color:var(--accent);margin-left:6px;font-size:10px;font-weight:500}.collab-invite-section{border-top:1px solid var(--border);margin-top:12px;padding-top:12px}.sidebar-logo{display:none}@media (width>=1024px){.bottom-nav{border:none;border-right:1px solid var(--nav-border);background:var(--nav-bg);width:220px;max-width:220px;height:100vh;box-shadow:var(--nav-shadow);border-radius:0;flex-direction:column;justify-content:flex-start;align-items:stretch;gap:2px;padding:0;position:fixed;inset:0 auto auto 0;overflow-y:auto;transform:none}.nav-item{border-radius:var(--r-sm)}.sidebar-logo{border-bottom:1px solid var(--nav-border);justify-content:center;align-items:center;margin-bottom:8px;padding:20px 24px 16px;display:flex}.sidebar-logo-img{object-fit:contain;width:auto;height:40px}.nav-item{letter-spacing:-.005em;border-radius:0;flex-direction:row;justify-content:flex-start;align-items:center;gap:12px;width:100%;height:auto;padding:12px 24px;font-size:14px;font-weight:500;display:flex}.nav-pill{display:none}.nav-item svg{flex-shrink:0;width:20px;height:20px}.nav-item__label{display:inline}.nav-item.active{border-left:3px solid var(--accent);background:#6366f11a;padding-left:21px}.nav-item:hover:not(.active){background:var(--hover-overlay)}.page{max-width:960px;margin-left:220px;padding:32px 40px}.page-title{letter-spacing:-.026em;font-size:28px}.dashboard-stats.four-col{gap:16px}.four-col .stat-card{padding:16px 12px}.four-col .stat-number{font-size:28px}.four-col .stat-label{font-size:12px}.task-card,.habit-card,.challenge-card,.friend-card,.card{padding:14px 20px;transition:border-color .2s,transform .15s}.task-card:hover,.habit-card:hover,.challenge-card:hover,.friend-card:hover,.card:hover{border-color:var(--glass-border);transform:translateY(-1px)}.modal-overlay{align-items:center}.modal-content{border-radius:var(--radius);border-bottom:1px solid var(--glass-border);max-width:520px;box-shadow:var(--glass-shadow)}input,textarea,select{font-size:14px}.category-section{max-width:none}.login-page{margin-left:auto;margin-right:auto}.onboarding-page{max-width:600px;margin-left:auto;margin-right:auto}.onboarding-welcome,.onboarding-loading{margin-left:auto;margin-right:auto}.fab{bottom:32px;right:max(32px,50% - 370px)}}.admin-stats{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px;display:grid}.admin-stat-card{background:var(--bg-card);border-radius:var(--radius-sm);text-align:center;padding:12px}.admin-stat-value{letter-spacing:-.022em;font-variant-numeric:tabular-nums;color:var(--accent);font-size:24px;font-weight:700}.admin-stat-label{color:var(--text-secondary);margin-top:4px;font-size:11px}.admin-user-row{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;padding:12px 0;transition:opacity .15s;display:flex}.admin-user-row:hover{opacity:.8}.admin-user-row:last-child{border-bottom:none}.admin-role-badge{text-transform:uppercase;border-radius:8px;padding:2px 8px;font-size:11px;font-weight:600}.admin-role-user{color:var(--text-secondary);background:#aaaaaa26}.admin-role-support{color:var(--accent);background:#f9731633}.admin-role-manager{color:var(--warning);background:#f59e0b33}.admin-role-admin{color:var(--danger);background:#d56b7033}.admin-blocked-badge{color:var(--danger);background:#d56b7033;border-radius:8px;padding:2px 8px;font-size:11px;font-weight:600}.chat-container{flex-direction:column;height:calc(100dvh - 140px);display:flex}.chat-messages{flex-direction:column;flex:1;gap:8px;padding:12px 0;display:flex;overflow-y:auto}.chat-bubble{word-wrap:break-word;border-radius:16px;max-width:80%;padding:10px 14px;font-size:14px;line-height:1.4}.chat-bubble-other{background:var(--bg-card);border-bottom-left-radius:4px;align-self:flex-start}.chat-bubble-self{background:var(--accent);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.chat-bubble-system{color:var(--text-secondary);text-align:center;background:#aaaaaa1a;border-radius:12px;align-self:center;padding:6px 14px;font-size:13px}.chat-bubble-time{color:var(--chat-time);margin-top:4px;font-size:10px}.chat-bubble-other .chat-bubble-time{color:var(--text-secondary)}.chat-status{margin-left:4px;font-size:10px;display:inline-block}.chat-status-read{color:var(--accent)}.chat-input-container{border-top:1px solid var(--border);gap:8px;padding:12px 0;display:flex}.chat-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);resize:none;flex:1;min-height:40px;max-height:120px;padding:10px 14px;font-family:inherit;font-size:14px}.chat-input:focus{border-color:var(--accent);outline:none}.chat-send-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:0 16px;font-size:14px;font-weight:500;transition:background .15s}.chat-send-btn:hover{background:var(--accent-hover)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.typing-indicator{color:var(--text-secondary);align-items:center;gap:4px;padding:4px 0;font-size:13px;display:flex}.typing-dot{background:var(--text-secondary);border-radius:50%;width:6px;height:6px;animation:1.4s infinite typingBounce}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}.conversation-list{flex-direction:column;gap:2px;display:flex}.conversation-item{border-radius:var(--radius-sm);cursor:pointer;align-items:center;padding:12px;transition:background .15s;display:flex}.conversation-item:hover,.conversation-item.active{background:var(--bg-card)}.conversation-item-info{flex:1;min-width:0}.conversation-item-name{font-size:14px;font-weight:500}.conversation-item-preview{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.conversation-unread-badge{background:var(--accent);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:11px;font-weight:600;display:flex}.support-layout{gap:16px;height:calc(100dvh - 140px);display:flex}.support-sidebar{flex-shrink:0;width:280px;overflow-y:auto}.support-chat-area{flex-direction:column;flex:1;min-width:0;display:flex}@media (width<=768px){.support-layout{flex-direction:column;height:auto}.support-sidebar{width:100%;max-height:200px}}.profile-name-edit{margin-top:4px}.coaching-report-content h1,.coaching-report-content h2,.coaching-report-content h3{color:var(--text-primary);margin:12px 0 6px;font-size:14px;font-weight:700}.coaching-report-content h1:first-child,.coaching-report-content h2:first-child,.coaching-report-content h3:first-child{margin-top:0}.coaching-report-content p{margin:6px 0}.coaching-report-content ul,.coaching-report-content ol{margin:6px 0;padding-left:20px}.coaching-report-content li{margin:4px 0}.ai-report-content h1,.ai-report-content h2,.ai-report-content h3{color:var(--text-primary);margin:12px 0 6px;font-size:14px;font-weight:700}.ai-report-content h1:first-child,.ai-report-content h2:first-child,.ai-report-content h3:first-child{margin-top:0}.ai-report-content p{word-break:break-word;margin:6px 0}.ai-report-content ul,.ai-report-content ol{margin:6px 0;padding-left:20px}.ai-report-content li{margin:4px 0}.ai-report-content table{border-collapse:collapse;width:100%;margin:8px 0;font-size:12px}.ai-report-content th,.ai-report-content td{border:1px solid var(--border);text-align:left;padding:4px 8px}.ai-report-content pre,.ai-report-content code{word-break:break-word;white-space:pre-wrap;overflow-x:auto}.coaching-report-content strong{color:var(--accent)}.toggle-switch{width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:var(--bg-secondary);border:1px solid var(--border);border-radius:24px;transition:all .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--text-secondary);border-radius:50%;width:18px;height:18px;transition:all .2s;position:absolute;bottom:2px;left:2px}.toggle-switch input:checked+.toggle-slider{background:var(--accent);border-color:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{background:#fff;transform:translate(20px)}.quick-capture{margin-bottom:16px}.quick-capture-row{align-items:center;gap:8px;display:flex}.quick-capture-input{border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:12px;outline:none;flex:1;padding:10px 14px;font-size:14px;transition:border-color .2s}.quick-capture-input:focus{border-color:var(--accent)}.quick-capture-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:opacity .2s;display:flex}.quick-capture-btn:disabled{opacity:.4;cursor:default}.quick-capture-error{color:var(--danger);margin-top:6px;font-size:12px}.mood-page{padding-top:0}.mood-input-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;margin-bottom:20px;padding:20px}.mood-input-section{margin-bottom:16px}.mood-label{color:var(--text-secondary);margin-bottom:8px;font-size:14px;display:block}.mood-emoji-row{justify-content:center;gap:6px;display:flex}.mood-emoji-row-large{gap:8px}.mood-emoji-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:background var(--d-fast) var(--ease-io), border-color var(--d-fast) var(--ease-io), box-shadow var(--d-fast) var(--ease-io), transform var(--d-fast) var(--ease-io);color:var(--text-primary);padding:8px;font-size:22px;line-height:1}.mood-emoji-btn-large{border-radius:var(--r-lg);padding:12px 14px;font-size:28px}.mood-emoji-btn:hover{background:var(--surface-hover);border-color:var(--border-strong);transform:translateY(-1px)}.mood-emoji-btn.selected{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-hover);box-shadow:0 0 0 3px var(--accent-glow);transform:translateY(-1px)}.mood-note-input{background:var(--bg-secondary);border:1px solid var(--border);width:100%;color:var(--text-primary);resize:none;border-radius:10px;margin-bottom:12px;padding:10px 12px;font-family:inherit;font-size:14px}.mood-note-input::placeholder{color:var(--text-secondary)}.mood-save-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;padding:12px;font-size:15px;font-weight:600;transition:opacity .2s}.mood-save-btn:disabled{opacity:.5;cursor:not-allowed}.mood-section{margin-bottom:20px}.mood-section-title{color:var(--text-primary);margin-bottom:12px;font-size:16px;font-weight:600}.mood-empty{color:var(--text-secondary);text-align:center;padding:20px;font-size:14px}.mood-entries-list{flex-direction:column;gap:8px;display:flex}.mood-entry{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;align-items:center;gap:10px;padding:10px 14px;display:flex}.mood-entry-time{color:var(--text-secondary);min-width:48px;font-size:13px}.mood-entry-emojis{gap:4px;font-size:20px;display:flex}.mood-entry-note{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.mood-entry-delete{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);justify-content:center;align-items:center;min-width:32px;min-height:32px;padding:4px 8px;font-size:16px;transition:all .2s;display:flex}.mood-entry-delete:hover{color:var(--danger);border-color:var(--danger);background:#d56b701a}.mood-chart-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.mood-chart-header .mood-section-title{margin-bottom:0}.mood-chart-tabs{gap:4px;display:flex}.mood-chart-tab{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:4px 12px;font-size:12px;transition:all .2s}.mood-chart-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.mood-chart-svg{background:var(--bg-card);border:1px solid var(--border);border-radius:12px}.mood-stats-grid{grid-template-columns:1fr 1fr 1fr;gap:10px;display:grid}.mood-stat-card{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:12px;padding:14px 10px}.mood-stat-label{color:var(--text-secondary);margin-bottom:6px;font-size:11px}.mood-stat-value{color:var(--text-primary);font-size:18px;font-weight:600}.mood-stat-sub{margin-top:4px;font-size:14px}.mood-stat-trend{letter-spacing:-.024em;font-variant-numeric:tabular-nums;font-size:28px}.mood-widget{background:var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:var(--s-5);margin-bottom:var(--s-4);transition:background var(--d-base) var(--ease-io), border-color var(--d-base) var(--ease-io), box-shadow var(--d-base) var(--ease-io), transform var(--d-fast) var(--ease-out)}.mood-widget:hover{background:var(--surface-hover);border-color:var(--border-strong);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.mood-widget-header{margin-bottom:var(--s-3);justify-content:space-between;align-items:center;display:flex}.mood-widget-title{letter-spacing:-.01em;color:var(--text-primary);font-size:15px;font-weight:600}.mood-widget-subtitle{color:var(--text-secondary);margin-bottom:var(--s-3);font-size:12.5px}.mood-widget-last{font-size:20px}.mood-widget-input{gap:var(--s-2);flex-direction:column;align-items:stretch;width:100%;display:flex}.mood-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);text-align:center;margin-bottom:2px;font-size:11px;font-weight:600}.mood-section-divider{background:var(--border);height:1px;margin:var(--s-2) 0 var(--s-1)}.mood-widget-save{background:linear-gradient(180deg, var(--accent-hover) 0%, var(--accent) 100%);color:#fff;border-radius:var(--r-sm);cursor:pointer;margin-top:var(--s-2);box-shadow:inset 0 1px 0 #ffffff40, inset 0 -1px 0 #0000001a, 0 1px 2px #0000004d, 0 4px 12px var(--accent-glow);transition:filter var(--d-fast) var(--ease-io), box-shadow var(--d-fast) var(--ease-io), transform var(--d-fast) var(--ease-io);border:none;align-self:center;padding:10px 24px;font-size:13.5px;font-weight:600;position:relative;overflow:hidden}.mood-widget-save:hover:not(:disabled){filter:brightness(1.05);box-shadow:inset 0 1px 0 #ffffff40, 0 2px 4px #0000004d, 0 8px 24px var(--accent-glow)}.mood-widget-save:active:not(:disabled){filter:brightness(.95);transform:scale(.98)}.mood-widget-save:disabled{opacity:.5;cursor:default}.mood-widget-sparklines{margin-top:var(--s-3);padding-top:var(--s-3);border-top:1px solid var(--border);justify-content:center;display:flex}.life-score-card{background:var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:var(--s-5);margin-bottom:var(--s-4);transition:background var(--d-base) var(--ease-io), border-color var(--d-base) var(--ease-io), box-shadow var(--d-base) var(--ease-io), transform var(--d-fast) var(--ease-out)}.life-score-card:hover{background:var(--surface-hover);border-color:var(--border-strong);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.life-score-card__head{margin-bottom:var(--s-4);justify-content:space-between;align-items:center;display:flex}.life-score-card__title{letter-spacing:-.012em;color:var(--text-primary);align-items:center;gap:10px;margin:0;font-size:16px;font-weight:600;display:flex}.life-score-card__eyebrow{color:var(--text-tertiary);letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:600}.life-score-card__body{align-items:center;gap:var(--s-4);display:flex}.life-score-card__ring{flex-shrink:0;width:84px;height:84px;position:relative}.life-score-card__ring-value{flex-direction:column;justify-content:center;align-items:center;line-height:1;display:flex;position:absolute;inset:0}.life-score-card__ring-skel{border-radius:50%;flex-shrink:0;width:84px;height:84px}.life-score-card__score{letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:24px;font-weight:700;line-height:1}.life-score-card__score-sub{color:var(--text-tertiary);font-variant-numeric:tabular-nums;letter-spacing:.05em;margin-top:2px;font-size:10px}.life-score-card__meta{flex:1;min-width:0}.life-score-card__trend{margin-bottom:var(--s-2);font-variant-numeric:tabular-nums;align-items:center;gap:4px;font-size:12.5px;font-weight:600;display:inline-flex}.life-score-card__trend--up{color:var(--success)}.life-score-card__trend--down{color:var(--danger)}.life-score-card__trend--flat{color:var(--text-secondary)}.life-score-card__breakdown{flex-wrap:wrap;gap:6px;display:flex}.life-score-card__chip{background:var(--surface-strong,var(--bg-secondary));border:1px solid var(--border);color:var(--text-secondary);white-space:nowrap;font-variant-numeric:tabular-nums;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;display:inline-flex}.life-score-card__chip .num{color:var(--text-primary);font-weight:600}.life-score-card__spark{margin-top:var(--s-4);padding-top:var(--s-3);border-top:1px solid var(--border)}.life-score-card__info{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:var(--s-3);color:var(--text-secondary);padding:10px 12px;font-size:12px;line-height:1.55}.life-score-card__info-title{color:var(--text-primary);margin-bottom:6px;font-weight:600}.life-score-card__info-list{flex-direction:column;gap:8px;margin:10px 0 0;padding:0;list-style:none;display:flex}.life-score-card__info-list li{grid-template-rows:auto auto;grid-template-columns:36px minmax(0,1fr);align-items:start;gap:2px 10px;display:grid}.life-score-card__info-weight{background:var(--accent-soft);min-width:32px;color:var(--accent);font-variant-numeric:tabular-nums;letter-spacing:0;border-radius:999px;grid-area:1/1/span 2;justify-content:center;align-self:center;align-items:center;padding:3px 6px;font-size:11px;font-weight:700;display:inline-flex}.life-score-card__info-weight:after{content:"%";opacity:.7;margin-left:1px;font-weight:600}.life-score-card__info-label{color:var(--text-primary);grid-area:1/2;font-size:12px;font-weight:600}.life-score-card__info-desc{color:var(--text-secondary);grid-area:2/2;font-size:11.5px;line-height:1.45}.life-score-card__info-foot{border-top:1px solid var(--border);color:var(--text-tertiary);margin-top:10px;padding-top:8px;font-size:11px}.skel{background:var(--glass-bg);border-radius:var(--r-sm);flex-shrink:0;position:relative;overflow:hidden}.skel:after{content:"";background:linear-gradient(90deg, transparent 0%, var(--glass-hover) 50%, transparent 100%);animation:1.4s infinite shimmer;position:absolute;inset:0}@media (prefers-reduced-motion:reduce){.skel:after{animation:none}}.streak-card{background:var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:var(--s-5);margin-bottom:var(--s-4);transition:background var(--d-base) var(--ease-io), border-color var(--d-base) var(--ease-io), box-shadow var(--d-base) var(--ease-io)}.streak-card__head{justify-content:space-between;align-items:center;gap:var(--s-2);margin-bottom:var(--s-3);display:flex}.streak-card__title{letter-spacing:-.012em;color:var(--text-primary);align-items:center;gap:10px;min-width:0;margin:0;font-size:16px;font-weight:600;display:flex}.streak-card__eyebrow{color:var(--text-tertiary);letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:600}.info-btn--sm{width:22px;height:22px;font-size:11px}.streak-card__year-nav{flex-shrink:0;align-items:center;gap:6px;display:inline-flex}.btn--icon-sm{border-radius:var(--r-xs,6px);width:28px;height:28px;font-size:14px}.streak-card__year{color:var(--text-secondary);font-variant-numeric:tabular-nums;text-align:center;min-width:36px;font-size:12.5px}.streak-card__info{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:var(--s-3);color:var(--text-secondary);padding:10px 12px;font-size:12px;line-height:1.55}.streak-card__info-title{color:var(--text-primary);margin-bottom:6px;font-weight:600}.streak-card__legend{flex-wrap:wrap;align-items:center;gap:12px;margin-top:10px;display:flex}.streak-card__legend-item{align-items:center;gap:6px;font-size:11px;display:inline-flex}.streak-banner{border-radius:var(--r-md);background:linear-gradient(135deg, var(--accent-glow), transparent 70%);border:1px solid var(--accent-soft);margin-bottom:var(--s-3);align-items:center;gap:12px;padding:10px 14px;display:flex}.streak-banner__icon{filter:drop-shadow(0 0 8px var(--accent-glow));font-size:22px}.streak-banner__count{min-width:0}.streak-banner__num{color:var(--accent);letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:20px;font-weight:700;line-height:1}.streak-banner__label{color:var(--text-secondary);margin-top:3px;font-size:11px}.streak-banner__dots{align-items:center;gap:4px;margin-left:auto;display:flex}.streak-banner__dot{background:var(--glass-bg);border:1px solid var(--border);box-sizing:border-box;border-radius:50%;width:10px;height:10px}.streak-banner__dot--partial{background:var(--accent-glow);border-color:var(--accent-soft)}.streak-banner__dot--done{background:var(--accent);border-color:var(--accent-hover);box-shadow:0 0 6px var(--accent-glow)}.streak-banner__dot--today{outline:1.5px solid var(--accent);outline-offset:2px}.heatmap-tooltip{background:var(--surface);-webkit-backdrop-filter:blur(12px)saturate(180%);border:1px solid var(--border-strong);border-radius:var(--r-xs,6px);color:var(--text-primary);white-space:nowrap;pointer-events:none;z-index:1000;box-shadow:var(--shadow-md);padding:4px 8px;font-size:11px;position:fixed;transform:translate(-50%,-100%)}.customize-list{flex-direction:column;gap:4px;display:flex}.customize-item{background:var(--bg-secondary);border-radius:8px;justify-content:space-between;align-items:center;padding:8px 10px;display:flex}.customize-checkbox{color:var(--text-primary);cursor:pointer;align-items:center;gap:10px;font-size:14px;display:flex}.customize-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.drag-handle{cursor:grab;touch-action:none;min-width:44px;min-height:44px;color:var(--text-secondary);-webkit-user-select:none;user-select:none;flex-shrink:0;order:1;justify-content:center;align-items:center;margin-left:auto;font-size:18px;display:inline-flex}.drag-handle:active{cursor:grabbing}.card{background:var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:var(--s-6);transition:transform var(--d-base) var(--ease-out), box-shadow var(--d-base) var(--ease-out), background var(--d-base) var(--ease-io), border-color var(--d-base) var(--ease-io);position:relative}.card--interactive{cursor:pointer}.card--interactive:hover{background:var(--surface-hover);border-color:var(--border-strong);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.card--inset{background:var(--bg-1);-webkit-backdrop-filter:none;backdrop-filter:none}.card--compact{padding:var(--s-4);border-radius:var(--r-md)}.card--hero{padding:var(--s-8);border-radius:var(--r-xl)}.btn--primary{background:linear-gradient(180deg, var(--accent-hover) 0%, var(--accent) 100%);color:#fff;box-shadow:inset 0 1px #ffffff40,inset 0 -1px #0000001a,0 1px 2px #0000004d,0 4px 12px #ff7a3038}.btn--primary:after{content:"";transition:transform .7s var(--ease-out);pointer-events:none;background:linear-gradient(120deg,#0000 30%,#ffffff40 50%,#0000 70%);position:absolute;inset:0;transform:translate(-120%)}.btn--primary:hover:after{transform:translate(120%)}.btn--primary:hover{filter:brightness(1.05);box-shadow:inset 0 1px #ffffff40,0 2px 4px #0000004d,0 8px 24px #ff7a3057}.btn--primary:active{filter:brightness(.95);transform:scale(.98)}.btn--ghost{background:var(--surface);color:var(--text-primary);border:1px solid var(--border);-webkit-backdrop-filter:blur(10px)}.btn--ghost:hover{background:var(--surface-hover);border-color:var(--border-strong)}.btn--danger{background:linear-gradient(180deg, #fb7185, var(--danger,#f87171));color:#fff;border:1px solid #f8717166;box-shadow:inset 0 1px #ffffff2e,0 2px 8px #f8717147}.btn--danger:hover{filter:brightness(1.05);box-shadow:inset 0 1px #ffffff38,0 4px 14px #f8717166}.btn--danger:active{filter:brightness(.95);transform:scale(.98)}.btn--icon{border-radius:var(--r-sm);width:40px;height:40px;color:var(--text-secondary);background:var(--surface);border:1px solid var(--border);transition:color var(--d-fast) var(--ease-io), background var(--d-fast) var(--ease-io);justify-content:center;align-items:center;padding:0;display:inline-flex}.btn--icon:hover{color:var(--text-primary);background:var(--surface-hover)}.btn--sm{height:36px;padding:0 var(--s-4);font-size:13px}.btn--lg{height:52px;padding:0 var(--s-6);border-radius:var(--r-md);font-size:16px}.field{flex-direction:column;display:flex;position:relative}.field__input{width:100%;height:52px;padding:20px var(--s-4) 8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-primary);transition:border-color var(--d-fast) var(--ease-io), box-shadow var(--d-fast) var(--ease-io), background var(--d-fast) var(--ease-io);outline:none;font-size:15px}.field__input::placeholder{color:#0000}.field__label{top:50%;left:var(--s-4);color:var(--text-secondary);pointer-events:none;transition:all var(--d-fast) var(--ease-io);font-size:15px;position:absolute;transform:translateY(-50%)}.field__input:focus,.field__input:not(:placeholder-shown){border-color:var(--border-strong);background:var(--surface-hover)}.field__input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}.field__input:focus+.field__label,.field__input:not(:placeholder-shown)+.field__label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary);font-size:10px;font-weight:600;top:6px;transform:translateY(0)}.field__input:focus+.field__label{color:var(--accent)}.chip{border-radius:var(--r-full);background:var(--surface);border:1px solid var(--border);height:30px;color:var(--text-secondary);transition:all var(--d-fast) var(--ease-io);white-space:nowrap;cursor:pointer;align-items:center;gap:6px;padding:0 12px;font-size:12.5px;font-weight:500;display:inline-flex}.chip:hover{background:var(--surface-hover);color:var(--text-primary)}.chip--active{background:var(--accent-soft);color:var(--accent-hover);border-color:#ff7a304d}.chip--sm{height:22px;padding:0 8px;font-size:11px;font-weight:500}.dot{background:currentColor;border-radius:50%;flex-shrink:0;width:6px;height:6px;display:inline-block}.check{appearance:none;border:1.5px solid var(--border-strong);background:var(--surface);cursor:pointer;width:22px;height:22px;transition:all var(--d-base) var(--ease-spring);border-radius:7px;flex-shrink:0;margin:0;position:relative}.check:hover{border-color:var(--accent)}.check:checked{background:linear-gradient(180deg, var(--accent-hover), var(--accent));border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow), inset 0 1px 0 #ffffff4d}.check:checked:after{content:"";width:5px;height:10px;animation:check-pop .35s var(--ease-spring);border:2px solid #fff;border-width:0 2px 2px 0;position:absolute;top:3px;left:7px;transform:rotate(45deg)}@keyframes check-pop{0%{opacity:0;transform:rotate(45deg)scale(0)}to{opacity:1;transform:rotate(45deg)scale(1)}}.ring{--size:120px;--track:8px;--value:0;--ring-color:var(--accent);width:var(--size);height:var(--size);background:conic-gradient(var(--ring-color) calc(var(--value) * 360deg), #ffffff0f 0);transition:background .8s var(--ease-out);border-radius:50%;flex-shrink:0;place-items:center;display:grid;position:relative}.ring:before{content:"";inset:var(--track);background:var(--bg-1);border-radius:50%;position:absolute;box-shadow:inset 0 1px #ffffff0a}.ring__value{z-index:1;text-align:center;flex-direction:column;justify-content:center;align-items:center;line-height:1;display:flex;position:relative}@keyframes rise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.rise{animation:rise .55s var(--ease-out) both}.rise--d1{animation-delay:80ms}.rise--d2{animation-delay:.14s}.rise--d3{animation-delay:.2s}.rise--d4{animation-delay:.26s}.rise--d5{animation-delay:.32s}@media (prefers-reduced-motion:reduce){.rise,.rise--d1,.rise--d2,.rise--d3,.rise--d4,.rise--d5{opacity:1;animation:none;transform:none}}.h-display{letter-spacing:-.035em;font-size:clamp(32px,5vw,56px);font-weight:600;line-height:1.05}.h-1{letter-spacing:-.028em;font-size:32px;font-weight:600;line-height:1.15}.h-2{letter-spacing:-.022em;font-size:24px;font-weight:600;line-height:1.2}.h-3{letter-spacing:-.015em;font-size:18px;font-weight:600;line-height:1.3}.caption{color:var(--text-secondary);font-size:13px;line-height:1.45}.label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);font-size:11px;font-weight:600}.mute{color:var(--text-secondary)}.mute-2{color:var(--text-tertiary)}.stack{gap:var(--s-4);flex-direction:column;display:flex}.stack-sm{gap:var(--s-2);flex-direction:column;display:flex}.stack-lg{gap:var(--s-6);flex-direction:column;display:flex}.row{align-items:center;gap:var(--s-3);display:flex}.row-sm{align-items:center;gap:var(--s-2);display:flex}.grow{flex:1}.between{justify-content:space-between;align-items:center;display:flex}.grid-2{gap:var(--s-3);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--s-3);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--s-3);grid-template-columns:repeat(4,1fr);display:grid}.section-head{margin:var(--s-8) 0 var(--s-4);justify-content:space-between;align-items:baseline;display:flex}.section-head h2{letter-spacing:-.015em;margin:0;font-size:18px;font-weight:600}.section-head a,.section-head button{color:var(--text-secondary);transition:color var(--d-fast) var(--ease-io);cursor:pointer;background:0 0;border:none;padding:0;font-size:13.5px}.section-head a:hover,.section-head button:hover{color:var(--accent)}.ico{stroke:currentColor;fill:none;stroke-width:1.6px;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;width:20px;height:20px}.ico--sm{width:16px;height:16px}.ico--lg{width:24px;height:24px}.ico--xl{width:32px;height:32px}.icon-badge{width:42px;height:42px;color:var(--accent);background:var(--accent-soft);border:1px solid #ff7a3033;border-radius:12px;flex-shrink:0;place-items:center;display:grid}.icon-badge--green{color:var(--success);background:var(--success-soft);border-color:#4ade8033}.icon-badge--blue{color:var(--info);background:var(--info-soft);border-color:#60a5fa33}.icon-badge--purple{color:#c084fc;background:#c084fc1f;border-color:#c084fc33}.icon-badge--warning{color:var(--warning);background:var(--warning-soft);border-color:#fbbf2433}.icon-badge--danger{color:var(--danger);background:var(--danger-soft);border-color:#f8717133}.icon-badge--sm{border-radius:10px;width:32px;height:32px}.hero-widget{gap:var(--s-4);margin-bottom:var(--s-4);flex-direction:column;display:flex}.hero{padding:var(--s-6);border-radius:var(--r-xl);background:radial-gradient(ellipse 400px 300px at 20% 20%, #ff7a301a, transparent 60%), var(--surface);-webkit-backdrop-filter:blur(24px)saturate(180%);border:1px solid var(--border);box-shadow:var(--shadow-md);align-items:center;gap:var(--s-6);display:flex}.hero--dashboard{padding:var(--s-4) var(--s-5);gap:var(--s-4)}.hero--dashboard .hero__ring{--size:86px;--track:7px}.hero--dashboard .hero__ring .xp{font-size:20px}.hero--dashboard .hero__ring .of{letter-spacing:.03em;margin-top:2px;font-size:9.5px}.hero--dashboard .hero__rank{margin-bottom:4px;padding:3px 9px;font-size:11.5px}.hero--dashboard .hero__rank svg{width:12px;height:12px}.hero--dashboard .hero__title{margin-bottom:2px;font-size:14.5px;line-height:1.25}.hero--dashboard .hero__desc{font-size:12px;line-height:1.4}.hero__ring{--size:132px;--track:10px;--value:0;flex-shrink:0}.hero__ring .xp{letter-spacing:-.03em;color:var(--text-primary);font-size:28px;font-weight:600;line-height:1}.hero__ring .of{color:var(--text-tertiary);letter-spacing:.04em;text-transform:uppercase;margin-top:4px;font-size:11px;font-weight:500}.hero__info{flex:1;min-width:0}.hero__rank{border-radius:var(--r-full);background:var(--accent-soft);color:var(--accent-hover);margin-bottom:var(--s-3);cursor:pointer;transition:background var(--d-fast) var(--ease-io), border-color var(--d-fast) var(--ease-io);border:1px solid #ff7a303d;align-items:center;gap:6px;padding:5px 11px;font-size:12.5px;font-weight:550;display:inline-flex}.hero__rank:hover{background:#ff7a302e;border-color:#ff7a3066}.hero__rank svg{stroke-width:2px;width:14px;height:14px}.hero__title{letter-spacing:-.02em;color:var(--text-primary);margin-bottom:4px;font-size:19px;font-weight:600;line-height:1.25}.hero__desc{color:var(--text-secondary);font-size:13.5px;line-height:1.5}.hero__info-top{justify-content:space-between;align-items:center;gap:var(--s-2);margin-bottom:var(--s-3);display:flex}.hero__info-top .hero__rank{margin-bottom:0}.hero--dashboard .hero__info-top{margin-bottom:4px}.hero__info-panel{padding:var(--s-3) var(--s-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);-webkit-backdrop-filter:blur(18px)saturate(160%);box-shadow:var(--shadow-sm);color:var(--text-secondary);white-space:pre-line;cursor:pointer;animation:hero-info-in var(--d-base) var(--ease-out);font-size:12px;line-height:1.6}.hero__info-title{color:var(--text-primary);margin-bottom:var(--s-2);font-size:12.5px;font-weight:600}.hero__info-body{font-size:12px}@keyframes hero-info-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.stat__value-sep{color:var(--text-tertiary);margin:0 2px;font-weight:500}@media (width<=480px){.hero{text-align:center;gap:var(--s-4);padding:var(--s-5);flex-direction:column}.hero__ring{--size:116px;--track:9px}.hero__ring .xp{font-size:24px}.hero__rank{margin-left:auto;margin-right:auto}.hero--dashboard{padding:var(--s-3) var(--s-4);gap:var(--s-3)}.hero--dashboard .hero__ring{--size:76px;--track:6px}.hero--dashboard .hero__ring .xp{font-size:18px}}.stats{gap:var(--s-3);grid-template-columns:repeat(3,1fr);display:grid}.stat{padding:var(--s-4) var(--s-4);background:var(--surface);-webkit-backdrop-filter:blur(18px)saturate(160%);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);transition:background var(--d-base) var(--ease-out), border-color var(--d-base) var(--ease-out), box-shadow var(--d-base) var(--ease-out), transform var(--d-fast) var(--ease-io);min-width:0}.stat[role=button]{cursor:pointer}.stat:hover{background:var(--surface-hover);border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat__label{color:var(--text-tertiary);letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--s-3);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:5px;font-size:10.5px;font-weight:600;display:flex;overflow:hidden}.stat__value{letter-spacing:-.028em;color:var(--text-primary);font-size:26px;font-weight:600;line-height:1}.stat__delta{color:var(--success);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:4px;margin-top:6px;font-size:11.5px;display:inline-flex;overflow:hidden}.stat__delta--muted{color:var(--text-tertiary)}@media (width<=380px){.stat__value{font-size:22px}.stat__label{font-size:10px}}.habit-row{align-items:center;gap:var(--s-3);background:var(--surface);-webkit-backdrop-filter:blur(18px)saturate(160%);border:1px solid var(--border);border-radius:var(--r-md);transition:background var(--d-base) var(--ease-io), border-color var(--d-base) var(--ease-io), transform var(--d-fast) var(--ease-io);padding:12px 14px;display:flex}.habit-row:hover{background:var(--surface-hover);border-color:var(--border-strong)}.habit-row.is-completing{animation:check-pop-row .38s var(--ease-spring)}@keyframes check-pop-row{0%{transform:scale(1)}40%{transform:scale(1.015)}to{transform:scale(1)}}.habit-row__body{flex:1;min-width:0}.habit-row__name{letter-spacing:-.01em;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:14.5px;font-weight:550;line-height:1.3;overflow:hidden}.habit-row--done .habit-row__name{color:var(--text-secondary);text-decoration:line-through;text-decoration-thickness:1px;-webkit-text-decoration-color:var(--text-tertiary);text-decoration-color:var(--text-tertiary)}.habit-row__meta{color:var(--text-tertiary);flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;display:flex}.habit-row__streak{color:var(--warning);font-variant-numeric:tabular-nums;align-items:center;gap:3px;font-weight:500;display:inline-flex}.habit-row--page{gap:var(--s-4);margin-bottom:10px;padding:14px 16px}.habit-row__actions{flex-shrink:0;gap:4px;display:flex}.chip--done{color:var(--success);background:var(--success-soft);border-color:#4ade804d}.sphere-grid-premium{gap:var(--s-3);grid-template-columns:repeat(2,1fr);display:grid}.sphere-card-premium{padding:var(--s-4);background:var(--surface);-webkit-backdrop-filter:blur(18px)saturate(160%);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:background var(--d-base) var(--ease-out), border-color var(--d-base) var(--ease-out), box-shadow var(--d-base) var(--ease-out), transform var(--d-fast) var(--ease-io);position:relative;overflow:hidden}.sphere-card-premium:before{content:"";background:var(--sphere-color,var(--accent));opacity:.08;filter:blur(30px);width:80px;height:80px;transition:all var(--d-base) var(--ease-out);pointer-events:none;position:absolute;top:0;left:0}.sphere-card-premium:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-2px)}.sphere-card-premium:hover:before{opacity:.14;width:120px;height:120px}.sphere-card-premium__head{margin-bottom:var(--s-4);justify-content:space-between;align-items:center;display:flex;position:relative}.sphere-card-premium__name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:8px;font-size:13.5px;font-weight:550;display:flex;overflow:hidden}.sphere-card-premium__rank{background:var(--surface-strong);border:1px solid var(--border);width:26px;height:26px;color:var(--text-primary);border-radius:8px;flex-shrink:0;place-items:center;font-size:11.5px;font-weight:600;display:grid}.sphere-card-premium__progress{background:var(--surface-strong);border-radius:999px;height:6px;position:relative;overflow:hidden}.sphere-card-premium__bar{background:linear-gradient(90deg, var(--sphere-color,var(--accent)), var(--sphere-color-soft,var(--sphere-color,var(--accent))));transform-origin:0;height:100%;animation:sphere-grow .9s var(--ease-out) both;border-radius:999px}@keyframes sphere-grow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@media (prefers-reduced-motion:reduce){.sphere-card-premium__bar{animation:none}}.sphere-card-premium__numbers{color:var(--text-tertiary);font-variant-numeric:tabular-nums;justify-content:space-between;margin-top:8px;font-size:11.5px;display:flex}.page-top{justify-content:flex-end;align-items:center;gap:var(--s-2);margin-bottom:var(--s-4);display:flex}.notification-bell__trigger{border-radius:var(--r-sm);background:var(--surface);border:1px solid var(--border);width:40px;height:40px;color:var(--text-secondary);transition:background var(--d-fast) var(--ease-io), color var(--d-fast) var(--ease-io), border-color var(--d-fast) var(--ease-io);cursor:pointer;justify-content:center;align-items:center;padding:0;display:inline-flex;position:relative}.notification-bell__trigger:hover{color:var(--text-primary);background:var(--surface-hover);border-color:var(--border-strong)}.notification-bell__badge{border-radius:var(--r-full);background:linear-gradient(180deg, var(--danger), #dc5656);color:#fff;font-variant-numeric:tabular-nums;border:1.5px solid var(--bg-primary);justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;line-height:1;display:inline-flex;position:absolute;top:-3px;right:-3px;box-shadow:0 2px 6px #f8717166}.empty-state-card{background:var(--surface);-webkit-backdrop-filter:blur(18px)saturate(160%);border:1px dashed var(--border-strong);border-radius:var(--r-md);padding:var(--s-6);text-align:center;align-items:center;gap:var(--s-3);flex-direction:column;display:flex}.empty-state-card .empty-title{color:var(--text-secondary);font-size:15px;font-weight:550}.page-head{margin-bottom:var(--s-5);justify-content:space-between;align-items:center;display:flex}.page-head h1{letter-spacing:-.03em;margin:0;font-size:30px;font-weight:600;line-height:1.1}.page-head__sub{color:var(--text-tertiary);font-variant-numeric:tabular-nums;margin-top:4px;font-size:13.5px}.page-info-panel{padding:var(--s-3) var(--s-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);-webkit-backdrop-filter:blur(18px)saturate(160%);box-shadow:var(--shadow-sm);color:var(--text-secondary);white-space:pre-line;margin-bottom:var(--s-4);animation:hero-info-in var(--d-base) var(--ease-out);font-size:12.5px;line-height:1.6}.page-info-panel__title{color:var(--text-primary);margin-bottom:var(--s-2);font-size:13px;font-weight:600}.habits-progress{margin-bottom:var(--s-4);padding:var(--s-4) var(--s-5);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);-webkit-backdrop-filter:blur(18px)saturate(160%);box-shadow:var(--shadow-sm)}.habits-progress__top{align-items:baseline;gap:var(--s-3);margin-bottom:var(--s-3);display:flex}.habits-progress__count{letter-spacing:-.028em;color:var(--text-primary);font-size:26px;font-weight:600;line-height:1}.habits-progress__of{color:var(--text-tertiary);margin-left:2px;font-size:18px;font-weight:500}.habits-progress__label{color:var(--text-secondary);letter-spacing:.01em;font-size:12.5px}.habits-progress__bar{background:var(--bg-secondary);border-radius:var(--r-full);height:6px;overflow:hidden}.habits-progress__fill{background:linear-gradient(90deg, var(--accent-hover), var(--accent));border-radius:var(--r-full);height:100%;transition:width var(--d-slow) var(--ease-out)}.habits-special-cta{justify-content:center;align-items:center;gap:var(--s-2);margin-bottom:var(--s-4);font-size:14px;font-weight:600;display:inline-flex}.habits-special-cta svg{flex-shrink:0}.filter-row{margin-bottom:var(--s-4);flex-wrap:wrap;gap:6px;display:flex}.filter-row__divider{background:var(--border);align-self:stretch;width:1px;margin:0 4px}.tasks-group{margin-bottom:var(--s-6)}.tasks-group__head{margin-bottom:var(--s-3);padding-left:var(--s-1);align-items:baseline;gap:10px;display:flex}.tasks-group__head h3{color:var(--text-secondary);letter-spacing:.02em;margin:0;font-size:13px;font-weight:600}.tasks-group__count{color:var(--text-tertiary);font-variant-numeric:tabular-nums;background:var(--surface);border-radius:var(--r-full);border:1px solid var(--border);padding:2px 8px;font-size:11.5px}.task-list{flex-direction:column;gap:6px;display:flex}.task{align-items:center;gap:var(--s-4);background:var(--surface);-webkit-backdrop-filter:blur(16px)saturate(160%);border:1px solid var(--border);border-radius:var(--r-md);transition:background var(--d-fast) var(--ease-io), border-color var(--d-fast) var(--ease-io), transform var(--d-fast) var(--ease-io);cursor:pointer;padding:14px 16px;display:flex}.task:hover{background:var(--surface-hover);border-color:var(--border-strong);transform:translate(2px)}.task.is-completing{animation:check-pop-row .38s var(--ease-spring)}.task__body{flex:1;min-width:0}.task__title{letter-spacing:-.01em;color:var(--text-primary);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:4px;font-size:15px;font-weight:500;line-height:1.35;display:-webkit-box;overflow:hidden}.task__meta{align-items:center;gap:var(--s-3);color:var(--text-tertiary);flex-wrap:wrap;row-gap:4px;font-size:12.5px;display:flex}.task__sphere{border-radius:var(--r-full);color:var(--sphere-color,var(--accent));background:var(--sphere-bg,var(--accent-soft));align-items:center;gap:5px;padding:2px 9px;font-size:11.5px;font-weight:500;display:inline-flex}.task__sphere .dot{color:var(--sphere-color,var(--accent))}.task__due{font-variant-numeric:tabular-nums;align-items:center;gap:4px;display:inline-flex}.task__due--warn{color:var(--warning)}.task__due--urgent{color:var(--danger)}.task__goal{color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:5px;max-width:160px;display:inline-flex;overflow:hidden}.task__xp{flex-shrink:0;font-size:11.5px}.task--done .task__title{color:var(--text-secondary);text-decoration:line-through;-webkit-text-decoration-color:var(--text-tertiary);text-decoration-color:var(--text-tertiary);text-decoration-thickness:1px}.task--overdue{border-color:#f8717140}.task--overdue:hover{border-color:#f8717166}.empty-scene{padding:var(--s-10) var(--s-6);text-align:center;background:var(--surface);border:1px dashed var(--border-strong);border-radius:var(--r-lg)}.empty-scene__art{width:160px;height:140px;margin:0 auto var(--s-5);position:relative}.empty-scene__art .orb{border-radius:50%;position:absolute}.empty-scene__art .orb-1{--tx:-50%;background:radial-gradient(circle at 30% 30%,#ffad7a,#ff7a30);width:100px;height:100px;animation:4s ease-in-out infinite bob;top:0;left:50%;box-shadow:0 20px 60px #ff7a3066,inset 0 -10px 20px #0003}.empty-scene__art .orb-2{background:radial-gradient(circle at 30% 30%,#93bbfc,#60a5fa);width:40px;height:40px;animation:4s ease-in-out .5s infinite bob;bottom:20px;left:10px;box-shadow:0 10px 30px #60a5fa66}.empty-scene__art .orb-3{background:radial-gradient(circle at 30% 30%,#86efac,#4ade80);width:30px;height:30px;animation:4s ease-in-out 1s infinite bob;bottom:30px;right:20px;box-shadow:0 10px 30px #4ade8066}.empty-scene__art .base{background:radial-gradient(#ffffff0f,#0000 70%);width:120px;height:12px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}@keyframes bob{0%,to{transform:translateY(0) translateX(var(--tx,0))}50%{transform:translateY(-10px) translateX(var(--tx,0))}}@media (prefers-reduced-motion:reduce){.empty-scene__art .orb{animation:none}}.empty-scene__title{letter-spacing:-.015em;color:var(--text-primary);margin-bottom:6px;font-size:18px;font-weight:600}.empty-scene__desc{color:var(--text-secondary);max-width:320px;margin:0 auto;font-size:14px;line-height:1.55}html[data-telegram-webapp] .pwa-install-card,html[data-telegram-webapp] .install-banner,html[data-telegram-webapp] .install-ios-hint,html[data-telegram-webapp] .pwa-install-btn,html[data-telegram-webapp] .login-telegram-btn{display:none!important}html[data-telegram-webapp] ::-webkit-scrollbar{background:0 0;width:0;height:0}html[data-telegram-webapp] .page{padding-bottom:140px}html[data-telegram-fullscreen] .page{padding-bottom:calc(100px + env(safe-area-inset-bottom,0px))}html[data-telegram-fullscreen] body{background:var(--bg-primary)}.toast-stack{left:50%;bottom:calc(90px + env(safe-area-inset-bottom,0px));z-index:150;pointer-events:none;flex-direction:column-reverse;gap:8px;width:calc(100% - 24px);max-width:420px;margin:0;padding:0;list-style:none;display:flex;position:fixed;transform:translate(-50%)}.toast-stack>.toast{pointer-events:auto}html[data-telegram-webapp] .toast-stack{bottom:calc(140px + env(safe-area-inset-bottom,0px))}@media (width>=720px){.toast-stack{bottom:24px;left:auto;right:24px;transform:none}}.toast{background:var(--modal-bg);-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-border);border-radius:var(--radius-sm);box-shadow:var(--glass-shadow);color:var(--text-primary);animation:toastIn var(--d-base) var(--ease-out);border-left-width:3px;align-items:center;gap:10px;padding:12px 14px;font-size:14px;line-height:1.35;display:flex;position:relative;overflow:hidden}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.toast-icon{border-radius:50%;flex:0 0 22px;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;font-weight:700;line-height:1;display:flex}.toast-body{flex:1;min-width:0}.toast-message{word-break:break-word}.toast-action{color:var(--accent);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:none;padding:4px 8px;font-size:13px;font-weight:600}.toast-action:hover{background:var(--hover-overlay)}.toast-close{color:var(--text-secondary);cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:6px;flex:none;padding:4px 6px;font-size:18px;line-height:1}.toast-close:hover{opacity:1;background:var(--hover-overlay)}.toast-progress{opacity:.35;transform-origin:0;background:currentColor;width:100%;height:2px;transition:transform 60ms linear;position:absolute;bottom:0;left:0}.toast-success{border-left-color:var(--success);color:var(--text-primary)}.toast-success .toast-icon{background:var(--success);color:#fff}.toast-success .toast-progress{color:var(--success)}.toast-error{border-left-color:var(--danger)}.toast-error .toast-icon{background:var(--danger);color:#fff}.toast-error .toast-progress{color:var(--danger)}.toast-warning{border-left-color:var(--warning)}.toast-warning .toast-icon{background:var(--warning);color:#1a1a1a}.toast-warning .toast-progress{color:var(--warning)}.toast-info{border-left-color:var(--accent)}.toast-info .toast-icon{background:var(--accent);color:#fff}.toast-info .toast-progress{color:var(--accent)}.toast-undo{border-left-color:var(--warning)}.toast-undo .toast-icon{background:var(--warning);color:#1a1a1a;font-size:16px}.toast-undo .toast-progress{color:var(--warning)}.command-palette-overlay{-webkit-backdrop-filter:blur(6px);z-index:250;background:#0000008c;justify-content:center;align-items:flex-start;padding:12vh 16px 16px;animation:.15s fadeOverlay;display:flex;position:fixed;inset:0}@media (width<=520px){.command-palette-overlay{padding-top:6vh}}.command-palette{background:var(--modal-bg);-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-border);border-radius:var(--radius);width:100%;max-width:600px;box-shadow:var(--modal-shadow);max-height:70vh;animation:commandPaletteIn var(--d-fast) var(--ease-out);flex-direction:column;display:flex;overflow:hidden}@keyframes commandPaletteIn{0%{opacity:0;transform:translateY(-8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.command-palette-searchbar{border-bottom:1px solid var(--glass-border);align-items:center;gap:10px;padding:14px 16px;display:flex}.command-palette-search-icon{width:18px;height:18px;color:var(--text-secondary);flex:none}.command-palette-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:16px;font-weight:500}.command-palette-input::placeholder{color:var(--text-secondary);font-weight:400}.command-palette-kbd,.command-palette-footer kbd{color:var(--text-secondary);background:var(--hover-overlay);border:1px solid var(--glass-border);border-radius:4px;padding:2px 6px;font-family:inherit;font-size:11px;font-weight:600;line-height:1.2;display:inline-block}.command-palette-list{-webkit-overflow-scrolling:touch;flex:1;min-height:0;margin:0;padding:6px;list-style:none;overflow-y:auto}.command-palette-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-primary);-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:9px 10px;display:flex}.command-palette-item.active,.command-palette-item:hover{background:var(--accent-glow)}.command-palette-item-icon{background:var(--hover-overlay);width:26px;height:26px;color:var(--text-primary);border-radius:6px;flex:0 0 26px;justify-content:center;align-items:center;font-size:14px;display:flex}.command-palette-item-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.command-palette-item-title{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.command-palette-item-subtitle{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.command-palette-item-kind{background:var(--hover-overlay);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;border-radius:4px;flex:none;padding:2px 6px;font-size:10px;font-weight:600}.command-palette-item-kind-task{color:var(--accent)}.command-palette-item-kind-habit{color:var(--success)}.command-palette-item-kind-goal{color:var(--warning)}.command-palette-item-kind-action{color:var(--danger)}.command-palette-empty{text-align:center;color:var(--text-secondary);padding:24px 12px;font-size:14px}.command-palette-footer{border-top:1px solid var(--glass-border);color:var(--text-secondary);flex-wrap:wrap;gap:14px;padding:8px 14px;font-size:11px;display:flex}.command-palette-footer kbd{margin-right:3px}@media (width<=719px){.command-palette-footer,.command-palette-kbd{display:none}}.command-palette-fab{right:16px;bottom:calc(80px + env(safe-area-inset-bottom,0px));background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);width:48px;height:48px;box-shadow:var(--glass-shadow-md);color:var(--text-primary);cursor:pointer;z-index:100;border-radius:50%;justify-content:center;align-items:center;transition:transform .15s,background .15s;display:flex;position:fixed}.command-palette-fab svg{width:20px;height:20px}.command-palette-fab:hover,.command-palette-fab:active{background:var(--accent-glow);transform:scale(.96)}@media (width>=720px){.command-palette-fab{display:none}}.btn--lg{border-radius:var(--r-md);padding:16px 28px;font-size:16px}.btn--full{width:100%}.is-completing{animation:checkPop .4s var(--ease-spring) 1}@keyframes checkPop{40%{box-shadow:var(--shadow-md), 0 0 0 8px var(--accent-glow);transform:scale(1.03)}to{transform:scale(1)}}@media (prefers-reduced-motion:reduce){.is-completing{animation:none}}.task__prio{border-radius:var(--r-full);letter-spacing:.02em;background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);flex-shrink:0;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.task__prio--urgent{color:var(--danger);background:#f871711f;border-color:#f8717147}.task__prio--high{color:#fb923c;background:#fb923c1f;border-color:#fb923c47}.task__prio--medium{color:#60a5fa;background:#60a5fa1f;border-color:#60a5fa47}.task__prio--low{color:var(--text-tertiary);background:var(--surface);border-color:var(--border)}.progress-summary{padding:var(--s-4) var(--s-5);background:var(--surface);-webkit-backdrop-filter:blur(22px)saturate(170%);border:1px solid var(--border);border-radius:var(--r-lg);position:relative;overflow:hidden}.progress-summary:before{content:"";background:radial-gradient(ellipse at 90% -20%, var(--accent-glow), transparent 55%);pointer-events:none;opacity:.6;position:absolute;inset:0}.progress-summary__row{gap:var(--s-5);align-items:stretch;display:flex;position:relative}.progress-summary__col{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.progress-summary__label{color:var(--text-tertiary);letter-spacing:.02em;justify-content:space-between;align-items:baseline;font-size:11.5px;font-weight:500;display:flex}.progress-summary__count{font-variant-numeric:tabular-nums;color:var(--text-secondary);font-weight:600}.progress-summary__bar{border-radius:var(--r-full);background:#ffffff0a;height:6px;position:relative;overflow:hidden}.progress-summary__fill{border-radius:var(--r-full);background:linear-gradient(90deg, var(--accent), var(--accent-hover));height:100%;transition:width var(--d-base) var(--ease-out);box-shadow:0 0 12px var(--accent-glow)}.progress-summary__fill--success{background:linear-gradient(90deg, var(--success), #22d3ee);box-shadow:0 0 12px #4ade8059}.progress-summary__time{color:var(--text-tertiary);margin-top:var(--s-3);align-items:center;gap:6px;font-size:12px;display:flex;position:relative}.progress-summary--done{text-align:center;padding:var(--s-5);color:var(--success);letter-spacing:-.01em;font-size:15px;font-weight:650}.progress-summary--done:after{content:"✨";margin-left:6px;display:inline-block}.section-head{margin:var(--s-5) 0 var(--s-3);color:var(--text-secondary);letter-spacing:.02em;align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.section-head--danger{color:var(--danger)}.section-head--danger:before{content:"";background:var(--danger);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse-dot;box-shadow:0 0 8px #f8717199}.section-head__count{font-variant-numeric:tabular-nums;color:var(--text-tertiary);margin-left:4px;font-weight:500}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(1.15)}}.week-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.week-grid__day{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);text-align:center;cursor:pointer;transition:all var(--d-fast) var(--ease-out);-webkit-backdrop-filter:blur(14px);padding:10px 4px 12px;position:relative}.week-grid__day:hover{background:var(--surface-hover);border-color:var(--border-strong);transform:translateY(-2px)}.week-grid__day--today{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent), 0 8px 24px var(--accent-glow)}.week-grid__day--selected{background:linear-gradient(145deg, var(--accent-soft), var(--accent-ghost));border-color:var(--accent);box-shadow:0 4px 18px var(--accent-glow)}.week-grid__day--selected.week-grid__day--today{background:linear-gradient(145deg, var(--accent-soft), var(--accent-ghost));box-shadow:0 0 0 1px var(--accent), 0 8px 24px var(--accent-glow)}.week-grid__dow{letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:4px;font-size:10.5px;font-weight:600}.week-grid__date{letter-spacing:-.02em;color:var(--text-primary);font-variant-numeric:tabular-nums;margin-bottom:4px;font-size:18px;font-weight:650;line-height:1}.week-grid__day--selected .week-grid__date{color:var(--accent-hover)}.week-grid__count{color:var(--text-tertiary);font-variant-numeric:tabular-nums;font-size:11px}.week-grid__load{border-radius:50%;width:6px;height:6px;margin-top:4px;display:inline-block;box-shadow:0 0 6px}.week-grid__load--low{color:#22c55e;background:#22c55e}.week-grid__load--mid{color:#eab308;background:#eab308}.week-grid__load--high{color:#ef4444;background:#ef4444}.month-nav{padding:var(--s-3) 0 var(--s-4);justify-content:space-between;align-items:center;display:flex}.month-nav__title{letter-spacing:-.01em;text-transform:capitalize;color:var(--text-primary);font-size:16px;font-weight:650}.month-nav__group{gap:2px;display:inline-flex}.month-nav__btn{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--r-xs);cursor:pointer;width:32px;height:32px;transition:all var(--d-fast) var(--ease-out);background:0 0;justify-content:center;align-items:center;font-size:14px;display:inline-flex}.month-nav__btn:hover{background:var(--surface-hover);border-color:var(--border-strong);color:var(--text-primary)}.month-nav__btn--sm{width:26px;height:32px;font-size:11px}.month-grid__headers{grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px;display:grid}.month-grid__dow{text-transform:uppercase;letter-spacing:.08em;text-align:center;color:var(--text-tertiary);padding:4px 0;font-size:10.5px;font-weight:600}.month-grid__row{grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px;display:grid}.month-grid__cell{border-radius:var(--r-xs);font-variant-numeric:tabular-nums;cursor:pointer;height:44px;transition:all var(--d-fast) var(--ease-out);color:var(--text-secondary);border:1.5px solid #0000;justify-content:center;align-items:center;font-size:13.5px;font-weight:500;display:flex;position:relative}.month-grid__cell:hover:not(.month-grid__cell--empty){background:var(--surface-hover);color:var(--text-primary);transform:scale(1.05)}.month-grid__cell--empty{cursor:default}.month-grid__cell--heat1{background:#ff7a3014}.month-grid__cell--heat2{background:#ff7a3029}.month-grid__cell--heat3{color:var(--text-primary);background:#ff7a3047}.month-grid__cell--today{border-color:var(--accent);color:var(--text-primary);font-weight:700}.month-grid__cell--selected{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 18px var(--accent-glow);font-weight:650}.section-title{margin:var(--s-5) 0 var(--s-3);justify-content:space-between;align-items:baseline;gap:12px;display:flex}.section-title__label{color:var(--text-primary);letter-spacing:-.01em;font-size:14px;font-weight:600}.section-title__count{font-variant-numeric:tabular-nums;color:var(--text-tertiary);margin-left:4px;font-size:13px;font-weight:500}.dashboard-empty-inline{text-align:center;padding:var(--s-6) var(--s-4);color:var(--text-tertiary);font-size:13px}.planner{gap:var(--s-3);flex-direction:column;display:flex}.planner__controls{justify-content:space-between;align-items:center;gap:var(--s-2);flex-wrap:wrap;display:flex}.planner__toggle{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-secondary);align-items:center;gap:8px;padding:4px 2px;font-size:13px;display:inline-flex}.planner__toggle input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;margin:0}.planner__zoom{align-items:center;gap:8px;display:inline-flex}.planner__zoom-label{color:var(--text-tertiary);font-size:12px}.planner__zoom-group{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xs);gap:2px;padding:3px;display:inline-flex}.planner__zoom-btn{color:var(--text-tertiary);cursor:pointer;letter-spacing:.03em;text-transform:uppercase;transition:all var(--d-fast) var(--ease-out);background:0 0;border:none;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600}.planner__zoom-btn:hover:not([aria-pressed=true]){color:var(--text-primary)}.planner__zoom-btn[aria-pressed=true]{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.planner__untimed{color:var(--text-secondary);background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--warning);border-radius:var(--r-sm);padding:10px 14px;font-size:12px;line-height:1.5}.planner__scroll{background:var(--bg-1,var(--surface));border:1px solid var(--border);border-radius:var(--r-md);-webkit-backdrop-filter:blur(18px)saturate(170%);height:min(72vh,720px);position:relative;overflow-y:auto}.planner__scroll:before{content:"";z-index:0;pointer-events:none;height:0;position:sticky;top:0;left:0;right:0}.planner__grid{min-height:100%;display:flex;position:relative}.planner__axis{border-right:1px solid var(--border);flex-shrink:0;width:60px;position:relative}.planner__axis-hour{color:var(--text-tertiary);font-variant-numeric:tabular-nums;pointer-events:none;letter-spacing:.02em;font-size:11px;position:absolute;right:10px;transform:translateY(-50%)}.planner__track{cursor:copy;flex:1;position:relative}.planner__line{background:var(--border);pointer-events:none;height:1px;position:absolute;left:0;right:0}.planner__line--half{opacity:.35;border-top:1px dashed var(--border);background:0 0}.planner__now{background:linear-gradient(90deg, var(--accent), transparent);height:2px;box-shadow:0 0 14px var(--accent-glow), 0 0 4px #ff7a30b3;z-index:4;pointer-events:none;position:absolute;left:0;right:0}.planner__now:before{content:"";background:var(--accent);width:8px;height:8px;box-shadow:0 0 10px var(--accent-glow);border-radius:50%;animation:2s ease-in-out infinite pulse-dot;position:absolute;top:-3px;left:-4px}.planner__block{background:var(--surface-strong,#ffffff0f);-webkit-backdrop-filter:blur(14px)saturate(170%);border:1px solid var(--border);border-left:3px solid var(--planner-p,var(--accent));border-radius:var(--r-xs);cursor:pointer;transition:background var(--d-fast) var(--ease-out), border-color var(--d-fast) var(--ease-out), transform var(--d-fast) var(--ease-out), box-shadow var(--d-fast) var(--ease-out);text-align:left;color:var(--text-primary);z-index:2;flex-direction:column;padding:6px 10px;font-family:inherit;display:flex;position:absolute;overflow:hidden;box-shadow:0 1px 3px #00000040}.planner__block:hover{border-color:var(--planner-p,var(--accent));background:var(--surface-hover);box-shadow:0 4px 14px #00000059, 0 0 0 1px var(--planner-p-soft,var(--accent-glow));transform:translate(2px)}.planner__block--habit{border-left-style:dashed}.planner__block--done{opacity:.55}.planner__block--done .planner__block-title{text-decoration:line-through}.planner__block--conflict{border-color:#ffffff59}.planner__block--inline{flex-direction:row;align-items:center;gap:6px;padding:2px 8px}.planner__block-time{color:var(--text-tertiary);font-variant-numeric:tabular-nums;letter-spacing:.03em;white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;font-size:10px;font-weight:500;overflow:hidden}.planner__block--inline .planner__block-time{margin-right:2px}.planner__block-title{letter-spacing:-.01em;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:12.5px;font-weight:600;line-height:1.25;overflow:hidden}.planner__block-icon{margin-right:4px}.planner__block[data-p=URGENT]{--planner-p:#f87171;--planner-p-soft:#f8717147}.planner__block[data-p=HIGH]{--planner-p:#fb923c;--planner-p-soft:#fb923c47}.planner__block[data-p=MEDIUM]{--planner-p:#60a5fa;--planner-p-soft:#60a5fa47}.planner__block[data-p=LOW]{--planner-p:#9ca3af;--planner-p-soft:#9ca3af38}@media (prefers-reduced-motion:reduce){.planner__block{transition:none}.planner__now:before,.section-head--danger:before{animation:none}}.summary{gap:var(--s-3);margin-bottom:var(--s-6);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=640px){.summary{gap:var(--s-2);grid-template-columns:1fr}}.summary__card{padding:var(--s-5);background:var(--surface);-webkit-backdrop-filter:blur(18px)saturate(160%);backdrop-filter:blur(18px)saturate(160%);border:1px solid var(--border);border-radius:var(--r-md)}.summary__label{color:var(--text-tertiary);letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px;font-size:11px;font-weight:600}.summary__value{letter-spacing:-.025em;font-variant-numeric:tabular-nums;font-size:26px;font-weight:600;line-height:1}.summary__hint{color:var(--text-tertiary);font-variant-numeric:tabular-nums;margin-top:5px;font-size:11.5px}.goals{gap:var(--s-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.goal{padding:var(--s-6);background:var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border);border-radius:var(--r-lg);transition:transform var(--d-base) var(--ease-out), box-shadow var(--d-base) var(--ease-out), border-color var(--d-base) var(--ease-out);position:relative;overflow:hidden}.goal:before{content:"";background:var(--goal-color,var(--accent));opacity:.06;filter:blur(30px);width:160px;height:160px;transition:opacity var(--d-base) var(--ease-out);pointer-events:none;border-radius:50%;position:absolute;top:-40px;right:-40px}.goal:hover{box-shadow:var(--shadow-lg);border-color:var(--border-strong);transform:translateY(-3px)}.goal:hover:before{opacity:.12}.goal__head{justify-content:space-between;align-items:flex-start;gap:var(--s-4);margin-bottom:var(--s-5);display:flex;position:relative}.goal__head-main{cursor:pointer;flex:1;min-width:0}.goal__sphere{border-radius:var(--r-full);background:var(--goal-soft,var(--accent-soft));color:var(--goal-color,var(--accent));border:1px solid var(--goal-border,var(--border));white-space:nowrap;align-items:center;gap:6px;padding:4px 10px;font-size:11.5px;font-weight:500;display:inline-flex}.goal__sphere .dot{background:var(--goal-color,var(--accent));border-radius:50%;width:6px;height:6px}.goal__actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.goal__ring{--size:64px;--track:5px;--value:0;--ring-color:var(--goal-color,var(--accent))}.goal__ring .pct{letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:15px;font-weight:600}.goal__title{letter-spacing:-.02em;margin-bottom:6px;font-size:18px;font-weight:600;line-height:1.25;position:relative}.goal__desc{color:var(--text-secondary);margin-bottom:var(--s-5);font-size:13.5px;line-height:1.5;position:relative}.goal__deadline{padding-top:var(--s-4);border-top:1px solid var(--border);color:var(--text-tertiary);justify-content:space-between;align-items:center;font-size:12.5px;display:flex;position:relative}.goal__deadline-info{align-items:center;gap:6px;display:flex}.goal__deadline-days{color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:550}.goal__deadline-days--urgent{color:var(--warning,#f59e0b)}.goal__counter{margin-bottom:var(--s-5);align-items:baseline;gap:6px;display:flex;position:relative}.goal__counter-num{letter-spacing:-.02em;color:var(--goal-color,var(--accent));font-variant-numeric:tabular-nums;font-size:26px;font-weight:600}.goal__counter-label{color:var(--text-secondary);font-size:12.5px}.goal__tasks{margin-top:var(--s-4);padding-top:var(--s-4);border-top:1px solid var(--border);flex-direction:column;gap:6px;display:flex;position:relative}.goal__tasks-toggle{cursor:pointer;color:var(--accent);background:0 0;border:none;align-items:center;gap:4px;padding:0;font-family:inherit;font-size:12px;display:flex}.goal__tasks-toggle-chevron{transition:transform var(--d-fast,.18s) var(--ease-out);font-size:10px;display:inline-block}.goal__tasks-toggle[aria-expanded=true] .goal__tasks-toggle-chevron{transform:rotate(90deg)}.goal__task{color:var(--text-secondary);border-radius:var(--r-sm);background:var(--bg-secondary);cursor:pointer;transition:background var(--d-fast) var(--ease-out);align-items:center;gap:8px;padding:6px 10px;font-size:13px;display:flex}.goal__task:hover{background:var(--surface-hover,var(--surface))}.goal__task--done{color:var(--text-tertiary)}.goal__task--done .goal__task-name{opacity:.7;text-decoration:line-through}.goal__task--archived{opacity:.55;cursor:default;-webkit-user-select:none;user-select:none}.goal__task--archived:hover{background:var(--bg-secondary)}.goal__task--archived .goal__task-name{text-decoration:line-through}.goal__task-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.goal__task-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.goal__task-count{color:var(--text-tertiary);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:11px}.goal__add-task{border-radius:var(--r-sm);border:1px dashed var(--border-strong);color:var(--accent);cursor:pointer;transition:background var(--d-fast) var(--ease-out), border-color var(--d-fast) var(--ease-out);background:0 0;justify-content:center;align-items:center;gap:6px;margin-top:2px;padding:8px 10px;font-family:inherit;font-size:13px;font-weight:500;display:flex}.goal__add-task:hover{background:var(--accent-ghost);border-color:var(--accent)}.goal__footer{margin-top:var(--s-4);flex-wrap:wrap;align-items:center;gap:10px 8px;display:flex;position:relative}.goal__footer-status{color:var(--text-tertiary);white-space:nowrap;font-size:12px}.goal__footer-duration{color:var(--accent);margin-left:6px;font-size:11px}.goal__footer-actions{flex-wrap:wrap;justify-content:flex-end;gap:4px;margin-left:auto;display:flex}.goal--done{background:linear-gradient(135deg, #4ade800f, var(--surface));border-color:#4ade802e}.goal--done .goal__title{color:var(--text-secondary)}.goal--done:after{content:"";background:var(--success);pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 6 9 17l-5-5' stroke='%23000' stroke-width='3' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:18px;border-radius:50%;width:28px;height:28px;position:absolute;top:12px;right:12px;box-shadow:0 4px 12px #4ade804d}.goal--ghost{border:1px dashed var(--border-strong);min-height:240px;color:var(--text-secondary);transition:all var(--d-base) var(--ease-out);cursor:pointer;background:0 0;flex-direction:column;justify-content:center;align-items:center;display:flex}.goal--ghost:before{display:none}.goal--ghost:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-ghost);transform:translateY(-2px)}.goal--ghost__plus{background:var(--surface);border:1px solid var(--border);width:48px;height:48px;margin-bottom:var(--s-3);transition:all var(--d-base) var(--ease-out);color:var(--accent);border-radius:50%;place-items:center;font-size:20px;display:grid}.goal--ghost:hover .goal--ghost__plus{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(90deg)}.goal--ghost__text{font-size:14px;font-weight:500}@media (prefers-reduced-motion:reduce){.goal,.goal--ghost,.goal--ghost__plus{transition:none}.goal:hover,.goal--ghost:hover,.goal--ghost:hover .goal--ghost__plus{transform:none}}.ch-grid{gap:var(--s-4);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.ch-card{padding:var(--s-6);background:radial-gradient(ellipse 260px 180px at 12% 8%, var(--ch-glow,#ff7a301f), transparent 60%), var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);transition:transform var(--d-base) var(--ease-out), box-shadow var(--d-base) var(--ease-out), border-color var(--d-base) var(--ease-out);flex-direction:column;display:flex;position:relative;overflow:hidden}.ch-card:before{content:"";background:radial-gradient(circle at 30% 30%, var(--ch-color,var(--accent)), transparent 70%);opacity:.1;filter:blur(35px);width:180px;height:180px;transition:opacity var(--d-base) var(--ease-out);pointer-events:none;border-radius:50%;position:absolute;top:-40px;right:-40px}.ch-card:hover{box-shadow:var(--shadow-lg);border-color:var(--border-strong);transform:translateY(-3px)}.ch-card:hover:before{opacity:.18}.ch-card__head{justify-content:space-between;align-items:flex-start;gap:var(--s-4);margin-bottom:var(--s-4);display:flex;position:relative}.ch-card__head-main{flex:1;min-width:0}.ch-card__sphere{border-radius:var(--r-full);background:var(--ch-soft,var(--accent-soft));color:var(--ch-color,var(--accent));border:1px solid var(--ch-border,var(--border));white-space:nowrap;align-items:center;gap:5px;margin-bottom:6px;padding:3px 8px;font-size:11px;font-weight:500;display:inline-flex}.ch-card__sphere .dot{background:var(--ch-color,var(--accent));border-radius:50%;width:5px;height:5px}.ch-card__title{letter-spacing:-.02em;font-size:17px;font-weight:600;line-height:1.25;position:relative}.ch-card__ring{--size:72px;--track:6px;--value:0;--ring-color:var(--ch-color,var(--accent));flex-shrink:0}.ch-card__ring .day{letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:17px;font-weight:600;line-height:1}.ch-card__ring .of{color:var(--text-tertiary);letter-spacing:.06em;font-variant-numeric:tabular-nums;margin-top:3px;font-size:9.5px}.ch-card__stats{gap:var(--s-2);padding:var(--s-3) 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:var(--s-4);grid-template-columns:repeat(3,1fr);display:grid;position:relative}.ch-card__stat-label{color:var(--text-tertiary);letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px;font-size:9.5px;font-weight:600}.ch-card__stat-value{letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:16px;font-weight:600;line-height:1}.ch-card__stat-value--accent{color:var(--ch-color,var(--accent))}.ch-card__habits{flex-direction:column;gap:8px;display:flex;position:relative}.ch-habit{align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-4);border:1px solid var(--border);border-radius:var(--r-md);transition:background var(--d-fast) var(--ease-out), border-color var(--d-fast) var(--ease-out);background:#ffffff05;display:flex}[data-theme=light] .ch-habit{background:#00000005}.ch-habit:hover{background:var(--surface-hover);border-color:var(--border-strong)}.ch-habit--done{background:linear-gradient(135deg,#4ade8014,#4ade8005);border-color:#4ade8038}.ch-habit__icon{background:var(--ch-soft,var(--accent-soft));width:32px;height:32px;color:var(--ch-color,var(--accent));border:1px solid var(--ch-border,var(--border));border-radius:8px;flex-shrink:0;place-items:center;font-size:16px;display:grid}.ch-habit__body{flex:1;min-width:0}.ch-habit__name{letter-spacing:-.01em;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:550;line-height:1.2;overflow:hidden}.ch-habit--done .ch-habit__name{color:var(--text-secondary);text-decoration:line-through;-webkit-text-decoration-color:var(--text-tertiary);text-decoration-color:var(--text-tertiary)}.ch-habit__meta{color:var(--text-tertiary);font-variant-numeric:tabular-nums;align-items:center;gap:8px;margin-top:3px;font-size:11px;display:flex}.ch-habit__bar{background:#ffffff0d;border-radius:2px;flex-shrink:0;width:48px;height:4px;overflow:hidden}[data-theme=light] .ch-habit__bar{background:#0000000f}.ch-habit__bar-fill{background:linear-gradient(90deg, var(--ch-color,var(--accent)), color-mix(in srgb, var(--ch-color,var(--accent)) 60%, white));height:100%;transition:width .6s var(--ease-out);border-radius:2px}.ch-habit--done .ch-habit__bar-fill{background:var(--success)}.ch-habit__check{border:2px solid var(--border-strong);cursor:pointer;color:#0000;width:28px;height:28px;transition:all var(--d-fast) var(--ease-out);background:0 0;border-radius:8px;flex-shrink:0;place-items:center;font-size:14px;display:grid}.ch-habit__check:hover{border-color:var(--ch-color,var(--accent));background:var(--ch-soft,var(--accent-ghost))}.ch-habit--done .ch-habit__check{background:var(--success);border-color:var(--success);color:var(--bg-primary,#000)}.ch-card__actions{z-index:1;flex-shrink:0;gap:4px;display:flex;position:relative}.ch-card__footer{margin-top:var(--s-4);padding-top:var(--s-3);border-top:1px solid var(--border);color:var(--text-tertiary);justify-content:space-between;align-items:center;font-size:11.5px;display:flex;position:relative}.ch-card--done{background:linear-gradient(135deg, #4ade800f, var(--surface));opacity:.9;border-color:#4ade802e}.ch-card--done .ch-card__title{color:var(--text-secondary)}.ch-card--done:after{content:"";background:var(--success);pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 6 9 17l-5-5' stroke='%23000' stroke-width='3' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:16px;border-radius:50%;width:26px;height:26px;position:absolute;top:12px;right:12px;box-shadow:0 4px 12px #4ade804d}.ch-card--all-done-today{box-shadow:0 0 0 3px #4ade8014, var(--shadow-md);border-color:#4ade8059}.ch-card--ghost{border:1px dashed var(--border-strong);min-height:200px;color:var(--text-secondary);cursor:pointer;background:0 0;flex-direction:column;justify-content:center;align-items:center;display:flex}.ch-card--ghost:before,.ch-card--ghost:after{display:none}.ch-card--ghost:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-ghost);transform:translateY(-2px)}.ch-card--ghost__plus{background:var(--surface);border:1px solid var(--border);width:44px;height:44px;transition:all var(--d-base) var(--ease-out);color:var(--accent);border-radius:50%;place-items:center;margin-bottom:10px;font-size:18px;display:grid}.ch-card--ghost:hover .ch-card--ghost__plus{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(90deg)}.ch-preset-section{margin-bottom:var(--s-5)}.ch-preset-section__label{color:var(--text-tertiary);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:600}.ch-preset-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;display:grid}.ch-preset{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:transform var(--d-fast) var(--ease-out), border-color var(--d-fast) var(--ease-out), background var(--d-fast) var(--ease-out);text-align:left;color:inherit;padding:12px;font-family:inherit;position:relative;overflow:hidden}.ch-preset:before{content:"";background:var(--ch-color,var(--accent));filter:blur(22px);opacity:.1;pointer-events:none;border-radius:50%;width:80px;height:80px;position:absolute;top:-20px;right:-20px}.ch-preset:hover{border-color:var(--ch-border,var(--accent));transform:translateY(-2px)}.ch-preset--selected{border-color:var(--ch-color,var(--accent));background:var(--ch-soft,var(--accent-soft))}.ch-preset__head{justify-content:space-between;align-items:center;gap:6px;margin-bottom:6px;display:flex;position:relative}.ch-preset__name{letter-spacing:-.015em;flex:1;min-width:0;font-size:13.5px;font-weight:600;line-height:1.25}.ch-preset__days{border-radius:var(--r-full);background:var(--ch-soft,var(--accent-soft));color:var(--ch-color,var(--accent));font-variant-numeric:tabular-nums;flex-shrink:0;padding:2px 6px;font-size:10.5px;font-weight:600}.ch-preset__desc{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:8px;font-size:11.5px;line-height:1.4;display:-webkit-box;position:relative;overflow:hidden}.ch-preset__habits{flex-wrap:wrap;gap:4px;display:flex;position:relative}.ch-preset__habit{border-radius:var(--r-sm);color:var(--text-secondary);white-space:nowrap;background:#ffffff0a;padding:2px 6px;font-size:10.5px}[data-theme=light] .ch-preset__habit{background:#0000000a}.ch-preset-divider{color:var(--text-tertiary);letter-spacing:.08em;text-transform:uppercase;align-items:center;gap:10px;margin:14px 0 10px;font-size:11px;font-weight:600;display:flex}.ch-preset-divider:before,.ch-preset-divider:after{content:"";background:var(--border);flex:1;height:1px}@media (prefers-reduced-motion:reduce){.ch-card,.ch-habit,.ch-habit__check,.ch-preset,.ch-card--ghost__plus{transition:none}.ch-card:hover,.ch-card--ghost:hover,.ch-preset:hover,.ch-card--ghost:hover .ch-card--ghost__plus{transform:none}}.adm__head{justify-content:space-between;align-items:flex-end;gap:var(--s-6);margin-bottom:var(--s-6);flex-wrap:wrap;display:flex}.adm__title-wrap h1{letter-spacing:-.032em;background:linear-gradient(180deg, var(--text-grad-from) 30%, var(--text-grad-to) 100%);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:30px;font-weight:600;line-height:1.1}.adm__sub{color:var(--text-3);margin-top:6px;font-size:13.5px}.adm__pulse{border-radius:var(--r-full);background:var(--success-soft);color:var(--success);font-variant-numeric:tabular-nums;border:1px solid #4ade8040;align-items:center;gap:8px;padding:7px 12px;font-size:12.5px;font-weight:550;line-height:1;display:inline-flex}.adm__pulse-dot{background:var(--success);border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite adm-ping;box-shadow:0 0 0 4px #4ade8033}@keyframes adm-ping{0%,to{opacity:1;box-shadow:0 0 0 4px #4ade8033}50%{opacity:.6;box-shadow:0 0 0 7px #4ade800d}}.adm__kpi{gap:var(--s-3);margin-bottom:var(--s-6);grid-template-columns:repeat(auto-fit,minmax(170px,1fr));display:grid}.kpi{padding:var(--s-4);background:var(--surface);-webkit-backdrop-filter:blur(18px)saturate(160%);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);transition:transform var(--d-base) var(--ease-out), box-shadow var(--d-base) var(--ease-out), border-color var(--d-base) var(--ease-out);position:relative;overflow:hidden}.kpi:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-2px)}.kpi:before{content:"";background:radial-gradient(circle at 30% 30%, var(--kpi-color,var(--accent)), transparent 70%);opacity:.1;filter:blur(26px);pointer-events:none;border-radius:50%;width:120px;height:120px;position:absolute;top:-30px;right:-30px}.kpi__label{color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;margin-bottom:10px;font-size:10.5px;font-weight:600;display:flex;overflow:hidden}.kpi__label-dot{background:var(--kpi-color,var(--accent));border-radius:50%;flex-shrink:0;width:6px;height:6px}.kpi__value{letter-spacing:-.032em;font-variant-numeric:tabular-nums;font-size:28px;font-weight:600;line-height:1}.adm__tabs{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-full);margin-bottom:var(--s-5);-webkit-backdrop-filter:blur(14px)saturate(150%);flex-wrap:wrap;gap:2px;max-width:100%;padding:4px;display:inline-flex}.adm__tab{color:var(--text-2);border-radius:var(--r-full);cursor:pointer;transition:all var(--d-fast) var(--ease-io);letter-spacing:-.005em;background:0 0;border:none;align-items:center;gap:7px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex}.adm__tab:hover{color:var(--text-1)}.adm__tab--active{background:var(--surface-strong);color:var(--text-1);box-shadow:inset 0 1px #ffffff14}.adm__tab svg{width:15px;height:15px}.adm__tab__badge{border-radius:var(--r-full);background:var(--accent-soft);min-width:20px;height:18px;color:var(--accent);font-variant-numeric:tabular-nums;justify-content:center;align-items:center;padding:0 6px;font-size:10.5px;font-weight:600;display:inline-flex}.panel{background:var(--surface);-webkit-backdrop-filter:blur(18px)saturate(160%);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);overflow:hidden}.panel+.panel{margin-top:var(--s-4)}.panel__head{justify-content:space-between;align-items:center;gap:var(--s-4);padding:var(--s-4) var(--s-5);border-bottom:1px solid var(--border);flex-wrap:wrap;display:flex}.panel__title{letter-spacing:-.015em;margin:0;font-size:14.5px;font-weight:600}.panel__sub{color:var(--text-3);font-variant-numeric:tabular-nums;font-size:12px}.panel__body{padding:var(--s-4) var(--s-5)}.panel--padded .panel__body{padding:var(--s-5)}.adm__toolbar{gap:var(--s-3);padding:var(--s-3) var(--s-5);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;display:flex}.adm__search{flex:1;min-width:200px;position:relative}.adm__search input{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text-1);transition:border-color var(--d-fast), background var(--d-fast), box-shadow var(--d-fast);box-sizing:border-box;padding:10px 14px 10px 36px;font-family:inherit;font-size:13.5px}.adm__search input:focus{border-color:var(--accent);background:var(--bg-1);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.adm__search__ico{color:var(--text-3);width:16px;height:16px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.adm__chip-group{flex-wrap:wrap;gap:6px;display:inline-flex}.adm-chip{border-radius:var(--r-full);background:var(--bg-2);border:1px solid var(--border);color:var(--text-2);cursor:pointer;transition:all var(--d-fast) var(--ease-io);align-items:center;gap:4px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:500;display:inline-flex}.adm-chip:hover{color:var(--text-1);border-color:var(--border-strong)}.adm-chip:disabled{opacity:.5;cursor:not-allowed}.adm-chip--active{background:var(--accent-soft);color:var(--accent);border-color:#ff7a304d}.adm-chip--ghost{background:0 0}.adm-chip--danger{color:var(--danger);border-color:#f8717140}.adm-chip--danger:hover{background:var(--danger-soft);border-color:var(--danger)}.adm__filters{padding:var(--s-4) var(--s-5);border-bottom:1px solid var(--border);background:#ffffff04;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;display:grid}[data-theme=light] .adm__filters{background:#14141905}.adm__filters label{color:var(--text-3);letter-spacing:.04em;text-transform:uppercase;flex-direction:column;gap:4px;font-size:10.5px;font-weight:600;display:flex}.adm__filters input,.adm__filters select{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-xs);color:var(--text-1);box-sizing:border-box;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;text-transform:none;letter-spacing:normal;width:100%;padding:8px 10px;font-family:inherit;font-size:13px}[data-theme=light] .adm__filters input,[data-theme=light] .adm__filters select{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}.adm__filters input:focus,.adm__filters select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.adm__filters__actions{grid-column:1/-1;justify-content:flex-end;gap:8px;display:flex}.u-head{gap:var(--s-3);padding:10px var(--s-5);background:var(--bg-2);color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;grid-template-columns:44px minmax(0,1.2fr) minmax(0,1fr) 88px 88px 96px;align-items:center;font-size:10.5px;font-weight:600;display:grid}.u-row{gap:var(--s-3);padding:var(--s-3) var(--s-5);border-top:1px solid var(--border);transition:background var(--d-fast) var(--ease-io);cursor:pointer;grid-template-columns:44px minmax(0,1.2fr) minmax(0,1fr) 88px 88px 96px;align-items:center;font-size:13px;display:grid}.u-row:first-of-type{border-top:none}.u-row:hover{background:var(--surface-hover)}.u-empty{padding:var(--s-8) var(--s-5);text-align:center;color:var(--text-3);font-size:13px}@media (width<=720px){.u-head{display:none}.u-row{grid-template-columns:40px 1fr auto;grid-template-areas:"avatar name role""avatar email when";gap:4px 10px}.u-row__avatar{grid-area:avatar}.u-row__name{grid-area:name}.u-row__email{grid-area:email}.u-row__role{grid-area:role;justify-self:end}.u-row__xp{display:none}.u-row__when{grid-area:when;justify-self:end;font-size:11px}}.avatar{background:linear-gradient(135deg, var(--av-a,#ff7a30), var(--av-b,#5f8aac));color:#fff;letter-spacing:-.01em;text-transform:uppercase;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12.5px;font-weight:600;display:inline-flex;position:relative}.avatar--sm{width:32px;height:32px;font-size:11px}.avatar__online{background:var(--success);border:2px solid var(--bg-1);border-radius:50%;width:10px;height:10px;position:absolute;bottom:-1px;right:-1px}.u-name{color:var(--text-1);letter-spacing:-.01em;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:550;line-height:1.3;overflow:hidden}.u-email{color:var(--text-3);text-overflow:ellipsis;white-space:nowrap;font-variant-numeric:tabular-nums;font-size:12px;overflow:hidden}.u-role{border-radius:var(--r-full);letter-spacing:.04em;color:var(--info);text-transform:uppercase;white-space:nowrap;background:#60a5fa1f;border:1px solid #60a5fa38;align-items:center;padding:3px 8px;font-size:10px;font-weight:600;display:inline-flex}.u-role--admin{background:var(--accent-soft);color:var(--accent);border-color:#ff7a3040}.u-role--manager{background:var(--warning-soft);color:var(--warning);border-color:#fbbf2438}.u-role--support{color:#a78bfa;background:#8b5cf61f;border-color:#8b5cf638}.u-role--user{color:var(--text-2);border-color:var(--border);background:#ffffff0d}.u-role--blocked{background:var(--danger-soft);color:var(--danger);border-color:#f8717138}.u-row__star{color:var(--warning);margin-right:4px;font-size:14px;line-height:1}.u-xp{font-variant-numeric:tabular-nums;color:var(--text-1);font-size:12.5px;font-weight:600;line-height:1.15}.u-xp span{color:var(--text-3);letter-spacing:.04em;text-transform:uppercase;margin-top:1px;font-size:10px;font-weight:500;display:block}.u-when{color:var(--text-2);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:11.5px}.u-when--stale{color:var(--text-3)}.u-footer{justify-content:space-between;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-5);border-top:1px solid var(--border);color:var(--text-3);flex-wrap:wrap;font-size:12px;display:flex}.pager{gap:4px;display:inline-flex}.pager button{background:var(--bg-2);border:1px solid var(--border);color:var(--text-2);border-radius:var(--r-xs);cursor:pointer;font-variant-numeric:tabular-nums;transition:all var(--d-fast) var(--ease-io);min-width:32px;padding:6px 10px;font-family:inherit;font-size:12.5px}.pager button:hover:not(:disabled){color:var(--text-1);border-color:var(--border-strong)}.pager button:disabled{opacity:.4;cursor:not-allowed}.pager button.active{background:var(--accent);border-color:var(--accent);color:#fff}.sub-stats{gap:var(--s-3);padding:var(--s-4) var(--s-5);border-bottom:1px solid var(--border);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));display:grid}.sub-stat{flex-direction:column;gap:4px;display:flex}.sub-stat__label{color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;font-size:10.5px;font-weight:600}.sub-stat__value{letter-spacing:-.022em;font-variant-numeric:tabular-nums;color:var(--text-1);font-size:20px;font-weight:600;line-height:1}.sub-stat__hint{color:var(--text-3);font-variant-numeric:tabular-nums;font-size:11px}.split-2{gap:var(--s-3);padding:var(--s-4) var(--s-5);border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;display:grid}@media (width<=540px){.split-2{grid-template-columns:1fr}}.split-card{padding:var(--s-4);border-radius:var(--r-sm);background:var(--bg-2);border:1px solid var(--border);position:relative;overflow:hidden}.split-card:before{content:"";background:var(--split-color,var(--accent));opacity:.1;filter:blur(20px);border-radius:50%;width:80px;height:80px;position:absolute;top:-20px;right:-20px}.split-card__name{color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:10.5px;font-weight:600;position:relative}.split-card__value{letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-bottom:4px;font-size:20px;font-weight:600;position:relative}.split-card__sub{color:var(--text-2);font-variant-numeric:tabular-nums;font-size:11.5px;position:relative}.split-card__neg{color:var(--danger)}.split-card__pending{color:var(--warning)}.adm__period{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-xs);gap:2px;padding:3px;display:inline-flex}.adm__period button{color:var(--text-3);cursor:pointer;letter-spacing:.02em;font-variant-numeric:tabular-nums;transition:color var(--d-fast), background var(--d-fast);background:0 0;border:none;border-radius:6px;padding:5px 12px;font-family:inherit;font-size:11.5px;font-weight:600}.adm__period button:hover{color:var(--text-1)}.adm__period button.active{background:var(--accent);color:#fff}.chart{padding:var(--s-4) var(--s-5);border-bottom:1px solid var(--border)}.chart--last{border-bottom:none}.chart__title{letter-spacing:-.01em;color:var(--text-1);justify-content:space-between;align-items:center;gap:10px;margin:0 0 10px;font-size:13px;font-weight:600;display:flex}.chart__legend{color:var(--text-3);gap:12px;font-size:11px;font-weight:500;display:inline-flex}.chart__legend-dot{vertical-align:middle;border-radius:2px;width:8px;height:8px;margin-right:5px;display:inline-block}.bars{align-items:flex-end;gap:2px;height:100px;display:flex}.bars--sm{height:72px}.bar{min-width:3px;transition:opacity var(--d-fast);flex-direction:column-reverse;flex:1;gap:0;display:flex}.bar:hover{opacity:.75}.bar__seg{background:var(--accent);border-radius:0;width:100%}.bar__seg--top,.bar__seg--only{border-radius:3px 3px 0 0}.bar__seg--stars{background:orange}.bar__seg--rub{background:var(--accent)}.bar__seg--ai{background:#8b5cf6}.chart__xaxis{color:var(--text-3);font-variant-numeric:tabular-nums;justify-content:space-between;margin-top:6px;font-size:10px;display:flex}.tbl{border-collapse:collapse;width:100%;font-size:12.5px}.tbl th{text-align:left;color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;padding:8px var(--s-5);background:var(--bg-2);font-size:10.5px;font-weight:600}.tbl th.right,.tbl td.right{text-align:right;font-variant-numeric:tabular-nums}.tbl td{padding:10px var(--s-5);border-top:1px solid var(--border);color:var(--text-1)}.tbl td.muted{color:var(--text-2)}.tbl tbody tr:hover td{background:var(--surface-hover)}.top-row{padding:10px var(--s-5);border-top:1px solid var(--border);cursor:pointer;transition:background var(--d-fast);grid-template-columns:28px 40px minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.top-row:hover{background:var(--surface-hover)}.top-row__rank{color:var(--text-3);font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.top-row__rank--1{color:#ffd166}.top-row__rank--2{color:silver}.top-row__rank--3{color:#cd7f32}.top-row__right{text-align:right;font-variant-numeric:tabular-nums;color:var(--text-1);font-size:13px;font-weight:600}.top-row__right-sub{color:var(--text-3);margin-top:2px;font-size:11px;font-weight:500}.push-subtabs{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-xs);margin-bottom:var(--s-4);gap:2px;padding:3px;display:inline-flex}.push-subtabs button{color:var(--text-3);cursor:pointer;transition:color var(--d-fast), background var(--d-fast);background:0 0;border:none;border-radius:6px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:600}.push-subtabs button:hover{color:var(--text-1)}.push-subtabs button.active{background:var(--accent);color:#fff}.push-form{flex-direction:column;gap:10px;display:flex}.push-form__row{grid-template-columns:1fr 1fr;gap:10px;display:grid}@media (width<=540px){.push-form__row{grid-template-columns:1fr}}.form-row{flex-direction:column;gap:4px;display:flex}.form-row__label{color:var(--text-3);letter-spacing:.04em;text-transform:uppercase;font-size:10.5px;font-weight:600}.adm-input{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text-1);transition:border-color var(--d-fast), background var(--d-fast), box-shadow var(--d-fast);box-sizing:border-box;padding:10px 12px;font-family:inherit;font-size:13.5px}.adm-input:focus{border-color:var(--accent);background:var(--bg-1);box-shadow:0 0 0 3px var(--accent-soft);outline:none}textarea.adm-input{resize:vertical;min-height:80px;font-family:inherit}textarea.adm-input--mono{font-family:var(--font-mono);font-size:12.5px}select.adm-input{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2398989a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-position:right 10px center;background-repeat:no-repeat;background-size:16px 16px;padding-right:36px}.adm-btn{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-2);color:var(--text-1);cursor:pointer;transition:all var(--d-fast) var(--ease-io);letter-spacing:-.005em;justify-content:center;align-items:center;gap:6px;padding:9px 16px;font-family:inherit;font-size:13px;font-weight:550;line-height:1;display:inline-flex}.adm-btn:hover:not(:disabled){border-color:var(--border-strong)}.adm-btn:disabled{opacity:.5;cursor:not-allowed}.adm-btn--primary{background:linear-gradient(180deg, var(--accent-hover) 0%, var(--accent) 100%);border-color:var(--accent);color:#fff;position:relative;overflow:hidden;box-shadow:0 1px 2px #0000004d,0 4px 12px #ff7a3033,inset 0 1px #ffffff38}.adm-btn--primary:after{content:"";transition:transform .7s var(--ease-out);pointer-events:none;background:linear-gradient(120deg,#0000 30%,#ffffff40 50%,#0000 70%);position:absolute;inset:0;transform:translate(-120%)}.adm-btn--primary:hover:after{transform:translate(120%)}.adm-btn--primary:hover:not(:disabled){filter:brightness(1.05);box-shadow:0 2px 4px #0000004d,0 8px 24px #ff7a304d,inset 0 1px #ffffff38}.adm-btn--primary:active:not(:disabled){filter:brightness(.95);transform:scale(.98)}.adm-btn--ghost{border-color:var(--border);color:var(--text-2);background:0 0}.adm-btn--ghost:hover:not(:disabled){color:var(--text-1);border-color:var(--border-strong)}.adm-btn--danger{color:var(--danger);border-color:#f8717140}.adm-btn--danger:hover:not(:disabled){background:var(--danger-soft);border-color:var(--danger)}.adm-btn--full{width:100%}.alert{margin-top:var(--s-3);border-radius:var(--r-sm);align-items:center;gap:8px;padding:10px 14px;font-size:12.5px;line-height:1.4;display:flex}.alert--success{background:var(--success-soft);color:var(--success);border:1px solid #4ade8040}.alert--error{background:var(--danger-soft);color:var(--danger);border:1px solid #f8717140}.alert--info{background:var(--info-soft);color:var(--info);border:1px solid #60a5fa38}.alert svg{flex-shrink:0;width:16px;height:16px}.push-preview{background:linear-gradient(135deg, var(--bg-2), var(--bg-1));border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s-4);margin-top:var(--s-3);box-shadow:var(--shadow-sm);position:relative}.push-preview__head{align-items:center;gap:10px;margin-bottom:8px;display:flex}.push-preview__ico{border-radius:var(--r-xs);background:linear-gradient(135deg, var(--accent), #ff5a16);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:inline-flex}.push-preview__meta{flex:1;justify-content:space-between;align-items:baseline;gap:10px;min-width:0;display:flex}.push-preview__app{color:var(--text-2);letter-spacing:.02em;text-transform:uppercase;font-size:11.5px;font-weight:600}.push-preview__time{color:var(--text-3);font-variant-numeric:tabular-nums;font-size:10.5px}.push-preview__title{letter-spacing:-.01em;color:var(--text-1);word-break:break-word;margin-bottom:2px;font-size:14px;font-weight:600}.push-preview__body{color:var(--text-2);word-break:break-word;font-size:13px;line-height:1.4}.push-preview__empty{color:var(--text-3);text-align:center;padding:10px 0;font-size:12.5px}.backup{border-radius:var(--r-sm);background:var(--bg-2);border:1px solid var(--border);transition:border-color var(--d-fast), transform var(--d-fast);flex-direction:column;gap:10px;padding:12px 14px;display:flex}.backup:hover{border-color:var(--border-strong);transform:translateY(-1px)}.backup__head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.backup__name{font-family:var(--font-mono);color:var(--text-1);text-overflow:ellipsis;white-space:nowrap;word-break:break-all;font-size:12.5px;font-weight:550;overflow:hidden}.backup__meta{color:var(--text-3);font-variant-numeric:tabular-nums;flex-wrap:wrap;align-items:center;gap:12px;margin-top:4px;font-size:11.5px;display:flex}.backup__badge{border-radius:var(--r-full);letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;font-size:10px;font-weight:600}.backup__badge--manual{background:var(--accent-soft);color:var(--accent);border:1px solid #ff7a3040}.backup__badge--auto{background:var(--info-soft);color:var(--info);border:1px solid #60a5fa38}.backup__actions{flex-wrap:wrap;gap:6px;display:flex}.backup__actions .adm-btn{flex:auto;padding:6px 12px;font-size:12px}.backup-list{flex-direction:column;gap:10px;display:flex}@media (prefers-reduced-motion:reduce){.kpi,.u-row,.adm-chip,.adm__tab,.backup,.bar,.top-row{transition:none;animation:none}.kpi:hover,.backup:hover{transform:none}.adm__pulse-dot{animation:none}.adm-btn--primary:after{display:none}}.sph-summary{gap:var(--s-3);margin-bottom:var(--s-6);grid-template-columns:repeat(3,1fr);display:grid}.sph-summary__card{padding:var(--s-5);background:var(--surface);-webkit-backdrop-filter:blur(18px)saturate(160%);border:1px solid var(--border);border-radius:var(--r-md);position:relative;overflow:hidden}.sph-summary__card:before{content:"";background:var(--card-color,var(--accent));opacity:.06;filter:blur(30px);pointer-events:none;border-radius:50%;width:140px;height:140px;position:absolute;top:-40px;right:-40px}.sph-summary__label{color:var(--text-tertiary);letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px;font-size:11px;font-weight:600}.sph-summary__value{letter-spacing:-.025em;font-variant-numeric:tabular-nums;align-items:center;gap:8px;font-size:28px;font-weight:600;line-height:1;display:flex}.sph-summary__hint{color:var(--text-tertiary);align-items:center;gap:6px;margin-top:8px;font-size:11.5px;display:flex}.sph-summary--solo{grid-template-columns:1fr}.sph-summary__spark{align-items:flex-end;gap:2px;height:12px;display:inline-flex}.sph-summary__spark span{background:var(--card-color,var(--accent));opacity:.7;border-radius:2px;width:3px}.sph-grid{gap:var(--s-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.sph{padding:var(--s-6);background:var(--surface);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:transform var(--d-base) var(--ease-out), box-shadow var(--d-base) var(--ease-out), border-color var(--d-base) var(--ease-out);position:relative;overflow:hidden}.sph:before{content:"";background:var(--sph-color,var(--accent));opacity:.1;filter:blur(32px);width:180px;height:180px;transition:opacity var(--d-base) var(--ease-out);pointer-events:none;border-radius:50%;position:absolute;top:-60px;right:-60px}.sph:hover{box-shadow:var(--shadow-lg);border-color:var(--border-strong);transform:translateY(-3px)}.sph:hover:before{opacity:.18}.sph__head{justify-content:space-between;align-items:flex-start;gap:var(--s-3);margin-bottom:var(--s-5);display:flex;position:relative}.sph__icon{background:var(--sph-soft);border:1px solid var(--sph-border);width:56px;height:56px;box-shadow:inset 0 1px 0 #ffffff14, 0 4px 16px var(--sph-glow);transition:transform var(--d-base) var(--ease-spring);border-radius:18px;flex-shrink:0;place-items:center;font-size:28px;display:grid}.sph:hover .sph__icon{transform:rotate(-4deg)scale(1.05)}.sph__rating{background:conic-gradient(var(--sph-color) calc(var(--sph-progress,0) * 1%), #ffffff14 0);width:64px;height:64px;transition:background .8s var(--ease-out);box-shadow:0 0 20px var(--sph-glow);border-radius:50%;flex-shrink:0;place-items:center;display:grid;position:relative}.sph__rating:before{content:"";background:var(--bg-1);border-radius:50%;position:absolute;inset:4px;box-shadow:inset 0 1px #ffffff0d}.sph__rating-value{z-index:1;letter-spacing:-.025em;font-variant-numeric:tabular-nums;color:var(--sph-color);font-size:22px;font-weight:600;line-height:1;position:relative}.sph__rating-next{z-index:1;color:var(--text-tertiary);letter-spacing:.04em;font-variant-numeric:tabular-nums;margin-top:2px;font-size:9px;font-weight:500;position:relative}.sph__name{letter-spacing:-.015em;margin-bottom:6px;font-size:17px;font-weight:600;line-height:1.25;position:relative}.sph__meta{border-radius:var(--r-full);background:var(--sph-soft);border:1px solid var(--sph-border);color:var(--sph-color);align-items:center;gap:6px;padding:3px 9px;font-size:12px;font-weight:500;display:inline-flex;position:relative}.sph__meta--custom{background:var(--surface-strong);border-color:var(--border-strong);color:var(--text-secondary)}.sph__progress{margin-top:var(--s-5);position:relative}.sph__progress-head{color:var(--text-tertiary);font-variant-numeric:tabular-nums;justify-content:space-between;align-items:baseline;margin-bottom:6px;font-size:11.5px;display:flex}.sph__progress-pts{color:var(--sph-color);font-weight:600}.sph__progress-bar{background:var(--surface-strong);border:1px solid var(--border);border-radius:2px;height:4px;position:relative;overflow:hidden}.sph__progress-bar:after{content:"";width:calc(var(--sph-progress,0) * 1%);background:var(--sph-color);box-shadow:0 0 8px var(--sph-glow);transition:width .8s var(--ease-out);border-radius:2px;position:absolute;inset:0}.sph__foot{margin-top:var(--s-4);padding-top:var(--s-4);border-top:1px solid var(--border);color:var(--text-tertiary);justify-content:space-between;align-items:center;min-height:36px;font-size:12.5px;display:flex;position:relative}.sph__delta{align-items:center;gap:4px;font-weight:550;display:inline-flex}.sph__delta--up{color:var(--success)}.sph__delta--flat{color:var(--text-tertiary)}.sph__delta--down{color:var(--danger)}.sph__delta svg{width:12px;height:12px}.sph__actions{gap:4px;display:inline-flex}.sph__btn{width:30px;height:30px;color:var(--text-tertiary);background:var(--surface);border:1px solid var(--border);transition:all var(--d-fast) var(--ease-io);cursor:pointer;border-radius:8px;place-items:center;display:grid}.sph__btn:hover{color:var(--text-primary);background:var(--surface-hover);border-color:var(--border-strong)}.sph__btn--danger:hover{color:var(--danger);background:var(--danger-soft);border-color:#f871714d}.sph__btn svg{width:14px;height:14px}.sph__badge{top:var(--s-3);left:var(--s-3);z-index:2;border-radius:var(--r-full);color:#1a1a1f;letter-spacing:.02em;background:linear-gradient(135deg,#fbbf24,#f59e0b);align-items:center;gap:4px;padding:3px 8px;font-size:10.5px;font-weight:600;display:inline-flex;position:absolute;box-shadow:0 4px 12px #f59e0b4d}.sph__badge svg{width:10px;height:10px}.sph--ghost{border:1px dashed var(--border-strong);min-height:260px;color:var(--text-secondary);cursor:pointer;transition:all var(--d-base) var(--ease-out);background:0 0;flex-direction:column;justify-content:center;align-items:center;display:flex}.sph--ghost:before{display:none}.sph--ghost:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-ghost);transform:translateY(-2px)}.sph--ghost__plus{background:var(--surface);border:1px solid var(--border);width:52px;height:52px;margin-bottom:var(--s-3);transition:all var(--d-base) var(--ease-out);color:inherit;border-radius:50%;place-items:center;display:grid}.sph--ghost:hover .sph--ghost__plus{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(90deg)}.sph--ghost__plus svg{width:22px;height:22px}.sph--ghost__text{margin-bottom:2px;font-size:14px;font-weight:500}.sph--ghost__hint{color:var(--text-tertiary);font-size:12px}.sph-help{margin-top:var(--s-6);padding:var(--s-5);background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--r-md);color:var(--text-secondary);font-size:13.5px;line-height:1.55}.sph-help__title{color:var(--text-primary);margin-bottom:6px;font-size:13px;font-weight:600}@media (width<=720px){.sph-summary{grid-template-columns:1fr 1fr}.sph-summary__card:nth-child(3){grid-column:1/-1}}@media (prefers-reduced-motion:reduce){.sph{transition:none}.sph:hover,.sph:hover .sph__icon{transform:none}.sph__progress-bar:after,.sph__rating{transition:none}}
