*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--green:#047857;--green-light:#10b981;--green-bg:#d1fae5;--amber:#b45309;--amber-bg:#fef3c7;--red:#dc2626;--red-bg:#fee2e2;--blue:#2563eb;--blue-dark:#1e3a8a;--blue-bg:#dbeafe;--teal:#0f766e;--teal-bg:#ccfbf1;--purple:#7c3aed;--purple-bg:#ede9fe;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-700:#334155;--gray-900:#0f172a;--white:#fff;--radius:14px;--radius-lg:22px;--shadow:0 10px 30px #0f172a14;--shadow-soft:0 1px 2px #0f172a0f, 0 1px 8px #0f172a0a;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--nav-height:76px;--header-height:58px}html,body,#root{height:100%}body{font-family:var(--font);color:var(--gray-900);-webkit-font-smoothing:antialiased;background:radial-gradient(circle at 0 0,#14b8a62e,#0000 34%),linear-gradient(135deg,#f8fafc 0%,#e0f2fe 48%,#f8fafc 100%);font-size:14px;line-height:1.5}button{font-family:var(--font);cursor:pointer;background:0 0;border:none}input,select,textarea{font-family:var(--font);font-size:14px}ul{list-style:none}.app{width:100%;max-width:960px;height:100%;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffe0;flex-direction:column;margin:0 auto;display:flex}.app-header{height:var(--header-height);background:linear-gradient(135deg, var(--gray-900), #164e63);color:var(--white);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 18px;display:flex}.app-title{letter-spacing:.2px;font-size:17px;font-weight:700}.app-user{color:var(--gray-400);font-size:13px}.app-main{flex:1;padding-bottom:10px;overflow-y:auto}.storage-error{border-radius:var(--radius);background:var(--red-bg);color:var(--red);margin:12px 16px 0;padding:10px 12px;font-size:13px}.nav{min-height:var(--nav-height);border-top:1px solid var(--gray-200);padding:7px 8px max(7px, env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffffff0;flex-shrink:0;grid-template-columns:repeat(6,minmax(0,1fr));gap:4px;display:grid;box-shadow:0 -12px 28px #0f172a12}.nav-btn{min-width:0;color:var(--gray-500);white-space:nowrap;border-radius:12px;padding:8px 5px;font-size:10px;font-weight:700;transition:color .15s,background .15s}.nav-btn--active{color:var(--white);background:linear-gradient(135deg, var(--blue), var(--teal));box-shadow:0 8px 18px #2563eb38}.nav-btn:hover:not(.nav-btn--active){color:var(--gray-700);background:var(--gray-100)}.screen{padding:18px}.screen-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.screen-header h1{color:var(--gray-900);letter-spacing:-.03em;margin:0;font-size:24px;font-weight:800}.screen-sub{color:var(--gray-500);font-size:12px}.section-title{text-transform:uppercase;letter-spacing:.8px;color:var(--gray-500);margin:20px 0 10px;font-size:11px;font-weight:600}.eyebrow{color:#ffffffc7;letter-spacing:.1em;text-transform:uppercase;align-items:center;gap:6px;font-size:12px;font-weight:800;display:inline-flex}.empty-hint{color:var(--gray-500);text-align:center;padding:32px 0;font-size:13px}.keto-status{text-align:center;box-shadow:var(--shadow-soft);border-radius:999px;margin-bottom:16px;padding:11px 16px;font-size:14px;font-weight:800}.keto-status--success{background:var(--green-bg);color:var(--green)}.keto-status--warning{background:var(--amber-bg);color:var(--amber)}.keto-status--danger{background:var(--red-bg);color:var(--red)}.cards-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:8px;display:grid}.cards-grid--hero{grid-template-columns:repeat(4,minmax(0,1fr))}.cards-grid--calories{margin-top:14px}.cards-grid--4{grid-template-columns:repeat(2,1fr)}.stat-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:14px}.stat-card--success{background:linear-gradient(180deg, var(--green-bg), var(--white));border-color:#10b98159}.stat-card--warning{background:linear-gradient(180deg, var(--amber-bg), var(--white));border-color:#b4530959}.stat-card--danger{background:linear-gradient(180deg, var(--red-bg), var(--white));border-color:#dc262659}.stat-card-label{color:var(--gray-500);margin-bottom:4px;font-size:11px}.stat-card-value{color:var(--gray-900);letter-spacing:-.04em;font-size:24px;font-weight:850;line-height:1}.stat-card-sub{color:var(--gray-500);margin-top:3px;font-size:11px}.progress-bar-wrap{margin-bottom:12px}.progress-panel{border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:var(--white);box-shadow:var(--shadow-soft);padding:14px}.progress-panel .progress-bar-wrap:last-child{margin-bottom:0}.progress-bar-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.progress-bar-label{color:var(--gray-700);font-size:13px;font-weight:500}.progress-bar-values{color:var(--gray-500);font-size:12px}.progress-bar-track{background:var(--gray-200);border-radius:999px;height:10px;overflow:hidden}.progress-bar-fill{border-radius:999px;height:100%;transition:width .3s}.progress-bar-fill--default{background:var(--blue)}.progress-bar-fill--success{background:var(--green-light)}.progress-bar-fill--warning{background:var(--amber)}.progress-bar-fill--danger{background:var(--red)}.recommendations{flex-direction:column;gap:8px;display:flex}.rec{border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:12px 14px;font-size:13px;line-height:1.4}.rec--info{background:var(--blue-bg);color:var(--blue)}.rec--warning{background:var(--amber-bg);color:var(--amber)}.rec--success{background:var(--green-bg);color:var(--green)}.btn{cursor:pointer;border:none;border-radius:999px;justify-content:center;align-items:center;padding:10px 16px;font-size:14px;font-weight:800;transition:transform .15s,opacity .15s,background .15s,box-shadow .15s;display:inline-flex}.btn--sm{padding:5px 10px;font-size:12px}.btn--primary{background:linear-gradient(135deg, var(--blue), var(--teal));color:var(--white);box-shadow:0 10px 18px #2563eb3d}.btn--primary:hover{transform:translateY(-1px)}.btn--secondary{background:var(--white);color:var(--gray-700);border:1px solid var(--gray-200);box-shadow:var(--shadow-soft)}.btn--secondary:hover{background:var(--gray-300)}.btn--ghost{background:var(--white);color:var(--blue);border:1px solid var(--blue)}.btn--danger{background:var(--red-bg);color:var(--red)}.btn--danger:hover{background:#fca5a5}.btn--favourite{background:var(--amber-bg);color:var(--amber)}.dashboard-hero{border-radius:var(--radius-lg);color:var(--white);background:radial-gradient(circle at top right, #2dd4bf61, transparent 36%), linear-gradient(135deg, var(--gray-900), #0f766e 58%, #2563eb);flex-direction:column;gap:12px;margin:-2px 0 16px;padding:20px;display:flex;box-shadow:0 18px 44px #0f172a38}.dashboard-hero__top,.dashboard-hero__meta{justify-content:space-between;align-items:center;gap:14px;display:flex}.dashboard-hero h1{letter-spacing:-.08em;margin:2px 0 0;font-size:clamp(42px,10vw,70px);font-weight:900;line-height:.9}.dashboard-hero p{color:#ffffffc7;margin:4px 0 0;font-size:14px;font-weight:650}.dashboard-hero .btn{color:var(--gray-900);background:#fffffff2;flex-shrink:0;box-shadow:0 12px 26px #0f172a2e}.dashboard-hero__meta{color:#ffffffc7;font-size:12px;font-weight:700}.hero-meter{background:#ffffff38;border-radius:999px;height:12px;overflow:hidden}.hero-meter span{border-radius:inherit;background:linear-gradient(90deg,#67e8f9,#a7f3d0);height:100%;display:block;box-shadow:0 0 16px #67e8f98c}.btn:disabled{opacity:.55;cursor:not-allowed}.food-form,.profile-form{flex-direction:column;gap:0;display:flex}.form-group{flex-direction:column;gap:4px;margin-bottom:12px;display:flex}.form-group-header{justify-content:space-between;align-items:center;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-section-title{text-transform:uppercase;letter-spacing:.8px;color:var(--gray-500);margin:8px 0;font-size:11px;font-weight:600}label{color:var(--gray-700);font-size:12px;font-weight:500}input[type=text],input[type=number],input[type=date],input[type=search],select{border:1px solid var(--gray-300);width:100%;color:var(--gray-900);background:var(--white);appearance:auto;border-radius:12px;padding:10px 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}input:focus,select:focus{border-color:var(--blue);outline:none;box-shadow:0 0 0 3px #2563eb26}input:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.form-error{color:var(--red);font-size:11px}.form-actions{align-items:center;gap:10px;margin-top:8px;display:flex}.net-carbs-preview{background:linear-gradient(135deg, var(--blue-bg), var(--white));border:1px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-700);margin-bottom:12px;padding:10px 12px;font-size:13px}.success-toast{background:var(--green-bg);color:var(--green);border-radius:var(--radius);margin-bottom:16px;padding:10px 12px;font-size:13px}.success-inline{color:var(--green);font-size:13px;font-weight:500}.date-picker{border:1px solid var(--gray-300);color:var(--gray-700);border-radius:999px;padding:8px 10px;font-size:13px}.log-list{flex-direction:column;gap:10px;display:flex}.meal-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px;display:grid}.meal-summary-card{border:1px solid var(--gray-200);border-radius:var(--radius);background:var(--white);box-shadow:var(--shadow-soft);flex-direction:column;gap:2px;padding:10px 12px;display:flex}.meal-summary-card strong{color:var(--gray-900);font-size:13px}.meal-summary-card span,.meal-summary-card small{color:var(--gray-500);font-size:11px}.meal-summary-card--empty{opacity:.7}.meal-log-section{border:1px solid var(--gray-200);border-radius:var(--radius);box-shadow:var(--shadow-soft);background:#ffffffc7;flex-direction:column;gap:8px;padding:12px;display:flex}.meal-log-section--empty{background:var(--gray-50)}.meal-log-header{color:var(--gray-900);justify-content:space-between;align-items:center;gap:8px;display:flex}.meal-log-header span{color:var(--gray-500);font-size:11px}.meal-log-items{flex-direction:column;gap:8px;display:flex}.log-item{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:12px}.log-item-row{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.log-item-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.log-item-name{color:var(--gray-900);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.log-item-serving{color:var(--gray-500);font-size:12px}.log-item-macros{color:var(--gray-700);font-size:12px}.log-item-actions{flex-shrink:0;gap:6px;display:flex}.meal-select-label{color:var(--gray-500);align-items:center;gap:5px;font-size:10px;display:flex}.meal-select-label select{width:auto;min-width:96px;padding:5px 7px;font-size:12px}.log-item-edit{flex-direction:column;gap:8px;display:flex}.search-input{width:100%;margin-bottom:12px}.saved-foods-list{flex-direction:column;gap:10px;display:flex}.saved-food-item{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);box-shadow:var(--shadow-soft);justify-content:space-between;align-items:flex-start;gap:10px;padding:14px;display:flex}.saved-food-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.saved-food-name{font-size:14px;font-weight:600}.saved-food-serving,.saved-food-electrolytes{color:var(--gray-500);font-size:11px}.saved-food-macros{color:var(--gray-700);font-size:12px}.saved-food-actions{flex-direction:column;flex-shrink:0;gap:6px;display:flex}.week-table{border-collapse:collapse;width:100%;margin-bottom:16px;font-size:12px}.week-table th{text-align:left;color:var(--gray-500);border-bottom:1px solid var(--gray-200);padding:6px 8px;font-weight:600}.week-table td{border-bottom:1px solid var(--gray-100);color:var(--gray-700);padding:6px 8px}.week-table__empty td{color:var(--gray-300)}.cell--danger{font-weight:600;color:var(--red)!important}.weight-form{align-items:flex-end;gap:8px;margin-bottom:16px;display:flex}.weight-input{border:1px solid var(--gray-300);border-radius:var(--radius);flex:1;padding:8px 10px;font-size:14px}.weight-list{flex-direction:column;gap:4px;margin-top:12px;display:flex}.weight-entry{color:var(--gray-500);border-bottom:1px solid var(--gray-100);padding:4px 0;font-size:13px}.diet-mode-group{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.diet-mode-option{border:1px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;align-items:center;gap:10px;padding:10px 12px;transition:border-color .15s,background .15s;display:flex}.diet-mode-option--selected{border-color:var(--blue);background:var(--blue-bg)}.diet-mode-option input[type=radio]{flex-shrink:0;width:auto}.diet-mode-label{color:var(--gray-700);font-size:13px;font-weight:500}.checkbox-label{color:var(--gray-500);cursor:pointer;align-items:center;gap:6px;font-size:11px;font-weight:500;display:flex}.checkbox-label input{width:auto}.suggestions-section{margin-top:16px}.search-row{align-items:center;gap:8px;margin-bottom:12px;display:flex}.search-row .search-input{flex:1;margin-bottom:0}.inline-form-panel{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);margin-bottom:16px;padding:16px}.inline-form-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.inline-form-header h2{margin:0;font-size:15px;font-weight:600}.autocomplete-list{background:var(--white);border:1px solid var(--gray-300);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:4px;overflow:hidden}.autocomplete-item{text-align:left;width:100%;color:var(--gray-700);border-bottom:1px solid var(--gray-100);padding:9px 12px;font-size:13px;transition:background .1s}.autocomplete-item:hover{background:var(--blue-bg);color:var(--blue)}.autocomplete-item-row{color:var(--gray-700);border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:6px 12px;font-size:13px;display:flex}.template-list{flex-direction:column;gap:10px;display:flex}.template-list-item{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);box-shadow:var(--shadow-soft);justify-content:space-between;align-items:flex-start;gap:10px;padding:12px;display:flex}.template-list-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.template-list-name{color:var(--gray-900);font-size:14px;font-weight:600}.template-items-list{flex-direction:column;gap:6px;margin-bottom:10px;display:flex}.template-item{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);align-items:center;gap:8px;padding:8px 10px;font-size:13px;display:flex}.template-item-name{flex:1;font-weight:500}.template-item-controls{align-items:center;gap:4px;display:flex}.template-totals{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-700);flex-wrap:wrap;gap:8px;margin:8px 0;padding:10px 12px;font-size:12px;display:flex}.template-totals strong{color:var(--gray-900)}.qty-input{width:60px!important;padding:4px 6px!important;font-size:13px!important}.btn--xs{padding:3px 7px;font-size:11px}.dim{color:var(--gray-500);font-size:11px}.ingredient-row{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);margin-bottom:8px;padding:10px}.ingredient-header{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:6px;display:flex}.ingredient-num{color:var(--gray-500);min-width:16px;font-size:12px;font-weight:600}.ingredient-nutrition{flex-wrap:wrap;gap:6px;display:flex}.form-group--tiny{flex:1;min-width:60px;margin-bottom:0!important}.form-group--tiny label{font-size:10px}.form-group--tiny input{padding:4px 6px!important;font-size:12px!important}.log-servings-row{align-items:center;gap:6px;display:flex}.shopping-add-row{gap:8px;margin-bottom:12px;display:flex}.shopping-add-row .search-input{flex:1;margin-bottom:0}.qty-text-input{border:1px solid var(--gray-300);border-radius:var(--radius);padding:8px 10px;font-size:14px}.shopping-generate{margin-bottom:12px}.generate-buttons{flex-wrap:wrap;gap:6px;display:flex}.shopping-list{flex-direction:column;gap:4px;display:flex}.shopping-list--done{opacity:.65}.shopping-item{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);box-shadow:var(--shadow-soft);justify-content:space-between;align-items:center;padding:8px 10px;font-size:13px;display:flex}.shopping-item--done .shopping-item-name{color:var(--gray-400);text-decoration:line-through}.shopping-check-label{cursor:pointer;flex:1;align-items:center;gap:8px;display:flex}.shopping-check-label input[type=checkbox]{flex-shrink:0;width:auto;margin:0}.shopping-item-name{flex:1}.shopping-item-qty,.shopping-item-source{color:var(--gray-500);font-size:11px}.plan-type-tabs{gap:6px;margin-bottom:12px;display:flex}.tab-btn{border-radius:var(--radius);color:var(--gray-600);background:var(--gray-100);border:1px solid var(--gray-200);cursor:pointer;padding:6px 14px;font-size:13px;font-weight:500;transition:background .15s,color .15s}.tab-btn--active{background:var(--blue);color:var(--white);border-color:var(--blue)}.plan-item--converted{opacity:.6}.badge-converted{background:var(--green-bg);color:var(--green);vertical-align:middle;border-radius:10px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.weight-add-row{flex-wrap:wrap;align-items:flex-end;gap:8px;margin-bottom:16px;display:flex}.weight-add-row .weight-input{flex:1;min-width:80px}.weight-entry--full{border-bottom:1px solid var(--gray-100);align-items:center;gap:8px;padding:8px 0;display:flex}.weight-entry-date{color:var(--gray-500);min-width:90px;font-size:13px}.weight-entry-value{color:var(--gray-900);flex:1;font-size:14px;font-weight:600}.weight-input--inline{flex:none!important;width:80px!important;padding:4px 8px!important;font-size:13px!important}.backup-actions{gap:10px;margin-bottom:12px;display:flex}.import-msg{border-radius:var(--radius);margin-top:8px;padding:10px 12px;font-size:13px}.import-msg--success{background:var(--green-bg);color:var(--green)}.import-msg--error{background:var(--red-bg);color:var(--red)}.micro-toggle{margin-bottom:8px}.form-group--micro{flex:1;min-width:80px}.empty-hint--compact{padding:12px 0}.quick-groups{flex-direction:column;gap:14px;display:flex}.quick-group h2{color:var(--gray-500);letter-spacing:.7px;text-transform:uppercase;margin:0 0 6px;font-size:11px;font-weight:600}.quick-result-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;display:grid}.quick-result{border:1px solid var(--gray-200);border-radius:var(--radius);background:var(--white);min-width:0;color:var(--gray-900);text-align:left;box-shadow:var(--shadow-soft);padding:12px}.quick-result span,.quick-result small{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.quick-result span{font-size:13px;font-weight:600}.quick-result small{color:var(--gray-500);text-transform:capitalize;font-size:10px}.quick-result--selected{border-color:var(--blue);background:var(--blue-bg)}.quick-add-panel,.copy-panel{border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:var(--white);box-shadow:var(--shadow-soft);flex-direction:column;gap:9px;margin-top:14px;padding:14px;display:flex}.serving-options{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.serving-chip{border:1px solid var(--gray-300);background:var(--white);color:var(--gray-700);border-radius:999px;padding:6px 9px;font-size:12px}.serving-chip--active{border-color:var(--blue);background:var(--blue);color:var(--white)}.serving-options input{width:72px!important;padding:6px 8px!important}.copy-panel-header,.copy-panel li{justify-content:space-between;align-items:center;gap:10px;display:flex}.copy-panel ul{flex-direction:column;gap:5px;display:flex}.copy-panel li{border-top:1px solid var(--gray-200);padding-top:6px;font-size:12px}.manual-entry{margin-top:20px}.manual-entry summary{cursor:pointer;color:var(--blue);padding:8px 0;font-weight:600}.manual-entry .food-form{padding-top:10px}.meal-type-badge{background:var(--blue-bg);color:var(--blue);text-transform:capitalize;border-radius:999px;align-self:flex-start;padding:1px 6px;font-size:10px}@media (width<=380px){.quick-result-list{grid-template-columns:1fr}.log-item-row{flex-direction:column}.log-item-actions{flex-wrap:wrap;width:100%}}.estimate-warning{border:1px solid var(--amber);border-radius:var(--radius);background:var(--amber-bg);color:var(--gray-700);box-shadow:var(--shadow-soft);flex-direction:column;gap:3px;padding:11px 12px;font-size:12px;display:flex}.privacy-note{color:var(--gray-500);margin:10px 0 14px;font-size:11px}.nutrition-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.barcode-panel,.barcode-review{flex-direction:column;gap:10px;margin-top:14px;display:flex}.barcode-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.barcode-video{object-fit:cover;border-radius:var(--radius);background:var(--gray-900);width:100%;max-height:280px}.barcode-product-card{border:1px solid var(--gray-200);border-radius:var(--radius);background:var(--white);box-shadow:var(--shadow-soft);flex-direction:column;gap:3px;padding:14px;display:flex}.barcode-product-card span,.barcode-product-card small{color:var(--gray-500)}@media (width<=760px){.app{max-width:none;box-shadow:none}.screen{padding:16px}.cards-grid--hero{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-hero{padding:18px}}@media (width<=520px){.nav{grid-template-columns:repeat(4,minmax(0,1fr));min-height:112px}.dashboard-hero__top{flex-direction:column;align-items:flex-start}.dashboard-hero .btn{width:100%}.form-row,.cards-grid,.meal-summary-grid,.nutrition-grid{grid-template-columns:1fr}.saved-food-item,.template-list-item,.log-item-row{flex-direction:column}.saved-food-actions,.log-item-actions{flex-flow:wrap;width:100%}.saved-food-actions .btn,.log-item-actions .btn{flex:1}}
