@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap";:root{--bg:#0a0a0a;--bg-2:#111;--bg-card:#141414;--border:#1e1e1e;--border-2:#2a2a2a;--text:#f0f0f0;--text-2:#888;--text-3:#444;--accent:#2563eb;--accent-h:#1d4ed8;--accent-dim:#2563eb21;--success:#16a34a;--danger:#dc2626;--radius:5px;--radius-lg:10px;--nav-h:60px;--header-h:52px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100dvh;font-family:Space Grotesk,system-ui,sans-serif;line-height:1.5}a{color:var(--accent);text-decoration:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:1rem}ul{list-style:none}#root{flex-direction:column;min-height:100dvh;display:flex}.app-shell{flex-direction:column;width:100%;max-width:480px;min-height:100dvh;margin:0 auto;display:flex}.app-header{height:var(--header-h);border-bottom:1px solid var(--border);z-index:10;background:var(--bg);align-items:center;padding:0 16px;display:flex;position:sticky;top:0}.app-header__logo{letter-spacing:.18em;color:var(--text);font-size:.75rem;font-weight:700}.app-main{overscroll-behavior:none;padding-bottom:calc(var(--nav-h) + 24px + env(safe-area-inset-bottom));flex:1;overflow-y:auto}.bottom-nav{bottom:calc(12px + env(safe-area-inset-bottom));width:calc(100% - 32px);max-width:448px;height:var(--nav-h);-webkit-backdrop-filter:blur(60px)saturate(250%)brightness(.9);backdrop-filter:blur(60px)saturate(250%)brightness(.9);box-shadow:none;z-index:10;background:#0a0a0a26;border-top:.5px solid #ffffff0f;border-radius:22px;display:flex;position:fixed;left:50%;transform:translate(-50%)}.bottom-nav__item{color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;font-size:.65rem;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.bottom-nav__item--active,.bottom-nav__item:hover{color:var(--accent)}.btn{border-radius:var(--radius);white-space:nowrap;box-sizing:border-box;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;font-size:.9rem;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.btn--primary{background:var(--accent);color:#fff;border-color:#0000;height:42px;padding:0 20px}.btn--primary:hover:not(:disabled){background:var(--accent-h)}.btn--ghost{color:var(--text-2);border:1px solid var(--border-2);background:0 0;height:42px;padding:0 16px}.btn--ghost:hover:not(:disabled){border-color:var(--border-2);color:var(--text)}.btn--danger-ghost{color:var(--danger);background:0 0;border:1px solid #dc262659;height:42px;padding:0 16px}.btn--danger-ghost:hover:not(:disabled){background:#dc26261a}.btn--full{width:100%}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--sm{height:34px;padding:0 14px;font-size:.8rem}.btn__spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.field{flex-direction:column;gap:5px;display:flex}.field__label{color:var(--text-2);letter-spacing:.04em;text-transform:uppercase;font-size:.75rem;font-weight:500}.field__input{background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius);color:var(--text);outline:none;height:42px;padding:0 12px;transition:border-color .15s}.field__input:focus{border-color:var(--accent)}.field__input--error{border-color:var(--danger)}.field__error{color:var(--danger);font-size:.78rem}.progress-item{flex-direction:column;gap:5px;display:flex}.progress-item__header{justify-content:space-between;align-items:baseline;display:flex}.progress-item__label{color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem}.progress-item__values{font-size:.78rem}.progress-item__current{color:var(--text);font-weight:500}.progress-item__current--over{color:var(--danger);font-weight:500}.progress-item__goal{color:var(--text-3)}.progress-track{background:var(--border-2);border-radius:2px;height:3px;overflow:hidden}.progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .3s}.progress-fill--over{background:var(--danger)}.auth-page{justify-content:center;align-items:center;min-height:100dvh;padding:24px 16px;display:flex}.auth-card{flex-direction:column;gap:20px;width:100%;max-width:360px;display:flex}.auth-logo{letter-spacing:.2em;color:var(--text);font-size:.85rem;font-weight:700}.auth-subtitle{color:var(--text-2);margin-top:-12px;font-size:.95rem}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-error{color:var(--danger);border-radius:var(--radius);background:#dc262614;border:1px solid #dc262633;padding:10px 12px;font-size:.82rem}.auth-switch{color:var(--text-2);font-size:.82rem}.auth-switch a{color:var(--accent)}.page-loading,.diary-loading{text-align:center;color:var(--text-3);padding:48px 16px;font-size:.85rem}.diary-page{min-height:calc(100dvh - var(--header-h) - var(--nav-h));padding:0 0 24px}.date-nav{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.date-nav__arrow{color:var(--text-2);border-radius:var(--radius);padding:6px 10px;font-size:1rem;transition:color .15s}.date-nav__arrow:hover{color:var(--text)}.date-nav__label{cursor:pointer;font-size:.9rem;font-weight:500;position:relative}.date-nav__input{opacity:0;width:0;height:0;position:absolute;top:0;left:50%}.day-summary{border-bottom:1px solid var(--border);flex-direction:column;gap:12px;padding:16px;display:flex}.day-cal-compact{font-size:.82rem}.day-cal-compact__val{color:var(--text);font-weight:600}.day-cal-compact__sep{color:var(--text-3)}.day-cal-compact__goal{color:var(--text-2)}.day-summary__bars{flex-direction:column;gap:8px;display:flex}.meals-list{flex-direction:column;gap:8px;padding:8px 12px 12px;display:flex}.meal-section{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.meal-section__header,.meal-item{grid-template-columns:1fr 40px 40px 40px 44px 24px;column-gap:8px;width:100%;padding:10px 12px 10px 16px;display:grid}.meal-section__header{cursor:pointer;align-items:center;transition:background .12s}@media (hover:hover){.meal-section__header:hover{background:#1c1c1c}}.meal-item{border-top:1px solid var(--border);align-items:end}.meal-section__name{letter-spacing:.1em;text-transform:uppercase;color:var(--text-2);font-size:.72rem;font-weight:600}.meal-hdr-col{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.meal-hdr-col__lbl{letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);font-size:.6rem;font-weight:700;line-height:1}.meal-hdr-col__val{color:var(--text-2);white-space:nowrap;font-size:.82rem;font-weight:600;line-height:1.2}.meal-chevron{color:var(--text-3);justify-self:end;line-height:0;transition:transform .2s}.meal-chevron--collapsed{transform:rotate(-90deg)}.meal-items{flex-direction:column;display:flex}.meal-item__info{flex-direction:column;align-self:start;gap:2px;min-width:0;display:flex}.meal-item__name{white-space:normal;font-size:.88rem;font-weight:500}.meal-item__grams{color:var(--text-2);font-size:.75rem}.meal-col{color:var(--text-3);text-align:right;white-space:nowrap;font-size:.78rem}.meal-item--clickable{cursor:pointer;transition:background .12s}@media (hover:hover){.meal-item--clickable:hover{background:var(--bg-2)}}.meal-add-btn{text-align:left;width:100%;color:var(--text-3);border-top:1px solid var(--border);padding:10px 16px;font-size:.8rem;transition:color .15s;display:block}@media (hover:hover){.meal-add-btn:hover{color:var(--accent)}}.modal-overlay{z-index:50;background:#000000b3;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media (height>=600px){.modal-overlay{align-items:center}}.modal{background:var(--bg-card);border:1px solid var(--border-2);border-radius:var(--radius-lg) var(--radius-lg) 0 0;flex-direction:column;width:100%;min-width:0;max-width:480px;max-height:85dvh;display:flex;overflow:hidden}@media (height>=600px){.modal{border-radius:var(--radius-lg);max-height:80dvh}}.modal__header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;font-size:.88rem;font-weight:500;display:flex}.modal__close{color:var(--text-3);padding:4px 6px;font-size:.9rem;transition:color .15s}.modal__close:hover{color:var(--text)}.modal__search{border-bottom:1px solid var(--border);flex-shrink:0;padding:12px 16px;position:relative}.search-input{background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius);width:100%;color:var(--text);outline:none;height:40px;padding:0 44px 0 12px}.search-input:focus{border-color:var(--accent)}.search-camera-btn{color:var(--text-3);padding:4px;line-height:0;transition:color .15s;position:absolute;top:50%;right:24px;transform:translateY(-50%)}.search-camera-btn:hover{color:var(--accent)}.search-spinner{border:2px solid var(--border-2);border-top-color:var(--accent);border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:block;position:absolute;top:50%;right:28px;transform:translateY(-50%)}.modal__results{flex:1;padding:4px 0 12px;overflow-y:auto}.results-group-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);padding:10px 16px 4px;font-size:.68rem;font-weight:600}.results-group-label--basic{color:#a78bfa}.results-group-label--vv{color:#4ade80}.results-empty,.results-hint{color:var(--text-3);text-align:center;padding:24px 16px;font-size:.85rem}.recent-row{border-bottom:1px solid var(--border);align-items:center;display:flex}.recent-row:last-child{border-bottom:none}.recent-row--adding{opacity:.55}.recent-row__info{text-align:left;cursor:pointer;min-width:0;color:var(--text);background:0 0;flex:1;padding:10px 8px 10px 16px;transition:background .12s}.recent-row--adding .recent-row__info{cursor:default}@media (hover:hover){.recent-row:not(.recent-row--adding) .recent-row__info:hover{background:var(--bg-2)}}.recent-row__name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;overflow:hidden}.recent-row__brand{color:var(--text-3);font-weight:400}.recent-row__sub{color:var(--text-3);margin-top:2px;font-size:.78rem}.spin-icon{animation:.7s linear infinite spin}.food-row{border-bottom:1px solid var(--border);align-items:center;width:100%;display:flex}.food-row:last-child{border-bottom:none}.food-row__info{text-align:left;min-width:0;color:var(--text);flex:1;padding:10px 8px 10px 16px;transition:background .12s}@media (hover:hover){.food-row__info:hover{background:var(--accent-dim)}}.food-row__checkbox{color:var(--border-2);flex-shrink:0;align-items:center;padding:10px 14px;transition:color .12s;display:flex}.food-row__checkbox--checked{color:var(--accent)}@media (hover:hover){.food-row__checkbox:hover:not(.food-row__checkbox--checked){color:var(--text-3)}}.food-row__name{color:var(--text);font-size:.88rem;font-weight:500}.food-row__brand{color:var(--text-3);font-weight:400}.modal__bulk-bar{border-top:1px solid var(--border);flex-shrink:0;padding:8px 16px}.bulk-add-btn{background:var(--accent);color:#fff;border-radius:var(--radius);width:100%;padding:12px;font-size:.9rem;font-weight:600;transition:background .15s}@media (hover:hover){.bulk-add-btn:hover{background:var(--accent-h)}}.bulk-add-btn:disabled{opacity:.6;cursor:default}.brand-field{flex-direction:column;gap:4px;display:flex;position:relative}.brand-suggestions{z-index:100;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);position:absolute;top:calc(100% + 2px);left:0;right:0;overflow:hidden;box-shadow:0 4px 16px #0006}.brand-suggestion{text-align:left;width:100%;color:var(--text);border-bottom:1px solid var(--border);padding:9px 12px;font-size:.85rem;transition:background .1s}.brand-suggestion:last-child{border-bottom:none}@media (hover:hover){.brand-suggestion:hover{background:var(--accent-dim);color:var(--accent)}}.food-macros{color:var(--text-3);gap:8px;margin-top:3px;font-size:.72rem;display:flex}.modal__confirm{flex-direction:column;gap:16px;min-width:0;padding:20px;display:flex;overflow-y:auto}.confirm-food-name{font-size:1rem;font-weight:600}.confirm-food-base{align-items:center;gap:8px;display:flex}.confirm-food-base__label{color:var(--text-3);font-size:.72rem}.unit-selector{border-radius:var(--radius);border:1px solid var(--border-2);display:flex;overflow:hidden}.unit-btn{color:var(--text-2);background:var(--bg-2);flex:1;padding:8px 4px;font-size:.82rem;transition:background .12s,color .12s}.unit-btn--active{background:var(--accent);color:#fff}.unit-selector--sm{flex-shrink:0;min-width:80px}.confirm-grams{flex-direction:column;gap:5px;display:flex}.confirm-grams__input{text-align:center;max-width:150px;font-size:1.1rem}.confirm-serving{flex-direction:column;gap:5px;display:flex}.confirm-serving__row{align-items:center;gap:8px;display:flex}.confirm-serving__row .field__input{flex:1;min-width:0}.confirm-preview{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px}.confirm-preview__calories{font-size:1.4rem;font-weight:600}.confirm-preview__macros{color:var(--text-2);margin-top:2px;font-size:.82rem}.confirm-actions{gap:10px;display:flex}.confirm-actions .btn:last-child{flex:1}.confirm-food-header{align-items:flex-start;gap:10px;display:flex}.edit-food-btn{color:var(--text-3);border-radius:var(--radius);flex-shrink:0;margin-top:2px;padding:6px;transition:color .15s,background .15s}.edit-food-btn:hover{color:var(--accent);background:var(--accent-dim)}.edit-food-panel{flex-direction:column;gap:14px;display:flex}.modal__create-row{border-top:1px solid var(--border);flex-shrink:0;padding:10px 16px 14px}.create-food-btn{border:1px dashed var(--border);border-radius:var(--radius);width:100%;color:var(--text-2);cursor:pointer;background:0 0;padding:10px;font-size:.85rem;transition:border-color .15s,color .15s}.create-food-btn:hover{border-color:var(--accent);color:var(--accent)}.csv-import-modal{max-height:70dvh}.csv-import-body{flex-direction:column;gap:16px;padding:20px;display:flex;overflow-y:auto}.csv-import-body--center{justify-content:center;align-items:center;min-height:160px}.csv-import-hint{color:var(--text-2);font-size:.85rem;line-height:1.5}.csv-import-filebtn{align-self:flex-start}.csv-import-stats{gap:12px;display:flex}.csv-import-stat{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);text-align:center;flex:1;padding:12px}.csv-import-stat__val{color:var(--accent);font-size:1.6rem;font-weight:700;display:block}.csv-import-stat__lbl{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}.csv-import-params{flex-wrap:wrap;gap:6px;display:flex}.csv-import-param{background:var(--accent-dim);color:var(--accent);border-radius:4px;padding:3px 8px;font-size:.78rem;font-weight:500}.csv-import-dates-preview{color:var(--text-2);font-size:.82rem}.csv-import-dates-preview__label{color:var(--text-3);margin-right:4px;font-weight:500}.csv-import-year{flex-direction:column;gap:8px;display:flex}.csv-import-year__btns{gap:8px;display:flex}.csv-import-progress{flex-direction:column;align-items:center;gap:8px;width:100%;display:flex}.csv-import-progress__bar{background:var(--border);border-radius:3px;width:100%;height:6px;overflow:hidden}.csv-import-progress__fill{background:var(--accent);border-radius:3px;height:100%;transition:width .2s}.csv-import-progress__label{color:var(--text-3);font-size:.85rem}.csv-import-done{flex-direction:column;align-items:center;gap:10px;display:flex}.csv-import-done__icon{background:var(--success);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.4rem;font-weight:700;display:flex}.csv-import-done__text{text-align:center;color:var(--text);font-size:.95rem}.profile-page{flex-direction:column;padding:0 0 24px;display:flex}.profile-section{border-bottom:1px solid var(--border);flex-direction:column;gap:12px;padding:20px;display:flex}.profile-user__name{font-size:1.05rem;font-weight:600}.profile-user__email{color:var(--text-2);margin-top:2px;font-size:.83rem}.section-title{letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);font-size:.72rem;font-weight:600}.goals-form{flex-direction:column;gap:14px;display:flex}.goals-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.goals-grid>*{min-width:0}.macro-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.macro-grid>*{min-width:0}.macro-grid__wide{grid-column:1/-1}.calories-field{flex-direction:column;gap:6px;display:flex}.calories-reset{color:var(--accent);align-self:flex-start;padding:2px 0;font-size:.75rem}.save-success{color:var(--success);border-radius:var(--radius);background:#16a34a14;border:1px solid #16a34a33;padding:10px 12px;font-size:.82rem}.export-types{flex-direction:column;gap:6px;display:flex}.export-type-btn{text-align:left;border-radius:var(--radius);background:var(--bg-2);width:100%;color:var(--text-2);border:1px solid #0000;padding:10px 14px;font-size:.88rem;transition:background .12s,color .12s,border-color .12s}.export-type-btn--active{background:var(--accent-dim);color:var(--accent);border-color:#2563eb40}.export-date-field{margin-top:4px}.export-period-chips{gap:8px;margin-top:4px;display:flex}.export-chip{text-align:center;background:var(--bg-2);color:var(--text-2);border-radius:var(--radius);border:1px solid #0000;flex:1;padding:9px;font-size:.85rem;transition:background .12s,color .12s}.export-chip--active{background:var(--accent-dim);color:var(--accent);border-color:#2563eb40}.export-error{color:var(--danger);font-size:.82rem}.diary-export-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;padding:8px 16px;display:flex}.diary-export-period{align-items:center;gap:6px;display:flex}.diary-export-btn{color:var(--text-2);border:1px solid var(--border-2);border-radius:var(--radius);cursor:pointer;white-space:nowrap;background:0 0;align-items:center;gap:5px;padding:6px 10px;font-size:.8rem;line-height:1;transition:color .15s,border-color .15s;display:flex}.diary-export-btn:hover:not(:disabled){color:var(--text);border-color:var(--text-2)}.diary-export-btn:disabled{opacity:.45;cursor:not-allowed}.diary-export-chip{border-radius:var(--radius);background:var(--bg-2);color:var(--text-2);cursor:pointer;white-space:nowrap;border:1px solid #0000;padding:5px 10px;font-size:.78rem;transition:background .12s,color .12s}.diary-export-chip--active{background:var(--accent-dim);color:var(--accent);border-color:#2563eb40}.scanner-overlay{z-index:100;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);background:#000;flex-direction:column;display:flex;position:fixed;inset:0}.scanner-header{background:#0000008c;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.scanner-title{color:#fff;font-size:.88rem;font-weight:500}.scanner-header .modal__close{color:#fffc}.scanner-header .modal__close:hover{color:#fff}.scanner-viewport{background:#000;flex:1;position:relative;overflow:hidden}.scanner-video{object-fit:cover;width:100%;height:100%;display:block}.scanner-frame{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.scanner-box{border:2px solid var(--accent);border-radius:6px;width:240px;height:150px;position:relative;box-shadow:0 0 0 2000px #00000080}.scanner-line{background:var(--accent);opacity:.85;height:2px;animation:2s ease-in-out infinite scan-line;position:absolute;left:4px;right:4px}@keyframes scan-line{0%{top:4px}50%{top:calc(100% - 6px)}to{top:4px}}.scanner-hint{text-align:center;color:#ffffffbf;padding:0 24px;font-size:.78rem;position:absolute;bottom:20px;left:0;right:0}.scanner-error{text-align:center;color:#fff;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:32px 20px;display:flex}.scanner-error__text{color:#ffffffb3;font-size:.88rem;line-height:1.5}.page-loader{text-align:center;color:var(--text-3);padding:40px 20px;font-size:.88rem}.profile-hint{color:var(--text-3);margin-bottom:10px;font-size:.82rem;line-height:1.5}.day-chips{flex-wrap:wrap;gap:6px;display:flex}.day-chip{border:1px solid var(--border-2);width:40px;height:40px;color:var(--text-2);cursor:pointer;background:0 0;border-radius:50%;font-family:inherit;font-size:.8rem;font-weight:500;transition:border-color .15s,color .15s,background .15s}.day-chip:hover{border-color:var(--accent);color:var(--accent)}.day-chip--active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent);font-weight:600}.body-page{flex-direction:column;padding:0 0 24px;display:flex}.measurement-banner{background:var(--accent-dim);border-bottom:1px solid var(--accent);color:var(--accent);align-items:center;gap:10px;padding:12px 16px;font-size:.85rem;font-weight:500;line-height:1.4;display:flex}.measurements-section{border-bottom:1px solid var(--border);flex-direction:column;gap:12px;padding:16px;display:flex}.measurements-list{flex-direction:column;gap:2px;display:flex}.measurement-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 0;display:flex}.measurement-row:last-child{border-bottom:none}.measurement-row__label{color:var(--text);flex:1;font-size:.9rem}.measurement-row__input-wrap{align-items:center;gap:6px;display:flex}.measurement-row__input{text-align:right;background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius);width:90px;color:var(--text);-moz-appearance:textfield;outline:none;padding:7px 10px;font-family:inherit;font-size:1rem;transition:border-color .15s}.measurement-row__input::-webkit-inner-spin-button{-webkit-appearance:none}.measurement-row__input::-webkit-outer-spin-button{-webkit-appearance:none}.measurement-row__input:focus{border-color:var(--accent)}.measurement-row__unit{color:var(--text-3);width:20px;font-size:.8rem}.measurements-footer{justify-content:flex-end;align-items:center;gap:12px;padding-top:4px;display:flex}.measurements-saved{color:var(--success);font-size:.82rem}.chart-section{flex-direction:column;gap:12px;padding:16px;display:flex}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px 8px 8px;overflow:hidden}.weight-chart{width:100%;height:auto;display:block}.chart-empty{color:var(--text-3);text-align:center;padding:24px 16px;font-size:.83rem}.workouts-page{flex-direction:column;padding:0 0 24px;display:flex}.workout-form-section{flex-direction:column;gap:16px;padding:16px;display:flex}.workout-types{flex-wrap:wrap;gap:8px;display:flex}.workout-type-chip{border:1px solid var(--border-2);color:var(--text-2);cursor:pointer;background:0 0;border-radius:20px;padding:7px 16px;font-family:inherit;font-size:.85rem;transition:border-color .15s,color .15s,background .15s}.workout-type-chip:hover{border-color:var(--accent);color:var(--accent)}.workout-type-chip--active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent);font-weight:500}.workout-notes{resize:vertical;background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius);width:100%;min-height:80px;color:var(--text);outline:none;padding:10px 12px;font-family:inherit;font-size:.9rem;line-height:1.5;transition:border-color .15s}.workout-notes:focus{border-color:var(--accent)}.workout-notes::placeholder{color:var(--text-3)}.workout-form-actions{justify-content:flex-end;gap:10px;display:flex}.workout-card__type{color:var(--accent);font-size:1rem;font-weight:600}.workout-card__actions{gap:4px;display:flex}.workout-card__notes{color:var(--text-2);white-space:pre-wrap;font-size:.88rem;line-height:1.55}.icon-btn{border-radius:var(--radius);width:32px;height:32px;color:var(--text-3);justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.icon-btn:hover{color:var(--text);background:var(--bg-2)}.icon-btn--danger:hover{color:var(--danger);background:#dc26261a}.workout-cal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;margin:8px 12px 4px;padding:16px;overflow:hidden}.cal-month-nav{justify-content:space-between;align-items:center;padding:0 0 8px;display:flex}.cal-month-label{font-size:1rem;font-weight:600}.cal-weekdays{grid-template-columns:repeat(7,1fr);padding:0 0 4px;display:grid}.cal-weekday{text-align:center;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);padding:4px 0;font-size:.68rem;font-weight:600}.cal-grid{grid-template-columns:repeat(7,1fr);gap:2px;padding:0;display:grid}.cal-day{aspect-ratio:1;border-radius:var(--radius);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;transition:background .12s;display:flex;position:relative}@media (hover:hover){.cal-day:hover{background:var(--bg-2)}}.cal-day--empty{pointer-events:none}.cal-day__num{color:#f0f0f0;font-size:.85rem;line-height:1}.cal-day--today:not(.cal-day--selected) .cal-day__num{color:var(--accent);font-weight:700}.cal-day--selected{background:#2563eb33}.cal-day--selected .cal-day__num{color:var(--accent);font-weight:600}@media (hover:hover){.cal-day--selected:hover{background:#2563eb4d}}.cal-day__dot{background:var(--accent);border-radius:50%;width:4px;height:4px;position:absolute;bottom:5px;left:50%;transform:translate(-50%)}.workout-detail{border-top:1px solid var(--border);flex-direction:column;gap:12px;padding:14px 16px 24px;display:flex}.workout-detail__date{letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);font-size:.8rem;font-weight:600}.workout-detail__form,.workout-detail__card{flex-direction:column;gap:10px;display:flex}.workout-detail__card-header{justify-content:space-between;align-items:center;display:flex}.workout-detail__empty{display:flex}.history-section{flex-direction:column;gap:12px;padding:16px;display:flex}.history-tabs{background:var(--bg-2);border-radius:var(--radius);gap:2px;padding:3px;display:flex}.history-tab{border-radius:calc(var(--radius) - 1px);color:var(--text-2);flex:1;padding:6px 0;font-size:.85rem;font-weight:500;transition:background .15s,color .15s}.history-tab--active{background:var(--bg-card);color:var(--text)}.period-chips{gap:6px;display:flex}.period-chip{border:1px solid var(--border-2);color:var(--text-2);border-radius:20px;padding:5px 12px;font-size:.8rem;font-weight:500;transition:border-color .15s,color .15s,background .15s}.period-chip--active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.history-empty{text-align:center;color:var(--text-3);padding:24px 0;font-size:.85rem}.history-empty--sm{padding:8px 0;font-size:.8rem}.history-list{flex-direction:column;gap:2px;display:flex}.history-entry{border-bottom:1px solid var(--border);padding:12px 0}.history-entry:last-child{border-bottom:none}.history-entry__date{color:var(--text-2);margin-bottom:6px;font-size:.82rem}.history-entry__values{flex-wrap:wrap;gap:8px;display:flex}.history-entry__value{background:var(--bg-2);border-radius:var(--radius);align-items:baseline;gap:3px;padding:3px 8px;font-size:.82rem;display:flex}.history-entry__name{color:var(--text-2)}.history-entry__num{color:var(--text);font-weight:600}.history-entry__unit{color:var(--text-3);font-size:.75rem}.history-charts{flex-direction:column;gap:16px;display:flex}.chart-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px 12px 8px;overflow:hidden}.chart-item__header{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.chart-item__name{color:var(--text);font-size:.88rem;font-weight:600}.chart-item__last{color:var(--accent);font-size:1rem;font-weight:700}.chart-item__unit{color:var(--text-2);font-size:.75rem;font-weight:400}.chart-svg{width:100%;height:auto;display:block}.week-strip{border-bottom:1px solid var(--border);align-items:center;gap:4px;padding:8px 12px 8px 8px;display:flex}.week-strip__days{flex:1;gap:2px;display:flex}.week-strip__cal{color:var(--text-2);border-radius:var(--radius);flex-shrink:0;padding:6px;transition:color .15s,background .15s}@media (hover:hover){.week-strip__cal:hover{color:var(--text);background:var(--bg-2)}}.wday{border-radius:var(--radius);flex-direction:column;flex:1;align-items:center;gap:3px;padding:6px 2px 5px;transition:background .15s;display:flex}@media (hover:hover){.wday:hover:not(.wday--viewed){background:var(--bg-2)}}.wday__name{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-size:.65rem;font-weight:600}.wday__num{color:#f0f0f0;font-size:.82rem;font-weight:500;line-height:1}.wday__dot{background:0 0;border-radius:50%;width:4px;height:4px}.wday__dot--on{background:var(--accent)}.wday--today .wday__num{color:var(--accent)}.wday--viewed{background:var(--accent-dim,#6366f126)}.wday--viewed .wday__num{color:var(--accent);font-weight:700}.wday--viewed .wday__name{color:var(--accent)}.diary-cal-modal{width:100%;max-width:360px}.modal__title{font-size:.88rem;font-weight:500}.meal-item__delete{cursor:pointer;color:var(--text-3);background:0 0;border:none;justify-self:end;padding:4px;font-size:1.1rem;line-height:1;transition:color .15s}.meal-item__delete:hover{color:var(--danger)}@keyframes item-remove{0%{opacity:1;max-height:120px}45%{opacity:0;max-height:120px}to{opacity:0;max-height:0;padding-top:0;padding-bottom:0}}.meal-item--removing{pointer-events:none;animation:.3s forwards item-remove;overflow:hidden}.edit-entry__food{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex;overflow:hidden}.edit-entry__name{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.edit-entry__brand{color:var(--text-2);font-size:.75rem}.edit-entry__body{flex-direction:column;gap:16px;padding:16px 20px;display:flex;overflow-y:auto}.edit-entry__grams-row{flex-direction:column;gap:6px;display:flex}.edit-entry__grams-wrap{align-items:center;gap:10px;display:flex}.edit-entry__grams-wrap .field__input{flex:1;width:0;min-width:0}.edit-entry__unit{color:var(--text-2);flex-shrink:0;font-size:.9rem}.edit-entry__serving-hint{color:var(--text-3);font-size:.78rem}.edit-entry__macros{background:var(--bg-2);border-radius:var(--radius);text-align:center;grid-template-columns:repeat(4,1fr);padding:12px 8px;display:grid}.edit-entry__macro{flex-direction:column;align-items:center;gap:3px;display:flex}.edit-entry__macro-val{font-size:1rem;font-weight:600}.edit-entry__macro-label{color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;font-size:.65rem}.edit-entry__per100{flex-direction:column;gap:8px;display:flex}.edit-entry__per100-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.edit-entry__per100-grid>*{min-width:0}.edit-entry__per100-grid .field__input{width:100%}.edit-entry__cal-label-row{align-items:baseline;gap:6px;margin-bottom:4px;display:flex}.edit-entry__cal-mode{color:var(--accent);cursor:pointer;font-size:.72rem}.edit-entry__footer{flex-shrink:0;align-items:center;gap:10px;padding:12px 20px 20px;display:flex}.edit-entry__footer .btn{box-sizing:border-box;flex:1;height:44px;min-height:44px}
