@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;700;800&family=Space+Grotesk:wght@500;700&display=swap";:root{font-family:Manrope,sans-serif;line-height:1.45;font-weight:500;color:#16263b;background:radial-gradient(circle at top left,rgba(132,212,255,.32),transparent 24%),radial-gradient(circle at bottom right,rgba(173,240,116,.26),transparent 22%),linear-gradient(180deg,#edf7ff,#eef9ef 62%,#eff8ff);--text-main: #142433;--text-soft: #6b7b8f;--accent-lime: #5dd7a7;--accent-carbs: #ef5ca8;--accent-protein: #5977ff;--accent-fat: #8d59f2;--accent-fire: #ff9a3d;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-height:100%;width:100%;overflow-x:hidden}body{margin:0;min-width:320px;color:var(--text-main);overflow-x:hidden}h1,h2,h3,p{margin:0}h1,h2{font-family:Space Grotesk,sans-serif;letter-spacing:-.04em;color:inherit}h1{font-size:clamp(2.4rem,6vw,4rem)}h2{font-size:clamp(1.3rem,2vw,1.8rem)}a{color:inherit}.app-shell{min-height:100dvh;padding:20px 14px 126px;width:100%;overflow-x:hidden}.auth-screen,.mobile-shell{width:min(100%,460px);margin:0 auto;max-width:100%;min-width:0;overflow-x:hidden}.auth-screen{display:grid;gap:16px;padding-top:24px}.welcome-card,.info-card,.hero-stat-card,.card-section,.macro-card,.action-card,.timeline-card,.history-card,.weight-hero,.profile-hero,.stat-tile,.onboarding-sheet,.drawer-menu{background:#ffffffeb;border:1px solid rgba(216,228,238,.88);box-shadow:0 22px 50px #213a591a}.welcome-card,.info-card,.card-section,.weight-hero,.profile-hero{border-radius:30px;padding:24px}.welcome-card{background:radial-gradient(circle at 82% 66%,rgba(255,174,99,.32),transparent 22%),linear-gradient(145deg,#132426f5,#0f2530f5);border-color:#25343d59;color:#f8f5ef;min-height:320px}.welcome-card p,.info-card p,.subtle,.timeline-card p,.history-card p,.macro-card span,.action-card span,.stat-tile p,.field span,.choice-card span,.option-row span,.empty-state p{color:var(--text-soft)}.welcome-card p{max-width:320px;margin:14px 0 22px;color:#f8f5efd1}.info-card{background:linear-gradient(180deg,#fbfcfffa,#edf8f0f0)}.gradient-badge{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:0 16px;border-radius:999px;background:linear-gradient(135deg,#66ccff2e,#9ae46542);color:#2d6044;font-size:.82rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.gradient-badge.giant{min-height:52px;padding:0 24px}.eyebrow-light,.step-caption{display:inline-flex;color:#46bf9f;font-weight:800;letter-spacing:.06em;text-transform:uppercase;font-size:.78rem}.primary-button,.ghost-pill,.pill,.bottom-nav-item,.action-card,.choice-card,.option-row,.timezone-option,.drawer-link{transition:transform .18s ease,background .18s ease,color .18s ease,border-color .18s ease}.primary-button{border:0;border-radius:22px;background:linear-gradient(135deg,#87d8ff,#4ccfa4 55%,#d7f84d);color:#fff;font:inherit;font-weight:800;cursor:pointer;box-shadow:0 18px 34px #48c5a53d}.primary-button:disabled{opacity:.56;cursor:not-allowed;box-shadow:none}.primary-button.xl{min-height:86px;padding:22px 28px;font-size:1.1rem}.primary-button.wide{width:100%;min-height:56px}.ghost-pill,.pill,.icon-button,.bottom-nav-item,.drawer-link{border:0;background:#ebf2f8e6;color:var(--text-main);cursor:pointer;font:inherit}.ghost-pill{min-height:42px;border-radius:999px;padding:0 16px;font-weight:700}.ghost-pill.small{min-height:34px;padding:0 12px;font-size:.82rem}.hero-stat-card{border-radius:30px;padding:24px;display:flex;justify-content:space-between;gap:18px;align-items:center;background:radial-gradient(circle at top right,rgba(198,255,127,.38),transparent 18%),linear-gradient(180deg,#fffffff5,#f7fcf8f2)}.hero-stat-card p{margin-top:8px;color:var(--text-soft)}.home-hero{padding:18px;gap:12px;align-items:flex-start}.home-hero h2{font-size:clamp(1.7rem,5.4vw,2.2rem)}.home-hero .progress-ring{width:88px;height:88px;align-self:flex-start}.home-hero-copy{display:grid;gap:10px}.hero-mini-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.hero-mini-stat{border-radius:18px;padding:10px 12px;background:#f4faffcc;border:1px solid rgba(221,231,241,.86)}.hero-mini-stat span{display:block;font-size:.72rem;font-weight:700;color:var(--text-soft)}.hero-mini-stat strong{display:block;margin-top:4px;font-size:1rem}.progress-ring{width:110px;height:110px;border-radius:999px;padding:8px;display:grid;place-items:center;flex-shrink:0}.progress-ring>div,.macro-ring>div{width:100%;height:100%;border-radius:999px;background:#fff;display:grid;place-items:center;text-align:center}.progress-ring strong{font-size:1.15rem}.progress-ring span,.macro-ring div{color:var(--text-soft);font-size:.8rem}.macro-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}.home-macro-grid{gap:8px}.macro-card,.action-card,.stat-tile{border-radius:26px;padding:18px}.macro-card{display:grid;gap:8px}.home-macro-grid .macro-card{padding:12px;gap:8px;min-height:0}.macro-card strong,.stat-tile strong,.timeline-card strong,.history-card strong,.choice-card strong,.option-row strong{color:var(--text-main)}.macro-ring{width:76px;height:76px;border-radius:999px;padding:7px}.home-macro-grid .macro-ring{width:54px;height:54px;padding:6px}.macro-card.compact{display:flex;align-items:center;gap:12px}.macro-card.compact .macro-card-copy{display:grid;gap:2px}.macro-card.compact strong{font-size:.98rem}.macro-card.compact span{font-size:.88rem}.quick-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px}.home-quick-actions{gap:10px}.action-card{border:0;text-align:left;min-height:104px}.home-quick-actions .action-card{min-height:74px;padding:12px;border-radius:22px}.action-card strong{display:block;margin-top:8px;font-size:1rem}.home-quick-actions .action-card span{font-size:.76rem}.home-quick-actions .action-card strong{margin-top:6px;font-size:.94rem;line-height:1.15}.card-section{margin-top:14px;min-width:0;max-width:100%;overflow-x:hidden}.section-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;flex-wrap:wrap;margin-bottom:16px;min-width:0}.timeline-list,.stack{display:grid;gap:12px;min-width:0}.timeline-card,.history-card,.ingredient-card,.empty-state,.option-row,.choice-card,.upload-card{border-radius:24px;padding:16px;background:#f5faffe6;border:1px solid rgba(220,231,241,.9)}.timeline-card,.history-card-head{display:flex;justify-content:space-between;gap:12px}.timeline-card{align-items:center}.day-log-card .timeline-card{padding:12px 14px}.day-log-card .timeline-card.compact{align-items:flex-start}.day-log-card .timeline-card p{margin-top:4px;font-size:.88rem}.timeline-label,.history-card span{display:inline-flex;color:#52b7f3;font-size:.82rem;font-weight:700;margin-bottom:6px}.timeline-side{text-align:right}.timeline-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}.timeline-actions button{border:0;border-radius:999px;padding:8px 12px;background:#dfe8eff0;font:inherit;font-weight:700;cursor:pointer}.screen-stack{display:grid;gap:0;min-width:0;max-width:100%;overflow-x:hidden}.topbar{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:16px;min-width:0}.topbar-title{text-align:center;flex:1 1 auto;min-width:0}.topbar-title span{display:block;font-size:.84rem;color:var(--text-soft);overflow-wrap:anywhere}.topbar-title strong{display:block;margin-top:2px;font-size:1.45rem;color:var(--text-main);line-height:1.05;overflow-wrap:anywhere}.topbar-actions{display:flex;gap:8px;flex-shrink:0;min-width:0}.topbar>.icon-button{flex-shrink:0}.icon-button{width:48px;height:48px;border-radius:50%;font-size:1.35rem}.icon-button.ghost{background:#ffffff8a}.banner{width:min(100%,460px);margin:0 auto 14px;border-radius:20px;padding:14px 16px;font-weight:700}.banner.error{background:#ff6a6a24;color:#c14747}.banner.success{background:#47d39e29;color:#0f7e60}.bottom-nav{position:fixed;left:50%;bottom:14px;transform:translate(-50%);width:min(calc(100% - 20px),460px);display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;padding:8px;border-radius:28px;background:#0e1c27e6;box-shadow:0 18px 42px #10203133}.bottom-nav-item{min-height:48px;border-radius:18px;color:#ffffffb3;background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-weight:700}.bottom-nav-item.active{background:#ffffff1f;color:#fff}.bottom-nav-icon{font-size:1rem;line-height:1}.bottom-nav-label{font-size:.72rem;line-height:1}.pill-row,.choice-grid,.summary-strip,.split-fields,.triple-grid,.tag-cloud{display:grid;gap:10px}.pill-row{display:flex;flex-wrap:wrap}.pill-row.scrollable{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding-bottom:4px;scrollbar-width:none;width:100%;max-width:100%}.pill-row.scrollable .pill{min-width:124px;flex:0 0 auto}.activity-type-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;width:100%;max-width:100%}.activity-type-grid .pill{width:100%;min-width:0;min-height:52px;padding:12px 10px;white-space:normal;text-align:center;line-height:1.15}.pill-row.compact{flex-wrap:nowrap}.pill{min-height:44px;border-radius:999px;padding:0 18px;font-weight:700}.pill.active,.ghost-pill:hover,.pill:hover,.choice-card.selected,.option-row.selected,.timezone-option.selected,.drawer-link.active,.tag-chip.active{background:linear-gradient(135deg,#87d8ff2e,#4ccfa429,#d7f84d42);color:var(--text-main);border-color:#5fd6b56b}.field{display:grid;gap:8px;min-width:0}input,textarea,select{width:100%;border:1px solid rgba(218,229,241,.98);border-radius:18px;background:#fafcfffa;color:var(--text-main);padding:14px 16px;font:inherit;font-size:16px;min-width:0}textarea{min-height:108px;resize:vertical}.editor-panel{display:grid;gap:14px;margin-top:16px}.composer-helper{margin-top:14px;padding:16px 18px;border-radius:22px;background:linear-gradient(180deg,#f5fafffa,#edf8f0f0);border:1px solid rgba(220,231,241,.92)}.composer-helper p{margin-top:6px;color:var(--text-soft)}.primary-food-helper{margin-bottom:4px}.food-mode-actions,.food-inline-actions{display:flex;gap:8px;flex-wrap:wrap}.meal-result-panel{border-top:1px solid rgba(220,231,241,.82);padding-top:14px}.analysis-header{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}.analysis-header p{margin-top:6px;color:var(--text-soft)}.analysis-actions{display:flex;gap:8px;flex-wrap:wrap}.split-fields{grid-template-columns:repeat(2,minmax(0,1fr))}.triple-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.food-preview{width:100%;border-radius:24px;object-fit:cover;max-height:260px}.upload-card{position:relative;display:grid;place-items:center;min-height:120px;border-style:dashed;color:var(--text-soft)}.upload-card input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.summary-strip{grid-template-columns:repeat(3,minmax(0,1fr))}.page-actions{display:flex;gap:10px;margin-top:14px}.progress-actions{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);align-items:stretch}.page-action-main{flex:1;min-height:56px}.progress-secondary-action{min-height:56px;display:inline-flex;align-items:center;justify-content:center}.profile-metrics{margin-top:14px}.stat-tile{text-align:left}.stat-tile span{color:var(--text-soft);font-size:.82rem;font-weight:700}.stat-tile strong{display:block;margin:10px 0 4px;font-size:1.45rem}.weight-hero{margin-top:14px;background:linear-gradient(135deg,#62c2ff,#49d6b1 52%,#95e36a);color:#fff}.progress-hero{padding:18px}.weight-hero .eyebrow-light,.weight-hero h3,.weight-hero strong,.weight-hero span,.weight-hero p{color:#fff}.weight-hero .empty-state{background:#ffffff24;border-color:#fff3}.weight-hero .empty-state strong,.weight-hero .empty-state p{color:#fff}.weight-hero-top{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px}.progress-hero .weight-hero-top{margin-bottom:14px}.goal-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.goal-metrics span{display:block;opacity:.82;font-size:.8rem}.goal-metrics strong{display:block;margin-top:4px;font-size:1.35rem}.progress-range-toggle{display:inline-flex;flex-wrap:nowrap}.progress-range-toggle .pill{min-width:0;padding-inline:18px}.line-chart{border-radius:24px;overflow:hidden;background:#ffffff29;padding:10px}.line-chart-empty{background:#ffffff24;min-height:108px;display:grid;align-items:center}.line-chart svg{width:100%;height:124px}.line-chart-path{fill:none;stroke:#fffffff5;stroke-width:4;stroke-linejoin:round;stroke-linecap:round}.line-chart-labels{display:flex;justify-content:space-between;gap:8px;margin-top:6px;color:#ffffffe0;font-size:.72rem}.progress-hero-empty{padding:16px 18px;border-radius:22px;background:#ffffff29;border:1px solid rgba(255,255,255,.2)}.progress-hero-empty p{margin-top:6px;color:#ffffffe0}.bar-chart-scroller{overflow:hidden;padding-bottom:2px;width:100%;max-width:100%}.bar-chart{display:grid;align-items:flex-end;height:128px;padding:8px 0 0;width:100%;min-width:0}.bar-column{display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:6px;min-width:0}.bar-fill{width:100%;border-radius:999px;min-height:12px;background:linear-gradient(180deg,#76cbff,#56dbb5)}.bar-fill.over{background:linear-gradient(180deg,#76cbff,#d8ef5f)}.bar-column span{font-size:.68rem;color:var(--text-soft);white-space:nowrap}.progress-summary-strip{margin-top:10px;gap:8px}.progress-summary-strip .stat-tile{padding:14px}.progress-summary-strip .stat-tile strong{margin:8px 0 2px;font-size:1.18rem}.profile-hero{margin-top:14px;display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#87d8ff66,#4ccfa46b,#d7f84d80)}.profile-avatar,.drawer-avatar,.choice-icon{display:grid;place-items:center;border-radius:50%}.profile-avatar{width:68px;height:68px;background:#ffffffad;font-size:1.6rem;font-weight:800}.profile-copy{flex:1}.choice-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.choice-grid.compact{margin-bottom:14px}.choice-card{border:1px solid rgba(216,229,240,.94);display:grid;gap:8px;align-content:start;text-align:left;font:inherit;cursor:pointer}.choice-card.compact{min-height:120px}.choice-icon{width:58px;height:58px;margin-bottom:14px;background:linear-gradient(135deg,#87d8ff,#4ccfa4 55%,#d7f84d);color:#fff;font-size:1.5rem}.option-row{border:1px solid rgba(216,229,240,.94);display:grid;gap:8px;align-content:start;text-align:left;font:inherit;cursor:pointer}.choice-card strong,.choice-card span,.option-row strong,.option-row span{display:block}.choice-card strong,.option-row strong{line-height:1.1}.choice-card span,.option-row span{line-height:1.35}.timezone-select{display:grid;gap:10px}.timezone-options{max-height:240px;overflow:auto;display:grid;gap:8px}.timezone-option{border:1px solid rgba(216,229,240,.94);border-radius:16px;padding:12px 14px;background:#f5faffe0;text-align:left;cursor:pointer}.tag-cloud{grid-template-columns:repeat(2,minmax(0,1fr))}.tag-chip{border:1px solid rgba(216,229,240,.94);border-radius:18px;padding:12px 14px;background:#f5faffe0;font:inherit;font-weight:700;color:var(--text-main);cursor:pointer}.section-divider{height:1px;background:#d9e4efd6;margin:4px 0}.drawer-backdrop,.onboarding-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;background:#0811196b;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow:auto}.drawer-menu{width:min(86vw,340px);height:100%;padding:26px;border-radius:0 34px 34px 0}.drawer-profile{display:grid;justify-items:start;gap:6px;padding-bottom:24px}.drawer-avatar{width:72px;height:72px;background:linear-gradient(135deg,#87d8ff,#4ccfa4 55%,#d7f84d);color:#fff;font-size:1.7rem;font-weight:800}.drawer-profile span{color:var(--text-soft)}.drawer-links{display:grid;gap:8px;margin-bottom:20px}.drawer-link{text-align:left;min-height:50px;border-radius:18px;padding:0 16px;font-weight:700}.onboarding-sheet{width:min(calc(100vw - 24px),460px);margin:20px auto;border-radius:36px;padding:18px;display:flex;flex-direction:column;max-height:calc(100dvh - 28px);overflow:hidden}.onboarding-progress{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}.ghost-link{border:0;background:transparent;color:var(--text-soft);font:inherit;font-weight:700;cursor:pointer}.progress-track{height:8px;border-radius:999px;background:#e2eaf2eb;overflow:hidden}.progress-track span{display:block;height:100%;border-radius:999px;background:linear-gradient(135deg,#4ccfa4,#89e36f)}.onboarding-page{display:grid;gap:18px;padding:18px 6px 16px;overflow:auto}.metric-picker{display:flex;align-items:center;gap:12px}.metric-picker input{font-size:2rem;font-weight:800;text-align:center}.metric-picker span{font-weight:800;color:var(--text-main)}.unit-toggle{display:inline-grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:8px;border-radius:999px;background:#eef4f9eb}.unit-toggle button{min-width:100px;min-height:42px;border:0;border-radius:999px;background:transparent;font:inherit;font-weight:800;color:var(--text-soft);cursor:pointer}.unit-toggle button.selected{background:#fff;color:var(--text-main);box-shadow:0 8px 20px #42647c14}.onboarding-actions{margin-top:auto;padding:14px 6px 6px;position:sticky;bottom:0;background:linear-gradient(180deg,#fff0,#fffffff5 22%,#fffffffa)}.empty-state{text-align:left}.activity-helper,.estimate-note,.modal-sheet{background:#f5faffe0;border:1px solid rgba(220,231,241,.9);border-radius:24px;box-shadow:0 22px 50px #213a591a}.activity-helper,.estimate-note{margin-top:14px;padding:16px;min-width:0;max-width:100%;overflow-x:hidden}.activity-helper p,.estimate-note p{margin-top:6px;color:var(--text-soft);overflow-wrap:anywhere}.activity-helper strong{display:block;overflow-wrap:anywhere}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;padding:12px;background:#08111970;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal-sheet{width:min(100%,460px);padding:22px;max-height:calc(100dvh - 24px);overflow:auto}.modal-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:16px}.modal-actions{display:grid;gap:10px;margin-top:18px}.ingredient-card-head{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:10px}.ingredient-summary-card{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:16px;border-radius:20px;background:#f5faffd1;border:1px solid rgba(220,231,241,.9)}.ingredient-summary-card p{margin-top:6px;color:var(--text-soft)}.nutrition-grid{display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 640px){.app-shell{padding-inline:10px}.summary-strip,.triple-grid,.split-fields,.tag-cloud,.choice-grid{grid-template-columns:1fr}.pill-row{gap:8px}.activity-type-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-stat-card,.weight-hero-top,.timeline-card,.history-card-head{flex-direction:column;align-items:flex-start}.timeline-side{width:100%;text-align:left}.timeline-actions{justify-content:flex-start}.topbar-title strong{font-size:1.25rem}.topbar{gap:8px}.home-hero{padding:18px}.home-hero .progress-ring{width:80px;height:80px}.home-macro-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.home-macro-grid .macro-card{min-height:0}.home-quick-actions{grid-template-columns:repeat(3,minmax(0,1fr))}.home-quick-actions .action-card{min-height:76px;padding:12px}.bottom-nav{width:min(calc(100% - 12px),460px);bottom:10px;gap:4px}.bottom-nav-item{min-height:46px;font-size:.88rem;gap:3px}.bottom-nav-icon{font-size:.95rem}.bottom-nav-label{font-size:.64rem}.activity-type-grid .pill{font-size:.98rem;padding-inline:8px}.page-actions{flex-direction:column}.progress-actions{grid-template-columns:1fr 1fr}.progress-secondary-action{width:100%}.progress-hero{padding:18px}.progress-summary-strip{grid-template-columns:repeat(3,minmax(0,1fr))}.progress-summary-strip .stat-tile{min-height:0}.progress-stats-card .section-head{gap:10px;margin-bottom:12px}.onboarding-sheet{width:calc(100vw - 12px);margin:6px auto;border-radius:30px;padding:14px;max-height:calc(100dvh - 12px)}.modal-sheet{width:calc(100vw - 12px);padding:18px;border-radius:28px}.nutrition-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.food-mode-actions,.food-inline-actions,.analysis-actions{display:grid;grid-template-columns:1fr}}@media (max-width: 420px){.topbar-title span{font-size:.8rem}.topbar-title strong{font-size:1.18rem}.activity-type-grid .pill{font-size:.92rem}.home-macro-grid .macro-card{padding:12px}.home-quick-actions .action-card strong{font-size:.88rem}.progress-actions{grid-template-columns:1fr}.progress-range-toggle{width:100%}.progress-range-toggle .pill{flex:1 1 0}}
