@import"https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,300;0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700&display=swap";.nav-item-wrap{display:contents}.nav-item-wrap--bottom{margin-top:auto}.bottom-nav__account{position:relative;display:flex;flex:1;height:100%;overflow:visible}.bottom-nav__account-trigger{position:relative;display:flex;align-items:center;justify-content:center;gap:var(--space-3);width:100%;height:100%;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;padding:0}.bottom-nav__account-avatar,.bottom-nav__account-menu-avatar,.bottom-nav__account-avatar-image,.bottom-nav__account-menu-avatar-image{display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--color-accent) 12%,var(--color-bg-raised));color:var(--color-accent);font-family:var(--font-display);font-weight:800;border:1px solid color-mix(in srgb,var(--color-accent) 35%,var(--color-border))}.bottom-nav__account-avatar{width:38px;height:38px;border-radius:14px}.bottom-nav__account-avatar-image{width:38px;height:38px;border-radius:14px;object-fit:cover}.bottom-nav__account-menu-avatar{width:44px;height:44px;border-radius:14px;flex-shrink:0}.bottom-nav__account-menu-avatar-image{width:44px;height:44px;border-radius:14px;object-fit:cover;flex-shrink:0}.bottom-nav__account-label{display:none;font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:inherit}.bottom-nav__account-status{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--color-success);border:2px solid var(--color-bg-elevated)}.bottom-nav__account-menu{position:absolute;left:8px;bottom:calc(100% - 8px);width:min(320px,calc(100vw - 24px));background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 24px 48px #0000005c;z-index:120;overflow:hidden}.bottom-nav__account-identity,.bottom-nav__account-group{background:var(--color-bg-elevated)}.bottom-nav__account-identity{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--color-border)}.bottom-nav__account-name{font-size:var(--text-lg);font-weight:700}.bottom-nav__account-email{font-size:var(--text-xs);color:var(--color-text-tertiary);font-family:var(--font-mono);margin-top:2px}.bottom-nav__account-group{padding:var(--space-2)}.bottom-nav__account-group+.bottom-nav__account-group{border-top:1px solid var(--color-border)}.bottom-nav__account-footer{padding:0 var(--space-4) var(--space-4);font-family:var(--font-display);font-size:var(--text-xs);font-weight:600;color:var(--color-text-tertiary);letter-spacing:.04em}.bottom-nav__account-item{width:100%;border:none;background:transparent;color:var(--color-text-primary);border-radius:var(--radius-md);padding:12px 14px;text-align:left;cursor:pointer;font-family:var(--font-display);font-size:var(--text-base);font-weight:800;transition:background var(--duration-fast),color var(--duration-fast)}.bottom-nav__account-item:hover,.bottom-nav__account-item.active{background:var(--color-bg-overlay);color:var(--color-accent)}.bottom-nav__account-item--danger{color:var(--color-danger)}.bottom-nav__account-item--danger:hover{background:#f8717114;color:var(--color-danger)}.log-subitems{display:none}@media (min-width: 768px){.nav-item-wrap{display:flex;flex-direction:column}.nav-item-wrap--bottom{margin-top:auto;border-top:1px solid var(--color-border);padding-top:var(--space-4);position:relative}.log-subitems{display:flex;flex-direction:column;gap:2px;padding:var(--space-1) var(--space-2) var(--space-2);margin-top:2px}.log-subitem{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);border:none;background:transparent;cursor:pointer;transition:background var(--duration-fast);width:100%;text-align:left}.log-subitem:hover{background:var(--color-bg-raised)}.log-subitem.active{background:color-mix(in srgb,var(--item-color) 12%,transparent)}.log-subitem__emoji{font-size:1rem;width:22px;text-align:center;flex-shrink:0}.log-subitem__label{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--item-color)}.bottom-nav__account-trigger{justify-content:flex-start;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary)}.bottom-nav__account-label{display:block}.bottom-nav__account-trigger:hover,.bottom-nav__account-trigger.active{background:var(--color-bg-raised);color:var(--color-text-primary)}.bottom-nav__account{flex:0;height:auto}.bottom-nav__account-status{left:38px;bottom:10px}.bottom-nav__account-menu{left:0;bottom:calc(100% - 10px)}}.bottom-nav__brand{display:none}@media (min-width: 768px){.bottom-nav__brand{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3) var(--space-6)}.bottom-nav__logo-mark{width:32px;height:32px;display:inline-block;background:currentColor;-webkit-mask:url(/logo.svg) center / contain no-repeat;mask:url(/logo.svg) center / contain no-repeat;flex-shrink:0}.bottom-nav__wordmark{font-family:var(--font-display);font-size:var(--text-xl);font-weight:900;letter-spacing:-.02em;color:var(--color-accent)}}.bottom-nav__logo-mark--dark{color:#121212e0}.bottom-nav__logo-mark--light{color:#fffffff0}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:50;background:var(--color-bg-elevated);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-top:1.5px solid var(--color-border);padding-bottom:var(--safe-bottom);overflow:visible}.bottom-nav__inner{display:flex;align-items:center;justify-content:space-around;max-width:var(--max-width);margin:0 auto;height:var(--nav-height);padding:0 var(--space-2);overflow:visible}.bottom-nav__item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:6px;padding-bottom:6px;gap:4px;flex:1;height:100%;text-decoration:none;color:var(--color-text-secondary);transition:color var(--duration-fast) var(--ease-smooth);position:relative}.bottom-nav__item.active{color:var(--color-accent)}.bottom-nav__item--primary{color:var(--color-bg)}.bottom-nav__item--primary .bottom-nav__icon{background:var(--color-accent);color:var(--color-bg);width:44px;height:44px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-accent);transition:transform var(--duration-fast) var(--ease-spring),background var(--duration-base)}.bottom-nav__item--primary.active .bottom-nav__icon,.bottom-nav__item--primary:active .bottom-nav__icon{transform:scale(.92)}.bottom-nav__item--primary .bottom-nav__label{color:var(--color-text-secondary)}.bottom-nav__icon{display:flex;align-items:center;justify-content:center;height:24px;transition:transform var(--duration-fast) var(--ease-spring)}.bottom-nav__item:active .bottom-nav__icon{transform:scale(.88)}.bottom-nav__label{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.02em}.bottom-nav__item.active:not(.bottom-nav__item--primary):after{content:"";position:absolute;bottom:6px;width:4px;height:4px;border-radius:50%;background:var(--color-accent)}@media (min-width: 768px){.bottom-nav{top:0;bottom:auto;left:0;right:auto;width:240px;height:100vh;border-top:none;border-right:none;padding-bottom:0;background:#f4f4f4}[data-theme=dark] .bottom-nav{background:#1c1c1e;border-right:none}[data-theme=light] .bottom-nav{background:#f4f4f4;border-right:1px solid var(--color-border)}[data-theme=light] .bottom-nav .bottom-nav__item{color:#393c41}[data-theme=light] .bottom-nav .bottom-nav__item.active,[data-theme=light] .bottom-nav .bottom-nav__item:hover{color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 10%,transparent)}[data-theme=light] .bottom-nav .bottom-nav__item .bottom-nav__label{color:#393c41}[data-theme=light] .bottom-nav .bottom-nav__item.active .bottom-nav__label,[data-theme=light] .bottom-nav .bottom-nav__wordmark{color:var(--color-accent)}[data-theme=light] .bottom-nav .log-subitem__label{color:#393c41}[data-theme=light] .bottom-nav .log-subitem:hover .log-subitem__label,[data-theme=light] .bottom-nav .log-subitem.active .log-subitem__label{color:var(--color-accent)}[data-theme=light] .bottom-nav .log-subitem:hover,[data-theme=light] .bottom-nav .log-subitem.active{background:color-mix(in srgb,var(--color-accent) 8%,transparent)}[data-theme=light] .bottom-nav .bottom-nav__account-trigger{color:#393c41}[data-theme=light] .bottom-nav .bottom-nav__account-trigger:hover,[data-theme=light] .bottom-nav .bottom-nav__account-trigger.active{background:#0000000f;color:#1a1a1a}[data-theme=light] .bottom-nav .nav-item-wrap--bottom{border-top-color:var(--color-border)}[data-theme=light] .bottom-nav .bottom-nav__logo{filter:none}[data-theme=dark] .bottom-nav .bottom-nav__item{color:#ffffffa6}[data-theme=dark] .bottom-nav .bottom-nav__item.active,[data-theme=dark] .bottom-nav .bottom-nav__item:hover{color:#fff;background:#ffffff14}[data-theme=dark] .bottom-nav .bottom-nav__wordmark,[data-theme=dark] .bottom-nav .bottom-nav__label,[data-theme=dark] .bottom-nav .bottom-nav__version{color:#ffffff73}[data-theme=dark] .bottom-nav .bottom-nav__item.active .bottom-nav__label{color:#fff}[data-theme=dark] .bottom-nav .log-subitem__label{color:#ffffffa6}[data-theme=dark] .bottom-nav .log-subitem.active .log-subitem__label,[data-theme=dark] .bottom-nav .log-subitem:hover .log-subitem__label{color:#fff}[data-theme=dark] .bottom-nav .log-subitem:hover,[data-theme=dark] .bottom-nav .log-subitem.active{background:#ffffff14}[data-theme=dark] .bottom-nav .bottom-nav__logo{filter:brightness(0) invert(1)}[data-theme=dark] .bottom-nav .bottom-nav__logo-mark,[data-theme=dark] .bottom-nav .bottom-nav__wordmark{color:#ffffffe6}[data-theme=dark] .bottom-nav .nav-item-wrap--bottom{border-top-color:#ffffff1a}[data-theme=dark] .bottom-nav .bottom-nav__account-trigger{color:#ffffffa6}[data-theme=dark] .bottom-nav .bottom-nav__account-trigger:hover,[data-theme=dark] .bottom-nav .bottom-nav__account-trigger.active{background:#ffffff14;color:#fff}.bottom-nav__inner{flex-direction:column;justify-content:flex-start;align-items:stretch;height:100%;padding:var(--space-6) var(--space-4) var(--space-4);gap:2px;max-width:none}.bottom-nav__inner:before{display:none}.bottom-nav__inner:after{display:none}.bottom-nav__item{flex-direction:row;justify-content:flex-start;flex:0;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);height:40px;color:var(--color-text-secondary)}.bottom-nav__item:hover{background:var(--color-bg-raised);color:var(--color-text-primary)}.bottom-nav__item.active{background:var(--color-accent-dim);color:var(--color-accent)}.bottom-nav__item--bottom{border-top:1px solid var(--color-border);padding-top:var(--space-4);margin-top:auto}.bottom-nav__item.active:after{display:none}.bottom-nav__item--primary{color:var(--color-text-secondary)}.bottom-nav__item--primary .bottom-nav__icon{width:32px;height:32px;border-radius:var(--radius-md)}.bottom-nav__label{font-size:var(--text-base);font-weight:800}}@media (max-width: 767px){.bottom-nav__account-trigger{flex-direction:column;gap:5px}.bottom-nav__account-status{right:calc(50% - 18px);top:6px}.bottom-nav__account-menu{left:auto;right:8px}}.app-layout{min-height:100dvh;display:flex;flex-direction:column}.app-main{flex:1;width:100%}@media (min-width: 768px){.app-layout{flex-direction:row}.app-main{margin-left:220px}}.bottom-sheet__top{position:sticky;top:calc(var(--space-6) * -1);z-index:2;margin:calc(var(--space-6) * -1) calc(var(--space-5) * -1) var(--space-4);padding:var(--space-3) var(--space-5) 0;background:linear-gradient(to bottom,var(--color-bg-elevated) 0%,var(--color-bg-elevated) 80%,transparent 100%);touch-action:none}.bottom-sheet__top--compact{margin-bottom:var(--space-3)}.bottom-sheet__handle{margin:0 auto var(--space-3)}.bottom-sheet__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);min-height:32px}.bottom-sheet__title{font-size:var(--text-xl);font-weight:700;letter-spacing:-.01em;min-width:0}.bottom-sheet__close{background:var(--color-bg-overlay);border:none;color:var(--color-text-secondary);width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--duration-fast)}.bottom-sheet__close:hover{background:var(--color-border-strong)}.bottom-sheet__body{display:flex;flex-direction:column;gap:var(--space-3)}@media (min-width: 768px){.bottom-sheet__top{position:static;margin:0 0 var(--space-5);padding:0;background:transparent;touch-action:auto}.bottom-sheet__top--compact{margin-bottom:var(--space-5)}}.bev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.bev-tile{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-3);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);position:relative;overflow:hidden}.bev-tile:before{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--color);opacity:0;transition:opacity var(--duration-fast)}.bev-tile:hover:before,.bev-tile:active:before{opacity:1}.bev-tile:hover{border-color:var(--color);background:var(--color-bg-elevated)}.bev-tile:active{transform:scale(.95)}.bev-tile__icon{font-size:1.75rem;line-height:1}.bev-tile__label{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary)}.bev-tile__sub{font-size:var(--text-xs);color:var(--color-text-tertiary)}.bev-options{display:flex;flex-direction:column;gap:var(--space-3)}.bev-back{align-self:flex-start;font-size:var(--text-sm);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-1)}.bev-option-btn{display:flex;align-items:center;gap:var(--space-4);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);cursor:pointer;transition:all var(--duration-fast);width:100%}.bev-option-btn:hover{border-color:var(--color);background:var(--color-bg-elevated)}.bev-option-btn:active{transform:scale(.98)}.bev-option-btn__icon{font-size:1.5rem}.bev-option-btn__label{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--color-text-primary)}.bev-custom{display:flex;gap:var(--space-3);align-items:center}.bev-custom__input{flex:1;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-family:var(--font-mono);font-size:var(--text-lg);color:var(--color-text-primary);outline:none;transition:border-color var(--duration-fast)}.bev-custom__input:focus{border-color:var(--color-accent)}.bev-custom__input::placeholder{color:var(--color-text-tertiary)}.bev-success{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-8) 0;animation:fadeUp .3s var(--ease-spring)}.bev-success__check{animation:scaleIn .3s var(--ease-spring)}@keyframes scaleIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.bev-success__label{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;color:var(--color-text-primary);margin-top:var(--space-1)}.bev-success__stat{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-tertiary)}.bev-other{display:flex;flex-direction:column;gap:var(--space-3)}.bev-chat{display:flex;flex-direction:column;gap:var(--space-2);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3)}.bev-chat__msg{display:flex;align-items:flex-start;gap:var(--space-2)}.bev-chat__msg--model{flex-direction:row}.bev-chat__msg--user{flex-direction:row-reverse}.bev-chat__avatar{width:22px;height:22px;border-radius:50%;background:var(--color-accent-dim);display:flex;align-items:center;justify-content:center;flex-shrink:0}.bev-chat__text{font-size:var(--text-sm);color:var(--color-text-primary);background:var(--color-bg-overlay);border-radius:var(--radius-md);padding:7px 10px;max-width:85%;line-height:1.4}.bev-chat__msg--user .bev-chat__text{background:var(--color-accent-dim);color:var(--color-accent)}.bev-chat__dots{display:flex;align-items:center;gap:4px;padding:10px 12px;background:var(--color-bg-overlay);border-radius:var(--radius-md)}.bev-chat__dots span{width:5px;height:5px;border-radius:50%;background:var(--color-text-tertiary);animation:chatDot 1.2s infinite}.bev-chat__dots span:nth-child(2){animation-delay:.2s}.bev-chat__dots span:nth-child(3){animation-delay:.4s}@keyframes chatDot{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.bev-chat__estimate{display:flex;align-items:center;gap:6px;font-size:var(--text-xs);color:var(--color-accent);background:var(--color-accent-dim);border-radius:var(--radius-sm);padding:6px 10px;margin-top:var(--space-1)}.bev-chat__estimate-note{color:var(--color-text-tertiary);margin-left:4px}.bev-chat__input-row{display:flex;gap:var(--space-2);align-items:center}.bev-chat__send{padding:10px 12px;flex-shrink:0}.checkin{display:flex;flex-direction:column;gap:var(--space-4)}.checkin__title{font-size:var(--text-2xl);font-weight:800;letter-spacing:-.01em;margin-bottom:var(--space-2)}.checkin__section{background:var(--color-bg-raised);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4)}.checkin__section-label{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-display);font-size:var(--text-base);font-weight:800;color:var(--color-text-primary);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border)}.checkin__section-header-row{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border)}.screen-time-link{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--color-accent);text-decoration:none}.checkin__mode-toggle{display:flex;gap:2px;background:var(--color-bg-overlay);border-radius:var(--radius-md);padding:3px}.mode-btn{flex:1;font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;padding:8px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast)}.mode-btn.active{background:var(--color-bg-elevated);color:var(--color-accent)}.time-inputs-row{display:flex;gap:var(--space-3);align-items:flex-end;flex-wrap:wrap}.time-input-wrap{display:flex;flex-direction:column;gap:var(--space-1);flex:1;min-width:120px}.checkin__item-label{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--color-text-secondary)}.time-hm-row{display:flex;align-items:center;gap:var(--space-2)}.time-input--half{flex:1}.time-sep{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;color:var(--color-text-secondary);flex-shrink:0}.time-input{background:var(--color-bg-elevated);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;color:var(--color-text-primary);outline:none;min-height:52px;transition:border-color var(--duration-fast);width:100%;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none}.time-input:focus{border-color:var(--color-accent)}.sleep-calculated{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-3);background:var(--color-accent-dim);border-radius:var(--radius-md);border:1.5px solid var(--color-accent);min-width:80px}.sleep-hours-value{font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;color:var(--color-accent)}.checkin__item{display:flex;flex-direction:column;gap:var(--space-3)}.checkin__item-header{display:flex;align-items:center;gap:var(--space-3)}.checkin__icon{display:flex;align-items:center}.checkin__value{font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;color:var(--color-accent);min-width:64px;text-align:right;margin-left:auto}.checkin__slider-row{display:flex;align-items:center;gap:var(--space-3)}.checkin__tick{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--color-text-tertiary);min-width:20px}.checkin__slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:var(--color-border-strong);border-radius:var(--radius-full);outline:none;cursor:pointer}.checkin__slider::-webkit-slider-thumb{-webkit-appearance:none;width:28px;height:28px;border-radius:50%;background:var(--color-accent);cursor:pointer;box-shadow:0 0 0 4px var(--color-accent-dim);transition:transform var(--duration-fast) var(--ease-spring)}.checkin__slider::-webkit-slider-thumb:active{transform:scale(1.2)}.checkin__slider::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:var(--color-accent);border:none;cursor:pointer}.weight-entry{display:flex;flex-direction:column;gap:var(--space-3)}.weight-entry__input-row{display:flex;align-items:baseline;justify-content:center;gap:var(--space-3);padding:var(--space-4) 0}.weight-entry__input{background:transparent;border:none;border-bottom:2px solid var(--color-accent);font-size:var(--text-hero);font-weight:700;color:var(--color-text-primary);width:6ch;text-align:center;outline:none;padding-bottom:var(--space-2);letter-spacing:-.02em}.weight-entry__input::placeholder{color:var(--color-text-tertiary)}.weight-entry__unit{font-size:var(--text-2xl);font-weight:600;color:var(--color-text-secondary)}.log-page{padding-top:var(--space-8)}.log-header{margin-bottom:var(--space-6)}.log-title{font-size:var(--text-3xl);font-weight:700;letter-spacing:-.02em;margin-top:var(--space-1)}.log-grid{display:flex;flex-direction:column;gap:var(--space-3)}.log-tile{display:flex;align-items:center;gap:var(--space-4);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);text-align:left;position:relative;overflow:hidden}.log-tile:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color);opacity:0;transition:opacity var(--duration-fast)}.log-tile:hover:before{opacity:1}.log-tile:hover{border-color:var(--color);transform:translate(3px)}.log-tile:active{transform:scale(.98) translate(0)}.log-tile__icon{font-size:1.75rem;min-width:32px;text-align:center}.log-tile__text{flex:1;display:flex;flex-direction:column;gap:2px}.log-tile__label{font-size:var(--text-lg);font-weight:700;color:var(--color-text-primary)}.log-tile__sub{font-size:var(--text-sm);color:var(--color-text-tertiary)}.log-tile__arrow{color:var(--color-text-tertiary)}.journal-textarea{width:100%;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);line-height:1.6;resize:none;outline:none;transition:border-color var(--duration-fast)}.hk-step__num{background:var(--color-accent-dim);color:var(--color-accent);width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;flex-shrink:0}.hk-step__text{font-size:var(--text-sm);color:var(--color-text-secondary);padding-top:2px}.hk-result{background:var(--color-success-dim);border:1px solid var(--color-success);border-radius:var(--radius-md);padding:var(--space-4);font-family:var(--font-display);font-weight:600;color:var(--color-success);text-align:center}.screentime-sheet{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-2) 0 var(--space-4)}.screentime-rollers{display:flex;justify-content:center;align-items:flex-end;gap:var(--space-8);padding:var(--space-6) 0}.screentime-roller{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.screentime-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;font-family:var(--font-mono);font-size:2rem;font-weight:700;line-height:1;text-align:center;text-align-last:center;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-5);color:var(--color-text-primary);min-width:96px;cursor:pointer;transition:border-color var(--duration-fast)}.screentime-select:focus{outline:none;border-color:var(--color-accent)}.screentime-unit{font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.08em}.weekly-card{background:linear-gradient(135deg,var(--color-bg-elevated),var(--color-bg-raised));border:1.5px solid var(--color-accent-dim);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-5);position:relative;overflow:hidden}.weekly-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 50% at 50% -10%,var(--color-accent-glow),transparent);pointer-events:none}.weekly-card__title{margin-bottom:var(--space-2)}.weekly-card__headline{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-5);line-height:1.3}.weekly-stats{display:flex;flex-direction:column;gap:var(--space-4)}.weekly-stat{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.weekly-stat:last-child{border-bottom:none}.weekly-stat__left{display:flex;align-items:center;gap:var(--space-3)}.weekly-stat__icon{font-size:1.5rem;width:32px;text-align:center}.weekly-stat__label{font-family:var(--font-display);font-size:var(--text-base);font-weight:600;color:var(--color-text-secondary)}.weekly-stat__value{font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;color:var(--color-accent);line-height:1}.today-page{padding-top:var(--space-8)}.today-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-6);padding-top:max(var(--space-4),env(safe-area-inset-top,0px))}.today-date{font-size:.75rem;color:var(--color-text-tertiary);font-weight:400;text-transform:uppercase;letter-spacing:.06em}.today-greeting{font-size:clamp(1.375rem,5vw,1.875rem);font-weight:600;line-height:1.2}.checkin-banner{display:flex;align-items:center;justify-content:space-between;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-left:3px solid var(--color-accent);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-5)}.checkin-banner__text p{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.metrics-grid{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-6)}.metrics-hero,.metrics-secondary{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.metrics-hero .metric-card{min-height:140px}@media (max-width: 380px){.metrics-hero,.metrics-secondary{gap:var(--space-1)}.metric-card{padding:var(--space-3) var(--space-2)}}.metric-card{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);position:relative;overflow:visible;min-height:80px;justify-content:space-between}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);opacity:.6}.metric-card__label{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--color-text-secondary);align-self:flex-start;line-height:1.2}.metric-card--clickable{cursor:pointer}.metric-card--clickable:hover{border-color:var(--color-accent)}.metrics-hero__content{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-1)}@media (max-width: 600px){.metrics-hero__content{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.metrics-hero__numbers{width:100%}}.metrics-hero__numbers{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1;overflow:hidden}.ring-container{position:relative;flex-shrink:0}.ring-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.ring-value{font-size:10px;font-weight:700;color:var(--color-text-secondary);line-height:1}.metric-empty{font-family:var(--font-mono);font-size:var(--text-xl);color:var(--color-text-tertiary)}.today-section{margin-bottom:var(--space-6)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.empty-state{background:var(--color-bg-raised);border:1px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8);text-align:center;color:var(--color-text-tertiary);font-size:var(--text-sm)}.today-badges{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-2)}.checkin-banner{display:flex;align-items:center;justify-content:space-between;width:100%;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-left:3px solid var(--color-accent);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-5);cursor:pointer;transition:border-color var(--duration-fast);text-align:left}.checkin-banner:hover{border-color:var(--color-accent)}.checkin-banner p{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1);font-family:var(--font-display);font-weight:500}.checkin-banner__arrow{color:var(--color-accent);font-size:var(--text-lg)}.hydration-quick-add{background:none;border:none;color:var(--color-text-tertiary);font-family:var(--font-display);font-size:var(--text-xs);font-weight:600;cursor:pointer;padding:0;margin-top:auto;transition:color var(--duration-fast);text-align:left}.hydration-quick-add:hover{color:var(--color-accent)}.metrics-activity{display:flex;gap:var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4)}.activity-chip{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1;text-align:center}.activity-chip__label{font-size:var(--text-xs);color:var(--color-text-tertiary)}.food-list{display:flex;flex-direction:column;gap:var(--space-2)}.meal-item{display:grid;grid-template-columns:1fr auto;gap:var(--space-4);align-items:start;background:var(--color-bg-raised);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}.meal-item__text{min-width:0;overflow:hidden}.meal-item__name{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary);line-height:1.4;overflow-wrap:break-word;word-break:break-word}.meal-item__meta{font-size:var(--text-xs);color:var(--color-text-tertiary);text-transform:capitalize;margin-top:2px}.meal-item__value{font-size:var(--text-sm);font-weight:700;white-space:nowrap;flex-shrink:0;padding-top:2px}.metric-empty{background:none;border:none;font-family:var(--font-mono);font-size:var(--text-xl);color:var(--color-text-tertiary);cursor:pointer;padding:0}.metric-empty--static{cursor:default}.today-body{display:flex;flex-direction:column;gap:var(--space-6)}.today-sidebar{display:none}@media (min-width: 768px){.today-page{max-width:none;margin:0;padding-left:var(--space-6);padding-right:var(--space-6)}.today-page .container{max-width:none;padding:0}.metrics-hero__content{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.metrics-hero__numbers{width:100%}}@media (min-width: 1024px){.today-body{flex-direction:row;align-items:flex-start;gap:var(--space-6)}.today-main{flex:1;min-width:0}.today-sidebar{display:block;flex:0 0 280px;position:sticky;top:var(--space-6);align-self:flex-start}.metrics-secondary .metric-card{min-height:120px}}.metric-large{font-size:clamp(1.25rem,6vw,1.75rem)!important;font-weight:700;line-height:1.1;white-space:nowrap;display:block}.metric-unit{font-size:clamp(.7rem,2.5vw,.875rem);white-space:nowrap}.food-chat{display:flex;flex-direction:column;gap:var(--space-4)}.food-chat__prompt{display:flex;align-items:flex-start;gap:var(--space-3);background:var(--color-bg-raised);border-radius:var(--radius-lg);padding:var(--space-4)}.food-chat__prompt-icon{font-size:1.5rem;flex-shrink:0}.food-chat__prompt-text{font-size:var(--text-base);font-weight:500;color:var(--color-text-secondary);line-height:1.5}.food-chat__messages{display:flex;flex-direction:column;gap:var(--space-3);max-height:380px;overflow-y:auto;padding:var(--space-2) 0}.chat-bubble{display:flex;align-items:flex-start;gap:var(--space-2);animation:fadeUp var(--duration-base) var(--ease-spring)}.chat-bubble--user{flex-direction:row-reverse}.chat-bubble--user .chat-bubble__text{background:var(--color-accent);color:var(--color-bg);border-radius:var(--radius-lg) var(--radius-sm) var(--radius-lg) var(--radius-lg)}.chat-bubble--user .chat-bubble__text ::selection{background:#ffffff4d;color:var(--color-bg)}.chat-bubble--model .chat-bubble__text{background:var(--color-bg-elevated);border:1px solid var(--color-border);color:var(--color-text-primary);border-radius:var(--radius-sm) var(--radius-lg) var(--radius-lg) var(--radius-lg)}.chat-bubble__avatar{font-size:1.25rem;flex-shrink:0;margin-top:2px}.chat-bubble__text{font-family:var(--font-body);font-size:var(--text-base);font-weight:500;line-height:1.5;padding:var(--space-3) var(--space-4);max-width:85%}.chat-typing{display:flex;align-items:center;gap:5px;padding:var(--space-3) var(--space-4);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm) var(--radius-lg) var(--radius-lg) var(--radius-lg)}.chat-typing span{width:8px;height:8px;border-radius:50%;background:var(--color-text-tertiary);animation:typingBounce 1.2s infinite}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-6px);opacity:1}}.chat-error{background:#b840401a;border:1px solid var(--color-danger);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-danger)}.food-chat__input-row{display:flex;gap:var(--space-3);align-items:flex-end}.food-chat__input{flex:1;background:var(--color-bg-raised);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);font-weight:500;color:var(--color-text-primary);resize:none;outline:none;transition:border-color var(--duration-fast);line-height:1.5}.food-chat__input:focus{border-color:var(--color-accent)}.food-chat__input::placeholder{color:var(--color-text-tertiary)}.food-chat__input:disabled{opacity:.6}.food-chat__send{width:52px;height:52px;min-height:52px;padding:0;border-radius:var(--radius-lg);flex-shrink:0}.food-chat__send:disabled{opacity:.4}.food-chat__suggestions{margin-bottom:var(--space-3);padding:var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.food-chat__suggestion{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--space-2) var(--space-3);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-2);cursor:pointer;transition:all var(--duration-fast);text-align:left}.food-chat__suggestion:last-child{margin-bottom:0}.food-chat__suggestion:hover{border-color:var(--color-accent);background:var(--color-accent-dim)}.food-chat__suggestion-name{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--color-text-primary)}.food-chat__suggestion-brand{font-size:var(--text-sm);color:var(--color-text-tertiary)}.food-chat__suggestion-cal{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:700;color:var(--color-accent);flex-shrink:0;margin-left:var(--space-3)}.food-logger{display:flex;flex-direction:column;gap:var(--space-3)}.meal-type-row{display:flex;gap:var(--space-2);flex-wrap:wrap}.meal-type-btn{flex:1;font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;padding:10px 8px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast);display:flex;flex-direction:column;align-items:center;gap:4px}.meal-type-btn.active{background:var(--color-accent-dim);border-color:var(--color-accent);color:var(--color-accent)}.analysis-screen{display:flex;flex-direction:column;align-items:center;gap:var(--space-5);padding:var(--space-6) 0}.analysis-preview-wrap{position:relative;width:100%;max-height:220px;border-radius:var(--radius-lg);overflow:hidden}.analysis-preview{width:100%;max-height:220px;object-fit:cover;display:block;filter:brightness(.75)}.analysis-scan-line{position:absolute;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,var(--color-accent) 30%,rgba(255,255,255,.9) 50%,var(--color-accent) 70%,transparent 100%);animation:scanDown 2s ease-in-out infinite;box-shadow:0 0 12px var(--color-accent-glow)}@keyframes scanDown{0%{top:0%;opacity:0}10%{opacity:1}90%{opacity:1}to{top:100%;opacity:0}}.analysis-chat-icon{font-size:3rem;animation:float 2s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.analysis-orb{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.analysis-orb__ring{position:absolute;border-radius:50%;border:2px solid var(--color-accent);opacity:0;animation:orbPulse 2.4s ease-out infinite}.analysis-orb__ring--1{width:80px;height:80px;animation-delay:0s}.analysis-orb__ring--2{width:60px;height:60px;animation-delay:.4s}.analysis-orb__ring--3{width:40px;height:40px;animation-delay:.8s}@keyframes orbPulse{0%{transform:scale(.6);opacity:.8}to{transform:scale(1.8);opacity:0}}.analysis-orb__core{width:48px;height:48px;border-radius:50%;background:var(--color-accent-dim);border:2px solid var(--color-accent);display:flex;align-items:center;justify-content:center;font-size:1.5rem;animation:coreGlow 1.2s ease-in-out infinite alternate;z-index:1}@keyframes coreGlow{0%{box-shadow:0 0 8px var(--color-accent-glow)}to{box-shadow:0 0 24px var(--color-accent-glow),0 0 40px var(--color-accent-dim)}}.analysis-message{font-family:var(--font-display);font-size:var(--text-base);font-weight:700;color:var(--color-text-primary);text-align:center;animation:fadeUp .4s var(--ease-spring)}.analysis-sub{font-size:var(--text-sm);color:var(--color-text-tertiary);margin-top:calc(-1 * var(--space-3))}.confidence-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-full);background:var(--color-bg-elevated);border:1.5px solid var(--conf-color);align-self:flex-start}.confidence-badge__label{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--conf-color)}.confidence-badge__score{font-family:var(--font-display);font-size:var(--text-xs);color:var(--color-text-tertiary);font-weight:600}.food-clarify{display:flex;flex-direction:column;gap:var(--space-4)}.clarify-badge{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--color-text-secondary)}.clarify-question{display:flex;align-items:flex-start;gap:var(--space-3);background:var(--color-bg-elevated);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4)}.clarify-question__icon{font-size:1.5rem;flex-shrink:0}.clarify-question__text{font-family:var(--font-display);font-size:var(--text-base);font-weight:600;color:var(--color-text-primary);line-height:1.4}.clarify-actions{display:flex;flex-direction:column;gap:var(--space-3)}.field-hint{font-size:var(--text-xs);color:var(--color-warning);font-family:var(--font-display);font-weight:600;margin-top:4px}.food-capture-btn{display:flex;flex-direction:row;align-items:center;gap:var(--space-4);background:var(--color-bg-raised);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-5);cursor:pointer;transition:all var(--duration-base);width:100%;text-align:left}.food-capture-btn:hover{border-color:var(--color-accent);background:var(--color-accent-dim)}.food-describe-btn{display:flex;flex-direction:row;align-items:center;gap:var(--space-4);background:var(--color-bg-elevated);border:1.5px dashed var(--color-border-strong);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-5);cursor:pointer;transition:all var(--duration-base);width:100%;text-align:left}.food-describe-btn:hover{border-color:var(--color-accent);background:var(--color-accent-dim)}.food-capture-btn__icon{font-size:1.875rem;flex-shrink:0}.food-capture-btn__text{display:flex;flex-direction:column;gap:4px}.food-capture-btn__label{font-family:var(--font-display);font-size:var(--text-base);font-weight:800;color:var(--color-text-primary)}.food-capture-btn__sub{font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-text-tertiary);font-weight:500}.food-capture-btn.drag-over{border-color:var(--color-accent);border-style:dashed;background:var(--color-accent-dim)}.food-preview{width:100%;max-height:200px;object-fit:cover;border-radius:var(--radius-lg);border:1px solid var(--color-border)}.food-estimating{display:flex;flex-direction:column;align-items:center;gap:var(--space-5);padding-bottom:var(--space-4)}.food-estimating__status{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);text-align:center}.food-estimating__spinner{width:32px;height:32px;border:2.5px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.ai-confidence{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border-left:3px solid}.ai-confidence--high{border-color:var(--color-success);background:var(--color-success-dim)}.ai-confidence--medium{border-color:var(--color-warning);background:#fbbf241a}.ai-confidence--low{border-color:var(--color-danger);background:#f871711a}.ai-confidence p{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:4px}.food-form{display:flex;flex-direction:column;gap:var(--space-3)}.food-form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.food-form__field{display:flex;flex-direction:column;gap:var(--space-1)}.food-form__label{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary)}.food-form__input{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);outline:none;transition:border-color var(--duration-fast)}.food-form__input--mono{font-family:var(--font-mono)}.food-form__input:focus{border-color:var(--color-accent)}.food-confirm{display:flex;flex-direction:column;gap:var(--space-3)}.food-confirm__actions{display:flex;flex-direction:row;gap:var(--space-3);align-items:center}.input-with-unit{position:relative;display:flex;align-items:center}.input-with-unit .food-form__input{padding-right:var(--space-12);width:100%;-moz-appearance:textfield}.input-with-unit .food-form__input::-webkit-outer-spin-button,.input-with-unit .food-form__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.input-unit{position:absolute;right:var(--space-4);font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--color-text-tertiary);pointer-events:none}.food-error{background:#f871711a;border:1px solid var(--color-danger);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-danger)}.saved-foods{display:flex;flex-direction:column;gap:var(--space-2)}.saved-food-item{display:flex;align-items:center;justify-content:space-between;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);cursor:pointer;transition:all var(--duration-fast);width:100%;text-align:left}.saved-food-item:hover{border-color:var(--color-accent)}.saved-food-item:active{transform:scale(.99)}.saved-food-item__info{display:flex;flex-direction:column;gap:2px}.saved-food-item__name{font-family:var(--font-display);font-size:var(--text-base);font-weight:600;color:var(--color-text-primary)}.saved-food-item__count{font-size:var(--text-xs);color:var(--color-text-tertiary)}.saved-food-item__cal{font-size:var(--text-sm);color:var(--color-accent)}.food-saving{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-8) 0}.food-form__textarea{resize:none;overflow:hidden;min-height:56px;line-height:1.5}.workout-session{display:flex;flex-direction:column;gap:var(--space-4);padding-bottom:var(--space-8)}.session-header{display:flex;align-items:flex-start;justify-content:space-between}.session-title{font-size:var(--text-2xl);font-weight:700;letter-spacing:-.01em;margin-top:4px}.session-stats{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-5)}.session-elapsed{font-size:var(--text-base);font-weight:700;color:var(--color-text-secondary)}.session-abort-btn{background:var(--color-bg-raised);border:1.5px solid var(--color-border);color:var(--color-text-secondary);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;transition:all var(--duration-fast)}.session-abort-btn:hover{border-color:var(--color-danger);color:var(--color-danger)}.session-progress{height:3px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.session-progress__bar{height:100%;background:var(--color-accent);border-radius:var(--radius-full);transition:width .4s var(--ease-spring)}.exercise-list{display:flex;flex-direction:column;gap:var(--space-3)}.exercise-block{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);transition:border-color var(--duration-base)}.exercise-block--done{border-color:#4ade804d;background:var(--color-success-dim)}.exercise-block__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-2)}.exercise-block__name{font-size:var(--text-base);font-weight:700;color:var(--color-text-primary)}.exercise-block__target{margin-top:4px}.exercise-done-badge{color:var(--color-success);font-size:var(--text-lg);font-weight:700}.exercise-tip{font-size:var(--text-xs);color:var(--color-text-secondary);background:var(--color-bg-elevated);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);margin-bottom:var(--space-3);line-height:1.4}.sets-row{display:flex;gap:var(--space-2);margin-bottom:var(--space-3);flex-wrap:wrap}.set-chip{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:44px;padding:var(--space-2);border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-elevated);transition:all var(--duration-fast)}.set-chip.current{border-color:var(--color-accent);background:var(--color-accent-dim)}.set-chip.done{border-color:#4ade8066;background:var(--color-success-dim)}.set-chip__num{font-size:var(--text-xs);color:var(--color-text-tertiary);font-weight:700}.set-chip__val{font-size:var(--text-sm);font-weight:700;color:var(--color-success)}.set-logger{display:flex;flex-direction:column;gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--color-border)}.set-logger__label{margin-bottom:4px}.set-logger__input-row{display:flex;align-items:center;gap:var(--space-3);justify-content:center}.reps-input{width:72px;text-align:center;background:var(--color-bg-overlay);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);font-size:var(--text-2xl);font-weight:700;color:var(--color-text-primary);outline:none}.reps-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text-secondary);font-size:var(--text-xl);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast)}.reps-btn:active{transform:scale(.92);background:var(--color-accent-dim)}.reps-unit{font-size:var(--text-sm);font-weight:600;color:var(--color-text-tertiary)}.hold-target{font-size:var(--text-2xl);font-weight:700;color:var(--color-accent);text-align:center}.rpe-selector{display:flex;align-items:center;gap:var(--space-3)}.rpe-dots{display:flex;gap:8px}.rpe-dot{width:24px;height:24px;border-radius:50%;border:2px solid var(--color-border);background:transparent;cursor:pointer;transition:all var(--duration-fast)}.rpe-dot.filled{background:var(--color-accent);border-color:var(--color-accent)}.rest-timer{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4) 0}.rest-timer__ring{width:80px;height:80px;border-radius:50%;border:3px solid var(--color-accent);display:flex;align-items:center;justify-content:center;animation:pulse-glow 2s infinite}.rest-timer__time{font-size:var(--text-xl);font-weight:700;color:var(--color-accent)}.rest-timer__label{font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-text-secondary)}.session-abort-confirm{background:var(--color-bg-elevated);border:1px solid rgba(248,113,113,.3);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center;margin-top:var(--space-2)}.session-complete,.session-finish{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background:var(--color-success-dim);border:1px solid rgba(74,222,128,.2);border-radius:var(--radius-lg)}.fitness-page{padding-top:var(--space-8)}.fitness-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-5)}.fitness-title{font-size:var(--text-3xl);font-weight:700;letter-spacing:-.02em;margin-top:var(--space-1)}.fitness-stats{display:flex;gap:var(--space-5);margin-top:var(--space-5)}.fitness-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.fitness-tabs{position:sticky;top:0;z-index:20;background:var(--color-bg);padding:var(--space-2) 0;margin-left:calc(-1 * var(--space-5));margin-right:calc(-1 * var(--space-5));padding-left:var(--space-5);padding-right:var(--space-5);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-4);display:flex;gap:var(--space-2);overflow-x:auto;scrollbar-width:none;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.fitness-tabs::-webkit-scrollbar{display:none}.fitness-tab{font-family:var(--font-display);font-size:.8125rem;font-weight:600;white-space:nowrap;flex-shrink:0;scroll-snap-align:start;padding:7px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-full);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .12s ease}.fitness-tab.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff;font-weight:700}.fitness-tab:not(.active):hover{border-color:var(--color-accent);color:var(--color-accent)}@media (min-width: 768px){.fitness-tabs{display:flex;gap:2px;overflow-x:visible;scroll-snap-type:none;-webkit-mask-image:none;mask-image:none;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:3px}.fitness-tab{flex:1;border:none;border-radius:var(--radius-sm);padding:10px;white-space:normal;text-align:center}.fitness-tab.active{background:var(--color-bg);border:none;color:var(--color-text-primary);box-shadow:0 1px 3px #0000001a}}.fitness-section-label{font-size:var(--text-base);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-4);line-height:1.5}.program-card{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);margin-bottom:var(--space-4);position:relative;overflow:hidden}.program-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--color)}.program-card__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-3)}.program-card__name{font-size:var(--text-xl);font-weight:700;letter-spacing:-.01em;margin-top:4px}.program-card__days{font-size:var(--text-2xl);font-weight:800;color:var(--color);margin-top:var(--space-5)}.program-card__desc{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5;margin-bottom:var(--space-4)}.program-card__days-list{display:flex;gap:var(--space-2);flex-wrap:wrap}.day-chip{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-4);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast)}.day-chip:hover{border-color:var(--module-activity);color:var(--module-activity);background:#4ade801a}.day-chip:active{transform:scale(.96)}.lib-search{margin-bottom:var(--space-4);position:relative}.lib-searching{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%)}.lib-filters{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-5);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4)}.filter-row{display:flex;align-items:center;gap:var(--space-3)}.filter-chips{display:flex;gap:var(--space-2);flex-wrap:wrap;flex:1}.filter-chip{font-family:var(--font-display);font-size:var(--text-xs);font-weight:600;padding:5px 10px;border:1px solid var(--color-border);border-radius:var(--radius-full);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast);text-transform:capitalize}.filter-chip.active{background:var(--color-accent-dim);border-color:var(--color-accent);color:var(--color-accent)}.exercise-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-bottom:var(--space-8)}.exercise-card{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);text-align:left;cursor:pointer;transition:all var(--duration-fast);display:flex;flex-direction:column;gap:var(--space-2)}.exercise-card:hover{border-color:var(--color-border-strong);transform:translateY(-1px)}.exercise-card:active{transform:scale(.98)}.exercise-card__header{display:flex;align-items:center;justify-content:space-between}.exercise-card__icon{font-size:1.25rem}.exercise-card__diff{font-size:10px}.exercise-card__name{font-size:var(--text-sm);font-weight:700;color:var(--color-text-primary);line-height:1.3}.exercise-card__muscles{display:flex;flex-wrap:wrap;gap:4px}.muscle-tag{font-family:var(--font-mono);font-size:10px;padding:2px 7px;background:var(--color-bg-overlay);border-radius:var(--radius-full);color:var(--color-text-tertiary);text-transform:capitalize}.exercise-detail{display:flex;flex-direction:column;gap:var(--space-4)}.exercise-detail__hero{display:flex;align-items:center;gap:var(--space-4)}.exercise-detail__desc{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.6}.exercise-detail__tip{background:var(--color-bg-elevated);border-left:3px solid var(--color-accent);border-radius:0 var(--radius-md) var(--radius-md) 0;padding:var(--space-3) var(--space-4);display:flex;flex-direction:column;gap:4px}.exercise-detail__tip p{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:4px}.exercise-detail__meta{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.meta-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary)}.session-item{display:flex;align-items:center;justify-content:space-between;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-3)}.session-item__name{font-size:var(--text-base);font-weight:700;color:var(--color-text-primary);margin-bottom:4px}.session-item__meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-tertiary)}.session-item__date{flex-shrink:0}@media (min-width: 768px){.exercise-grid{grid-template-columns:repeat(3,1fr)}}.sports-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}@media (min-width: 768px){.sports-grid{grid-template-columns:repeat(3,1fr)}}.sport-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--color-bg-raised);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast);text-align:center}.sport-card:hover{border-color:var(--color-accent);background:var(--color-accent-dim)}.sport-card__emoji{font-size:2rem}.sport-card__label{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--color-text-primary)}.sport-card__met{color:var(--color-text-tertiary)}.fitness-history-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-2)}.fitness-history-item__emoji{font-size:1.5rem;flex-shrink:0}.fitness-history-item__text{flex:1;min-width:0}.fitness-history-item__label{font-family:var(--font-display);font-size:var(--text-base);font-weight:700;color:var(--color-text-primary)}.fitness-history-item__sub{font-size:var(--text-sm);color:var(--color-text-tertiary);margin-top:2px}.fitness-history-item__kcal{font-size:var(--text-sm);font-weight:700;color:var(--color-accent);flex-shrink:0}.sport-card--library{border-color:var(--color-accent);background:var(--color-accent-dim)}.sport-card--library .sport-card__label{color:var(--color-accent)}.insights-panel{display:flex;flex-direction:column;gap:var(--space-4)}.insights-coverage{display:flex;align-items:center;justify-content:space-between;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}.insights-intro{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5}.insights-list{display:flex;flex-direction:column;gap:var(--space-3)}.insight-card{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);position:relative;overflow:hidden;transition:border-color var(--duration-fast)}.insight-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color)}.insight-card__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.insight-card__metrics{display:flex;align-items:center;gap:var(--space-2);flex:1;flex-wrap:wrap}.insight-metric{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary)}.insight-arrow{font-size:var(--text-lg);font-weight:700;line-height:1}.insight-r{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.insight-r__value{font-size:var(--text-xl);font-weight:800;line-height:1}.insight-r__label{text-align:right}.insight-bar{height:4px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.insight-bar__fill{height:100%;border-radius:var(--radius-full);transition:width .8s var(--ease-spring);opacity:.8}.insight-card__text{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.55}.insight-card__points{align-self:flex-end}.insights-empty{background:var(--color-bg-raised);border:1px dashed var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8) var(--space-5);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.insights-empty__icon{font-size:2.5rem}.insights-empty__title{font-size:var(--text-lg);font-weight:700}.insights-empty__sub{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.55;max-width:300px}.insights-checklist{display:flex;flex-direction:column;gap:var(--space-1);margin-top:var(--space-2);text-align:left}.insights-checklist__item{font-size:var(--text-xs);color:var(--color-success);font-family:var(--font-mono)}.insights-method{background:var(--color-bg-elevated);border-radius:var(--radius-md);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.insights-method p{font-size:var(--text-xs);color:var(--color-text-tertiary);line-height:1.55}.progress-tabs{display:flex;gap:2px;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:3px;margin-bottom:var(--space-5)}.progress-tab{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;flex:1;padding:8px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-tertiary);cursor:pointer;transition:all var(--duration-fast);display:flex;align-items:center;justify-content:center;gap:6px}.progress-tab.active{background:var(--color-bg-overlay);color:var(--color-accent)}.progress-tab__badge{background:var(--color-accent);color:#0a0a0a;font-size:10px;font-weight:800;min-width:18px;height:18px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 4px}.progress-page{padding-top:var(--space-8)}.progress-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-4)}.progress-range-bar{position:sticky;top:0;z-index:20;background:var(--color-bg);padding:var(--space-2) 0;margin-left:calc(-1 * var(--space-5));margin-right:calc(-1 * var(--space-5));padding-left:var(--space-5);padding-right:var(--space-5);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-4)}@media (min-width: 768px){.progress-range-bar{margin-left:calc(-1 * var(--space-8));margin-right:calc(-1 * var(--space-8));padding-left:var(--space-8);padding-right:var(--space-8)}}.progress-header .module-label{font-size:var(--text-xs);font-weight:500}.progress-title{font-size:var(--text-2xl);font-weight:600;letter-spacing:-.01em;margin-top:var(--space-1)}.range-selector{display:flex;gap:var(--space-2);overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--space-1);-webkit-mask-image:linear-gradient(to right,black 85%,transparent 100%);mask-image:linear-gradient(to right,black 85%,transparent 100%)}.range-selector::-webkit-scrollbar{display:none}.range-btn{font-family:var(--font-display);font-size:.8125rem;font-weight:600;white-space:nowrap;flex-shrink:0;scroll-snap-align:start;min-width:52px;min-height:36px;padding:6px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-full);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .12s ease}.range-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff;font-weight:700}.custom-date-range{display:flex;gap:var(--space-3);margin-top:var(--space-3);margin-bottom:var(--space-2)}.custom-date-range input[type=date]{flex:1;padding:var(--space-2) var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-raised);color:var(--color-text-primary);font-family:var(--font-display);font-size:var(--text-sm);min-height:40px}.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-bottom:var(--space-5)}.stat-card{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-1);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--color);opacity:.7}.stat-card__value{font-size:var(--text-2xl);font-weight:700;color:var(--color);line-height:1;margin-top:4px}.stat-card__label{font-size:var(--text-xs);color:var(--color-text-tertiary);font-family:var(--font-display);font-weight:500}.stat-card__delta{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700;margin-top:2px}.bmi-card{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}.bmi-card__left{display:flex;align-items:baseline;gap:var(--space-3)}.bmi-card__value{font-size:var(--text-2xl);font-weight:700}.bmi-card__cat{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600}.bmi-bar{display:flex;height:8px;border-radius:var(--radius-full);overflow:hidden;gap:2px;position:relative}.bmi-seg{position:relative;height:100%;opacity:.6;border-radius:2px;display:flex;align-items:center;justify-content:center}.bmi-seg__label{position:absolute;bottom:-16px;font-size:9px;color:var(--color-text-tertiary);white-space:nowrap}.bmi-marker{position:absolute;top:-2px;width:12px;height:12px;background:var(--color-text-primary);border-radius:50%;transform:translate(-50%);border:2px solid var(--color-bg);z-index:1;transition:left .5s var(--ease-spring)}.chart-section{margin-bottom:var(--space-6)}.progress-section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:var(--space-4)}.progress-section-title{font-size:var(--text-lg);font-weight:700;letter-spacing:-.01em;margin-top:4px}.section-stat{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-bottom:2px}.chart-wrap{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-3) var(--space-3)}.chart-tooltip{background:var(--color-bg-overlay);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3)}.chart-tooltip__label{margin-bottom:4px}.chart-tooltip__value{font-size:var(--text-sm);font-weight:700}.chart-legend{display:flex;gap:var(--space-4);margin-top:var(--space-3);padding-left:var(--space-2)}.legend-item{display:flex;align-items:center;gap:6px;font-size:var(--text-xs);color:var(--color-text-secondary)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.photo-thumb{aspect-ratio:3/4;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.photo-thumb__placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3)}.photo-thumb__note{font-size:var(--text-xs);color:var(--color-text-tertiary);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.photo-form{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4)}.photo-form__preview{width:100%;max-height:240px;object-fit:cover;border-radius:var(--radius-lg);border:1px solid var(--color-border)}.progress-loading{display:flex;flex-direction:column;gap:var(--space-4)}@media (min-width: 1024px){.stats-row{grid-template-columns:repeat(4,1fr)}}.photo-carousel{width:100%;-webkit-user-select:none;user-select:none}.photo-carousel__track{position:relative;height:420px;display:flex;align-items:center;justify-content:center;perspective:1200px;overflow:hidden;cursor:grab}.photo-carousel__track:active{cursor:grabbing}.photo-carousel__card{position:absolute;width:min(300px,75vw);height:380px;border-radius:var(--radius-xl);transform-style:preserve-3d;will-change:transform;box-shadow:0 12px 40px #0000004d}.photo-carousel__overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--space-5);background:linear-gradient(transparent,#000000a6);border-radius:0 0 var(--radius-xl) var(--radius-xl);color:#fff;transform-style:flat}.photo-carousel__date{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600}.photo-carousel__notes{font-size:var(--text-xs);opacity:.8;margin-top:2px}.photo-carousel__dots{display:flex;justify-content:center;gap:8px;margin-top:var(--space-5)}.photo-carousel__dot{width:8px;height:8px;border-radius:50%;background:var(--color-accent);border:none;cursor:pointer;padding:0}.photo-carousel__nav{display:none}@media (min-width: 768px){.photo-carousel__nav{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-top:var(--space-4)}}.photo-carousel__nav-btn{background:var(--color-bg-raised);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);cursor:pointer;font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--color-text-secondary);transition:all .12s ease}.photo-carousel__nav-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.photo-carousel__nav-btn:disabled{opacity:.3;cursor:default}.photo-carousel__delete-btn{background:#ffffff26;border:none;border-radius:var(--radius-md);padding:6px;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .12s ease}.photo-carousel__delete-btn:hover{background:#dc262699}.photo-carousel__confirm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xl);z-index:20}.photo-carousel__confirm-box{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);width:min(280px,85%)}.btn--danger{background:var(--color-danger);color:#fff;border:none}.profile-page{padding-top:var(--space-8)}.profile-header{display:flex;align-items:flex-start;margin-bottom:var(--space-6)}.profile-title{font-size:var(--text-3xl);font-weight:700;letter-spacing:-.02em;margin-top:var(--space-1)}.profile-email{font-size:var(--text-sm);color:var(--color-text-tertiary);margin-top:4px;font-family:var(--font-mono)}.onboarding-banner{display:flex;gap:var(--space-4);align-items:flex-start;background:var(--color-accent-dim);border:1px solid rgba(232,160,32,.2);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-5);font-size:var(--text-sm);color:var(--color-text-secondary)}.onboarding-banner span{font-size:1.5rem;flex-shrink:0}.profile-tabs{display:flex;gap:4px;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:4px;margin-bottom:var(--space-6);overflow-x:auto;-webkit-overflow-scrolling:touch}.profile-tab{font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;padding:10px 14px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-tertiary);cursor:pointer;transition:all var(--duration-fast);white-space:nowrap;flex:1}.profile-tab.active{background:var(--color-bg-overlay);color:var(--color-accent)}.profile-section{margin-bottom:var(--space-5)}.profile-section-header{margin-bottom:var(--space-4)}.profile-section-title{font-size:var(--text-lg);font-weight:700;letter-spacing:-.01em;margin-top:4px}.profile-section-body{display:flex;flex-direction:column;gap:var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);overflow:hidden}input[type=date]{font-size:16px;width:100%;max-width:100%;min-width:0;box-sizing:border-box}.profile-field{display:flex;flex-direction:column;gap:var(--space-1)}.profile-field__label{margin-bottom:4px}.field-hint{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-top:4px}.profile-photo-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3);background:var(--color-bg-overlay);border:1px solid var(--color-border);border-radius:var(--radius-md)}.profile-photo-card__preview{width:72px;height:72px;border-radius:20px;background:color-mix(in srgb,var(--color-accent) 12%,var(--color-bg-raised));border:1px solid color-mix(in srgb,var(--color-accent) 35%,var(--color-border));display:flex;align-items:center;justify-content:center;color:var(--color-accent);font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;overflow:hidden;flex-shrink:0}.profile-photo-card__image{width:100%;height:100%;object-fit:cover}.profile-photo-card__body{min-width:0;flex:1}.profile-photo-card__title{font-size:var(--text-base);font-weight:700;margin-bottom:4px}.profile-photo-card__sub{font-size:var(--text-sm);color:var(--color-text-secondary)}.profile-photo-card__actions{display:flex;gap:var(--space-2);margin-top:var(--space-3);flex-wrap:wrap}.profile-photo-btn{flex:1;min-width:0;text-align:center;justify-content:center}@media (max-width: 767px){.profile-photo-card{flex-direction:column;align-items:flex-start}.profile-photo-card__body{width:100%}.profile-photo-card__actions{flex-direction:column}.profile-photo-btn{width:100%;flex:none}}.segmented{display:flex;gap:2px;background:var(--color-bg-overlay);border-radius:var(--radius-md);padding:3px}.segmented__btn{flex:1;font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;padding:7px 8px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast)}.segmented__btn.active{background:var(--color-bg-elevated);color:var(--color-accent)}.activity-list{display:flex;flex-direction:column;gap:var(--space-2)}.activity-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--color-bg-overlay);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast);text-align:left;width:100%}.activity-item.active{border-color:var(--color-accent);background:var(--color-accent-dim)}.activity-item__label{font-size:var(--text-sm);font-weight:600;color:var(--color-text-primary)}.activity-item__sub{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-top:2px}.tdee-card{background:var(--color-bg-overlay);border:1px solid var(--color-accent-dim);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.tdee-card__row{display:flex;justify-content:space-between;align-items:center}.water-presets{display:flex;gap:var(--space-2)}.preset-btn{flex:1;font-size:var(--text-sm);font-weight:700;padding:8px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-overlay);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast)}.preset-btn.active{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-dim)}.notif-card{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4)}.notif-enabled{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-success);flex-shrink:0}.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--color-success);animation:pulse-glow 2s infinite}.home-screen-steps{display:flex;flex-direction:column;gap:var(--space-2)}.profile-toggle-row{display:flex;align-items:center;justify-content:space-between;font-size:var(--text-sm);color:var(--color-text-secondary)}.token-reveal{display:flex;flex-direction:column;gap:var(--space-2)}.token-box{display:flex;align-items:center;gap:var(--space-3);background:var(--color-bg-overlay);border:1px solid var(--color-warning);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);overflow:hidden}.token-value{font-size:var(--text-xs);color:var(--color-text-primary);word-break:break-all;flex:1;letter-spacing:.02em}.token-list{margin-top:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.token-item{display:flex;align-items:center;justify-content:space-between;background:var(--color-bg-overlay);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}.profile-app-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.invite-form{display:flex;gap:var(--space-3);align-items:flex-start}.invite-form input{flex:1}@media (max-width: 767px){.profile-header{align-items:center}.notif-card,.profile-photo-card,.profile-app-meta,.token-box,.invite-form{flex-direction:column;align-items:stretch}}.avatar-crop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000b8;display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.avatar-crop-modal{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);width:min(340px,100%);display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.avatar-crop-modal__title{font-size:var(--text-lg);font-weight:700;color:var(--color-text-primary);align-self:flex-start}.avatar-crop-modal__hint{font-size:var(--text-xs);color:var(--color-text-tertiary);align-self:flex-start;margin-top:-12px}.avatar-crop-viewport{border-radius:50%;overflow:hidden;border:2px solid var(--color-border)}.avatar-crop-canvas{display:block;cursor:grab;touch-action:none}.avatar-crop-canvas:active{cursor:grabbing}.avatar-crop-zoom{display:flex;align-items:center;gap:var(--space-3);width:100%}.avatar-crop-zoom__label{font-size:var(--text-xs);color:var(--color-text-tertiary);white-space:nowrap}.avatar-crop-zoom__val{font-size:var(--text-xs);color:var(--color-text-tertiary);min-width:32px;text-align:right}.history-filters{position:sticky;top:0;z-index:20;background:var(--color-bg);padding:var(--space-2) 0;margin-left:calc(-1 * var(--space-5));margin-right:calc(-1 * var(--space-5));padding-left:var(--space-5);padding-right:var(--space-5);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-4);overflow-x:auto;scrollbar-width:none;display:flex;gap:var(--space-2);flex-wrap:nowrap}.history-filters::-webkit-scrollbar{display:none}.history-filter{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;padding:var(--space-2) var(--space-4);border:1.5px solid var(--color-border);border-radius:var(--radius-full);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast)}.history-filter.active{background:var(--color-accent-dim);border-color:var(--color-accent);color:var(--color-accent)}.history-day{margin-bottom:var(--space-6)}.history-day__label{margin-bottom:var(--space-3)}.history-day__entries{display:flex;flex-direction:column;gap:2px;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.history-entry{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);transition:background var(--duration-fast)}.history-entry:last-child{border-bottom:none}.history-entry:hover{background:var(--color-bg-elevated)}.history-entry__icon{font-size:1.25rem;flex-shrink:0;width:28px;text-align:center}.history-entry__text{flex:1;min-width:0}.history-entry__label{font-family:var(--font-display);font-size:var(--text-base);font-weight:600;color:var(--color-text-primary);white-space:normal;word-break:break-word;overflow:visible}.history-entry__sub{font-size:var(--text-sm);color:var(--color-text-tertiary);margin-top:2px}.history-entry__actions{display:flex;gap:var(--space-2);flex-shrink:0}.history-btn{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;padding:4px 10px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all var(--duration-fast)}.history-btn--edit{background:var(--color-accent-dim);color:var(--color-accent)}.history-btn--edit:hover{background:var(--color-accent);color:var(--color-bg)}.history-btn--delete{background:#b840401a;color:var(--color-danger)}.history-btn--delete:hover{background:var(--color-danger);color:#fff}.fl-search-wrap{margin-bottom:var(--space-4)}.fl-search{width:100%;background:var(--color-bg-raised);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);font-family:var(--font-display);font-size:var(--text-base);color:var(--color-text-primary);outline:none;transition:border-color var(--duration-fast)}.fl-search:focus{border-color:var(--color-accent)}.fl-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-5)}.fl-filters{display:flex;gap:var(--space-2);flex-wrap:wrap}.fl-filter{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;padding:var(--space-2) var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-full);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast)}.fl-filter.active{background:var(--color-accent-dim);border-color:var(--color-accent);color:var(--color-accent)}.fl-list{display:flex;flex-direction:column;gap:var(--space-3)}.fl-card{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4)}.fl-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-3)}.fl-card__name{font-family:var(--font-display);font-size:var(--text-base);font-weight:800;color:var(--color-text-primary)}.fl-card__brand{font-size:var(--text-sm);color:var(--color-text-tertiary);margin-top:2px}.fl-card__badge{font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;padding:2px 8px;border-radius:var(--radius-full);flex-shrink:0}.fl-card__badge--whole,.fl-card__badge--packaged{background:color-mix(in srgb,var(--module-activity) 15%,transparent);color:var(--module-activity)}.fl-card__macros{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-3)}.fl-macro{font-size:var(--text-sm);color:var(--color-text-secondary)}.fl-macro strong{color:var(--color-text-primary)}.fl-macro--label{color:var(--color-text-tertiary);font-size:var(--text-xs);align-self:flex-end}.fl-card__logged{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-bottom:var(--space-3)}.fl-card__actions{display:flex;gap:var(--space-2)}.signin-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:radial-gradient(ellipse 60% 40% at 50% 0%,rgba(232,160,32,.08) 0%,transparent 70%),var(--color-bg)}.signin-card{width:100%;max-width:360px;display:flex;flex-direction:column;gap:var(--space-3)}.signin-logo{font-size:var(--text-sm);letter-spacing:.2em;margin-bottom:var(--space-2)}.signin-title{font-size:clamp(2.5rem,8vw,3.5rem);font-weight:800;letter-spacing:-.03em;line-height:1.05;color:var(--color-text-primary)}.signin-sub{font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.5;margin-bottom:var(--space-2)}.signin-form{display:flex;flex-direction:column;gap:var(--space-3)}.signin-sent{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-3);margin-top:var(--space-4)}.signin-sent p{color:var(--color-text-secondary);font-family:var(--font-display);font-size:var(--text-base)}.signin-options{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-2)}.signin-google{min-height:52px}.signin-google__icon{display:inline-flex;align-items:center;justify-content:center}.signin-divider{display:flex;align-items:center;gap:var(--space-3);color:var(--color-text-tertiary);font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;letter-spacing:.06em;text-transform:uppercase}.signin-divider:before,.signin-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}:root{--font-display: "Inter", -apple-system, sans-serif;--font-body: "Inter", -apple-system, sans-serif;--font-mono: "SF Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-hero: 2.75rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 18px;--radius-full: 9999px;--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--duration-fast: .12s;--duration-base: .33s;--duration-slow: .33s;--nav-height: 64px;--max-width: 480px;--max-width-desk: 1200px;--safe-bottom: env(safe-area-inset-bottom, 0px)}:root,[data-theme=light]{--color-bg: #FFFFFF;--color-bg-raised: #F4F4F4;--color-bg-elevated: #EBEBEB;--color-bg-overlay: #E0E0E0;--color-border: rgba(0, 0, 0, .08);--color-border-strong: rgba(0, 0, 0, .16);--color-accent: #1D6AE5;--color-accent-dim: rgba(29, 106, 229, .1);--color-accent-glow: rgba(29, 106, 229, .2);--color-text-primary: #171A20;--color-text-secondary: #393C41;--color-text-tertiary: #6B6E74;--color-text-accent: #1D6AE5;--color-success: #059669;--color-success-dim: rgba(5, 150, 105, .1);--color-warning: #D97706;--color-danger: #DC2626;--color-info: #1D6AE5;--module-activity: #1D6AE5;--module-recovery: #7C3AED;--module-log: #059669;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.1);--shadow-accent: 0 0 24px rgba(29,106,229,.18);color-scheme:light}[data-theme=dark]{--color-bg: #0D0D0D;--color-bg-raised: #161616;--color-bg-elevated: #1E1E1E;--color-bg-overlay: #252525;--color-border: rgba(255, 255, 255, .08);--color-border-strong: rgba(255, 255, 255, .14);--color-accent: #4D9FFF;--color-accent-dim: rgba(77, 159, 255, .12);--color-accent-glow: rgba(77, 159, 255, .22);--color-text-primary: #F5F5F5;--color-text-secondary: #A0A0A0;--color-text-tertiary: #6B6B6B;--color-text-accent: #4D9FFF;--color-success: #34D399;--color-success-dim: rgba(52, 211, 153, .12);--color-warning: #FBBF24;--color-danger: #F87171;--color-info: #4D9FFF;--module-activity: #4D9FFF;--module-recovery: #A78BFA;--module-log: #34D399;--shadow-sm: 0 1px 3px rgba(0,0,0,.5);--shadow-md: 0 4px 16px rgba(0,0,0,.6);--shadow-lg: 0 8px 32px rgba(0,0,0,.7);--shadow-accent: 0 0 24px rgba(77,159,255,.22);color-scheme:dark}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);font-size:var(--text-base);font-weight:400;line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg);min-height:100dvh;overscroll-behavior:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--duration-base) var(--ease-smooth),color var(--duration-base) var(--ease-smooth)}#root{min-height:100dvh;display:flex;flex-direction:column}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:4px}::selection{background:var(--color-accent-dim);color:var(--color-accent)}.font-display{font-family:var(--font-display)}.font-mono{font-family:var(--font-mono);font-weight:500}.font-body{font-family:var(--font-body)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-accent{color:var(--color-accent)}.module-label{font-family:var(--font-display);font-size:var(--text-sm);font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-tertiary)}.page-label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-tertiary);margin-bottom:var(--space-4)}.metric-hero{font-family:var(--font-display);font-size:var(--text-hero);font-weight:600;line-height:1;letter-spacing:-.02em}.metric-large{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:600;line-height:1;letter-spacing:-.01em}.metric-unit{font-family:var(--font-display);font-size:var(--text-sm);font-weight:400;color:var(--color-text-secondary);margin-left:3px}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-4)}.page{flex:1;overflow-y:auto;padding-top:max(var(--space-6),env(safe-area-inset-top,0px));padding-left:var(--space-4);padding-right:var(--space-4);padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + var(--space-6));max-width:860px;margin:0 auto;width:100%}.card{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);transition:border-color var(--duration-base) var(--ease-smooth),background-color var(--duration-base) var(--ease-smooth)}.card:hover{border-color:var(--color-border-strong)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-display);font-size:var(--text-base);font-weight:700;letter-spacing:.01em;border:none;border-radius:var(--radius-md);padding:var(--space-3) var(--space-5);min-height:48px;cursor:pointer;transition:all var(--duration-fast) var(--ease-smooth);-webkit-user-select:none;user-select:none;white-space:nowrap}.btn--primary{background:var(--color-accent);color:var(--color-bg)}.btn--primary:hover{filter:brightness(1.08)}.btn--primary:active{transform:scale(.97)}.btn--ghost{background:transparent;color:var(--color-text-secondary);border:1.5px solid var(--color-border)}.btn--ghost:hover{border-color:var(--color-border-strong);color:var(--color-text-primary)}.btn--sm{font-size:var(--text-sm);padding:var(--space-2) var(--space-4);min-height:40px}.btn--full{width:100%}.streak-badge{display:inline-flex;align-items:center;gap:var(--space-1);font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;padding:4px 10px;border-radius:var(--radius-full);background:var(--color-accent-dim);color:var(--color-accent);border:1px solid var(--color-accent-dim)}.ring-container{position:relative;display:inline-flex;align-items:center;justify-content:center}.ring-container svg{transform:rotate(-90deg)}.divider{height:1px;background:var(--color-border);border:none;margin:var(--space-4) 0}.bottom-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:100;animation:fadeIn var(--duration-base) var(--ease-smooth)}.bottom-sheet{position:fixed;bottom:0;left:50%;transform:translate(-50%) translateY(var(--sheet-drag-offset, 0));width:100%;max-width:var(--max-width);background:var(--color-bg-elevated);border-top:1px solid var(--color-border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-6) var(--space-5);padding-bottom:calc(var(--space-6) + var(--safe-bottom));z-index:101;animation:slideUp var(--duration-slow) var(--ease-spring);max-height:96dvh;overflow-y:auto;overscroll-behavior:contain;transition:bottom var(--duration-fast) var(--ease-smooth),transform var(--duration-fast) var(--ease-smooth);will-change:transform,bottom}.bottom-sheet--dragging{transition:none}@media (min-width: 768px){.bottom-sheet{bottom:auto;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:var(--radius-xl);border:none;max-width:560px;width:90vw;max-height:88dvh;min-height:480px;animation:modalIn var(--duration-slow) var(--ease-spring);box-shadow:var(--shadow-lg);overflow-y:auto}}.bottom-sheet__handle{width:36px;height:4px;background:var(--color-border-strong);border-radius:var(--radius-full);margin:0 auto var(--space-5)}@media (min-width: 768px){.bottom-sheet__handle{display:none}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton{background:linear-gradient(90deg,var(--color-bg-raised) 25%,var(--color-bg-elevated) 50%,var(--color-bg-raised) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-sm)}.skeleton-layout{display:flex;flex-direction:column;gap:var(--space-4);padding-top:var(--space-8)}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translate(-50%) translateY(100%)}to{transform:translate(-50%) translateY(0)}}@keyframes modalIn{0%{opacity:0;transform:translate(-50%,-48%) scale(.97)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 0 0 var(--color-accent-glow)}50%{box-shadow:0 0 0 8px transparent}}@keyframes spin{to{transform:rotate(360deg)}}.animate-fade-up{animation:fadeUp var(--duration-slow) var(--ease-spring) both}.animate-fade-in{animation:fadeIn var(--duration-base) var(--ease-smooth) both}.stagger-children>*:nth-child(1){animation-delay:0ms}.stagger-children>*:nth-child(2){animation-delay:50ms}.stagger-children>*:nth-child(3){animation-delay:.1s}.stagger-children>*:nth-child(4){animation-delay:.15s}.stagger-children>*:nth-child(5){animation-delay:.2s}.stagger-children>*:nth-child(6){animation-delay:.25s}.food-form__input{background:var(--color-bg-raised);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);font-weight:500;color:var(--color-text-primary);outline:none;width:100%;min-height:48px;transition:border-color var(--duration-fast),background var(--duration-fast)}.food-form__input:focus{border-color:var(--color-accent);background:var(--color-bg-elevated)}.food-form__input::placeholder{color:var(--color-text-tertiary)}.journal-textarea{width:100%;background:var(--color-bg-raised);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);line-height:1.6;resize:none;outline:none;transition:border-color var(--duration-fast)}.journal-textarea:focus{border-color:var(--color-accent)}.journal-textarea::placeholder{color:var(--color-text-tertiary)}.hk-instructions{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4)}.hk-step{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-2) 0}.hk-step__num{background:var(--color-accent-dim);color:var(--color-accent);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;flex-shrink:0}.hk-step__text{font-size:var(--text-sm);color:var(--color-text-secondary);padding-top:3px}.hk-result{background:var(--color-success-dim);border:1px solid var(--color-success);border-radius:var(--radius-md);padding:var(--space-4);font-weight:700;color:var(--color-success);text-align:center;font-size:var(--text-base)}.empty-state{background:var(--color-bg-raised);border:1.5px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8);text-align:center;color:var(--color-text-secondary);font-size:var(--text-base);font-weight:500}@media (min-width: 768px){.container{max-width:var(--max-width-desk);padding:0 var(--space-8)}.page{padding-bottom:var(--space-10);padding-top:var(--space-8)}}
