:root{color-scheme:light;--color-charcoal: #222833;--color-mint: #47D5BF;--color-coral: #F5A08F;--color-off-white: #F7F4EF;--color-deep-slate: #131A24;--color-teal: var(--color-mint);--color-sky: #6BC9BE;--color-sun: #F7C4B8;--color-cream: var(--color-off-white);--color-navy: var(--color-charcoal);--header-bg: var(--color-off-white);--bg: var(--color-off-white);--bg-shell: #EDE8E0;--bg-card: #FFFFFF;--surface: #FFFFFF;--surface-glass: rgba(247, 244, 239, .97);--surface-muted: rgba(247, 244, 239, .82);--card-gradient-from: #FFFFFF;--text: var(--color-charcoal);--text-muted: rgba(34, 40, 51, .68);--text-light: rgba(34, 40, 51, .48);--primary: var(--color-mint);--primary-light: #6BE0CD;--primary-soft: rgba(71, 213, 191, .14);--btn-primary-fg: var(--color-deep-slate);--secondary: var(--color-sky);--secondary-soft: rgba(107, 201, 190, .16);--secondary-light: #8AD9CF;--nav-accent: var(--color-coral);--nav-accent-light: #F7B5A8;--nav-accent-soft: var(--rose-soft);--nav-accent-text: var(--color-mint);--nav-accent-on: var(--color-deep-slate);--nav-highlight-bg: var(--primary-soft);--nav-highlight-text: var(--color-charcoal);--shadow-nav: 0 2px 10px rgba(245, 160, 143, .32);--shadow-nav-lg: 0 4px 14px rgba(245, 160, 143, .38);--accent: var(--color-mint);--accent-soft: rgba(71, 213, 191, .12);--accent-text: #2FA894;--warm: var(--color-sun);--warm-soft: rgba(247, 196, 184, .22);--warm-text: #C97862;--warm-text-alt: #B86A55;--rose: var(--color-coral);--rose-soft: rgba(245, 160, 143, .14);--sky: var(--color-sky);--sky-soft: rgba(107, 201, 190, .16);--sky-text: #3A9A8E;--border: rgba(34, 40, 51, .1);--card-border: rgba(34, 40, 51, .08);--overlay: rgba(19, 26, 36, .45);--avatar-gradient: linear-gradient(135deg, var(--color-mint), var(--color-coral));--chip-rose-bg: rgba(245, 160, 143, .16);--chip-rose-text: #C97862;--chip-purple-bg: rgba(107, 201, 190, .18);--chip-purple-text: #3A9A8E;--chip-neutral-bg: rgba(34, 40, 51, .06);--chip-neutral-text: var(--text-muted);--challenge-active-bg: rgba(255, 209, 102, .38);--challenge-active-border: rgba(180, 120, 20, .45);--challenge-active-text: #5C4200;--challenge-active-status-bg: rgba(255, 193, 50, .55);--challenge-active-status-text: #4A3600;--challenge-completed-bg: rgba(71, 213, 191, .22);--challenge-completed-border: rgba(35, 140, 120, .4);--challenge-completed-text: #0F4A40;--challenge-completed-status-bg: rgba(53, 199, 161, .45);--challenge-completed-status-text: #0A3D34;--challenge-not-completed-bg: rgba(245, 160, 143, .28);--challenge-not-completed-border: rgba(180, 80, 60, .45);--challenge-not-completed-text: #6B2E1F;--challenge-not-completed-status-bg: rgba(220, 90, 70, .35);--challenge-not-completed-status-text: #5A1F12;--trend-guide: rgba(34, 40, 51, .1);--trend-commitment-fill: rgba(71, 213, 191, .14);--trend-consistency-fill: rgba(107, 201, 190, .16);--trend-plot-bg: linear-gradient(180deg, rgba(71, 213, 191, .06) 0%, rgba(71, 213, 191, 0) 100%), linear-gradient(180deg, rgba(107, 201, 190, .05) 0%, transparent 100%);--shadow-sm: 0 1px 3px rgba(34, 40, 51, .06);--shadow-md: 0 4px 16px rgba(34, 40, 51, .08);--shadow-lg: 0 8px 32px rgba(34, 40, 51, .1);--shadow-primary: 0 2px 10px rgba(71, 213, 191, .28);--toast-bg: var(--color-charcoal);--toast-fg: var(--color-off-white);--toast-border: transparent;--radius: 16px;--radius-sm: 10px;--radius-pill: 999px;--nav-height: 72px;--header-height: 64px;--shell-top: calc(var(--header-height) + env(safe-area-inset-top, 0px));--shell-bottom: calc(var(--nav-height) + env(safe-area-inset-bottom, 0px));--max-width: 480px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif}@media(prefers-color-scheme:dark){:root:not([data-theme-mode=light]){color-scheme:dark;--header-bg: var(--color-deep-slate);--bg: var(--color-deep-slate);--bg-shell: #0F141C;--bg-card: var(--color-charcoal);--surface: var(--color-charcoal);--surface-glass: rgba(34, 40, 51, .95);--surface-muted: rgba(34, 40, 51, .78);--card-gradient-from: #2A3140;--text: var(--color-off-white);--text-muted: rgba(247, 244, 239, .72);--text-light: rgba(247, 244, 239, .48);--primary: #55DCC7;--primary-light: #72E4D3;--primary-soft: rgba(71, 213, 191, .2);--btn-primary-fg: var(--color-deep-slate);--secondary-soft: rgba(107, 201, 190, .16);--secondary-light: #8AD9CF;--nav-accent: #F5A08F;--nav-accent-light: #F7B5A8;--nav-accent-soft: rgba(245, 160, 143, .18);--nav-accent-text: var(--color-mint);--nav-accent-on: var(--color-deep-slate);--nav-highlight-bg: var(--primary-soft);--nav-highlight-text: var(--color-off-white);--shadow-nav: 0 2px 10px rgba(245, 160, 143, .22);--shadow-nav-lg: 0 4px 14px rgba(245, 160, 143, .28);--accent-soft: rgba(71, 213, 191, .16);--accent-text: #6BE0CD;--warm-soft: rgba(247, 196, 184, .14);--warm-text: var(--color-sun);--warm-text-alt: var(--color-sun);--rose-soft: rgba(245, 160, 143, .16);--sky-soft: rgba(107, 201, 190, .14);--sky-text: var(--color-sky);--border: rgba(247, 244, 239, .1);--card-border: rgba(247, 244, 239, .08);--overlay: rgba(0, 0, 0, .65);--avatar-gradient: linear-gradient(135deg, var(--color-mint), var(--color-coral));--chip-rose-bg: rgba(245, 160, 143, .18);--chip-rose-text: #F7B5A8;--chip-purple-bg: rgba(107, 201, 190, .16);--chip-purple-text: var(--color-sky);--chip-neutral-bg: rgba(247, 244, 239, .08);--chip-neutral-text: var(--text-muted);--challenge-active-bg: rgba(255, 209, 102, .16);--challenge-active-border: rgba(255, 209, 102, .35);--challenge-active-text: #FFD166;--challenge-active-status-bg: rgba(255, 209, 102, .28);--challenge-active-status-text: #FFE8A3;--challenge-completed-bg: rgba(71, 213, 191, .14);--challenge-completed-border: rgba(71, 213, 191, .35);--challenge-completed-text: #9EF0E0;--challenge-completed-status-bg: rgba(53, 199, 161, .28);--challenge-completed-status-text: #C8FAEE;--challenge-not-completed-bg: rgba(245, 160, 143, .14);--challenge-not-completed-border: rgba(245, 160, 143, .35);--challenge-not-completed-text: #F7B5A8;--challenge-not-completed-status-bg: rgba(245, 160, 143, .25);--challenge-not-completed-status-text: #FFD4C8;--trend-guide: rgba(247, 244, 239, .1);--trend-commitment-fill: rgba(71, 213, 191, .22);--trend-consistency-fill: rgba(107, 201, 190, .18);--trend-plot-bg: linear-gradient(180deg, rgba(71, 213, 191, .08) 0%, rgba(71, 213, 191, 0) 100%), linear-gradient(180deg, rgba(107, 201, 190, .06) 0%, transparent 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .35);--shadow-md: 0 4px 16px rgba(0, 0, 0, .42);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .55);--shadow-primary: 0 2px 12px rgba(71, 213, 191, .25);--toast-bg: var(--color-off-white);--toast-fg: var(--color-charcoal);--toast-border: rgba(247, 244, 239, .12)}}html.theme-dark{color-scheme:dark;--header-bg: var(--color-deep-slate);--bg: var(--color-deep-slate);--bg-shell: #0F141C;--bg-card: var(--color-charcoal);--surface: var(--color-charcoal);--surface-glass: rgba(34, 40, 51, .95);--surface-muted: rgba(34, 40, 51, .78);--card-gradient-from: #2A3140;--text: var(--color-off-white);--text-muted: rgba(247, 244, 239, .72);--text-light: rgba(247, 244, 239, .48);--primary: #55DCC7;--primary-light: #72E4D3;--primary-soft: rgba(71, 213, 191, .2);--btn-primary-fg: var(--color-deep-slate);--secondary-soft: rgba(107, 201, 190, .16);--secondary-light: #8AD9CF;--nav-accent: #F5A08F;--nav-accent-light: #F7B5A8;--nav-accent-soft: rgba(245, 160, 143, .18);--nav-accent-text: var(--color-mint);--nav-accent-on: var(--color-deep-slate);--nav-highlight-bg: var(--primary-soft);--nav-highlight-text: var(--color-off-white);--shadow-nav: 0 2px 10px rgba(245, 160, 143, .22);--shadow-nav-lg: 0 4px 14px rgba(245, 160, 143, .28);--accent-soft: rgba(71, 213, 191, .16);--accent-text: #6BE0CD;--warm-soft: rgba(247, 196, 184, .14);--warm-text: var(--color-sun);--warm-text-alt: var(--color-sun);--rose-soft: rgba(245, 160, 143, .16);--sky-soft: rgba(107, 201, 190, .14);--sky-text: var(--color-sky);--border: rgba(247, 244, 239, .1);--card-border: rgba(247, 244, 239, .08);--overlay: rgba(0, 0, 0, .65);--avatar-gradient: linear-gradient(135deg, var(--color-mint), var(--color-coral));--chip-rose-bg: rgba(245, 160, 143, .18);--chip-rose-text: #F7B5A8;--chip-purple-bg: rgba(107, 201, 190, .16);--chip-purple-text: var(--color-sky);--chip-neutral-bg: rgba(247, 244, 239, .08);--chip-neutral-text: var(--text-muted);--challenge-active-bg: rgba(255, 209, 102, .16);--challenge-active-border: rgba(255, 209, 102, .35);--challenge-active-text: #FFD166;--challenge-active-status-bg: rgba(255, 209, 102, .28);--challenge-active-status-text: #FFE8A3;--challenge-completed-bg: rgba(71, 213, 191, .14);--challenge-completed-border: rgba(71, 213, 191, .35);--challenge-completed-text: #9EF0E0;--challenge-completed-status-bg: rgba(53, 199, 161, .28);--challenge-completed-status-text: #C8FAEE;--challenge-not-completed-bg: rgba(245, 160, 143, .14);--challenge-not-completed-border: rgba(245, 160, 143, .35);--challenge-not-completed-text: #F7B5A8;--challenge-not-completed-status-bg: rgba(245, 160, 143, .25);--challenge-not-completed-status-text: #FFD4C8;--trend-guide: rgba(247, 244, 239, .1);--trend-commitment-fill: rgba(71, 213, 191, .22);--trend-consistency-fill: rgba(107, 201, 190, .18);--trend-plot-bg: linear-gradient(180deg, rgba(71, 213, 191, .08) 0%, rgba(71, 213, 191, 0) 100%), linear-gradient(180deg, rgba(107, 201, 190, .06) 0%, transparent 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .35);--shadow-md: 0 4px 16px rgba(0, 0, 0, .42);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .55);--shadow-primary: 0 2px 12px rgba(71, 213, 191, .25);--toast-bg: var(--color-off-white);--toast-fg: var(--color-charcoal);--toast-border: rgba(247, 244, 239, .12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;overflow:hidden;width:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;height:100%;width:100%;overflow:hidden;-webkit-font-smoothing:antialiased}html.native-app{background:var(--bg);--header-height: 48px;--nav-height: 60px}html.native-app body{position:fixed;inset:0;overscroll-behavior:none;background:var(--bg)}html.native-app input,html.native-app textarea,html.native-app select{font-size:max(16px,1em);max-width:100%}html.native-app .screen.active{overflow-x:hidden;max-width:100%}@media(pointer:coarse){input,textarea,select{font-size:max(16px,1em)}}button,input,select,textarea{font-family:inherit;font-size:inherit}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.icon{width:18px;height:18px;stroke-width:2;flex-shrink:0}.icon--xs{width:14px;height:14px}.icon--sm{width:16px;height:16px}.icon--md{width:20px;height:20px}.icon--lg{width:22px;height:22px}.icon--white{color:#fff;stroke:#fff}.icon-inline{display:inline-flex;align-items:center;vertical-align:middle}.category-icon{color:var(--cat-fg);background:var(--cat-bg)}.category-icon--fitness{--cat-bg: rgba(255, 209, 102, .28);--cat-fg: #B8860B}.category-icon--mind{--cat-bg: rgba(126, 201, 245, .28);--cat-fg: #3A7FA8}.category-icon--health{--cat-bg: rgba(53, 199, 161, .2);--cat-fg: #2A9B7E}.category-icon--creative{--cat-bg: rgba(255, 140, 122, .22);--cat-fg: #D96655}.category-icon--social{--cat-bg: rgba(255, 209, 102, .24);--cat-fg: #C9920A}.category-icon--home{--cat-bg: rgba(53, 199, 161, .18);--cat-fg: #2A9B7E}.category-icon--avoid{--cat-bg: rgba(255, 140, 122, .18);--cat-fg: #C95545}.category-icon--other{--cat-bg: rgba(31, 42, 68, .06);--cat-fg: #5A6478}@media(prefers-color-scheme:dark){:root:not([data-theme-mode=light]) .category-icon--fitness{--cat-bg: rgba(255, 209, 102, .16);--cat-fg: #FFD166}:root:not([data-theme-mode=light]) .category-icon--mind{--cat-bg: rgba(126, 201, 245, .18);--cat-fg: #7EC9F5}:root:not([data-theme-mode=light]) .category-icon--health{--cat-bg: rgba(53, 199, 161, .16);--cat-fg: #6DE0BE}:root:not([data-theme-mode=light]) .category-icon--creative{--cat-bg: rgba(255, 140, 122, .16);--cat-fg: #FFAB9D}:root:not([data-theme-mode=light]) .category-icon--social{--cat-bg: rgba(255, 209, 102, .14);--cat-fg: #FFD166}:root:not([data-theme-mode=light]) .category-icon--home{--cat-bg: rgba(53, 199, 161, .14);--cat-fg: #6DE0BE}:root:not([data-theme-mode=light]) .category-icon--avoid{--cat-bg: rgba(255, 140, 122, .14);--cat-fg: #FFAB9D}:root:not([data-theme-mode=light]) .category-icon--other{--cat-bg: rgba(255, 248, 241, .08);--cat-fg: rgba(255, 248, 241, .72)}}html.theme-dark .category-icon--fitness{--cat-bg: rgba(255, 209, 102, .16);--cat-fg: #FFD166}html.theme-dark .category-icon--mind{--cat-bg: rgba(126, 201, 245, .18);--cat-fg: #7EC9F5}html.theme-dark .category-icon--health{--cat-bg: rgba(53, 199, 161, .16);--cat-fg: #6DE0BE}html.theme-dark .category-icon--creative{--cat-bg: rgba(255, 140, 122, .16);--cat-fg: #FFAB9D}html.theme-dark .category-icon--social{--cat-bg: rgba(255, 209, 102, .14);--cat-fg: #FFD166}html.theme-dark .category-icon--home{--cat-bg: rgba(53, 199, 161, .14);--cat-fg: #6DE0BE}html.theme-dark .category-icon--avoid{--cat-bg: rgba(255, 140, 122, .14);--cat-fg: #FFAB9D}html.theme-dark .category-icon--other{--cat-bg: rgba(255, 248, 241, .08);--cat-fg: rgba(255, 248, 241, .72)}.avatar-tone{color:var(--tone-fg);background:var(--tone-bg)}.avatar-tone--sky{--tone-bg: rgba(126, 201, 245, .35);--tone-fg: #3A7FA8}.avatar-tone--rose{--tone-bg: rgba(255, 140, 122, .28);--tone-fg: #C95545}.avatar-tone--mint{--tone-bg: rgba(53, 199, 161, .25);--tone-fg: #2A9B7E}.avatar-tone--violet{--tone-bg: rgba(126, 201, 245, .22);--tone-fg: #3A7FA8}.avatar-tone--amber{--tone-bg: rgba(255, 209, 102, .35);--tone-fg: #B8860B}.avatar-tone--indigo{--tone-bg: rgba(53, 199, 161, .2);--tone-fg: #2A9B7E}.avatar-tone--neutral{--tone-bg: rgba(31, 42, 68, .08);--tone-fg: #5A6478}.avatar-tone--self{--tone-bg: linear-gradient(135deg, rgba(126, 201, 245, .55), rgba(53, 199, 161, .45));--tone-fg: #222833}@media(prefers-color-scheme:dark){:root:not([data-theme-mode=light]) .avatar-tone--sky{--tone-bg: rgba(126, 201, 245, .2);--tone-fg: #7EC9F5}:root:not([data-theme-mode=light]) .avatar-tone--rose{--tone-bg: rgba(255, 140, 122, .18);--tone-fg: #FFAB9D}:root:not([data-theme-mode=light]) .avatar-tone--mint{--tone-bg: rgba(53, 199, 161, .18);--tone-fg: #6DE0BE}:root:not([data-theme-mode=light]) .avatar-tone--violet{--tone-bg: rgba(126, 201, 245, .16);--tone-fg: #7EC9F5}:root:not([data-theme-mode=light]) .avatar-tone--amber{--tone-bg: rgba(255, 209, 102, .18);--tone-fg: #FFD166}:root:not([data-theme-mode=light]) .avatar-tone--indigo{--tone-bg: rgba(53, 199, 161, .16);--tone-fg: #6DE0BE}:root:not([data-theme-mode=light]) .avatar-tone--neutral{--tone-bg: rgba(255, 248, 241, .1);--tone-fg: rgba(255, 248, 241, .75)}:root:not([data-theme-mode=light]) .avatar-tone--self{--tone-bg: linear-gradient(135deg, rgba(126, 201, 245, .35), rgba(53, 199, 161, .35));--tone-fg: #F7F4EF}}html.theme-dark .avatar-tone--sky{--tone-bg: rgba(126, 201, 245, .2);--tone-fg: #7EC9F5}html.theme-dark .avatar-tone--rose{--tone-bg: rgba(255, 140, 122, .18);--tone-fg: #FFAB9D}html.theme-dark .avatar-tone--mint{--tone-bg: rgba(53, 199, 161, .18);--tone-fg: #6DE0BE}html.theme-dark .avatar-tone--violet{--tone-bg: rgba(126, 201, 245, .16);--tone-fg: #7EC9F5}html.theme-dark .avatar-tone--amber{--tone-bg: rgba(255, 209, 102, .18);--tone-fg: #FFD166}html.theme-dark .avatar-tone--indigo{--tone-bg: rgba(53, 199, 161, .16);--tone-fg: #6DE0BE}html.theme-dark .avatar-tone--neutral{--tone-bg: rgba(255, 248, 241, .1);--tone-fg: rgba(255, 248, 241, .75)}html.theme-dark .avatar-tone--self{--tone-bg: linear-gradient(135deg, rgba(126, 201, 245, .35), rgba(53, 199, 161, .35));--tone-fg: #F7F4EF}.category-icon .icon,.habit-card__icon .icon,.feed-card__category .icon,.volume-item__icon .icon,.habit-picker-item__icon .icon,.public-habit-item__icon .icon,.log-sheet__habit-icon .icon{color:inherit;stroke:currentColor}.app{width:100%;max-width:100%;margin:0;height:100%;height:100dvh;max-height:100dvh;display:flex;flex-direction:column;position:relative;overflow:hidden}html.native-app .app{height:100%;min-height:100%;min-height:100dvh;max-height:none;background:var(--bg)}.app-center{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;width:100%;max-width:100%}.header{position:relative;top:auto;left:auto;transform:none;width:100%;max-width:100%;flex-shrink:0;z-index:100;background:var(--header-bg);border-bottom:1px solid var(--border);padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0px));height:var(--shell-top);box-sizing:border-box;display:flex;align-items:center;justify-content:space-between;gap:12px;overflow:hidden}.header__brand{display:flex;align-items:center;min-width:0;flex:0 1 auto}.header__metrics{display:none}.header__metric-pill{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:700}.header__metric-pill--commitment{background:var(--primary-soft);color:var(--primary)}.header__metric-pill--consistency{background:var(--accent-soft);color:var(--accent-text)}.header__metric-pill .icon{width:12px;height:12px}.header__avatar{width:38px;height:38px;flex-shrink:0;border-radius:50%;border:2px solid rgba(255,255,255,.72);background:var(--avatar-gradient);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s;color:#fff;font-size:13px;font-weight:700;line-height:1}.header__avatar .icon{color:#fff;stroke:#fff}.header__avatar:active{transform:scale(.95)}.header__avatar-photo{width:100%;height:100%;object-fit:cover;object-position:center;border-radius:50%;display:block}.main{flex:1;min-height:0;position:relative;overflow:hidden;padding:0}.screen{display:none}.screen.active{display:block;position:absolute;inset:0;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;padding:16px;animation:fadeIn .25s ease}html.native-app .screen.active{overflow-y:scroll}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.bottom-nav{position:relative;bottom:auto;left:auto;transform:none;width:100%;max-width:100%;flex-shrink:0;height:var(--shell-bottom);padding-bottom:env(safe-area-inset-bottom,0px);box-sizing:border-box;background:var(--surface-glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;padding-left:8px;padding-right:8px;z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;cursor:pointer;padding:8px 12px;border-radius:var(--radius-sm);color:var(--text-muted);transition:color .15s,background .15s;min-width:56px}.nav-item__icon{display:flex;align-items:center;justify-content:center;line-height:1}.nav-item__icon .icon{width:22px;height:22px}.nav-item__label{font-size:10px;font-weight:600;letter-spacing:.02em}.nav-item.active:not(.nav-item--add){color:var(--nav-accent-text)}.nav-item.active:not(.nav-item--add) .nav-item__icon .icon{color:var(--nav-accent-text);stroke:var(--nav-accent-text)}.nav-item--add{position:relative;top:-8px}.nav-item--add .nav-item__icon{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--nav-accent),var(--nav-accent-light));display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-nav-lg)}.nav-item__fab-plus{display:block;font-size:30px;font-weight:400;line-height:1;color:var(--nav-accent-on);-webkit-text-fill-color:var(--nav-accent-on);user-select:none;pointer-events:none}.nav-item.nav-item--add.active .nav-item__fab-plus,.nav-item.nav-item--add:active .nav-item__fab-plus{color:var(--nav-accent-on);-webkit-text-fill-color:var(--nav-accent-on)}.nav-item--add .nav-item__icon .icon{width:24px;height:24px;color:var(--nav-accent-on);stroke:var(--nav-accent-on)}.nav-item--add .nav-item__label{color:var(--nav-accent-text)}html.native-app .header{height:auto;min-height:calc(var(--header-height) + env(safe-area-inset-top,0px));padding-top:calc(6px + env(safe-area-inset-top,0px));padding-bottom:6px}html.native-app .bottom-nav{height:auto;min-height:calc(var(--nav-height) + env(safe-area-inset-bottom,0px));padding-top:4px;padding-bottom:calc(4px + env(safe-area-inset-bottom,0px))}html.native-app .nav-item--add{top:-6px}html.native-app .screen.active{padding-top:12px}.brand-logo-wordmark{display:block;line-height:0;min-width:0}.brand-logo-wordmark__img{display:block;height:28px;width:auto;max-width:min(200px,52vw);object-fit:contain;object-position:left center}.brand-logo-wordmark__img--dark,html.theme-dark .brand-logo-wordmark__img--light{display:none}html.theme-dark .brand-logo-wordmark__img--dark{display:block}@media(prefers-color-scheme:dark){html:not([data-theme-mode=light]) .brand-logo-wordmark__img--light{display:none}html:not([data-theme-mode=light]) .brand-logo-wordmark__img--dark{display:block}}html[data-theme-mode=light] .brand-logo-wordmark__img--light{display:block}html[data-theme-mode=light] .brand-logo-wordmark__img--dark{display:none}.brand-logo-wordmark--sidebar .brand-logo-wordmark__img{height:34px;max-width:100%}.brand-logo-wordmark--auth .brand-logo-wordmark__img{height:28px;max-width:min(240px,72vw);object-position:center center;margin-inline:auto}.brand-logo-wordmark--auth{display:inline-block}.brand-wordmark{display:inline-flex;align-items:baseline;flex-wrap:nowrap;flex-shrink:0;font-weight:800;line-height:1;letter-spacing:-.04em;white-space:nowrap}.brand-wordmark__lead,.brand-wordmark__core,.brand-wordmark__buddy{flex-shrink:0}.brand-wordmark__lead{font-weight:600;font-size:.9em;color:var(--text-light);letter-spacing:-.02em}.brand-wordmark__core{background:linear-gradient(125deg,var(--color-mint, #47D5BF) 0%,var(--primary) 55%,var(--color-coral, #F5A08F) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.brand-wordmark__buddy{background:linear-gradient(125deg,var(--color-coral, #F5A08F) 0%,var(--color-sun, #F7C4B8) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.brand-wordmark--compact .brand-wordmark__lead{display:none}.brand-wordmark--compact .brand-wordmark__core,.brand-wordmark--compact .brand-wordmark__buddy{font-size:1em}.card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--card-border)}.section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:12px}.screen-heading{font-size:24px;font-weight:800;letter-spacing:-.03em;margin-bottom:4px}.screen-subheading{color:var(--text-muted);font-size:14px;margin-bottom:20px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--radius-sm);font-weight:600;font-size:14px;border:none;cursor:pointer;transition:transform .12s,box-shadow .12s,background .12s}.btn:active{transform:scale(.97)}.btn--primary{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:var(--btn-primary-fg);box-shadow:var(--shadow-primary)}.btn--secondary{background:var(--primary-soft);color:var(--primary)}.btn--ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn--danger{background:#c0392b;color:#fff;border:1px solid #a93226}.btn--danger:disabled{opacity:.45;cursor:not-allowed}.btn--sm{padding:6px 12px;font-size:12px}.btn--full{width:100%}.avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.avatar--sm{width:32px;height:32px;font-size:12px}.avatar--lg{width:72px;height:72px;font-size:24px}.avatar--photo{padding:0;overflow:hidden;background:var(--border)}.avatar__photo{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.progress-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-pill);font-size:12px;font-weight:600}.progress-pill--green{background:var(--accent-soft);color:var(--accent-text)}.progress-pill--blue{background:var(--primary-soft);color:var(--primary)}.progress-pill--amber{background:var(--warm-soft);color:var(--warm-text-alt)}.progress-pill--rose{background:var(--rose-soft);color:var(--rose)}.mini-bar{height:4px;background:var(--border);border-radius:var(--radius-pill);overflow:hidden;margin-top:8px}.mini-bar__fill{height:100%;border-radius:var(--radius-pill);transition:width .4s ease}.mini-bar__fill--green{background:linear-gradient(90deg,var(--primary-light),var(--primary))}.mini-bar__fill--blue{background:linear-gradient(90deg,var(--color-sky, #7EC9F5),var(--primary))}.mini-bar__fill--amber{background:linear-gradient(90deg,var(--color-sun, #FFD166),var(--warm))}.toast{position:fixed;bottom:calc(var(--shell-bottom) + 16px);left:50%;transform:translate(-50%) translateY(20px);background:var(--toast-bg);color:var(--toast-fg);border:1px solid var(--toast-border);padding:12px 24px;border-radius:var(--radius-pill);font-size:14px;font-weight:600;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;z-index:1100;box-shadow:var(--shadow-lg)}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.progress-dashboard{margin-bottom:20px}.progress-dashboard__heading{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:10px}.progress-insight{padding:12px 14px;margin-bottom:12px;background:var(--surface-muted);border-radius:var(--radius-sm);font-size:13px;color:var(--text-muted);border:1px solid rgba(99,102,241,.1);line-height:1.45}.score-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.score-card{padding:16px;position:relative;overflow:hidden}.score-card--commitment{background:linear-gradient(145deg,var(--card-gradient-from) 0%,var(--primary-soft) 100%);border-color:#6366f12e}.score-card--consistency{background:linear-gradient(145deg,var(--card-gradient-from) 0%,var(--accent-soft) 100%);border-color:#10b9812e}.score-card__label{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:6px}.score-card__label .icon{width:13px;height:13px}.score-card__value{font-size:34px;font-weight:800;letter-spacing:-.03em;line-height:1;margin-bottom:2px}.score-card--commitment .score-card__value{color:var(--primary)}.score-card--consistency .score-card__value{color:var(--accent-text)}.score-card__period{font-size:10px;color:var(--text-light);margin-bottom:6px}.score-card__interpretation{font-size:11px;color:var(--text-muted);font-weight:500;line-height:1.35}.score-card__ring{position:absolute;top:14px;right:14px;width:40px;height:40px;border-radius:50%;background:conic-gradient(currentColor calc(var(--pct) * 1%),var(--border) 0);display:flex;align-items:center;justify-content:center}.score-card--commitment .score-card__ring{color:var(--primary)}.score-card--consistency .score-card__ring{color:var(--accent)}.score-card__ring-inner{width:28px;height:28px;border-radius:50%;background:var(--bg-card)}.consistency-dots{display:flex;gap:4px;margin-top:8px}.consistency-dot{flex:1;height:6px;border-radius:var(--radius-pill);background:var(--border)}.consistency-dot--active{background:var(--accent)}.consistency-dot-labels{display:flex;justify-content:space-between;margin-top:4px;font-size:9px;font-weight:600;color:var(--text-light);text-transform:uppercase}.volume-card{padding:16px;background:linear-gradient(145deg,var(--card-gradient-from) 0%,var(--warm-soft) 100%);border-color:#f59e0b2e}.volume-card__header{display:flex;align-items:center;gap:6px;margin-bottom:14px}.volume-card__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.volume-card__header .icon{width:14px;height:14px;color:var(--warm);stroke:var(--warm)}.volume-list{display:flex;flex-direction:column;gap:12px}.volume-item{display:flex;align-items:center;gap:12px}.volume-item__icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.volume-item__icon .icon{width:18px;height:18px}.volume-item__info{flex:1;min-width:0}.volume-item__label{font-size:11px;color:var(--text-muted);font-weight:500}.volume-item__value{font-size:18px;font-weight:800;letter-spacing:-.02em;color:var(--text)}.volume-item__bar{height:4px;background:var(--border);border-radius:var(--radius-pill);margin-top:4px;overflow:hidden}.volume-item__bar-fill{height:100%;border-radius:var(--radius-pill);background:linear-gradient(90deg,#fbbf24,var(--warm))}.feed-chrome,.feed-header{margin-bottom:16px}.feed-chrome .feed-header{margin-bottom:0}.feed-filter{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:16px}.feed-chrome .feed-filter{margin-bottom:0}.feed-filter__btn{padding:6px 14px;border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--bg-card);font-size:12px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s}.feed-filter__btn.selected{background:var(--nav-highlight-bg);border-color:transparent;color:var(--nav-highlight-text)}.feed-filter__btn--challenges{display:inline-flex;align-items:center;gap:5px;margin-left:auto;background:var(--challenge-active-status-bg);border-color:var(--challenge-active-border);color:var(--challenge-active-status-text)}.feed-filter__btn--challenges .icon{width:14px;height:14px;stroke:currentColor;flex-shrink:0}.feed-filter__btn--challenges:hover{background:var(--challenge-active-bg);border-color:var(--challenge-active-border);color:var(--challenge-active-text)}html[data-layout=desktop] .feed-filter__btn--challenges{display:none}.feed-card--self{border:1px solid rgba(99,102,241,.2);background:linear-gradient(135deg,var(--card-gradient-from) 0%,var(--primary-soft) 100%)}.feed-card__you-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-pill);background:var(--primary-soft);color:var(--primary);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-left:6px}.feed-card__buddy-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:var(--radius-pill);background:var(--sky-soft);color:var(--sky-text);flex-shrink:0}.feed-card__buddy-badge .icon{width:13px;height:13px}.feed-empty{text-align:center;padding:32px 16px;color:var(--text-muted);font-size:14px}.habit-picker-grid{display:flex;flex-direction:column;gap:0;margin-bottom:20px}.habit-picker-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .12s,border-color .15s,box-shadow .15s;text-align:center}.habit-picker-item:active{transform:scale(.97)}.habit-picker-item:hover{border-color:var(--primary-light);box-shadow:var(--shadow-md)}.habit-picker-item__icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center}.habit-picker-item__icon .icon{width:26px;height:26px}.habit-picker-item__name{font-size:12px;font-weight:700;line-height:1.25;color:var(--text)}.habit-picker-item__target{font-size:10px;color:var(--text-muted);line-height:1.2}.habit-picker-new{margin-top:4px}.add-back-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:none;padding:0;margin-bottom:16px;font-size:14px;font-weight:600;color:var(--primary);cursor:pointer}.add-back-btn .icon{width:18px;height:18px}.log-sheet{position:fixed;inset:0;z-index:300;pointer-events:none;visibility:hidden;transition:visibility .25s}.log-sheet.open{pointer-events:auto;visibility:visible}.log-sheet__backdrop{position:absolute;inset:0;background:var(--overlay);opacity:0;transition:opacity .25s}.log-sheet.open .log-sheet__backdrop{opacity:1}.log-sheet__panel{position:absolute;left:50%;bottom:0;transform:translate(-50%) translateY(100%);width:100%;max-width:var(--max-width);max-height:min(92dvh,720px);background:var(--bg-card);border-radius:20px 20px 0 0;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;transition:transform .28s cubic-bezier(.32,.72,0,1);padding-bottom:env(safe-area-inset-bottom,0px)}.log-sheet.open .log-sheet__panel{transform:translate(-50%) translateY(0)}.log-sheet__handle{width:36px;height:4px;background:var(--border);border-radius:var(--radius-pill);margin:10px auto 0;flex-shrink:0}.log-sheet__header{padding:12px 20px 8px;flex-shrink:0}.log-sheet__header-row{display:flex;align-items:center}.log-sheet__close{display:none}.log-sheet__title{font-size:18px;font-weight:800;letter-spacing:-.02em;display:flex;align-items:center;gap:10px}.log-sheet__habit-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center}.log-sheet__prompt{font-size:14px;color:var(--text-muted);margin-top:6px}.log-sheet__body{flex:1;min-height:0;overflow-y:auto;padding:8px 20px 16px;-webkit-overflow-scrolling:touch}.log-sheet__footer{display:grid;grid-template-columns:1fr 1.4fr;gap:10px;padding:12px 20px 16px;border-top:1px solid var(--border);flex-shrink:0;background:var(--bg-card)}.log-field{margin-bottom:18px}.log-field__header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}.log-field__label{font-size:13px;font-weight:700;color:var(--text)}.log-field__value{font-size:22px;font-weight:800;color:var(--primary);letter-spacing:-.02em}.log-slider{width:100%;height:6px;accent-color:var(--primary);cursor:pointer}.log-slider-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--text-light);margin-top:6px;font-weight:600}.log-slider-meta__goal{color:var(--primary)}.log-number-row{display:flex;align-items:center;gap:10px;margin-top:10px}.log-number-btn{width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);font-size:22px;font-weight:600;line-height:1;color:var(--text);-webkit-text-fill-color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;user-select:none;-webkit-user-select:none}.log-number-btn:active,.log-number-btn:focus-visible{background:var(--primary-soft);color:var(--text);-webkit-text-fill-color:var(--text)}.log-number-input{flex:1;min-width:0;max-width:100%;text-align:center;padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:16px;font-weight:700;color:var(--primary)}.log-timer{padding:16px;margin-bottom:18px;background:linear-gradient(145deg,var(--card-gradient-from),var(--primary-soft));border:1px solid rgba(99,102,241,.15)}.log-timer__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px;display:flex;align-items:center;gap:5px}.log-timer__display{font-size:40px;font-weight:800;letter-spacing:.04em;font-variant-numeric:tabular-nums;color:var(--text);line-height:1;margin-bottom:4px}.log-timer__display--running{color:var(--primary)}.log-timer__status{font-size:12px;color:var(--text-muted);margin-bottom:12px}.log-timer__actions{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.log-timer__btn{padding:8px 4px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);font-size:11px;font-weight:700;color:var(--text-muted);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px}.log-timer__btn .icon{width:16px;height:16px}.log-timer__btn--primary{background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}.log-timer__btn:disabled{opacity:.4;cursor:not-allowed}.log-preview{padding:12px 14px;background:var(--bg);border-radius:var(--radius-sm);font-size:13px;color:var(--text-muted);border:1px dashed var(--border);line-height:1.45}.log-preview strong{color:var(--text)}.feed-list{display:flex;flex-direction:column;gap:14px;max-width:100%;overflow-x:hidden}.feed-card{padding:16px;position:relative;overflow:hidden}.feed-card--milestone{border-left:3px solid var(--warm)}.feed-card--consistency{border-left:3px solid var(--accent)}.feed-card--volume{border-left:3px solid var(--warm)}.feed-card--reflection{border-left:3px solid #a78bfa}.feed-card--challenge{border-left:3px solid var(--sky);background:linear-gradient(135deg,var(--card-gradient-from) 0%,var(--sky-soft) 100%)}.feed-card--achievement{border-left:3px solid var(--accent)}.feed-card__header{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}.feed-card__meta{flex:1;min-width:0}.feed-card__name{display:flex;flex-wrap:wrap;align-items:center;gap:4px 6px;font-weight:700;font-size:14px}.user-flags{display:inline-flex;flex-wrap:wrap;align-items:center;gap:4px}.user-flag{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:var(--radius-pill);font-size:10px;font-weight:700;letter-spacing:.02em;white-space:nowrap;line-height:1.2}.user-flag .icon{width:11px;height:11px;flex-shrink:0}.user-flag--supporter{background:var(--chip-rose-bg);color:var(--chip-rose-text)}.user-flag--early-adopter{background:var(--chip-purple-bg);color:var(--chip-purple-text)}.user-flag--tenure{background:var(--chip-neutral-bg);color:var(--chip-neutral-text)}.feed-card__username{font-weight:700}.feed-username-link{background:none;border:none;padding:0;margin:0;font:inherit;font-weight:700;color:inherit;cursor:pointer;text-align:left}.feed-username-link:hover,.feed-username-link:focus-visible{color:var(--primary);text-decoration:underline;outline:none}.feed-username-link--inline{display:inline}.feed-username-link--inline strong{font-weight:inherit}.feed-comment__name.feed-username-link{font-size:12px}.feed-card__time{font-size:12px;color:var(--text-light)}.feed-card__category{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.feed-card__category .icon{width:18px;height:18px}.feed-card__body{font-size:14px;line-height:1.55;margin-bottom:10px;padding-left:52px}.feed-card__body strong{font-weight:700}.feed-card__progress-row{padding-left:52px;margin-bottom:12px}.feed-card__reflection{margin-bottom:12px;padding:12px;background:var(--bg);border-radius:var(--radius-sm);font-size:13px;color:var(--text-muted);font-style:italic;border-left:2px solid #c4b5fd}.feed-card__badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.feed-card__badge--milestone{background:var(--warm-soft);color:var(--warm-text)}.feed-card__badge--consistency{background:var(--accent-soft);color:var(--accent-text)}.feed-card__badge--volume{background:var(--warm-soft);color:var(--warm-text)}.feed-card__badge--challenge{background:var(--sky-soft);color:var(--sky-text)}.feed-card__badge--achievement{background:var(--accent-soft);color:var(--accent-text)}.feed-card__actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.reaction-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--bg-card);font-size:12px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .15s}.reaction-btn .icon{width:14px;height:14px}.reaction-btn.active{background:var(--primary-soft);border-color:var(--primary);color:var(--primary);font-weight:600}.same-goal-status{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--radius-pill);border:1px solid var(--accent-soft);background:var(--accent-soft);font-size:12px;font-weight:600;color:var(--accent-text)}.same-goal-status--muted{border-color:var(--border);background:var(--bg-card);color:var(--text-muted);font-weight:500}.same-goal-status__you{font-weight:700;color:var(--primary)}.reaction-btn:disabled{opacity:.45;cursor:not-allowed}.feed-card__comments{display:none}.encourage-input{flex:1;min-width:0;max-width:100%;padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius-pill);font-size:16px;background:var(--bg);outline:none;transition:border-color .15s}.encourage-input:focus{border-color:var(--primary)}.encourage-btn{padding:8px 14px;border-radius:var(--radius-pill);border:none;background:var(--primary-soft);color:var(--primary);font-weight:600;font-size:12px;cursor:pointer}.feed-pull-indicator{height:0;overflow:hidden;transition:height .2s ease;margin:0 0 8px}.feed-pull-indicator.is-pulling,.feed-pull-indicator.is-refreshing{height:44px}.feed-pull-indicator__inner{display:flex;align-items:center;justify-content:center;gap:8px;height:44px;font-size:13px;font-weight:600;color:var(--text-muted)}.feed-pull-indicator__spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;opacity:0;transition:opacity .15s}.feed-pull-indicator.is-refreshing .feed-pull-indicator__spinner{opacity:1;animation:feedSpin .7s linear infinite}.feed-pull-indicator.is-ready .feed-pull-indicator__spinner{opacity:1;border-top-color:var(--accent);transform:rotate(180deg)}.feed-card__footer{padding-left:52px}.feed-card__comments-toggle{display:inline-flex;align-items:center;gap:6px;margin-top:10px;padding:0;border:none;background:none;font-size:12px;font-weight:600;color:var(--text-light);cursor:pointer}.feed-card__comments-toggle:hover{color:var(--primary)}.feed-card__comments-toggle .icon{width:14px;height:14px}.feed-card__comments-panel{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.feed-comments{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.feed-comment{display:flex;gap:10px;align-items:flex-start}.feed-comment__avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}.feed-comment__bubble{flex:1;min-width:0;padding:8px 12px;background:var(--bg);border-radius:4px 12px 12px}.feed-comment__meta{display:flex;flex-wrap:wrap;align-items:center;gap:4px 6px;margin-bottom:2px}.feed-comment__name{font-size:12px;font-weight:700}.feed-comment__time{font-size:11px;color:var(--text-light)}.feed-comment__text{font-size:13px;line-height:1.45;color:var(--text)}.feed-comment-compose{display:flex;gap:8px;align-items:center}.feed-comment-compose .encourage-input{margin:0}.feed-footer{padding:8px 0 4px;min-height:48px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.feed-loading[hidden],.feed-end[hidden]{display:none!important}.feed-loading{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;color:var(--text-muted)}.feed-loading__spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:feedSpin .7s linear infinite}.feed-end{margin:0;font-size:13px;color:var(--text-light);text-align:center}@keyframes feedSpin{to{transform:rotate(360deg)}}.feed-layout-picker__hint{margin:-4px 0 12px;font-size:12px;color:var(--text-light);line-height:1.45}.feed-layout-picker{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:20px}.feed-layout-option{padding:10px;border:2px solid transparent;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .12s ease;text-align:left;background:var(--bg-card)}.feed-layout-option:hover{border-color:#ff8c7a47}.feed-layout-option--selected{border-color:var(--nav-accent);box-shadow:0 0 0 3px var(--nav-accent-soft)}.feed-layout-option:active{transform:scale(.98)}.feed-layout-preview{display:block;width:100%}.flp__shell{display:flex;flex-direction:column;gap:6px;min-height:74px}.flp__head{display:flex;align-items:center;gap:6px}.flp__av{width:14px;height:14px;border-radius:50%;background:var(--avatar-gradient);flex-shrink:0}.flp__meta{flex:1;display:flex;flex-direction:column;gap:3px}.flp__line{display:block;height:4px;border-radius:var(--radius-pill);background:var(--border)}.flp__line--name{width:58%;background:#6366f159}.flp__line--time{width:34%}.flp__body{display:block;height:16px;border-radius:4px;background:var(--bg);border:1px solid var(--border)}.flp__foot{display:flex;gap:4px}.flp__pill{height:8px;width:24%;border-radius:var(--radius-pill);background:var(--chip-neutral-bg)}.flp__pill--short{width:18%}.feed-layout-preview--classic .flp__shell{padding:8px;border-radius:10px;background:var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid var(--card-border)}.feed-layout-preview--classic .flp__body{margin-left:20px;width:calc(100% - 20px)}.feed-layout-preview--professional .flp__shell{padding:8px;border-radius:6px;background:var(--bg-card);border:1px solid var(--border)}.feed-layout-preview--professional .flp__foot{padding-top:6px;border-top:1px solid var(--border)}.feed-layout-preview--compact .flp__shell{gap:4px}.feed-layout-preview--compact .flp__av{width:10px;height:10px}.feed-layout-preview--compact .flp__body{height:12px;border:none;background:var(--chip-neutral-bg)}.feed-layout-preview--compact .flp__pill{height:6px}.feed-layout-preview--stream .flp__shell{padding-bottom:8px;border-bottom:2px solid var(--border)}.feed-layout-preview--stream .flp__head{align-items:flex-start}.feed-layout-preview--stream .flp__body{margin-left:20px;width:calc(100% - 20px);border:none;background:transparent;height:14px;box-shadow:inset 0 -1px 0 var(--border),inset 0 -5px 0 var(--bg),inset 0 -9px 0 var(--border)}.feed-layout-preview--stream .flp__foot{margin-left:20px}.feed-layout-preview--stream .flp__pill{width:10%;border-radius:2px}@media(min-width:520px){.feed-layout-picker{grid-template-columns:repeat(4,minmax(0,1fr))}}.feed-list.feed-layout--professional{gap:10px}.feed-list.feed-layout--professional .feed-card{padding:14px 16px 0;border-radius:8px;box-shadow:none}.feed-list.feed-layout--professional .feed-card__body,.feed-list.feed-layout--professional .feed-card__progress-row,.feed-list.feed-layout--professional .feed-card__reflection{padding-left:0}.feed-list.feed-layout--professional .feed-card__footer{padding:10px 0 12px;margin-top:4px;border-top:1px solid var(--border)}.feed-list.feed-layout--professional .feed-card__badge{margin-bottom:10px}.feed-list.feed-layout--professional .reaction-btn{border:none;background:transparent;border-radius:4px;padding:8px 10px}.feed-list.feed-layout--professional .reaction-btn:hover{background:var(--bg)}.feed-list.feed-layout--professional .feed-card--milestone,.feed-list.feed-layout--professional .feed-card--achievement,.feed-list.feed-layout--professional .feed-card--consistency,.feed-list.feed-layout--professional .feed-card--volume,.feed-list.feed-layout--professional .feed-card--reflection,.feed-list.feed-layout--professional .feed-card--challenge{border-left:none;border-top:3px solid transparent}.feed-list.feed-layout--professional .feed-card--milestone{border-top-color:var(--warm)}.feed-list.feed-layout--professional .feed-card--achievement,.feed-list.feed-layout--professional .feed-card--consistency{border-top-color:var(--accent)}.feed-list.feed-layout--professional .feed-card--volume{border-top-color:var(--warm)}.feed-list.feed-layout--professional .feed-card--reflection{border-top-color:#a78bfa}.feed-list.feed-layout--professional .feed-card--challenge{border-top-color:var(--sky)}.feed-list.feed-layout--compact{gap:8px}.feed-list.feed-layout--compact .feed-card{padding:10px 12px;border-radius:8px;box-shadow:none;background:var(--bg-card)}.feed-list.feed-layout--compact .feed-card__header{margin-bottom:6px;gap:8px}.feed-list.feed-layout--compact .feed-card__header .avatar{width:28px;height:28px;font-size:11px}.feed-list.feed-layout--compact .feed-card__name{font-size:12px}.feed-list.feed-layout--compact .feed-card__time{font-size:11px}.feed-list.feed-layout--compact .feed-card__category{width:28px;height:28px;border-radius:6px}.feed-list.feed-layout--compact .feed-card__body{padding-left:0;font-size:13px;margin-bottom:8px}.feed-list.feed-layout--compact .feed-card__progress-row,.feed-list.feed-layout--compact .feed-card__reflection,.feed-list.feed-layout--compact .feed-card__footer{padding-left:0}.feed-list.feed-layout--compact .feed-card__actions{gap:4px}.feed-list.feed-layout--compact .reaction-btn{padding:4px 8px;font-size:11px;background:var(--bg)}.feed-list.feed-layout--compact .feed-card__badge{font-size:10px;padding:2px 8px;margin-bottom:6px}.feed-list.feed-layout--compact .feed-card--milestone,.feed-list.feed-layout--compact .feed-card--achievement,.feed-list.feed-layout--compact .feed-card--consistency,.feed-list.feed-layout--compact .feed-card--volume,.feed-list.feed-layout--compact .feed-card--reflection,.feed-list.feed-layout--compact .feed-card--challenge{border-left:none}.feed-list.feed-layout--compact .feed-card--self{background:var(--bg-card);border-color:#6366f124}.feed-list.feed-layout--stream{gap:0}.feed-list.feed-layout--stream .feed-card{display:grid;grid-template-columns:42px minmax(0,1fr);grid-template-areas:"badge badge" "avatar meta" "avatar body" "avatar progress" "avatar reflection" "avatar footer";column-gap:10px;row-gap:0;padding:12px 2px;border-radius:0;box-shadow:none;border:none;border-bottom:1px solid var(--border);background:transparent}.feed-list.feed-layout--stream .feed-card__badge{grid-area:badge;margin-bottom:6px}.feed-list.feed-layout--stream .feed-card__header{display:contents}.feed-list.feed-layout--stream .feed-card__header .avatar{grid-area:avatar;width:40px;height:40px}.feed-list.feed-layout--stream .feed-card__meta{grid-area:meta;margin-bottom:2px}.feed-list.feed-layout--stream .feed-card__category{display:none}.feed-list.feed-layout--stream .feed-card__body{grid-area:body;padding-left:0;margin-bottom:8px}.feed-list.feed-layout--stream .feed-card__progress-row{grid-area:progress;padding-left:0;margin-bottom:8px}.feed-list.feed-layout--stream .feed-card__reflection{grid-area:reflection;padding-left:12px;margin-bottom:8px}.feed-list.feed-layout--stream .feed-card__footer{grid-area:footer;padding-left:0}.feed-list.feed-layout--stream .feed-card__actions{gap:2px;justify-content:space-between;max-width:280px}.feed-list.feed-layout--stream .reaction-btn{border:none;background:transparent;padding:6px 8px;border-radius:999px;font-size:0}.feed-list.feed-layout--stream .reaction-btn .icon{width:16px;height:16px}.feed-list.feed-layout--stream .reaction-btn span{font-size:12px;font-weight:600;margin-left:2px}.feed-list.feed-layout--stream .reaction-btn:hover{background:var(--primary-soft)}.feed-list.feed-layout--stream .feed-card--milestone,.feed-list.feed-layout--stream .feed-card--achievement,.feed-list.feed-layout--stream .feed-card--consistency,.feed-list.feed-layout--stream .feed-card--volume,.feed-list.feed-layout--stream .feed-card--reflection,.feed-list.feed-layout--stream .feed-card--challenge{border-left:none}.feed-list.feed-layout--stream .feed-card--self{background:transparent;border-bottom-color:#6366f12e}.feed-list.feed-layout--stream .feed-card--challenge{background:linear-gradient(180deg,var(--sky-soft) 0%,transparent 100%)}@media(prefers-color-scheme:dark){:root:not([data-theme-mode=light]) .feed-layout-option--selected{box-shadow:0 0 0 3px #7ec9f533}}html.theme-dark .feed-layout-option--selected{box-shadow:0 0 0 3px #7ec9f533}.period-nav{padding:14px;margin-bottom:14px}.period-nav__title{margin:0 0 10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.period-toggle{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;padding:5px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border)}.period-toggle__btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:54px;padding:8px 4px;border:1px solid transparent;border-radius:10px;background:transparent;cursor:pointer;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.period-toggle__label{font-size:13px;font-weight:700;line-height:1.15;color:var(--text);letter-spacing:-.01em}.period-toggle__hint{font-size:10px;font-weight:600;line-height:1.2;color:var(--text-light);text-align:center;max-width:100%}.period-toggle__btn:hover:not(.selected){background:var(--surface-muted);border-color:var(--border)}.period-toggle__btn.selected{background:var(--primary-soft);border-color:var(--primary);box-shadow:0 1px 4px #35c7a12e}.period-toggle__btn.selected .period-toggle__label{color:var(--accent-text)}.period-toggle__btn.selected .period-toggle__hint{color:var(--primary)}.period-toggle__btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.progress-strip{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}.progress-strip__item{padding:12px 10px;text-align:center}.progress-strip__label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:4px}.progress-strip__value{font-size:20px;font-weight:800;letter-spacing:-.02em}.progress-strip__item:nth-child(1) .progress-strip__value{color:var(--primary)}.progress-strip__item:nth-child(2) .progress-strip__value{color:var(--accent-text)}.progress-strip__sub{font-size:9px;color:var(--text-light);margin-top:2px}.habit-list{display:flex;flex-direction:column;gap:12px}#screen-habits .habit-picker-new{margin-top:16px}.habits-trend{padding:16px;margin-bottom:14px}.habits-trend__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.habits-trend__title{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:700;letter-spacing:-.01em}.habits-trend__title .icon{width:14px;height:14px;color:var(--primary)}.habits-trend__subtitle{margin-top:2px;font-size:11px;color:var(--text-light)}.habits-trend__legend{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.habits-trend__key{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;color:var(--text-muted)}.habits-trend__key:before{content:"";width:16px;height:3px;border-radius:var(--radius-pill)}.habits-trend__key--commitment:before{background:linear-gradient(90deg,var(--primary-light),var(--primary))}.habits-trend__key--consistency:before{background:linear-gradient(90deg,#34d399,var(--accent))}.habits-trend__plot{position:relative;height:112px;border-radius:var(--radius-sm);overflow:hidden;background:var(--trend-plot-bg)}.habits-trend__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:12px 16px;text-align:center;font-size:12px;font-weight:600;color:var(--text-muted)}.habits-trend__empty-hint{margin-top:4px;font-size:11px;font-weight:500;color:var(--text-light);max-width:28ch}.habits-trend__svg{display:block;width:100%;height:100%}.habits-trend__guide{stroke:var(--trend-guide);stroke-width:1;stroke-dasharray:4 6}.habits-trend__area{stroke:none}.habits-trend__area--commitment{fill:var(--trend-commitment-fill)}.habits-trend__area--consistency{fill:var(--trend-consistency-fill)}.habits-trend__line{fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.habits-trend__line--commitment{stroke:var(--primary);filter:drop-shadow(0 1px 2px rgba(99,102,241,.25))}.habits-trend__line--consistency{stroke:var(--accent);filter:drop-shadow(0 1px 2px rgba(16,185,129,.2))}.habits-trend__axis{display:flex;justify-content:space-between;margin-top:8px;padding:0 2px;font-size:10px;font-weight:600;color:var(--text-light)}.habit-card{padding:16px;display:flex;flex-direction:column;gap:12px}.habit-card--complete{background:linear-gradient(145deg,var(--card-gradient-from) 0%,var(--accent-soft) 100%);border-color:#10b98147}.habit-card--complete .habit-score{background:#ffffff8c}.habit-card--complete .habit-card__edit:active{background:#10b9811a}.habit-card--complete .habit-card__progress-label span:last-child{color:var(--accent-text)}.habit-card--complete .habit-card__bar-fill{background:linear-gradient(90deg,#34d399,var(--accent))}.habit-archived-section{margin-top:24px}.habit-archived-section__hint{margin:-4px 0 12px;font-size:12px;color:var(--text-light)}.habit-card--archived{opacity:.82;background:var(--chip-neutral-bg)}.habit-card__archived-badge{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;font-size:10px;font-weight:700;padding:4px 9px;border-radius:var(--radius-pill);background:var(--chip-neutral-bg);color:var(--chip-neutral-text);letter-spacing:.01em}.habit-card__archived-badge .icon{width:12px;height:12px}.habit-form-archive .form-hint{margin-bottom:10px}.habit-form-archive .btn+.btn{margin-top:8px}@media(prefers-color-scheme:dark){:root:not([data-theme-mode=light]) .habit-card--complete{border-color:#34d39938}:root:not([data-theme-mode=light]) .habit-card--complete .habit-score{background:#0000002e}:root:not([data-theme-mode=light]) .habit-card--complete .habit-card__edit:active{background:#34d3991f}}html.theme-dark .habit-card--complete{border-color:#34d39938}html.theme-dark .habit-card--complete .habit-score{background:#0000002e}html.theme-dark .habit-card--complete .habit-card__edit:active{background:#34d3991f}.habit-card__edit{display:block;width:100%;padding:0;margin:0;border:none;background:none;text-align:left;cursor:pointer;color:inherit;font:inherit;border-radius:var(--radius-sm);transition:background .15s ease}.habit-card__edit:active{background:var(--bg)}.habit-card__top{display:flex;align-items:center;gap:12px;margin-bottom:12px}.habit-card__chevron{flex-shrink:0;color:var(--text-muted);opacity:.45}.habit-card__chevron .icon{width:18px;height:18px}.habit-card__icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.habit-card__icon .icon{width:22px;height:22px}.habit-card__info{flex:1}.habit-card__title{font-weight:700;font-size:15px}.habit-card__target{font-size:12px;color:var(--text-muted)}.habit-visibility{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;font-size:10px;font-weight:700;padding:4px 9px;border-radius:var(--radius-pill);letter-spacing:.01em;line-height:1}.habit-visibility .icon{width:12px;height:12px;flex-shrink:0}.habit-visibility--public{background:var(--sky-soft);color:var(--sky-text)}.habit-visibility--public .icon{color:var(--sky-text);stroke:var(--sky-text)}.habit-visibility--buddies{background:var(--primary-soft);color:var(--primary)}.habit-visibility--buddies .icon{color:var(--primary);stroke:var(--primary)}.habit-visibility--private{background:var(--chip-neutral-bg);color:var(--chip-neutral-text)}.habit-visibility--private .icon{color:var(--chip-neutral-text);stroke:var(--chip-neutral-text)}.habit-card__scores{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}.habit-score{padding:8px 10px;background:var(--bg);border-radius:var(--radius-sm)}.habit-score__label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:2px}.habit-score__value{font-size:16px;font-weight:800}.habit-score--commitment .habit-score__value{color:var(--primary)}.habit-score--consistency .habit-score__value{color:var(--accent-text)}.habit-card__progress-label{display:flex;justify-content:space-between;font-size:12px;margin-bottom:6px}.habit-card__progress-label span:last-child{font-weight:700;color:var(--primary)}.habit-card__bar{height:6px;background:var(--border);border-radius:var(--radius-pill);overflow:hidden;margin-bottom:0}.habit-card__bar-fill{height:100%;border-radius:var(--radius-pill);background:linear-gradient(90deg,var(--primary-light),var(--primary))}.habit-card__volume{padding:10px 12px;background:var(--warm-soft);border-radius:var(--radius-sm);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}.habit-card__volume-label{font-size:11px;font-weight:600;color:var(--text-muted)}.habit-card__volume-value{font-size:16px;font-weight:800;color:var(--warm-text);letter-spacing:-.02em}.habits-section{margin-bottom:20px}.habits-section__hint{margin:-6px 0 12px;font-size:13px;color:var(--text-muted)}.habit-card__challenge-meta{margin-top:4px;font-size:12px;font-weight:600;color:var(--primary)}.habit-card__challenge-meta--history{color:var(--text-muted)}.challenge-catalog{display:grid;gap:12px}@media(min-width:1024px){html[data-layout=desktop] .challenge-catalog{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}html[data-layout=desktop] .challenge-catalog__item{height:100%;grid-template-rows:1fr auto}html[data-layout=desktop] .challenge-catalog__btn{margin-top:4px}}.challenge-catalog__item{padding:14px;display:grid;gap:12px}.challenges-category__header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.challenges-category__title{margin:0}.challenge-catalog__title{margin:0 0 4px;font-size:16px}.challenge-catalog__desc,.challenge-catalog__target,.challenge-catalog__stats{margin:0 0 4px;font-size:13px;color:var(--text-muted)}.challenge-catalog__stats{font-size:12px;font-weight:600}.challenges-by-category{display:grid;gap:24px}.challenges-category__header .section-title{margin:0}.challenge-catalog__btn{justify-self:start}.challenge-catalog__item--active{background:var(--challenge-active-bg);border-color:var(--challenge-active-border)}.challenge-catalog__item--active .challenge-catalog__title{color:var(--challenge-active-text)}.challenge-catalog__item--completed{background:var(--challenge-completed-bg);border-color:var(--challenge-completed-border)}.challenge-catalog__item--completed .challenge-catalog__title{color:var(--challenge-completed-text)}.challenge-catalog__item--not-completed{background:var(--challenge-not-completed-bg);border-color:var(--challenge-not-completed-border)}.challenge-catalog__item--not-completed .challenge-catalog__title{color:var(--challenge-not-completed-text)}.challenge-catalog__status{display:inline-flex;align-items:center;justify-content:center;align-self:start;padding:8px 14px;border-radius:var(--radius-pill);font-size:13px;font-weight:700;letter-spacing:.02em;border:1px solid transparent}.challenge-catalog__status--active{background:var(--challenge-active-status-bg);border-color:var(--challenge-active-border);color:var(--challenge-active-status-text)}.challenge-catalog__status--completed{background:var(--challenge-completed-status-bg);border-color:var(--challenge-completed-border);color:var(--challenge-completed-status-text)}.challenge-catalog__status--not-completed{background:var(--challenge-not-completed-status-bg);border-color:var(--challenge-not-completed-border);color:var(--challenge-not-completed-status-text)}.rail-suggested-card,.rail-coach-card{width:100%;max-width:100%;box-sizing:border-box}.rail-suggested-card{padding:16px;border-radius:16px;background:var(--surface);border:1px solid var(--border)}.rail-coach-card{border-radius:16px;background:var(--surface);border:1px solid var(--border);padding:0;color:var(--text);box-shadow:var(--shadow-sm);overflow:hidden}.rail-coach-card__header{display:flex;align-items:center;gap:8px;padding:12px 16px 10px;margin-bottom:0}.rail-coach-card__title{margin:0;font-size:14px;font-weight:700;line-height:1.2;color:var(--text)}.rail-coach-card__header-icon{flex-shrink:0;color:var(--warm-text);stroke:var(--warm-text)}.rail-coach-card__body{position:relative;border-radius:0;background:linear-gradient(145deg,var(--primary-soft) 0%,var(--secondary-soft) 48%,var(--warm-soft) 100%);padding:16px;min-height:128px;overflow:hidden}.rail-coach-card__content{position:relative;z-index:1;max-width:68%}.rail-coach-card__headline{margin:0 0 8px;font-size:15px;font-weight:700;line-height:1.35;color:var(--text)}.rail-coach-card__support{margin:0;font-size:13px;line-height:1.45;color:var(--text-muted)}.rail-coach-card__decor{position:absolute;inset:0;pointer-events:none}.rail-coach-card__decor-icon{position:absolute;display:flex;align-items:center;justify-content:center;color:var(--primary);opacity:.22}.rail-coach-card__decor-icon .icon{width:100%;height:100%;stroke:currentColor}.rail-coach-card__decor-icon--1{right:10px;bottom:14px;width:56px;height:56px;opacity:.28;color:var(--color-coral)}.rail-coach-card__decor-icon--2{right:48px;top:18px;width:34px;height:34px}.rail-coach-card__decor-icon--3{right:18px;top:42px;width:42px;height:42px;opacity:.18}.rail-coach-card__decor-icon--4{right:62px;bottom:28px;width:28px;height:28px;opacity:.16}.rail-coach-card__decor-icon--5{right:28px;top:8px;width:22px;height:22px;opacity:.14;color:var(--warm-text)}@media(prefers-color-scheme:dark){:root:not([data-theme-mode=light]) .rail-coach-card{background:var(--color-deep-slate);border-color:#ffffff14;color:var(--color-off-white);box-shadow:var(--shadow-md)}:root:not([data-theme-mode=light]) .rail-coach-card__title{color:#fffffff2}:root:not([data-theme-mode=light]) .rail-coach-card__header-icon{color:var(--color-sun);stroke:var(--color-sun)}:root:not([data-theme-mode=light]) .rail-coach-card__body{background:linear-gradient(145deg,#47d5bf47,#1e3336f5 52%,#131a24fa)}:root:not([data-theme-mode=light]) .rail-coach-card__headline{color:#fff}:root:not([data-theme-mode=light]) .rail-coach-card__support{color:#ffffff9e}:root:not([data-theme-mode=light]) .rail-coach-card__decor-icon{color:var(--color-mint);opacity:.2}:root:not([data-theme-mode=light]) .rail-coach-card__decor-icon--1{opacity:.24;color:var(--color-coral)}:root:not([data-theme-mode=light]) .rail-coach-card__decor-icon--5{color:var(--color-sun);opacity:.12}}html.theme-dark .rail-coach-card{background:var(--color-deep-slate);border-color:#ffffff14;color:var(--color-off-white);box-shadow:var(--shadow-md)}html.theme-dark .rail-coach-card__title{color:#fffffff2}html.theme-dark .rail-coach-card__header-icon{color:var(--color-sun);stroke:var(--color-sun)}html.theme-dark .rail-coach-card__body{background:linear-gradient(145deg,#47d5bf47,#1e3336f5 52%,#131a24fa)}html.theme-dark .rail-coach-card__headline{color:#fff}html.theme-dark .rail-coach-card__support{color:#ffffff9e}html.theme-dark .rail-coach-card__decor-icon{color:var(--color-mint);opacity:.2}html.theme-dark .rail-coach-card__decor-icon--1{opacity:.24;color:var(--color-coral)}html.theme-dark .rail-coach-card__decor-icon--5{color:var(--color-sun);opacity:.12}.rail-suggested-card__header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.rail-suggested-card__title{display:flex;align-items:center;gap:8px;margin:0;font-size:15px;font-weight:700;line-height:1.2;min-width:0}.rail-suggested-card__title .icon{flex-shrink:0;color:var(--primary);stroke:var(--primary)}.rail-suggested-card__see-all{flex-shrink:0;border:none;background:none;padding:4px 0;font-size:13px;font-weight:600;color:var(--primary);cursor:pointer;text-decoration:none}.rail-suggested-card__see-all:hover{color:var(--accent-text)}.rail-challenge-list{display:flex;flex-direction:column;gap:2px}.rail-challenge-row{display:flex;align-items:center;gap:12px;padding:10px 6px;border-radius:12px;transition:background .15s ease}.rail-challenge-row:hover{background:var(--primary-soft)}.rail-challenge-row__icon{flex-shrink:0;width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center}.rail-challenge-row__icon .icon{width:20px;height:20px}.rail-challenge-row__body{flex:1;min-width:0}.rail-challenge-row__title{margin:0 0 3px;font-size:14px;font-weight:700;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rail-challenge-row__meta{margin:0;font-size:12px;color:var(--text-muted);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rail-challenge-row__add{flex-shrink:0;width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--bg);color:var(--primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .15s ease}.rail-challenge-row__add:hover{background:var(--primary-soft);border-color:color-mix(in srgb,var(--primary) 45%,var(--border));transform:scale(1.04)}.rail-challenge-row__add .icon{width:18px;height:18px;stroke:var(--primary)}.rail-challenge-row__badge{flex-shrink:0;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid transparent}.rail-challenge-row__badge--active{background:var(--challenge-active-status-bg);border-color:var(--challenge-active-border);color:var(--challenge-active-status-text)}.rail-challenge-row__badge--active .icon{stroke:currentColor}.rail-challenge-row__badge--completed{background:var(--challenge-completed-status-bg);border-color:var(--challenge-completed-border);color:var(--challenge-completed-status-text)}.rail-challenge-row__badge--completed .icon{stroke:currentColor}.rail-suggested-card .feed-empty--compact{padding:8px 4px;text-align:center}.habit-picker-section{margin-bottom:18px}.habit-picker-section__title{margin:0 0 10px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.habit-picker-section__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.habits-challenges-entry{display:flex;align-items:center;gap:12px;width:100%;margin-bottom:16px;padding:14px 16px;border:1px solid var(--challenge-active-border);background:var(--challenge-active-bg);color:var(--challenge-active-text);cursor:pointer;text-align:left;transition:background .15s,border-color .15s,box-shadow .15s}.habits-challenges-entry:hover{background:var(--challenge-active-status-bg);box-shadow:var(--shadow-sm)}.habits-challenges-entry__icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:var(--challenge-active-status-bg);border:1px solid var(--challenge-active-border);flex-shrink:0}.habits-challenges-entry__icon .icon{stroke:var(--challenge-active-status-text)}.habits-challenges-entry__body{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.habits-challenges-entry__title{font-size:15px;font-weight:700;line-height:1.2;color:var(--challenge-active-text)}.habits-challenges-entry__meta{font-size:12px;line-height:1.3;color:var(--challenge-active-status-text);opacity:.9}.habits-challenges-entry__chevron{display:flex;align-items:center;flex-shrink:0;color:var(--challenge-active-status-text);opacity:.75}html[data-layout=desktop] .habits-challenges-entry{display:none}@media(max-width:520px){.habit-picker-section__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.sheet-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:flex-end;justify-content:center;padding:16px;background:#131a248c}.sheet-overlay[hidden]{display:none}.sheet-overlay .sheet{width:min(100%,420px);padding:18px}.sheet__title{margin:0 0 6px;font-size:20px}.sheet__meta{margin:0 0 14px;color:var(--text-muted);font-size:14px}.sheet__actions{display:grid;gap:8px;margin-top:16px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:13px;font-weight:700;margin-bottom:8px;color:var(--text)}.form-input{width:100%;max-width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:16px;outline:none;transition:border-color .15s;background:var(--bg-card)}.form-input:focus{border-color:var(--primary)}.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.category-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);cursor:pointer;transition:all .15s;color:var(--text-muted)}.category-btn .icon{width:22px;height:22px}.category-btn span{font-size:10px;font-weight:600;color:var(--text-muted)}.category-btn.selected{border-color:var(--primary);background:var(--primary-soft)}.category-btn.selected span{color:var(--primary)}.toggle-group{display:flex;gap:8px}.toggle-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;color:var(--text-muted)}.toggle-btn .icon{width:14px;height:14px}.toggle-btn.selected{background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}.form-hint{margin:8px 0 0;font-size:12px;color:var(--text-muted);line-height:1.4}.form-hint strong{color:var(--text);font-weight:600}.preview-card{padding:16px;margin-top:8px;background:linear-gradient(135deg,var(--primary-soft),var(--accent-soft));border:1px dashed var(--primary-light)}.preview-card__label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary);margin-bottom:10px}.preview-card__content{font-size:14px}.buddy-section{margin-bottom:24px}.buddy-section__metrics-note{margin:-4px 0 12px;font-size:11px;font-weight:600;color:var(--text-light)}.buddy-list{display:flex;flex-direction:column;gap:10px}.buddy-item{display:flex;align-items:center;gap:12px;padding:12px 16px;width:100%;border:none;text-align:left;cursor:pointer}.buddy-item__info{flex:1}.buddy-item__name{font-weight:700;font-size:14px}.buddy-item__status{font-size:12px;color:var(--text-muted)}.buddy-item__metrics{text-align:right;line-height:1.3}.buddy-item__metrics-row{font-size:10px;font-weight:600;color:var(--text-muted)}.buddy-item__metrics-row strong{font-size:13px;font-weight:800}.buddy-item__metrics-row--commitment strong{color:var(--primary)}.feed-empty--compact{padding:12px;font-size:12px}.rail-buddy-pending{margin:-4px 0 10px;font-size:12px;font-weight:600;color:var(--primary)}.rail-buddy-pending[hidden]{display:none!important}.invite-item{display:flex;align-items:center;gap:12px;padding:12px 16px}.invite-actions{display:flex;gap:6px}.suggested-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.suggested-card{padding:14px;text-align:center}.suggested-card__name{font-weight:700;font-size:13px;margin:8px 0 4px}.suggested-card__habit{font-size:11px;color:var(--text-muted);margin-bottom:10px}.challenge-banner{padding:20px;background:linear-gradient(135deg,var(--sky-soft),var(--primary-soft));border:1px solid rgba(14,165,233,.2);text-align:center}.challenge-banner__title{display:flex;align-items:center;justify-content:center;gap:6px;font-weight:800;font-size:16px;margin-bottom:4px}.challenge-banner__title .icon{width:18px;height:18px;color:var(--sky);stroke:var(--sky)}.challenge-banner__desc{font-size:13px;color:var(--text-muted);margin-bottom:14px}.challenge-banner__participants{display:flex;justify-content:center;gap:-8px;margin-bottom:14px}.challenge-banner__participants .avatar{margin-left:-8px;border:2px solid white}.challenge-banner__participants .avatar:first-child{margin-left:0}.profile-header{text-align:center;padding:24px 16px;margin-bottom:16px}.card.profile-header{overflow:visible}.profile-avatar-wrap{position:relative;width:72px;margin:0 auto;overflow:visible;z-index:1}.profile-avatar-wrap .avatar--lg{margin:0!important}.profile-avatar-edit{position:absolute;top:-2px;right:-2px;z-index:2;width:28px;height:28px;border-radius:50%;border:2px solid var(--surface);background:var(--surface);color:var(--text);box-shadow:0 2px 8px #1f2a4426;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s,background .15s}.profile-avatar-edit:hover{background:var(--bg)}.profile-avatar-edit:active{transform:scale(.95)}.profile-avatar-edit:disabled{opacity:.6;cursor:wait}.profile-header__name{font-size:20px;font-weight:800;margin:12px 0 4px}.profile-header__bio{display:flex;align-items:center;justify-content:center;gap:4px;font-size:13px;color:var(--text-muted)}.profile-name-card{padding:16px;margin-bottom:16px}.profile-name-card__label{display:block;font-size:13px;font-weight:700;margin-bottom:6px}.profile-name-card__hint{font-size:12px;color:var(--text-muted);line-height:1.45;margin-bottom:12px}.profile-name-card__hint strong{color:var(--text);font-weight:700}.profile-name-card__input{width:100%;min-height:44px;padding:0 14px;border:1.5px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);font-size:16px;outline:none;transition:border-color .15s,box-shadow .15s}.profile-name-card__input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.profile-header__username{font-size:13px;color:var(--text-muted);margin:-2px 0 4px}.profile-account{margin-top:28px;padding-top:20px;border-top:1px solid var(--border);text-align:center}.profile-account__logout{min-width:140px}.profile-account__hint{margin:10px 0 0;font-size:12px;color:var(--text-light)}.profile-account__danger{margin-top:28px;padding-top:20px;border-top:1px solid var(--border);text-align:left}.profile-account__danger-title{margin:0 0 8px;font-size:15px;color:var(--text)}.profile-account__danger-copy{margin:0 0 14px;font-size:13px;line-height:1.5;color:var(--text-muted)}.profile-account__delete{width:100%}.delete-account-sheet__list{margin:0 0 12px;padding-left:18px;color:var(--text-muted);font-size:14px;line-height:1.45}.delete-account-sheet__warn{margin:0 0 14px;font-size:13px;font-weight:600;color:#c0392b}.delete-account-sheet__field{margin-bottom:14px}.delete-account-sheet__status{margin:0 0 14px;font-size:13px;line-height:1.45;color:var(--text-muted)}.delete-account-sheet__status--error{color:#c0392b;font-weight:600}.public-profile__actions{display:flex;gap:10px;margin-bottom:20px}.public-profile__actions .btn{flex:1}.public-profile__stats-note{font-size:11px;color:var(--text-light);text-align:center;margin:-12px 0 20px;line-height:1.4}#public-profile-content .habits-trend{margin-bottom:20px}.public-habit-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.public-habit-item{display:flex;align-items:center;gap:12px;padding:14px 16px}.public-habit-item__icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.public-habit-item__info{flex:1;min-width:0}.public-habit-item__title{font-weight:700;font-size:14px;margin-bottom:2px}.public-habit-item__target{font-size:12px;color:var(--text-muted)}.public-habit-item__scores{display:flex;gap:10px;font-size:11px;font-weight:600;color:var(--text-muted)}.public-habit-item__scores strong{color:var(--text)}.public-profile__habit-summary{font-size:12px;color:var(--text-muted);margin:-8px 0 12px}.public-profile-empty{width:100%;margin:0;padding:16px;text-align:center;color:var(--text-light);font-size:13px;background:var(--bg);border:1px dashed var(--border);border-radius:12px;box-sizing:border-box}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.stat-card{padding:16px 12px;text-align:center}.stat-card__value{font-size:24px;font-weight:800;color:var(--primary);letter-spacing:-.02em}.stat-card--consistency .stat-card__value{color:var(--accent-text)}.stat-card__label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.stat-card__hint{font-size:10px;color:var(--text-light);margin-top:4px;line-height:1.3}.volume-profile-list{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.volume-profile-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px}.volume-profile-item__left{display:flex;align-items:center;gap:10px}.volume-profile-item__label{font-size:13px;font-weight:600}.volume-profile-item__value{font-size:16px;font-weight:800;color:var(--warm)}.badges-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.badges-row .public-profile-empty{flex:1 1 100%}.badge{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-pill);font-size:13px;font-weight:600;background:var(--warm-soft);color:var(--warm-text)}.badge .icon{width:14px;height:14px}.badge--green{background:var(--accent-soft);color:var(--accent-text)}.badge--blue{background:var(--primary-soft);color:var(--primary)}.badge--rose{background:var(--rose-soft);color:var(--rose)}.badge--amber{background:var(--warm-soft);color:var(--warm-text)}.wins-list{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.win-item{display:flex;align-items:center;gap:10px;padding:12px 16px;font-size:13px}.win-item__icon{display:flex;align-items:center;justify-content:center;color:var(--primary)}.win-item__icon .icon{width:20px;height:20px}.privacy-card{padding:16px;background:var(--bg)}.privacy-card__block{padding:8px 0 14px;border-bottom:1px solid var(--border)}.privacy-card__block:last-of-type{border-bottom:none;padding-bottom:0}.privacy-card__heading{display:flex;justify-content:space-between;align-items:center;gap:12px}.privacy-card__label{font-size:13px;font-weight:600}.privacy-card__hint{margin:4px 0 10px;font-size:12px;color:var(--text-light)}.privacy-card__row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;font-size:13px;border-bottom:1px solid var(--border)}.privacy-card__value,.privacy-card__stat{font-weight:600;color:var(--primary)}.visibility-picker{display:flex;gap:8px}.visibility-picker__btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text-muted);cursor:pointer;transition:border-color .15s,background .15s,color .15s}.visibility-picker__btn:hover{border-color:var(--primary-light);color:var(--primary)}.visibility-picker__btn--selected{border-color:var(--primary);background:var(--primary-soft);color:var(--primary)}.profile-empty{margin:0;padding:16px;text-align:center;font-size:13px;color:var(--text-light);background:var(--bg);border:1px dashed var(--border);border-radius:12px}.profile-invite-card{padding:16px;text-align:center}.profile-invite-card__heading{display:flex;justify-content:center;margin-bottom:8px}.profile-invite-card__title{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:700}.profile-invite-card__hint{margin:0 0 16px;font-size:12px;color:var(--text-muted);line-height:1.4}.profile-invite-card__qr-wrap{display:inline-flex;justify-content:center;margin:0 auto 16px;padding:12px;background:#fff;border-radius:12px;box-shadow:inset 0 0 0 1px #1f2a4414}.profile-invite-card__qr{display:block;border-radius:4px;background:#fff}.profile-invite-card__link-label{margin:0 0 8px;font-size:12px;color:var(--text-muted)}.profile-invite-card__link-row{display:flex;gap:8px;align-items:center}.profile-invite-card__link{flex:1;min-width:0;padding:10px 12px;border:1px solid var(--border);border-radius:10px;font-size:12px;background:var(--bg);color:var(--text-muted)}.about-page{display:flex;flex-direction:column;gap:20px;max-width:560px}.about-intro{padding:18px 16px}.about-intro__lead{margin:0 0 10px;font-size:16px;font-weight:700;line-height:1.45;color:var(--text)}.about-intro p:last-child{margin:0;color:var(--text-muted);line-height:1.55}.about-block__title{margin:0 0 10px;font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-text)}.about-block p{margin:0 0 10px;color:var(--text-muted);line-height:1.55}.about-block p:last-child{margin-bottom:0}.about-list{margin:0;padding-left:1.1rem;display:flex;flex-direction:column;gap:10px;color:var(--text-muted);line-height:1.55}.about-list strong{color:var(--text);font-weight:700}.about-cta{padding:16px;background:linear-gradient(135deg,var(--card-gradient-from) 0%,var(--primary-soft) 100%)}.about-cta__text{margin:0 0 12px;font-weight:600;line-height:1.45}.about-cta__actions{display:flex;flex-wrap:wrap;gap:8px}.about-back{margin:4px 0 0;text-align:center}.app-about-link{display:inline-flex;align-items:center;gap:6px;padding:0;border:none;background:none;color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;text-decoration:underline;text-underline-offset:3px;text-decoration-color:#47d5bf73;transition:color .15s}.app-about-link:hover{color:var(--primary)}.app-about-link.active{color:var(--accent-text);text-decoration-color:currentColor}.changelog-meta{margin:-8px 0 16px;font-size:13px;color:var(--text-light)}.changelog-page{max-width:560px}.changelog-loading{margin:0;font-size:14px;color:var(--text-muted)}.changelog-scroll{display:flex;flex-direction:column;gap:16px;padding-bottom:8px}.changelog-section--progress{padding:16px;border:1px solid rgba(71,213,191,.35);background:linear-gradient(145deg,var(--card-gradient-from) 0%,var(--primary-soft) 55%,rgba(245,160,143,.12) 100%)}.changelog-section__header{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}.changelog-section__icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:var(--primary-soft);color:var(--accent-text);flex-shrink:0}.changelog-section__eyebrow{margin:0 0 2px;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-text)}.changelog-section__title{margin:0;font-size:18px;font-weight:700;line-height:1.3;color:var(--text)}.changelog-progress-list{display:flex;flex-direction:column;gap:12px}.changelog-progress-item{padding:12px 14px;border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border)}.changelog-progress-item__head{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.changelog-progress-item__title{margin:0;font-size:15px;font-weight:700;color:var(--text);flex:1 1 auto}.changelog-progress-item__desc{margin:8px 0 10px;font-size:13px;line-height:1.5;color:var(--text-muted)}.changelog-progress-item__track{display:flex;align-items:center;gap:10px}.changelog-progress-item__bar{flex:1;height:8px;border-radius:var(--radius-pill);background:var(--border);overflow:hidden}.changelog-progress-item__bar-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--primary),var(--primary-light));transition:width .35s ease}.changelog-progress-item__pct{flex-shrink:0;min-width:2.5rem;font-size:12px;font-weight:700;color:var(--accent-text);text-align:right}.changelog-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:var(--radius-pill);font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.changelog-badge--feature,.changelog-badge--added{background:var(--primary-soft);color:var(--accent-text)}.changelog-badge--improved{background:var(--secondary-soft);color:var(--secondary)}.changelog-badge--fixed{background:var(--nav-accent-soft);color:var(--nav-accent-text)}.changelog-releases{display:flex;flex-direction:column;gap:14px}.changelog-release{padding:16px}.changelog-release__header{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}.changelog-release__version-wrap{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;margin-bottom:4px}.changelog-release__version{font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-text)}.changelog-release__date{font-size:12px;color:var(--text-light)}.changelog-release__title{margin:0;font-size:17px;font-weight:700;color:var(--text)}.changelog-release__body{display:flex;flex-direction:column;gap:12px}.changelog-group__label{margin:0 0 8px;font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.changelog-group--added .changelog-group__label{color:var(--accent-text)}.changelog-group--improved .changelog-group__label{color:var(--secondary)}.changelog-group--fixed .changelog-group__label{color:var(--nav-accent-text)}.changelog-group--feature .changelog-group__label{color:var(--accent-text)}.changelog-list{margin:0;padding-left:1.1rem;display:flex;flex-direction:column;gap:8px;color:var(--text-muted);font-size:14px;line-height:1.5}html[data-layout=desktop] .sidebar-nav__item--about{margin-top:4px;border-top:1px solid var(--border);padding-top:16px}html[data-layout=desktop] .sidebar-nav__item--changelog{line-height:1.35;white-space:normal;text-align:left}.bottom-nav:has(.nav-item:nth-child(6)) .nav-item:not(.nav-item--add){min-width:48px;padding-left:6px;padding-right:6px}.bottom-nav:has(.nav-item:nth-child(6)) .nav-item__label{font-size:9px}.dev-blog-page{max-width:560px}.dev-blog-loading{display:flex;align-items:center;gap:8px;margin:0;font-size:14px;color:var(--text-muted)}.dev-blog-scroll{display:flex;flex-direction:column;gap:16px;padding-bottom:8px}.dev-blog-intro{margin:0;padding:16px;font-size:14px;line-height:1.55;color:var(--text-muted);border:1px solid var(--border);background:var(--surface-muted)}.dev-blog-posts{display:flex;flex-direction:column;gap:14px}.dev-blog-post{padding:16px}.dev-blog-post__header{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}.dev-blog-post__date{display:block;margin-bottom:6px;font-size:12px;color:var(--text-light)}.dev-blog-post__title{margin:0 0 8px;font-size:18px;font-weight:700;line-height:1.35;color:var(--text)}.dev-blog-post__excerpt{margin:0 0 10px;font-size:14px;font-weight:600;line-height:1.45;color:var(--text-muted)}.dev-blog-tags{display:flex;flex-wrap:wrap;gap:6px;margin:0;padding:0;list-style:none}.dev-blog-tag{padding:3px 8px;border-radius:var(--radius-pill);font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:var(--secondary-soft);color:var(--secondary)}.dev-blog-post__body p{margin:0 0 12px;font-size:14px;line-height:1.6;color:var(--text-muted)}.dev-blog-post__body p:last-child{margin-bottom:0}.dev-blog-post__related{margin:14px 0 0;padding-top:12px;border-top:1px solid var(--border);font-size:13px;color:var(--text-light)}html[data-layout=desktop] .sidebar-nav__item--dev-blog,html[data-layout=desktop] .sidebar-nav__item--changelog{line-height:1.35;white-space:normal;text-align:left}.bottom-nav:has(.nav-item--changelog) .nav-item:not(.nav-item--add){min-width:44px;padding-left:4px;padding-right:4px}.bottom-nav:has(.nav-item--changelog) .nav-item__label{font-size:9px}.legal-page{display:flex;flex-direction:column;gap:20px;max-width:560px}.legal-meta{margin:-8px 0 16px;font-size:13px;color:var(--text-light)}.legal-intro{padding:18px 16px}.legal-intro__lead{margin:0;font-size:15px;font-weight:600;line-height:1.5;color:var(--text)}.legal-block__title{margin:0 0 10px;font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-text)}.legal-block p{margin:0 0 10px;color:var(--text-muted);line-height:1.55}.legal-block p:last-child{margin-bottom:0}.legal-list{margin:0;padding-left:1.1rem;display:flex;flex-direction:column;gap:10px;color:var(--text-muted);line-height:1.55}.legal-list strong{color:var(--text);font-weight:700}.legal-contact-link{color:var(--accent-text);font-weight:600;text-decoration:underline;text-underline-offset:3px}.legal-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;margin:8px 0 0;font-size:13px}.legal-footer__sep{color:var(--text-light)}.app-legal-link{color:var(--text-muted);font-weight:600;text-decoration:underline;text-underline-offset:3px;text-decoration-color:#47d5bf73;transition:color .15s}.app-legal-link:hover{color:var(--primary)}.auth-legal-note{margin:0 0 12px;font-size:12px;line-height:1.45;color:var(--text-muted);text-align:center}.auth-legal-note .app-legal-link{font-size:inherit}.auth-modal{position:fixed;inset:0;z-index:400;pointer-events:none;visibility:hidden;transition:visibility .25s}.auth-modal.open{pointer-events:auto;visibility:visible}.auth-modal__backdrop{position:absolute;inset:0;background:var(--overlay, rgba(15, 18, 25, .55));opacity:0;transition:opacity .25s}.auth-modal.open .auth-modal__backdrop{opacity:1}.auth-modal__panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(.96);width:min(400px,calc(100% - 32px));max-height:min(92dvh,720px);overflow-y:auto;padding:28px 24px 24px;opacity:0;background:var(--header-bg);border:1px solid var(--card-border);border-radius:20px;box-shadow:var(--shadow-lg);transition:transform .28s cubic-bezier(.32,.72,0,1),opacity .2s ease}.auth-modal.open .auth-modal__panel{transform:translate(-50%,-50%) scale(1);opacity:1}.auth-modal__close{position:absolute;top:14px;right:14px;z-index:1;width:36px;height:36px;border:none;border-radius:50%;background:var(--surface-muted, rgba(0, 0, 0, .04));color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.auth-modal__close:hover{background:var(--primary-soft);color:var(--primary)}.auth-modal__header{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;margin-bottom:20px;padding:0 28px}.auth-modal__brand{margin:0;display:flex;justify-content:center;width:100%;font-size:inherit;font-weight:inherit;line-height:0}.auth-modal__subtitle{margin:0;color:var(--text-muted);font-size:.92rem;line-height:1.45;max-width:28ch}.auth-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid var(--border)}.auth-tabs__btn{flex:1;border:none;border-bottom:2px solid transparent;border-radius:0;margin-bottom:-1px;padding:12px 8px;background:transparent;color:var(--text-muted);font-size:.95rem;font-weight:700;cursor:pointer;transition:color .15s,border-color .15s}.auth-tabs__btn:hover{color:var(--text)}.auth-tabs__btn.selected{color:var(--nav-accent-text);border-bottom-color:var(--nav-accent);background:transparent}.auth-form{display:grid;gap:14px}.auth-form .field{display:flex;flex-direction:column;gap:6px}.auth-form .field__label{font-size:.8125rem;font-weight:700;letter-spacing:.01em;color:var(--text)}.auth-form .field__input{width:100%;min-height:48px;padding:0 14px;border:1.5px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);font-size:16px;line-height:1.2;outline:none;transition:border-color .15s,box-shadow .15s,background .15s;-webkit-appearance:none;appearance:none}.auth-form .field__input::placeholder{color:var(--text-light)}.auth-form .field__input:hover{border-color:color-mix(in srgb,var(--border) 50%,var(--text-muted))}.auth-form .field__input:focus{border-color:var(--primary);background:var(--bg-card);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 22%,transparent)}.auth-form .field__input--code{text-align:center;letter-spacing:.35em;font-size:1.25rem;font-weight:700;font-variant-numeric:tabular-nums;padding-left:.35em}.auth-form__submit{min-height:48px;margin-top:4px;border-radius:12px;font-size:15px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px}.auth-form__submit:disabled{opacity:.92;cursor:wait}.auth-form__submit-spinner{display:none;width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:authSpin .7s linear infinite;flex-shrink:0}.auth-form__submit.is-loading .auth-form__submit-spinner{display:inline-block}.auth-modal--busy .auth-modal__close,.auth-modal--busy .auth-tabs__btn{pointer-events:none;opacity:.55}@keyframes authSpin{to{transform:rotate(360deg)}}.auth-form--verify{gap:16px}.auth-form__footer{margin:0;text-align:center}.auth-form__link{background:none;border:none;padding:0;color:var(--accent-text);font-size:.875rem;font-weight:600;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.auth-form__link:hover{color:var(--primary)}.auth-hint{margin:-4px 0 0;font-size:.8125rem;color:var(--text-muted);line-height:1.45}.auth-hint--lead{margin:0;text-align:center;font-size:.9rem}.auth-invite-message{margin:0 0 14px;padding:12px 14px;border-radius:12px;background:var(--primary-soft);color:var(--primary);font-size:.875rem;font-weight:600;line-height:1.4;border:1px solid color-mix(in srgb,var(--primary) 18%,transparent)}.auth-invite-message[hidden]{display:none!important}.auth-error{margin:0 0 14px;padding:12px 14px;border-radius:12px;background:var(--rose-soft);color:var(--rose);font-size:.875rem;font-weight:600;line-height:1.4;border:1px solid color-mix(in srgb,var(--rose) 18%,transparent)}.auth-error[hidden]{display:none!important}body.auth-modal-open{overflow:hidden}@media(min-width:480px){.auth-modal__panel{padding:32px 28px 28px}}.feed-auth-banner{margin-top:12px;padding:16px 18px;display:grid;gap:12px;background:linear-gradient(135deg,var(--primary-soft),var(--accent-soft, rgba(236, 72, 153, .08)));border:1px solid var(--border)}.feed-auth-banner__title{margin:0 0 4px;font-size:1rem;font-weight:800;letter-spacing:-.02em}.feed-auth-banner__text{margin:0;color:var(--text-muted);font-size:.92rem;line-height:1.45}.feed-auth-banner__actions{display:flex;flex-wrap:wrap;gap:8px}.header__auth-actions{display:none;align-items:center;gap:6px;flex-shrink:0}html[data-auth=out][data-backend=on]:not(.native-app){--shell-bottom: env(safe-area-inset-bottom, 0px)}html[data-auth=out][data-backend=on]:not(.native-app) [data-auth-only]{display:none!important}html[data-auth=out][data-backend=on]:not(.native-app) .header__auth-actions{display:flex}html[data-auth=out][data-backend=on]:not(.native-app) .bottom-nav .nav-item[data-auth-only]{display:none}html[data-auth=out][data-backend=on]:not(.native-app):not([data-layout=desktop]) #app-rail{display:none!important}html[data-auth=out][data-backend=on]:not(.native-app) .feed-filter__btn[data-filter=buddies],html[data-auth=out][data-backend=on]:not(.native-app) .feed-filter__btn[data-filter=you]{display:none}html[data-auth=in] [data-guest-only],html[data-backend=off] [data-guest-only],html[data-backend=off] [data-backend-only],html[data-auth=in] .header__auth-actions{display:none!important}html.native-app[data-auth=out][data-backend=on] .auth-modal__close,html.native-app[data-auth=out][data-backend=on] .auth-modal__backdrop{display:none}@media(min-width:1024px){html[data-layout=desktop][data-auth=out][data-backend=on]:not(.native-app) .sidebar-nav__item:not([data-screen=feed]):not([data-screen=about]):not([data-screen=changelog]):not([data-screen=dev-blog]){display:none}html[data-layout=desktop][data-auth=out][data-backend=on]:not(.native-app) .sidebar__scores,html[data-layout=desktop][data-auth=out][data-backend=on]:not(.native-app) .sidebar__user{display:none!important}}@media(min-width:481px){body{background:linear-gradient(180deg,var(--bg-shell) 0%,var(--bg) 120px)}.app{max-width:var(--max-width);margin:16px auto;height:calc(100dvh - 32px);max-height:calc(100dvh - 32px);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-lg);background:var(--bg)}.header{border-radius:24px 24px 0 0}.bottom-nav{border-radius:0 0 24px 24px}}@media(min-width:1024px){:root{--max-width: none;--sidebar-width: 240px;--rail-width: 320px}html[data-layout=desktop] body{background:linear-gradient(180deg,var(--bg-shell) 0%,var(--bg) 160px)}html[data-layout=desktop] .app{display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr) var(--rail-width);grid-template-rows:1fr;max-width:1280px;width:calc(100% - 32px);height:calc(100dvh - 32px);max-height:calc(100dvh - 32px);margin:16px auto;border-radius:24px;overflow:hidden;box-shadow:var(--shadow-lg);background:var(--bg)}html[data-layout=desktop] .sidebar{display:flex;flex-direction:column;padding:20px 16px;border-right:1px solid var(--border);background:var(--header-bg);overflow-y:auto}html[data-layout=desktop] .sidebar__brand{display:flex;align-items:center;margin-bottom:24px;padding:0 8px;min-width:0}html[data-layout=desktop] .sidebar-nav{display:flex;flex-direction:column;gap:4px;flex:1}html[data-layout=desktop] .sidebar-nav__item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 14px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-weight:600;font-size:14px;cursor:pointer;text-align:left}html[data-layout=desktop] .sidebar-nav__item:hover,html[data-layout=desktop] .sidebar-nav__item.active{background:var(--nav-highlight-bg);color:var(--nav-highlight-text)}html[data-layout=desktop] .sidebar-nav__item:hover .icon,html[data-layout=desktop] .sidebar-nav__item.active .icon{color:var(--nav-highlight-text);stroke:var(--nav-highlight-text)}html[data-layout=desktop] .sidebar__scores{display:flex;flex-direction:column;gap:8px;margin-top:auto;padding-top:16px}html[data-layout=desktop] .sidebar-score{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border)}html[data-layout=desktop] .sidebar-score--commitment{background:var(--primary-soft);border-color:transparent}html[data-layout=desktop] .sidebar-score--commitment .sidebar-score__value{color:var(--primary)}html[data-layout=desktop] .sidebar-score--consistency{background:var(--accent-soft);border-color:transparent}html[data-layout=desktop] .sidebar-score--consistency .sidebar-score__value{color:var(--accent-text)}html[data-layout=desktop] .sidebar-score__body{display:flex;flex-direction:column;gap:1px;min-width:0}html[data-layout=desktop] .sidebar-score__label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light)}html[data-layout=desktop] .sidebar-score__value{font-size:18px;font-weight:800;letter-spacing:-.02em;line-height:1.1}html[data-layout=desktop] .sidebar__user{display:flex;align-items:center;gap:10px;width:100%;padding:12px;margin-top:12px;border:none;text-align:left;cursor:pointer;transition:background .15s,box-shadow .15s}html[data-layout=desktop] .sidebar__user:hover,html[data-layout=desktop] .sidebar__user.active{background:var(--nav-highlight-bg);color:var(--nav-highlight-text)}html[data-layout=desktop] .sidebar__user:hover .sidebar__user-label,html[data-layout=desktop] .sidebar__user.active .sidebar__user-label{color:inherit;opacity:.72}html[data-layout=desktop] .sidebar__username{font-weight:700;font-size:13px}html[data-layout=desktop] .sidebar__user-label{font-size:11px;color:var(--text-light)}html[data-layout=desktop] .app-center{display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}html[data-layout=desktop] .header{display:none}html[data-layout=desktop] .main{position:static;flex:1;min-height:0;height:auto;overflow-x:hidden;overflow-y:auto;overscroll-behavior-y:contain;padding:0 16px 16px;max-width:680px;width:100%;margin:0 auto}html[data-layout=desktop] .screen.active{position:static;display:block;inset:auto;overflow:visible;padding:16px 0 0;animation:fadeIn .25s ease}html[data-layout=desktop] .feed-chrome{position:sticky;top:0;z-index:5;margin:-16px -16px 16px;padding:16px 16px 12px;background:var(--bg);border-bottom:1px solid var(--border);box-shadow:0 4px 12px #0f172a0a}html[data-layout=desktop] .sidebar-right{display:block;padding:20px 16px;border-left:1px solid var(--border);background:var(--bg);overflow-y:auto}html[data-layout=desktop] .bottom-nav{display:none}html[data-layout=desktop] .rail-section{margin-bottom:20px;min-width:0}html[data-layout=desktop] .rail-section__title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-light);margin-bottom:10px;display:flex;align-items:center;gap:6px}html[data-layout=desktop] .rail-section__title .icon{width:14px;height:14px;flex-shrink:0}html[data-layout=desktop] .buddy-item--compact{padding:10px 12px;margin-bottom:8px}html[data-layout=desktop] .buddy-item--compact .avatar{width:36px;height:36px}html[data-layout=desktop] .suggested-card--rail,html[data-layout=desktop] .challenge-banner--rail{padding:14px;text-align:center}html[data-layout=desktop] .log-sheet{display:flex;align-items:center;justify-content:center;padding:24px}html[data-layout=desktop] .log-sheet__backdrop{backdrop-filter:blur(4px)}html[data-layout=desktop] .log-sheet.open{visibility:visible}html[data-layout=desktop] .log-sheet__handle{display:none}html[data-layout=desktop] .log-sheet__panel{position:relative;left:auto;bottom:auto;width:min(440px,calc(100vw - 48px));max-width:none;max-height:min(85vh,680px);border-radius:var(--radius);padding-bottom:0;transition:transform .22s cubic-bezier(.32,.72,0,1),opacity .22s ease}html[data-layout=desktop] .log-sheet:not(.open) .log-sheet__panel{opacity:0;transform:scale(.96) translateY(8px)}html[data-layout=desktop] .log-sheet.open .log-sheet__panel{opacity:1;transform:scale(1) translateY(0)}html[data-layout=desktop] .log-sheet__header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}html[data-layout=desktop] .log-sheet__close{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:36px;height:36px;margin:-4px -4px 0 0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);cursor:pointer}html[data-layout=desktop] .log-sheet__close:hover{background:var(--bg);color:var(--text)}html[data-layout=desktop] .log-sheet__footer{border-radius:0 0 var(--radius) var(--radius)}}.sidebar,.sidebar-right{display:none}@media(min-width:1024px){html[data-layout=desktop] .sidebar,html[data-layout=desktop] .sidebar-right{display:flex}html[data-layout=desktop] .sidebar-right{display:block}}
