@import"https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=DM+Sans:wght@400;500;600&display=swap";*,::backdrop,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;tab-size:4;-webkit-tap-highlight-color:transparent}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{color:inherit;font-family:inherit;font-feature-settings:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media(min-width:640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media(min-width:768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media(min-width:1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media(min-width:1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media(min-width:1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline{display:inline}.flex{display:flex}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.border{border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.outline{outline-style:solid}.blur{--tw-blur:blur(8px)}.blur,.drop-shadow{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px #0000001a) drop-shadow(0 1px 1px #0000000f)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}:root{--color-violet:#7c3aed;--color-violet-light:#a78bfa;--color-violet-dim:rgba(124,58,237,.15);--color-pink:#f472b6;--color-pink-dim:rgba(244,114,182,.15);--color-green:#34d399;--color-blue:#38bdf8;--color-orange:#fb923c;--sidebar-width:220px;--sidebar-width-collapsed:64px;--navbar-height:60px;--space-xs:4px;--space-sm:8px;--space-md:14px;--space-lg:20px;--space-xl:28px;--space-2xl:40px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s cubic-bezier(.4,0,.2,1);--font-display:"Sora",sans-serif;--font-body:"DM Sans",sans-serif}:root,[data-theme=dark]{--color-bg:#100e27;--color-bg2:#1a1145;--color-surface:#1e1540;--color-surface2:#261b54;--color-border:rgba(124,58,237,.18);--color-text:#f0ecff;--color-text-muted:#9d8fc4;--color-text-faint:#5c4f8a;--shadow-sm:0 2px 8px rgba(0,0,0,.35);--shadow-md:0 4px 16px rgba(0,0,0,.45);--shadow-violet:0 4px 20px rgba(124,58,237,.4);--shadow-pink:0 4px 20px rgba(244,114,182,.3);--navbar-bg:rgba(26,17,69,.88)}[data-theme=light]{--color-bg:#f4f2ff;--color-bg2:#fff;--color-surface:#fff;--color-surface2:#ede9fe;--color-border:rgba(124,58,237,.15);--color-text:#1a1145;--color-text-muted:#6b5fa0;--color-text-faint:#a89dc8;--shadow-sm:0 2px 8px rgba(124,58,237,.08);--shadow-md:0 4px 16px rgba(124,58,237,.12);--shadow-violet:0 4px 20px rgba(124,58,237,.2);--shadow-pink:0 4px 20px rgba(244,114,182,.15);--navbar-bg:hsla(0,0%,100%,.9)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{background-color:var(--color-bg);font-family:var(--font-body);line-height:1.5;-webkit-font-smoothing:antialiased;transition:background-color var(--transition-slow),color var(--transition-slow)}body,h1,h2,h3,h4,h5,h6{color:var(--color-text)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.2}a{color:inherit;text-decoration:none}button{cursor:pointer}button,input,select,textarea{font-family:var(--font-body)}img,svg{display:block;max-width:100%}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-surface2);border-radius:var(--radius-full)}.gradient-text{background:linear-gradient(135deg,var(--color-violet-light),var(--color-pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-shell{display:flex;min-height:100vh;min-height:100dvh}.main-wrapper{display:flex;flex:1;flex-direction:column;margin-left:var(--sidebar-width);min-width:0;transition:margin-left var(--transition-slow)}.app-shell.sidebar-collapsed .main-wrapper{margin-left:var(--sidebar-width-collapsed)}.page-content{flex:1;padding:var(--space-xl) var(--space-xl) 100px}.sidebar{background:var(--color-bg2);border-right:1px solid var(--color-border);bottom:0;display:flex;flex-direction:column;left:0;min-height:100vh;min-height:100dvh;overflow:hidden;position:fixed;top:0;transition:width var(--transition-slow),transform var(--transition-slow);width:var(--sidebar-width);z-index:100}.app-shell.sidebar-collapsed .sidebar{width:var(--sidebar-width-collapsed)}.sidebar__header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;min-height:var(--navbar-height);padding:var(--space-lg) var(--space-md) var(--space-md)}.sidebar__logo{align-items:center;display:flex;gap:10px;overflow:hidden}.sidebar__logo-gem{color:var(--color-violet-light);filter:drop-shadow(0 0 8px rgba(124,58,237,.5));flex-shrink:0;font-size:1.4rem}.sidebar__logo-text{background:linear-gradient(135deg,var(--color-violet-light),var(--color-pink));-webkit-background-clip:text;font-family:var(--font-display);font-size:1.1rem;font-weight:700;letter-spacing:-.02em;-webkit-text-fill-color:transparent;background-clip:text;transition:opacity var(--transition-base),width var(--transition-slow);white-space:nowrap}.app-shell.sidebar-collapsed .sidebar__logo{opacity:0;overflow:hidden;width:0}.sidebar__collapse-btn{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);display:flex;flex-shrink:0;font-size:1.1rem;font-weight:700;height:28px;justify-content:center;transition:background var(--transition-base),color var(--transition-base);width:28px}.sidebar__collapse-btn:hover{background:var(--color-surface2);color:var(--color-text)}.sidebar__nav{display:flex;flex:1;flex-direction:column;gap:var(--space-xs);overflow-x:hidden;overflow-y:auto;padding:var(--space-sm) var(--space-xs)}.nav-item{align-items:center;border-radius:var(--radius-md);color:var(--color-text-muted);display:flex;font-size:.875rem;font-weight:500;gap:12px;overflow:hidden;padding:10px 14px;transition:background var(--transition-base),color var(--transition-base);white-space:nowrap}.nav-item:hover{background:var(--color-surface);color:var(--color-text)}.nav-item--active,.nav-item.router-link-active{background:var(--color-violet-dim);color:var(--color-violet-light)}.nav-item__icon{flex-shrink:0;font-size:1.1rem;text-align:center;width:20px}.nav-item__label{transition:opacity var(--transition-base)}.app-shell.sidebar-collapsed .nav-item__label{opacity:0;pointer-events:none;width:0}.sidebar__footer{border-top:1px solid var(--color-border);padding:var(--space-sm) var(--space-xs) var(--space-lg);padding-bottom:max(var(--space-lg),env(safe-area-inset-bottom))}.sidebar-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0000008c;display:none;inset:0;position:fixed;z-index:99}.navbar{align-items:center;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:var(--navbar-bg);border-bottom:1px solid var(--color-border);display:flex;gap:var(--space-md);height:var(--navbar-height);padding:0 var(--space-lg);position:sticky;top:0;z-index:50}.navbar__menu-btn{background:none;border:none;display:none;flex-direction:column;gap:5px;padding:var(--space-xs)}.navbar__menu-btn span{background:var(--color-text-muted);border-radius:2px;display:block;height:2px;transition:background var(--transition-base);width:22px}.navbar__menu-btn:hover span{background:var(--color-text)}.navbar__center{flex:1}.navbar__right{align-items:center;display:flex;gap:var(--space-md)}.fab-container{align-items:flex-end;bottom:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-sm);position:fixed;right:var(--space-xl);z-index:200}.fab__main{align-items:center;background:linear-gradient(135deg,var(--color-violet),var(--color-pink));border:none;border-radius:var(--radius-full);box-shadow:var(--shadow-violet);color:#fff;display:flex;font-size:1.6rem;height:56px;justify-content:center;position:relative;transition:transform var(--transition-base),box-shadow var(--transition-base);width:56px;z-index:2}.fab__main:hover{box-shadow:0 6px 28px #7c3aed99;transform:scale(1.08)}.fab__cross{display:inline-block;line-height:1;transition:transform var(--transition-slow)}.fab__cross--rotated{transform:rotate(45deg)}.fab__menu{align-items:flex-end;display:flex;flex-direction:column;gap:var(--space-sm);opacity:0;pointer-events:none;transform:translateY(12px) scale(.95);transition:opacity var(--transition-base),transform var(--transition-slow)}.fab-container--open .fab__menu{opacity:1;pointer-events:all;transform:translateY(0) scale(1)}.fab__action{align-items:center;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);color:var(--color-text);display:flex;font-size:.85rem;font-weight:500;gap:10px;padding:var(--space-sm) var(--space-md) var(--space-sm) var(--space-sm);transition:background var(--transition-base),border-color var(--transition-base),transform var(--transition-fast);white-space:nowrap}.fab__action:hover{background:var(--color-violet-dim);border-color:#7c3aed66;transform:translate(-4px)}.fab__action-icon{font-size:1rem}@media(max-width:768px){.sidebar{transform:translate(-100%);width:var(--sidebar-width)!important}.app-shell.sidebar-open .sidebar{transform:translate(0)}.app-shell.sidebar-open .sidebar-overlay{display:block}.main-wrapper{margin-left:0!important}.navbar__menu-btn{display:flex}.page-content{padding:var(--space-lg) var(--space-md) 100px}.fab-container{bottom:var(--space-lg);right:var(--space-md)}}.date-nav-wrapper{display:flex;justify-content:center;margin-bottom:var(--space-md);width:100%}.avatar-wrapper{cursor:pointer;display:inline-flex;flex-shrink:0;text-decoration:none;transition:opacity .2s,transform .2s}.avatar{align-items:center;clip-path:polygon(25% 5%,75% 5%,95% 50%,75% 95%,25% 95%,5% 50%);color:#fff;display:flex;font-size:.85rem;font-weight:700;height:34px;justify-content:center;overflow:hidden;width:34px}.avatar-wrapper:hover{opacity:.85;transform:scale(1.05)}.avatar__img{height:100%;-o-object-fit:cover;object-fit:cover;width:100%}.avatar span{align-items:center;background:#7c3aed;display:flex;height:100%;justify-content:center;width:100%}.section{display:flex;flex-direction:column;gap:var(--space-md)}.section__header{align-items:center;display:flex;justify-content:space-between}.section__title{font-size:1rem;font-weight:700;letter-spacing:-.01em}.section__link{background:none;border:none;color:var(--color-violet-light);font-family:var(--font-body);font-size:.8rem;opacity:.8;transition:opacity var(--transition-base)}.section__link:hover{opacity:1}.greeting{align-items:baseline;display:flex;gap:6px}.greeting__time{color:var(--color-text-muted);font-size:.85rem}.greeting__name{font-family:var(--font-display);font-size:1rem;font-weight:700}.streak-pill{background:var(--color-pink-dim);border:1px solid rgba(244,114,182,.25);color:#f9a8d4;font-size:.8rem;font-weight:600;gap:var(--space-xs);padding:var(--space-xs) 12px}.avatar,.streak-pill{align-items:center;border-radius:var(--radius-full);display:flex}.avatar{box-shadow:0 0 0 2px #a78bfa66;color:#fff;flex-shrink:0;font-family:var(--font-display);font-size:.9rem;font-weight:700;height:36px;justify-content:center;width:36px}.period-tabs{background:#ffffff0d;border-radius:var(--radius-sm);display:flex;gap:var(--space-xs);padding:3px}.period-tabs__btn{background:none;border:none;border-radius:6px;color:var(--color-text-muted);font-family:var(--font-body);font-size:.75rem;padding:var(--space-xs) 10px;transition:background var(--transition-base),color var(--transition-base)}.period-tabs__btn--active,.period-tabs__btn:hover{background:var(--color-violet);color:#fff}.metric-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-sm);overflow:hidden;padding:var(--space-lg) var(--space-md);position:relative;transition:border-color var(--transition-base),transform var(--transition-base)}.metric-card:before{background:var(--card-accent,var(--color-violet));content:"";height:2px;left:0;opacity:.8;position:absolute;right:0;top:0}.metric-card:hover{border-color:var(--card-accent,var(--color-violet));transform:translateY(-2px)}.metric-card__top{align-items:center;display:flex;gap:var(--space-sm)}.metric-card__icon{font-size:1.1rem}.metric-card__label{color:var(--color-text-muted);font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.metric-card__value{font-family:var(--font-display);font-size:1.7rem;font-weight:800;letter-spacing:-.03em;line-height:1}.metric-card__unit{color:var(--color-text-muted);font-size:.8rem;font-weight:400;margin-left:3px}.metric-card__bar{background:#ffffff14;border-radius:var(--radius-full);height:4px;overflow:hidden}.metric-card__fill{background:var(--card-accent,var(--color-violet));border-radius:var(--radius-full);height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}.metric-card__sub{color:var(--color-text-muted);font-size:.72rem}.challenge-card{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;gap:var(--space-md);padding:var(--space-md) var(--space-md);transition:border-color var(--transition-base)}.challenge-card:hover{border-color:#7c3aed66}.challenge-card--done{border-color:#34d3994d}.challenge-card__icon{flex-shrink:0;font-size:1.4rem}.challenge-card__body{display:flex;flex:1;flex-direction:column;gap:6px;min-width:0}.challenge-card__name{font-size:.875rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.challenge-card__bar{background:#ffffff14;border-radius:var(--radius-full);height:4px;overflow:hidden}.challenge-card__fill{background:linear-gradient(90deg,var(--color-violet),var(--color-pink));border-radius:var(--radius-full);height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}.challenge-card--done .challenge-card__fill{background:var(--color-green)}.challenge-card__meta{color:var(--color-text-muted);font-size:.72rem}.challenge-card__check{align-items:center;background:#34d39926;border-radius:var(--radius-full);color:var(--color-green);display:flex;flex-shrink:0;font-size:.8rem;font-weight:700;height:26px;justify-content:center;width:26px}.chart-wrapper{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);gap:var(--space-md);padding:var(--space-lg)}.chart-area,.chart-wrapper{display:flex;flex-direction:column}.chart-area{gap:var(--space-sm)}.chart-svg{height:120px;width:100%}.chart-labels{color:var(--color-text-muted);display:flex;font-size:.7rem;justify-content:space-between;padding:0 10px}.chart-stat{align-items:center;border-top:1px solid var(--color-border);display:flex;gap:6px;padding-top:var(--space-xs)}.trend{font-size:.85rem;font-weight:700}.trend--down{color:var(--color-green)}.trend--up{color:#f87171}.trend__label{color:var(--color-text-muted);font-size:.75rem}.logs-wrapper{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);gap:var(--space-md);padding:var(--space-lg)}.logs-list,.logs-wrapper{display:flex;flex-direction:column}.log-item{align-items:center;border-bottom:1px solid var(--color-border);display:flex;gap:var(--space-sm);padding:10px 0}.log-item:last-child{border-bottom:none}.log-item__dot{border-radius:var(--radius-full);flex-shrink:0;height:8px;width:8px}.log-item__info{align-items:baseline;display:flex;flex:1;gap:6px}.log-item__type{color:var(--color-text-muted);font-size:.8rem}.log-item__value{font-size:.875rem;font-weight:600}.log-item__time{color:var(--color-text-muted);font-size:.72rem;white-space:nowrap}.btn{align-items:center;border:none;border-radius:var(--radius-md);display:inline-flex;font-family:var(--font-body);font-size:.9rem;font-weight:600;gap:var(--space-sm);justify-content:center;padding:10px var(--space-lg);transition:transform var(--transition-fast),box-shadow var(--transition-base),opacity var(--transition-base)}.btn:disabled{cursor:not-allowed;opacity:.6}.btn--primary{background:linear-gradient(135deg,var(--color-violet),var(--color-pink));box-shadow:var(--shadow-violet);color:#fff}.btn--primary:hover:not(:disabled){box-shadow:0 6px 24px #7c3aed80;transform:translateY(-1px)}.btn--ghost{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted)}.btn--ghost:hover:not(:disabled){background:var(--color-surface);color:var(--color-text)}.logout-btn{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--color-text-muted);display:flex;font-family:var(--font-body);font-size:.875rem;gap:12px;overflow:hidden;padding:10px 14px;transition:background var(--transition-base),color var(--transition-base);white-space:nowrap;width:100%}.logout-btn:hover{background:var(--color-pink-dim);color:var(--color-pink)}.app-shell.sidebar-collapsed .logout-btn .nav-item__label{opacity:0;width:0}.spinner{animation:spin .7s linear infinite;border:2px solid hsla(0,0%,100%,.3);border-radius:var(--radius-full);border-top-color:#fff;height:18px;width:18px}@keyframes spin{to{transform:rotate(1turn)}}.metrics-grid{align-items:start;display:grid;gap:var(--space-md);grid-template-columns:repeat(4,1fr)}.challenges-grid{display:grid;gap:var(--space-sm);grid-template-columns:repeat(2,1fr)}.two-col-grid{display:grid;gap:var(--space-md);grid-template-columns:1.4fr 1fr}@media(max-width:1100px){.metrics-grid{grid-template-columns:repeat(2,1fr)}.two-col-grid{grid-template-columns:1fr}}@media(max-width:640px){.challenges-grid{grid-template-columns:1fr}.streak-pill span:not(.streak-pill__fire){display:none}}.streak-pill__label{display:none}@media(min-width:640px){.streak-pill__label{display:inline}}.lang-switcher{position:relative}.lang-switcher__trigger{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);display:flex;font-family:var(--font-body);font-size:.8rem;font-weight:600;gap:var(--space-xs);padding:6px 10px;transition:background var(--transition-base),color var(--transition-base),border-color var(--transition-base)}.lang-switcher__trigger:hover{background:var(--color-surface2);border-color:#7c3aed59;color:var(--color-text)}.lang-switcher__globe{font-size:.9rem}.lang-switcher__current{letter-spacing:.05em}@media(max-width:640px){.lang-switcher__chevron,.lang-switcher__current{display:none}}.lang-switcher__chevron{font-size:.7rem;opacity:.6;transition:transform var(--transition-base)}.lang-switcher__chevron--open{transform:rotate(180deg)}.lang-switcher__dropdown{background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:2px;min-width:160px;padding:var(--space-xs);position:absolute;right:0;top:calc(100% + 8px);z-index:200}.lang-switcher__option{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);display:flex;font-family:var(--font-body);font-size:.875rem;justify-content:space-between;padding:8px 12px;text-align:left;transition:background var(--transition-base),color var(--transition-base);width:100%}.lang-switcher__option:hover{background:var(--color-violet-dim);color:var(--color-text)}.lang-switcher__option--active{color:var(--color-violet-light);font-weight:600}.lang-switcher__check{color:var(--color-violet-light);font-size:.8rem}.lang-dropdown-enter-active,.lang-dropdown-leave-active{transition:opacity var(--transition-fast),transform var(--transition-fast)}.lang-dropdown-enter-from,.lang-dropdown-leave-to{opacity:0;transform:translateY(-6px) scale(.97)}.settings-page{display:flex;flex-direction:column;gap:var(--space-xl);max-width:680px}.settings-page__header{display:flex;flex-direction:column;gap:var(--space-xs)}.settings-page__title{font-size:1.5rem}.settings-page__subtitle{color:var(--color-text-muted);font-size:.875rem}.settings-sections{display:flex;flex-direction:column;gap:var(--space-md)}.settings-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-lg);padding:var(--space-lg)}.settings-section__header{align-items:flex-start;display:flex;gap:var(--space-md)}.settings-section__icon{flex-shrink:0;font-size:1.3rem;margin-top:2px}.settings-section__title{font-size:1rem;font-weight:700}.settings-section__desc{color:var(--color-text-muted);font-size:.8rem;margin-top:2px}.lang-grid{display:grid;gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.lang-option{align-items:center;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);display:flex;font-family:var(--font-body);gap:var(--space-sm);justify-content:space-between;padding:var(--space-md);text-align:left;transition:border-color var(--transition-base),color var(--transition-base),background var(--transition-base)}.lang-option:hover{border-color:#7c3aed66;color:var(--color-text)}.lang-option--active{background:var(--color-violet-dim);border-color:var(--color-violet);color:var(--color-violet-light)}.lang-option__code{font-family:var(--font-display);font-size:.9rem;font-weight:700;letter-spacing:.05em}.lang-option__name{flex:1;font-size:.8rem}.lang-option__check{color:var(--color-violet-light);font-size:.8rem;font-weight:700}.date-nav__input{cursor:pointer;height:100%;inset:0;opacity:0;position:absolute;width:100%}.metric-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a061ec7;display:flex;inset:0;justify-content:center;position:fixed;z-index:200}.metric-modal{background:#1e1540;border:1px solid rgba(167,139,250,.22);border-radius:18px;display:flex;flex-direction:column;gap:0;overflow:hidden;width:min(400px,90vw)}.metric-modal__header{align-items:center;background:linear-gradient(135deg,#7c3aed29,#f472b614);border-bottom:1px solid rgba(167,139,250,.14);display:flex;gap:12px;padding:18px 20px 16px}.metric-modal__header-icon{align-items:center;background:#7c3aed33;border:1px solid rgba(167,139,250,.28);border-radius:10px;display:flex;flex-shrink:0;font-size:1.1rem;height:36px;justify-content:center;width:36px}.metric-modal__header-text{display:flex;flex:1;flex-direction:column;gap:1px}.metric-modal__header-sub{color:#a78bfa;font-size:10px;font-weight:600;letter-spacing:.07em;margin:0;text-transform:uppercase}.metric-modal__header h3{color:#f0eeff;font-size:1rem;font-weight:600;margin:0}.metric-modal__close{align-items:center;background:#ffffff0d;border:1px solid hsla(0,0%,100%,.08);border-radius:8px;color:#6b7280;cursor:pointer;display:flex;font-size:.85rem;height:28px;justify-content:center;transition:background .15s,color .15s;width:28px}.metric-modal__close:hover{background:#ffffff1a;color:#f0eeff}.metric-modal__body{display:flex;flex-direction:column;gap:16px;padding:20px}.metric-modal__section-label{color:#6b7280;font-size:10px;font-weight:600;letter-spacing:.07em;margin:0 0 10px;text-transform:uppercase}.metric-modal__quick-btns{display:grid;gap:8px;grid-template-columns:1fr 1fr}.quick-btn{background:#7c3aed12;border:1.5px solid rgba(124,58,237,.22);border-radius:10px;color:#a78bfa;cursor:pointer;font-size:.88rem;font-weight:500;padding:11px 10px;text-align:center;transition:background .15s,border-color .15s}.quick-btn:hover{background:#7c3aed2e;border-color:#7c3aed80}.metric-modal__divider{align-items:center;display:flex;gap:10px}.metric-modal__divider:after,.metric-modal__divider:before{background:#ffffff0f;content:"";flex:1;height:1px}.metric-modal__divider span{color:#4b5563;font-size:11px;font-weight:500}.metric-modal__input-row{align-items:center;display:flex;gap:8px}.metric-modal__input{background:#ffffff0a;border:1.5px solid rgba(124,58,237,.22);border-radius:10px;color:#f0eeff;flex:1;font-size:.95rem;outline:none;padding:10px 12px;transition:border-color .15s}.metric-modal__input:focus{border-color:#7c3aed}.metric-modal__sleep-row{align-items:flex-end;display:flex;gap:8px}.metric-modal__sleep-col{display:flex;flex:1;flex-direction:column;gap:5px}.metric-modal__sleep-col label{color:#6b7280;font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase}.metric-modal__sleep-col input{background:#ffffff0a;border:1.5px solid rgba(124,58,237,.22);border-radius:10px;box-sizing:border-box;color:#f0eeff;font-size:1.1rem;font-weight:600;outline:none;padding:10px 12px;text-align:center;transition:border-color .15s;width:100%}.metric-modal__sleep-col input:focus{border-color:#7c3aed}.metric-modal__sleep-sep{color:#4b5563;flex-shrink:0;font-size:1.4rem;font-weight:300;padding-bottom:10px}.metric-modal__input--small{flex:0 0 68px}.metric-modal__sep{color:#6b7280;font-size:.88rem}.metric-modal__submit{background:linear-gradient(135deg,#7c3aed,#9d4edd);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:.88rem;font-weight:600;padding:10px 18px;transition:opacity .15s,filter .15s;white-space:nowrap}.metric-modal__submit:hover:not(:disabled){filter:brightness(1.12)}.metric-modal__submit:disabled{cursor:not-allowed;opacity:.45}.metric-modal__submit--full{border-radius:10px;margin-top:4px;padding:11px;width:100%}.metric-modal__unit-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:#ffffff0a;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath fill='%23a78bfa' d='m0 0 5 6 5-6z'/%3E%3C/svg%3E");background-position:right 9px center;background-repeat:no-repeat;border:1.5px solid rgba(124,58,237,.3);border-radius:10px;color:#a78bfa;cursor:pointer;font-size:.88rem;outline:none;padding:10px 28px 10px 12px;transition:border-color .15s}.metric-modal__unit-select:focus{border-color:#7c3aed}.metric-modal__unit-toggle{border:1.5px solid rgba(124,58,237,.25);border-radius:10px;display:flex;overflow:hidden}.unit-btn{background:transparent;border:none;color:#6b7280;cursor:pointer;font-size:.85rem;padding:10px 13px;transition:background .15s,color .15s}.unit-btn--active{background:#7c3aed;color:#fff}.metric-modal__error{color:#f87171}.metric-modal__error,.metric-modal__success{font-size:.82rem;margin:0;padding:0 20px 16px}.metric-modal__success{color:#34d399}.metric-modal--confirm{border-color:#ef444447}.metric-modal--confirm .metric-modal__header{background:#ef444412;border-bottom-color:#ef444424}.metric-modal--confirm p{color:#9ca3af;font-size:.9rem;line-height:1.55;margin:0;padding:16px 20px 0}.metric-modal--confirm .metric-modal__input-row{padding:16px 20px 20px}.fab-container{display:none}.metric-card__actions{align-items:center;display:flex;gap:4px;margin-left:auto;opacity:0;transition:opacity .15s}.metric-card:hover .metric-card__actions{opacity:1}.metric-card__toggle-btn{align-items:center;background:transparent;border:1.5px solid hsla(0,0%,100%,.2);border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;font-size:9px;height:22px;justify-content:center;transition:border-color .15s,color .15s;width:22px}.metric-card__toggle-btn:hover{border-color:var(--card-accent);color:var(--card-accent)}.metric-card__add-btn{align-items:center;background:transparent;border:1.5px solid var(--card-accent,#7c3aed);border-radius:50%;color:var(--card-accent,#7c3aed);cursor:pointer;display:flex;font-size:16px;height:22px;justify-content:center;line-height:1;transition:background .15s;width:22px}.metric-card__add-btn:hover{background:var(--card-accent,#7c3aed);color:#fff}.metric-card__log-list{border-top:1px solid hsla(0,0%,100%,.06);display:flex;flex-direction:column;gap:6px;margin-top:var(--space-sm);overflow:hidden;padding-top:var(--space-sm)}.log-entry{align-items:center;background:#ffffff08;border-radius:8px;display:flex;justify-content:space-between;padding:6px 8px;transition:background .15s}.log-entry:hover{background:#ffffff0f}.log-entry__info{display:flex;flex-direction:column;gap:1px}.log-entry__value{color:var(--text-primary);font-size:.875rem;font-weight:600}.log-entry__time{color:var(--text-muted);font-size:.7rem}.log-entry__btns{display:flex;gap:4px}.log-entry:hover .log-entry__btns{opacity:1}.log-entry__btn{align-items:center;background:transparent;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.75rem;height:24px;justify-content:center;transition:background .15s,color .15s;width:24px}.log-entry__btn--edit{color:#a78bfa}.log-entry__btn--edit:hover{background:#a78bfa26}.log-entry__btn--delete{color:#f87171}.log-entry__btn--delete:hover{background:#f8727226}.slide-enter-active,.slide-leave-active{max-height:300px;transition:max-height .25s ease,opacity .2s ease}.slide-enter-from,.slide-leave-to{max-height:0;opacity:0}.metric-modal--confirm{gap:var(--space-sm)}.metric-modal--confirm p{color:var(--text-primary);font-size:.95rem;margin:0}.metric-card__expand-btn{background:#ffffff08;border:1px solid hsla(0,0%,100%,.08);border-radius:8px;color:var(--text-muted);cursor:pointer;font-size:.75rem;margin-top:var(--space-sm);padding:6px;transition:background .15s,color .15s;width:100%}.metric-card__expand-btn:hover{background:#ffffff12;color:var(--text-primary)}.profile-page{display:flex;flex-direction:column;gap:0;margin:0 auto;max-width:680px;padding:20px 18px 60px;position:relative}.profile-page__halo-1{background:radial-gradient(circle,rgba(124,58,237,.12) 0,transparent 70%);height:360px;left:-60px;top:-80px;width:360px}.profile-page__halo-1,.profile-page__halo-2{border-radius:50%;pointer-events:none;position:fixed;z-index:0}.profile-page__halo-2{background:radial-gradient(circle,rgba(244,114,182,.07) 0,transparent 70%);height:260px;right:-80px;top:100px;width:260px}.profile-stats-row{align-items:center;background:var(--color-surface,#12102e);border:1px solid rgba(167,139,250,.1);border-radius:16px;display:flex;justify-content:center;margin-bottom:24px;padding:16px 0;position:relative;z-index:1}.profile-stat{align-items:center;display:flex;flex:1;flex-direction:column;gap:3px}.profile-stat__val{color:var(--color-violet-light,#a78bfa);font-family:var(--font-display);font-size:20px;font-weight:700}.profile-stat__lbl{color:var(--color-text-muted);font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase}.profile-stat-divider{background:#a78bfa1a;flex-shrink:0;height:32px;width:1px}.profile-tabs{background:var(--color-surface,#12102e);border-radius:12px;display:flex;gap:2px;margin-bottom:20px;padding:4px;position:relative;z-index:1}.profile-tab{background:none;border:none;border-radius:9px;color:var(--color-text-muted);cursor:pointer;flex:1;font-family:var(--font-body);font-size:13px;font-weight:400;padding:9px 0;text-align:center;transition:all .15s}.profile-tab--active{background:var(--color-surface2,#1c1840);border:1px solid rgba(167,139,250,.2);color:var(--color-violet-light,#a78bfa);font-weight:500}.tab-content{gap:0;position:relative;z-index:1}.tab-content,.tab-empty{display:flex;flex-direction:column}.tab-empty{align-items:center;color:var(--color-text-muted);font-size:14px;gap:10px;padding:48px 0}.tab-empty__icon{font-size:2rem}.tab-empty p{margin:0}@media(max-width:480px){.profile-page{padding:16px 14px 60px}}.profile-hero{border-bottom:1px solid rgba(167,139,250,.08);flex-direction:column;margin-bottom:20px;padding-bottom:24px;text-align:center;z-index:1}.profile-hero,.profile-hex-wrap{align-items:center;display:flex;position:relative}.profile-hex-wrap{height:95px;justify-content:center;margin-bottom:14px;width:90px}.profile-hex-wrap--clickable{cursor:pointer}.profile-hex-initials{color:#fff;font-size:32px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%)}.profile-hex-initials,.profile-name{font-family:var(--font-display);font-weight:700}.profile-name{color:var(--color-text);font-size:20px;margin:0 0 6px}.profile-sub{color:var(--color-text-muted);font-size:12px;gap:8px;margin-bottom:12px}.profile-loc,.profile-sub{align-items:center;display:flex}.profile-loc{gap:3px}.profile-sep{background:var(--color-text-muted);border-radius:50%;height:3px;opacity:.4;width:3px}.profile-bio{color:var(--color-text-muted);font-size:13px;line-height:1.55;margin:0 0 12px;max-width:320px;text-align:center}.profile-tags{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:18px}.profile-tag{background:#7c3aed1f;border:1px solid rgba(124,58,237,.22);border-radius:999px;color:var(--color-violet-light,#a78bfa);font-size:11px;font-weight:500;padding:3px 10px}.profile-actions{gap:8px}.btn-friend,.profile-actions{align-items:center;display:flex}.btn-friend{border-radius:999px;cursor:pointer;font-family:var(--font-body);font-size:13px;font-weight:600;gap:7px;padding:9px 20px;transition:all .15s}.btn-friend:disabled{cursor:default;opacity:.6}.btn-friend--add{background:var(--color-violet,#7c3aed);border:none;color:#fff}.btn-friend--add:hover:not(:disabled){background:#6d28d9}.btn-friend--pending{background:#a78bfa1a;border:1px solid rgba(167,139,250,.25);color:var(--color-text-muted)}.btn-friend--friends{background:#34d3991a;border:1px solid rgba(52,211,153,.25);color:#34d399}.btn-friend--friends:hover:not(:disabled){background:#f872721a;border-color:#f8727240;color:#f87171}.btn-message{align-items:center;background:#a78bfa0f;border:1px solid rgba(167,139,250,.25);border-radius:50%;color:var(--color-text-muted);cursor:pointer;display:flex;height:38px;justify-content:center;transition:background .15s;width:38px}.btn-message:hover{background:#a78bfa1f;color:var(--color-violet-light,#a78bfa)}.btn-edit{align-items:center;background:#a78bfa14;border:1px solid rgba(167,139,250,.2);border-radius:999px;color:var(--color-text-muted);cursor:pointer;display:flex;font-family:var(--font-body);font-size:13px;font-weight:500;gap:7px;padding:9px 20px;transition:all .15s}.btn-edit:hover{background:#a78bfa24;color:var(--color-violet-light,#a78bfa)}.friends-search-wrap{margin-bottom:20px;position:relative}.friends-search-outer{align-items:center;border:1.5px solid rgba(167,139,250,.25);border-radius:9999px;display:flex;gap:10px;height:42px;overflow:hidden;padding:0 14px;transition:border-color .2s}.friends-search-outer--focus{border-color:#7c3aed8c;box-shadow:0 0 0 4px #7c3aed12}.friends-search-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--color-bg,#07051a)!important;border:none!important;-webkit-box-shadow:0 0 0 1000px var(--color-bg,#07051a) inset!important;color:var(--color-text);flex:1;font-family:var(--font-body);font-size:13px;outline:none!important;-webkit-text-fill-color:var(--color-text)!important;caret-color:var(--color-violet-light,#a78bfa);margin:0;padding:0;width:100%}.friends-search-input::-moz-placeholder{color:var(--color-text-muted);opacity:1}.friends-search-input::placeholder{color:var(--color-text-muted);opacity:1}.friends-search-clear{align-items:center;background:#ffffff14;border:none;border-radius:50%;color:var(--color-text-muted);cursor:pointer;display:flex;flex-shrink:0;height:18px;justify-content:center;padding:0;width:18px}.friends-search-dropdown{background:var(--color-surface,#12102e);border:1px solid rgba(167,139,250,.2);border-radius:16px;box-shadow:0 12px 40px #0006;left:0;overflow:hidden;padding:6px 0;position:absolute;right:0;top:calc(100% + 6px);z-index:20}.friends-search-dropdown--loading{align-items:center;display:flex;justify-content:center;padding:16px}.friends-search-row{align-items:center;cursor:pointer;display:flex;gap:10px;padding:9px 14px;transition:background .12s}.friends-search-row:hover{background:var(--color-surface2,#1c1840)}.friends-search-av{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-family:var(--font-display);font-size:12px;font-weight:700;height:32px;justify-content:center;width:32px}.friends-search-info{flex:1}.friends-search-name{color:var(--color-text);font-size:13px;font-weight:500}.friends-search-add{background:#7c3aed33;border:1px solid rgba(124,58,237,.35);border-radius:999px;color:var(--color-violet-light,#a78bfa);cursor:pointer;font-size:11px;font-weight:600;padding:5px 12px;transition:all .15s}.friends-search-add:hover{background:#7c3aed4d}.friends-search-add--pending{background:#a78bfa14;border-color:#a78bfa33;color:var(--color-text-muted);cursor:default}.friends-search-add--friends{background:#34d3991a;border-color:#34d39940;color:#34d399;cursor:default}.requests-section{background:#7c3aed0f;border:1px solid rgba(124,58,237,.2);border-radius:14px;margin-bottom:20px;padding:12px 14px}.requests-label{color:var(--color-violet-light,#a78bfa);font-size:11px;font-weight:600;letter-spacing:.07em;margin-bottom:12px;text-transform:uppercase}.request-row{align-items:center;border-bottom:1px solid rgba(167,139,250,.08);display:flex;gap:12px;padding:8px 0}.request-row:last-child{border-bottom:none;padding-bottom:0}.request-actions{display:flex;flex-shrink:0;gap:6px}.request-btn{align-items:center;border:1px solid;border-radius:50%;cursor:pointer;display:flex;font-size:12px;font-weight:600;height:30px;justify-content:center;transition:all .15s;width:30px}.request-btn--accept{background:#34d3991f;border-color:#34d3994d;color:#34d399}.request-btn--accept:hover{background:#34d39940}.request-btn--decline{background:#f872721a;border-color:#f8727240;color:#f87171}.request-btn--decline:hover{background:#f8727233}.friends-list-label{color:var(--color-text-muted);font-size:11px;font-weight:500;letter-spacing:.07em;margin-bottom:8px;text-transform:uppercase}.friend-row{align-items:center;border-bottom:1px solid rgba(167,139,250,.07);cursor:pointer;display:flex;gap:12px;padding:14px 0;transition:opacity .15s}.friend-row:hover{opacity:.8}.friend-row:last-child{border-bottom:none}.friend-hex-wrap{align-items:center;display:flex;flex-shrink:0;height:49px;justify-content:center;position:relative;width:46px}.friend-hex-initials{color:#fff;font-family:var(--font-display);font-size:14px;font-weight:700;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%)}.friend-online-dot{background:#2dd4aa;border:2px solid var(--color-bg,#07051a);border-radius:50%;bottom:3px;box-shadow:0 0 6px #2dd4aa80;height:9px;position:absolute;right:1px;width:9px}.friend-info{display:flex;flex:1;flex-direction:column;gap:2px}.friend-name{color:var(--color-text);font-family:var(--font-display);font-size:13px;font-weight:600}.friend-sub{font-size:11px}.friend-chevron,.friend-sub{color:var(--color-text-muted)}.friend-chevron{flex-shrink:0}.friends-spinner{animation:friends-spin .7s linear infinite;border:2px solid rgba(167,139,250,.2);border-radius:50%;border-top:2px solid var(--color-violet-light,#a78bfa);display:block;height:16px;width:16px}@keyframes friends-spin{to{transform:rotate(1turn)}}.dropdown-enter-active,.dropdown-leave-active{transition:opacity .15s,transform .15s}.dropdown-enter-from,.dropdown-leave-to{opacity:0;transform:translateY(-6px)}.metrics-intro{margin-bottom:16px}.metrics-intro__text{color:var(--color-text-muted);font-size:12px;line-height:1.55;margin:0}.metric-share-row{align-items:center;background:var(--color-surface,#12102e);border:1px solid rgba(167,139,250,.08);border-radius:12px;cursor:pointer;display:flex;gap:12px;margin-bottom:8px;padding:14px 16px;transition:border-color .15s}.metric-share-row--active{background:#7c3aed0a;border-color:#7c3aed4d}.metric-share-icon{flex-shrink:0;font-size:18px}.metric-share-info{display:flex;flex:1;flex-direction:column;gap:2px}.metric-share-label{color:var(--color-text);font-size:13px;font-weight:600}.metric-share-sub{color:var(--color-text-muted);font-size:11px}.metric-toggle{background:#ffffff1a;border-radius:11px;flex-shrink:0;height:22px;position:relative;transition:background .2s;width:40px}.metric-toggle--on{background:#7c3aed}.metric-toggle__thumb{background:#fff;border-radius:50%;height:16px;left:3px;position:absolute;top:3px;transition:transform .2s;width:16px}.metric-toggle--on .metric-toggle__thumb{transform:translate(18px)}.profile-metric-card{background:var(--color-surface,#12102e);border:1px solid rgba(167,139,250,.1);border-radius:14px;margin-bottom:10px;padding:14px 16px}.profile-metric-card--locked{opacity:.6}.profile-metric-card__head{align-items:center;display:flex;gap:10px;margin-bottom:12px}.profile-metric-card__icon{font-size:16px}.profile-metric-card__title{color:var(--color-text);flex:1;font-family:var(--font-display);font-size:13px;font-weight:600}.profile-metric-card__badge{background:#34d3991a;border:1px solid rgba(52,211,153,.2);border-radius:999px;color:#34d399;font-size:10px;font-weight:500;padding:2px 8px}.profile-metric-card__lock{color:var(--color-text-muted)}.profile-metric-card__values{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.profile-metric-val{background:#a78bfa0d;border:1px solid rgba(167,139,250,.1);border-radius:10px;padding:9px 12px}.profile-metric-val__num{color:var(--color-violet-light,#a78bfa);display:block;font-family:var(--font-display);font-size:17px;font-weight:700}.profile-metric-val__lbl{color:var(--color-text-muted);display:block;font-size:10px;margin-top:2px}.profile-metric-card__locked-text{color:var(--color-text-muted);font-size:12px;font-style:italic;margin:0}.settings-form{display:flex;flex-direction:column;gap:16px}.form-row{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{color:var(--color-text-muted);font-size:.78rem;font-weight:600}.form-label--small{font-size:.72rem}.input-with-unit{align-items:center;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;overflow:hidden;transition:border-color var(--transition-fast)}.input-with-unit:focus-within{border-color:var(--color-violet)}.form-input{background:transparent;border:none;color:var(--color-text);flex:1;font-size:.875rem;min-width:0;outline:none;padding:10px 12px}input[type=date].form-input{color-scheme:dark;padding:9px 12px}.input-unit{align-items:center;background:var(--color-surface);border-left:1px solid var(--color-border);color:var(--color-text-faint);display:flex;font-size:.75rem;font-weight:600;height:100%;padding:0 12px;white-space:nowrap}.btn-group{display:flex;flex-wrap:wrap;gap:8px}.btn-group__item{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;font-size:.82rem;padding:8px 16px;transition:all var(--transition-fast)}.btn-group__item--active,.btn-group__item:hover{border-color:var(--color-violet)}.btn-group__item--active{background:var(--color-violet-dim);color:var(--color-violet-light)}.form-actions{align-items:center;display:flex;gap:12px;justify-content:flex-end;padding-top:4px}.save-feedback{color:#34d399;font-size:.82rem;font-weight:600}.btn--sm{font-size:.78rem;padding:6px 12px}.lightbox-backdrop{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#05030fe0;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:2000}.lightbox-img{border-radius:var(--radius-xl,16px);box-shadow:0 25px 60px #0009;max-height:85vh;max-width:90vw;-o-object-fit:contain;object-fit:contain}.lightbox-close{align-items:center;background:#ffffff1a;border:1px solid hsla(0,0%,100%,.2);border-radius:999px;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;position:absolute;right:24px;top:20px;transition:background .15s;width:36px}.lightbox-close:hover{background:#fff3}.fade-enter-active,.fade-leave-active{transition:opacity .25s ease}.fade-enter-from,.fade-leave-to{opacity:0}.slide-down-enter-active,.slide-down-leave-active{transition:all .3s ease}.slide-down-enter-from,.slide-down-leave-to{opacity:0;transform:translateY(-12px)}.profile-edit-inline{margin:0 auto 1.5rem;max-width:640px}.tdee-banner{align-items:center;background:#7c3aed14;border:1px solid rgba(124,58,237,.25);border-radius:var(--radius-md);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:14px 16px}.tdee-banner__left{align-items:center;display:flex;gap:10px}.tdee-banner__icon{font-size:1.3rem}.tdee-banner__title{color:var(--color-text);font-size:.82rem;font-weight:600;margin:0 0 2px}.tdee-banner__sub{color:var(--color-text-muted);font-size:.72rem;margin:0}.tdee-banner__right{align-items:center;display:flex;gap:10px}.tdee-banner__kcal{color:var(--color-violet-light);font-size:1rem;font-weight:700}.tdee-missing{color:var(--color-text-faint);font-size:.78rem;font-style:italic;margin:0}.modules-grid{display:flex;flex-direction:column;gap:8px}.module-toggle{align-items:center;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;display:flex;gap:14px;padding:14px 16px;transition:border-color var(--transition-fast),background var(--transition-fast);-webkit-user-select:none;-moz-user-select:none;user-select:none}.module-toggle:hover{border-color:var(--color-violet)}.module-toggle--active{background:#7c3aed0f;border-color:#7c3aed66}.module-toggle__icon{flex-shrink:0;font-size:1.2rem;text-align:center;width:24px}.module-toggle__info{display:flex;flex:1;flex-direction:column;gap:2px}.module-toggle__label{color:var(--color-text);font-size:.875rem;font-weight:600}.module-toggle__desc{color:var(--color-text-muted);font-size:.75rem}.module-toggle__switch{background:var(--color-border);border-radius:11px;flex-shrink:0;height:22px;position:relative;transition:background var(--transition-fast);width:40px}.module-toggle__switch--on{background:#7c3aed}.module-toggle__thumb{background:#fff;border-radius:50%;height:16px;left:3px;position:absolute;top:3px;transition:transform var(--transition-fast);width:16px}.module-toggle__switch--on .module-toggle__thumb{transform:translate(18px)}.avatar-edit-wrap{align-items:center;display:flex;flex-direction:column;gap:12px;margin-bottom:8px}.avatar-hex-zone{align-items:center;cursor:pointer;display:flex;height:95px;justify-content:center;position:relative;width:90px}.avatar-edit-initial{color:#fff;font-family:var(--font-display);font-size:32px;font-weight:700;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:1}.avatar-edit-overlay{align-items:center;background:#00000073;color:#fff;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .2s;z-index:2}.avatar-hex-zone:hover .avatar-edit-overlay{opacity:1}.avatar-change-btn{align-items:center;background:#7c3aed14;border:1px solid rgba(124,58,237,.2);border-radius:999px;color:var(--color-violet-light,#a78bfa);cursor:pointer;display:flex;font-size:11px;font-weight:500;gap:6px;padding:5px 12px;transition:background .15s}.avatar-change-btn:hover:not(:disabled){background:#7c3aed26}.avatar-change-btn:disabled{cursor:default;opacity:.5}.avatar-remove-btn{align-items:center;background:#f8727214;border:1px solid hsla(0,91%,71%,.2);border-radius:999px;color:#f87171;cursor:pointer;display:flex;font-size:11px;font-weight:500;gap:6px;padding:5px 12px;transition:background .15s}.avatar-remove-btn:hover:not(:disabled){background:#f8727226}.avatar-remove-btn:disabled{cursor:default;opacity:.5}.avatar-loading{align-items:center;display:flex;justify-content:center}.profile-edit-fields{gap:16px}.edit-field,.profile-edit-fields{display:flex;flex-direction:column}.edit-field{gap:6px;position:relative}.edit-field__label{color:var(--color-text-muted);font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase}.edit-field__input{background:var(--color-surface,#12102e);border:1.5px solid rgba(167,139,250,.18);border-radius:12px;-webkit-box-shadow:0 0 0 1000px var(--color-surface,#12102e) inset!important;color:var(--color-text);font-family:var(--font-body);font-size:13px;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s;-webkit-text-fill-color:var(--color-text)!important;caret-color:var(--color-violet-light,#a78bfa)}.edit-field__input:focus{border-color:#7c3aed8c;box-shadow:0 0 0 4px #7c3aed12}.edit-field__input-wrap{align-items:center;display:flex;position:relative}.edit-field__icon{color:var(--color-text-muted);left:14px;pointer-events:none;position:absolute}.edit-field__input--icon{padding-left:34px}.edit-field__textarea{background:var(--color-surface,#12102e);border:1.5px solid rgba(167,139,250,.18);border-radius:12px;caret-color:var(--color-violet-light,#a78bfa);color:var(--color-text);font-family:var(--font-body);font-size:13px;line-height:1.5;outline:none;padding:10px 14px;resize:none;transition:border-color .2s,box-shadow .2s}.edit-field__textarea:focus{border-color:#7c3aed8c;box-shadow:0 0 0 4px #7c3aed12}.edit-field__counter{margin-top:-2px;text-align:right}.edit-field__counter,.edit-field__hint{color:var(--color-text-muted);font-size:10px}.edit-field__hint{opacity:.7}.tags-input-wrap{background:var(--color-surface,#12102e);border:1.5px solid rgba(167,139,250,.18);border-radius:12px;padding:8px 10px;transition:border-color .2s}.tags-input-wrap:focus-within{border-color:#7c3aed8c;box-shadow:0 0 0 4px #7c3aed12}.tags-list{flex-wrap:wrap;gap:6px}.tag-chip,.tags-list{align-items:center;display:flex}.tag-chip{background:#7c3aed26;border:1px solid rgba(124,58,237,.3);border-radius:999px;color:var(--color-violet-light,#a78bfa);font-size:12px;font-weight:500;gap:5px;padding:3px 10px}.tag-chip__remove{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:9px;line-height:1;padding:0;transition:color .15s}.tag-chip__remove:hover{color:#f87171}.tags-input{background:transparent;border:none;caret-color:var(--color-violet-light,#a78bfa);color:var(--color-text);flex:1;font-family:var(--font-body);font-size:13px;min-width:80px;outline:none;padding:2px 4px}.tags-input::-moz-placeholder{color:var(--color-text-muted);opacity:.6}.tags-input::placeholder{color:var(--color-text-muted);opacity:.6}
