@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.absolute{position:absolute}.relative{position:relative}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.flex{display:flex}.grid{display:grid}.hidden{display:none}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.line-through{text-decoration-line:line-through}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg-primary:#1e2530;--bg-secondary:#2a3240;--bg-tertiary:#242c38;--bg-elevated:#323e50;--accent-primary:#e07b54;--accent-light:#f0a882;--accent-dark:#b85a38;--text-primary:#eef2f7;--text-secondary:#89a;--text-muted:#556070;--text-on-accent:#fff;--border-subtle:#2e3a48;--border-card:#345;--status-success:#52c48a;--status-warning:#e8a844;--status-error:#e05454;--status-info:#59c;--macro-protein:#e07b54;--macro-fat:#d4a853;--macro-carbs:#59c;--text-xs:11px;--text-sm:13px;--text-base:15px;--text-md:17px;--text-lg:20px;--text-xl:24px;--text-2xl:32px;--text-3xl:42px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:22px;--radius-full:9999px;--shadow-card:0 2px 12px #00000059;--shadow-fab:0 4px 20px #e07b5466;--shadow-modal:0 8px 32px #0009;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--tg-bg:var(--bg-primary);--tg-text:var(--text-primary);--tg-hint:var(--text-secondary);--tg-btn:var(--accent-primary);--tg-btn-text:#fff;--tg-secondary-bg:var(--bg-secondary)}*,:before,:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:var(--text-base);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;margin:0;line-height:1.5;overflow-x:hidden}input,textarea,select,button{font-family:inherit}.btn-primary{background:var(--accent-primary);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:12px;justify-content:center;align-items:center;width:100%;height:52px;padding:0 24px;font-size:16px;font-weight:600;transition:background .15s,transform .1s;display:flex}.btn-primary:active{background:var(--accent-dark);transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:var(--accent-primary);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#e07b541f;border:1px solid #e07b544d;border-radius:12px;justify-content:center;align-items:center;height:52px;padding:0 20px;font-size:16px;font-weight:600;transition:background .15s,transform .1s;display:flex}.btn-secondary:active{background:#e07b5433;transform:scale(.97)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-destructive{color:var(--status-error);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#e054541f;border:1px solid #e0545440;border-radius:12px;justify-content:center;align-items:center;height:52px;padding:0 20px;font-size:16px;font-weight:600;transition:background .15s,transform .1s;display:flex}.btn-destructive:active{background:#e0545438;transform:scale(.97)}.btn-sm{height:38px;font-size:var(--text-sm);border-radius:10px;padding:0 14px}.input{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;height:48px;font-size:var(--text-base);color:var(--text-primary);appearance:none;outline:none;padding:0 14px;transition:border-color .2s,box-shadow .2s}.input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #e07b5426}.input::placeholder{color:var(--text-muted)}.input-label{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:6px;font-weight:500;display:block}.textarea{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;font-size:var(--text-base);color:var(--text-primary);resize:none;-webkit-appearance:none;outline:none;padding:12px 14px;line-height:1.5;transition:border-color .2s,box-shadow .2s}.textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #e07b5426}.textarea::placeholder{color:var(--text-muted)}.select{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;height:48px;font-size:var(--text-base);color:var(--text-primary);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238899AA' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;outline:none;padding:0 36px 0 14px;transition:border-color .2s,box-shadow .2s}.select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #e07b5426}.pill{border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:5px;height:28px;padding:0 12px;font-size:12px;font-weight:600;display:inline-flex}.pill-accent{color:var(--accent-primary);background:#e07b5426}.pill-neutral{background:var(--bg-secondary);color:var(--text-secondary)}.pill-success{color:var(--status-success);background:#52c48a26}.pill-warning{color:var(--status-warning);background:#e8a84426}.pill-error{color:var(--status-error);background:#e0545426}.pill-info{color:var(--status-info);background:#5599cc26}.macro-pill{border-radius:var(--radius-sm);height:28px;font-size:var(--text-sm);white-space:nowrap;align-items:center;gap:6px;padding:0 10px;display:flex}.macro-pill-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.macro-pill-protein{background:#e07b5426}.macro-pill-fat{background:#d4a85326}.macro-pill-carbs{background:#5599cc26}.card{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}.card-border{border:1px solid var(--border-card)}.product-card{border-radius:var(--radius-lg);cursor:pointer;-webkit-tap-highlight-color:transparent;width:100%;box-shadow:var(--shadow-card);background:var(--bg-secondary);transition:transform .1s;overflow:hidden}.product-card:active{transform:scale(.97)}.product-card__photo-wrap{width:100%;position:relative}.product-card__image{object-fit:cover;background:var(--bg-primary);width:100%;height:200px;display:block}.product-card__placeholder{background:var(--bg-primary);justify-content:center;align-items:center;width:100%;height:160px;font-size:56px;line-height:1;display:flex}.product-card__body{padding:12px 14px 14px}.product-card__category{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:4px;font-weight:600;line-height:1.3}.product-card__name-row{align-items:flex-start;gap:8px;margin-bottom:6px;display:flex}.product-card__name{font-size:var(--text-md);color:var(--text-primary);flex:1;min-width:0;font-weight:700;line-height:1.25}.product-card__add-btn{background:var(--accent-primary);cursor:pointer;color:#fff;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;margin-top:1px;transition:background .15s,transform .1s;display:flex;box-shadow:0 2px 8px #e07b5459}.product-card__add-btn:active{background:var(--accent-dark);transform:scale(.9)}.product-card__macros{align-items:baseline;gap:8px;margin-bottom:0;line-height:1;display:flex}.product-card__kcal{font-size:var(--text-sm);color:var(--accent-primary);font-weight:700}.product-card__macro-detail{font-size:var(--text-xs);color:var(--text-secondary)}.product-card__per-label{color:var(--text-muted);flex-shrink:0;margin-left:auto;font-size:10px}.product-card__author{font-size:var(--text-xs);color:var(--text-muted);align-items:center;gap:5px;margin-top:8px;display:flex}.product-card__author-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:18px;height:18px}.product-meta-author{align-items:center;gap:10px;display:flex}.product-meta-author__avatar{object-fit:cover;border:2px solid var(--border-subtle);border-radius:50%;flex-shrink:0;width:32px;height:32px}.progress-bar{background:var(--bg-primary);border-radius:4px;height:8px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .4s}.progress-calories{background:var(--accent-primary)}.progress-protein{background:var(--macro-protein)}.progress-fat{background:var(--macro-fat)}.progress-carbs{background:var(--macro-carbs)}.progress-water{background:var(--status-info)}.progress-bar-thin{height:4px}.category-scroll{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;gap:8px;padding:0 16px;display:flex;overflow-x:auto;-webkit-mask-image:linear-gradient(90deg,#000 calc(100% - 24px),#0000 100%);mask-image:linear-gradient(90deg,#000 calc(100% - 24px),#0000)}.category-scroll::-webkit-scrollbar{display:none}.category-pill{border-radius:var(--radius-full);height:34px;font-size:var(--text-sm);cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;border:none;flex-shrink:0;padding:0 14px;font-weight:500;transition:background .15s,color .15s}.category-pill--inactive{background:var(--bg-secondary);color:var(--text-secondary)}.category-pill--active{background:var(--accent-primary);color:#fff;font-weight:600}.search-bar{width:100%;position:relative}.search-bar__icon{color:var(--text-muted);pointer-events:none;align-items:center;display:flex;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-bar__input{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;height:44px;font-size:var(--text-base);color:var(--text-primary);-webkit-appearance:none;outline:none;padding:0 14px 0 40px;transition:border-color .2s,box-shadow .2s}.search-bar__input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #e07b5426}.search-bar__input::placeholder{color:var(--text-muted)}.search-bar__clear{color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:50%;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.bottom-nav{height:calc(60px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--bg-tertiary);border-top:1px solid var(--border-subtle);z-index:100;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav__item{cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:0;transition:color .15s;display:flex}.bottom-nav__item--active .bottom-nav__icon{color:var(--accent-primary)}.bottom-nav__item--active .bottom-nav__label{color:var(--accent-primary);font-weight:600}.bottom-nav__item--inactive .bottom-nav__icon,.bottom-nav__item--inactive .bottom-nav__label{color:var(--text-muted)}.bottom-nav__icon{justify-content:center;align-items:center;width:24px;height:24px;display:flex}.bottom-nav__label{letter-spacing:.01em;font-size:10px;line-height:1}.bottom-nav__fab-wrap{flex:1;justify-content:center;align-items:center;padding-bottom:4px;display:flex}.bottom-nav__fab{background:var(--accent-primary);cursor:pointer;width:52px;height:52px;box-shadow:var(--shadow-fab);-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,transform .1s;display:flex}.bottom-nav__fab:active{background:var(--accent-dark);transform:scale(.94)}.sheet-overlay{z-index:200;align-items:flex-end;animation:.2s overlay-in;display:flex;position:fixed;inset:0}.sheet-backdrop{background:#0000008c;position:absolute;inset:0}.sheet-content{background:var(--bg-secondary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-height:85vh;padding:20px 16px calc(20px + env(safe-area-inset-bottom,0px));box-shadow:var(--shadow-modal);animation:.32s ease-out sheet-up;position:relative;overflow-y:auto}.sheet-handle{background:var(--text-muted);border-radius:var(--radius-full);opacity:.5;width:40px;height:4px;margin:0 auto 20px}@keyframes sheet-up{0%{opacity:.6;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.day-summary{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);align-items:center;gap:16px;margin:16px 16px 0;padding:18px 20px;display:flex}.day-summary__donut-wrap{flex-shrink:0;width:80px;height:80px;position:relative}.day-summary__donut-text{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.day-summary__macros{flex-direction:column;flex:1;gap:6px;display:flex}.day-summary__kcal{margin-bottom:6px}.day-summary__kcal-label{color:var(--text-secondary);letter-spacing:.08em;text-transform:uppercase;font-size:11px;font-weight:600}.day-summary__kcal-num{align-items:baseline;gap:4px;margin-top:2px;display:flex}.stat-card{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);flex-direction:column;flex:1;align-items:center;padding:16px;display:flex}.skeleton{background:var(--bg-secondary);border-radius:var(--radius-md);background-size:200% 100%;background-image:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-elevated) 50%,var(--bg-secondary) 75%);animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-photo{border-radius:var(--radius-lg);height:200px}.skeleton-text{border-radius:var(--radius-sm);height:14px}.screen{padding-bottom:calc(80px + env(safe-area-inset-bottom,0px));min-height:100vh}.screen-content{padding-top:8px}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;padding:0 16px;display:flex}.section-title{font-size:var(--text-base);color:var(--text-primary);font-weight:600}.product-grid{flex-direction:column;gap:10px;padding:0 16px;display:flex}.detail-photo-wrap{width:100%;position:relative;overflow:hidden}.product-detail-hero{object-fit:cover;background:var(--bg-primary);width:100%;height:300px;display:block}.product-detail-hero-placeholder{background:var(--bg-primary);justify-content:center;align-items:center;width:100%;height:280px;font-size:80px;display:flex}.detail-photo-label{-webkit-backdrop-filter:blur(8px);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--text-primary);background:#1e2530cc;padding:4px 12px;font-weight:600;position:absolute;top:10px;left:10px}.detail-photo-arrow{-webkit-backdrop-filter:blur(6px);width:36px;height:36px;color:var(--text-primary);cursor:pointer;-webkit-tap-highlight-color:transparent;z-index:2;background:#1e2530b3;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:22px;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.detail-photo-arrow--left{left:10px}.detail-photo-arrow--right{right:10px}.detail-photo-arrow:active{background:#1e2530e6}.detail-photo-dots{z-index:2;gap:6px;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.detail-photo-dot{cursor:pointer;background:#ffffff59;border-radius:50%;width:8px;height:8px;transition:background .2s}.detail-photo-dot--active{background:var(--accent-primary)}.view-toggle{cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0;align-items:center;gap:8px;padding:4px 0;display:flex}.view-toggle__track{background:var(--bg-elevated);border-radius:11px;flex-shrink:0;width:40px;height:22px;transition:background .2s;position:relative}.view-toggle__track--on{background:var(--accent-primary)}.view-toggle__thumb{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0000004d}.view-toggle__track--on .view-toggle__thumb{transform:translate(18px)}.view-toggle__label{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;min-width:42px;font-weight:600}.portion-toggle{background:var(--bg-primary);border-radius:var(--radius-md);gap:3px;margin-bottom:12px;padding:3px;display:flex}.portion-toggle__btn{height:36px;font-size:var(--text-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:8px;flex:1;font-weight:600;transition:background .15s,color .15s}.portion-toggle__btn--active{background:var(--accent-primary);color:#fff}.portion-toggle__btn:not(.portion-toggle__btn--active){color:var(--text-secondary);background:0 0}.portion-input-wrap{margin-bottom:14px;position:relative}.portion-input{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;height:48px;font-size:var(--text-lg);color:var(--text-primary);appearance:none;-moz-appearance:textfield;outline:none;padding:0 36px 0 14px;font-weight:600;transition:border-color .2s,box-shadow .2s}.portion-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #e07b5426}.portion-input::placeholder{color:var(--text-muted);font-weight:400}.portion-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.portion-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.portion-input-unit{font-size:var(--text-sm);color:var(--text-muted);pointer-events:none;font-weight:600;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.macro-block{background:var(--bg-primary);border-radius:var(--radius-md);flex-direction:column;flex:1;align-items:center;min-width:0;padding:14px 8px;display:flex}.macro-block__value{font-size:var(--text-xl);font-weight:700;line-height:1.1}.macro-block__label{font-size:var(--text-xs);color:var(--text-secondary);text-align:center;letter-spacing:.06em;text-transform:uppercase;margin-top:4px}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 24px;display:flex}.empty-state__icon{opacity:.5;font-size:48px;line-height:1}.empty-state__text{font-size:var(--text-base);color:var(--text-secondary)}.field-group{margin-bottom:16px}.divider{background:var(--border-subtle);height:1px;margin:0 16px}.tap-target{-webkit-tap-highlight-color:transparent}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.scroll-row-wrap{position:relative}.profile-header{align-items:center;gap:16px;padding:20px 0 24px;display:flex}.profile-avatar{background:var(--bg-elevated);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;display:flex;position:relative;overflow:hidden}.profile-avatar__img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.profile-avatar__fallback{color:var(--accent-primary);font-size:24px;font-weight:700}.profile-name{font-size:var(--text-lg);color:var(--text-primary);font-weight:700}.profile-username{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.profile-section{margin-bottom:24px}.profile-section__title{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;font-weight:600}.profile-goal-pill{border-radius:var(--radius-full);border:1.5px solid var(--border-subtle);background:var(--bg-secondary);height:36px;color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;padding:0 14px;font-weight:500;transition:all .15s}.profile-goal-pill--active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;font-weight:600}.profile-targets-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.profile-target-item{flex-direction:column;gap:4px;display:flex}.profile-target-label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:500}.profile-target-input{text-align:center;font-size:16px!important;font-weight:600!important}.profile-links{background:var(--bg-secondary);border-radius:var(--radius-lg);flex-direction:column;gap:2px;display:flex;overflow:hidden}.profile-link{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:14px 16px;display:flex}.profile-link+.profile-link{border-top:1px solid var(--border-subtle)}.profile-link__icon{color:var(--text-secondary);align-items:center;display:flex}.profile-link__text{font-size:var(--text-base);color:var(--text-primary);flex:1;font-weight:500}.profile-link__arrow{color:var(--text-muted);align-items:center;display:flex}.about-hero{text-align:center;padding:32px 0 28px}.about-logo{background:linear-gradient(135deg,var(--accent-primary),var(--accent-dark));color:#fff;border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 12px;font-size:28px;font-weight:800;display:flex}.about-app-name{color:var(--text-primary);font-size:22px;font-weight:700}.about-app-desc{font-size:var(--text-sm);color:var(--text-secondary);margin-top:4px}.about-section{margin-bottom:24px}.about-section__title{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;font-weight:600}.changelog-entry{background:var(--bg-secondary);border-radius:var(--radius-lg);margin-bottom:12px;padding:16px}.changelog-version{align-items:center;gap:10px;margin-bottom:8px;display:flex}.changelog-badge{border-radius:var(--radius-full);background:var(--accent-primary);color:#fff;padding:2px 10px;font-size:12px;font-weight:700;display:inline-block}.changelog-badge--old{background:var(--bg-elevated);color:var(--text-secondary)}.changelog-date{font-size:var(--text-xs);color:var(--text-muted)}.changelog-title{font-size:var(--text-base);color:var(--text-primary);margin-bottom:8px;font-weight:600}.changelog-list{margin:0;padding:0;list-style:none}.changelog-list li{font-size:var(--text-sm);color:var(--text-secondary);padding-left:16px;line-height:1.7;position:relative}.changelog-list li:before{content:"";background:var(--accent-primary);border-radius:50%;width:5px;height:5px;position:absolute;top:9px;left:0}.about-footer{text-align:center;padding:24px 0}.profile-goal-card{background:var(--bg-secondary);border-radius:var(--radius-lg);margin-bottom:16px;padding:16px}.profile-goal-card--empty{text-align:center;border:1.5px dashed var(--border-subtle);background:0 0;padding:24px 16px}.profile-goal-card__label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;font-weight:600}.profile-goal-card__value{font-size:var(--text-md);color:var(--text-primary);margin-bottom:8px;font-weight:700}.profile-goal-card__targets{font-size:var(--text-sm);color:var(--text-secondary);gap:12px;font-weight:500;display:flex}.btn-secondary{border-radius:var(--radius-md);border:1.5px solid var(--border-subtle);background:var(--bg-secondary);width:100%;height:48px;color:var(--text-secondary);font-size:var(--text-base);cursor:pointer;font-weight:600;transition:all .15s;display:block}.btn-secondary:active{background:var(--bg-elevated)}.onboarding{flex-direction:column;min-height:100vh;padding:24px 16px;display:flex}.onboarding__steps{justify-content:center;gap:12px;margin-bottom:32px;display:flex}.onboarding__step-dot{background:var(--bg-secondary);width:28px;height:28px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;transition:all .3s;display:flex}.onboarding__step-dot--active{background:var(--accent-primary);color:#fff;transform:scale(1.15)}.onboarding__step-dot--done{background:var(--status-success);color:#fff}.onboarding__content{flex:1}.onboarding__title{color:var(--text-primary);margin-bottom:8px;font-size:22px;font-weight:700}.onboarding__subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:24px;line-height:1.5}.onboarding__goals{flex-direction:column;gap:10px;display:flex}.onboarding__goal-card{background:var(--bg-secondary);border:1.5px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;text-align:left;align-items:center;gap:14px;width:100%;padding:16px;transition:all .2s;display:flex}.onboarding__goal-card:active{transform:scale(.98)}.onboarding__goal-card--active{border-color:var(--accent-primary);background:#e07b541a}.onboarding__goal-emoji{flex-shrink:0;font-size:28px}.onboarding__goal-label{font-size:var(--text-base);color:var(--text-primary);font-weight:600}.onboarding__goal-desc{font-size:var(--text-xs);color:var(--text-secondary);margin-left:auto}.onboarding__weight-input{justify-content:center;align-items:center;margin-top:32px;display:flex}.onb-kcal-banner{background:var(--bg-secondary);border-radius:var(--radius-lg);align-items:baseline;gap:8px;margin-bottom:16px;padding:14px 16px;display:flex}.onb-kcal-banner__value{color:var(--text-primary);font-size:28px;font-weight:800}.onb-kcal-banner__label{font-size:var(--text-sm);color:var(--text-muted);font-weight:500}.onb-macro-card{background:var(--bg-secondary);border-radius:var(--radius-lg);margin-bottom:10px;padding:14px 16px}.onb-macro-card__header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.onb-macro-card__name{font-size:var(--text-base);font-weight:700}.onb-macro-card__kcal-per-g{font-size:var(--text-xs);color:var(--text-muted);background:var(--bg-primary);border-radius:var(--radius-full);padding:2px 8px;font-weight:600}.onb-macro-card__controls{justify-content:center;align-items:center;gap:16px;margin-bottom:10px;display:flex}.onb-macro-btn{border:1.5px solid var(--border-subtle);background:var(--bg-primary);width:44px;height:44px;color:var(--text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;transition:all .15s;display:flex}.onb-macro-btn:active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);transform:scale(.92)}.onb-macro-card__value-block{flex-direction:column;align-items:center;min-width:90px;display:flex}.onb-macro-card__grams{color:var(--text-primary);font-size:22px;font-weight:700;line-height:1.2}.onb-macro-card__kcal{font-size:var(--text-xs);color:var(--text-muted);font-weight:500}.onb-macro-card__per-kg{font-size:var(--text-xs);color:var(--accent-primary);margin-top:1px;font-weight:600}.onb-macro-card__hint{color:var(--text-secondary);border-top:1px solid var(--border-subtle);padding-top:8px;font-size:12px;line-height:1.45}.onb-kcal-bar{border-radius:3px;gap:2px;height:6px;margin-top:16px;display:flex;overflow:hidden}.onb-kcal-bar__segment{border-radius:3px;transition:flex .3s}.onb-kcal-bar__labels{justify-content:space-between;margin-top:6px;font-size:11px;font-weight:600;display:flex}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}
