@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}.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,.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:#0f0a1e;--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}.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;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)}.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%}.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{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{gap:var(--space-sm)}.date-nav,.date-nav__arrow{align-items:center;display:flex}.date-nav__arrow{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);font-size:1.1rem;height:30px;justify-content:center;line-height:1;transition:background var(--transition-base),color var(--transition-base),border-color var(--transition-base);width:30px}.date-nav__arrow:hover{background:var(--color-surface2);border-color:#7c3aed59;color:var(--color-text)}.date-nav__center{align-items:center;display:flex;gap:var(--space-sm)}.date-nav__label{color:var(--color-text);font-family:var(--font-display);font-size:1rem;font-weight:700;letter-spacing:-.01em;min-width:130px;text-align:center;transition:color var(--transition-base)}.date-nav__label--today{background:linear-gradient(135deg,var(--color-violet-light),var(--color-pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.date-nav__calendar-btn{align-items:center;cursor:pointer;display:flex;font-size:1rem;line-height:1;opacity:.6;position:relative;transition:opacity var(--transition-base)}.date-nav__calendar-btn:hover{opacity:1}.date-nav__input{cursor:pointer;height:100%;inset:0;opacity:0;position:absolute;width:100%}.metric-card__top{align-items:center;display:flex;gap:var(--space-xs)}.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;margin-left:auto;opacity:0;transition:opacity .15s,background .15s;width:22px}.metric-card:hover .metric-card__add-btn{opacity:1}.metric-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a061eb3;display:flex;inset:0;justify-content:center;position:fixed;z-index:200}.metric-modal{background:#1e1540;border:1px solid rgba(124,58,237,.3);border-radius:16px;display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg);width:min(400px,90vw)}.metric-modal__header{align-items:center;display:flex;gap:var(--space-sm)}.metric-modal__header h3{color:var(--text-primary);flex:1;font-size:1rem;font-weight:600;margin:0}.metric-modal__close{background:transparent;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:4px;transition:color .15s}.metric-modal__close:hover{color:var(--text-primary)}.metric-modal__quick-btns{display:grid;gap:8px;grid-template-columns:1fr 1fr}.quick-btn{background:#7c3aed0f;border:1.5px solid rgba(124,58,237,.3);border-radius:10px;color:#a78bfa;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px;text-align:center;transition:background .15s,border-color .15s}.quick-btn:hover{background:#7c3aed2e;border-color:#7c3aed}.metric-modal__input-row{align-items:center;display:flex;gap:var(--space-sm)}.metric-modal__input{background:#ffffff0a;border:1.5px solid rgba(124,58,237,.3);border-radius:8px;color:var(--text-primary);flex:1;font-size:1rem;outline:none;padding:8px 12px;transition:border-color .15s}.metric-modal__input:focus{border-color:#7c3aed}.metric-modal__input--small{flex:0 0 64px}.metric-modal__sep{color:var(--text-muted);font-size:.9rem}.metric-modal__submit{background:#7c3aed;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:8px 18px;transition:background .15s,opacity .15s;white-space:nowrap}.metric-modal__submit:hover:not(:disabled){background:#6d28d9}.metric-modal__submit:disabled{cursor:not-allowed;opacity:.5}.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 8px center;background-repeat:no-repeat;border:1.5px solid rgba(124,58,237,.4);border-radius:8px;color:#a78bfa;cursor:pointer;font-size:.9rem;outline:none;padding:8px 28px 8px 10px;transition:border-color .15s}.metric-modal__unit-select:focus{border-color:#7c3aed}.metric-modal__unit-toggle{border:1.5px solid rgba(124,58,237,.3);border-radius:8px;display:flex;overflow:hidden}.unit-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.85rem;padding:8px 12px;transition:background .15s,color .15s}.unit-btn--active{background:#7c3aed;color:#fff}.metric-modal__error{color:#f87171;font-size:.85rem;margin:0}.metric-modal__success{color:#34d399;font-size:.85rem;margin:0}.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)}
