:root{--bg: #282a36;--card: #2f3142;--card-hi: #44475a;--border: #383a4c;--grid: #44475a;--text: #f8f8f2;--text-soft: #d8d8d2;--muted: #6272a4;--accent-cal: #ff79c6;--accent-pro: #50fa7b;--primary: #bd93f9;--primary-ink: #1b1228;--danger: #ff5555;--warn: #ffb86c;--info: #8be9fd;--radius: 14px;--radius-lg: 18px;--shadow: 0 1px 0 rgba(255, 255, 255, .04), 0 12px 36px rgba(0, 0, 0, .4);--shadow-sm: 0 1px 0 rgba(255, 255, 255, .04), 0 4px 14px rgba(0, 0, 0, .3);--font-body: ui-rounded, "SF Pro Rounded", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:var(--font-body);background:radial-gradient(1200px 600px at 80% -10%,rgba(189,147,249,.1),transparent 60%),radial-gradient(900px 500px at -10% 110%,rgba(80,250,123,.06),transparent 60%),var(--bg);background-attachment:fixed;color:var(--text);-webkit-font-smoothing:antialiased;letter-spacing:-.005em}button{font:inherit;cursor:pointer;border:none;background:var(--primary);color:var(--primary-ink);padding:.6rem 1rem;border-radius:10px;font-weight:600;transition:filter .12s,transform .12s}button:disabled{opacity:.5;cursor:not-allowed}button:hover:not(:disabled){filter:brightness(1.08)}button:active:not(:disabled){transform:translateY(1px)}button.ghost{background:transparent;color:var(--text-soft);border:1px solid var(--border)}button.ghost:hover:not(:disabled){background:var(--card-hi)}button.ghost.danger{color:var(--danger);border-color:#f556}button.primary{background:var(--primary);color:var(--primary-ink)}input{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:.55rem .8rem;border-radius:10px;font:inherit}input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #bd93f940}.loading{padding:2rem;color:var(--muted);display:flex;align-items:center;justify-content:center}.error{color:var(--danger);margin-top:.5rem}.empty{padding:3rem 1rem;text-align:center;color:var(--muted);background:var(--card);border:1px dashed var(--border);border-radius:var(--radius-lg)}.login-screen{display:grid;place-items:center;height:100vh}.login-card{background:var(--card);border:1px solid var(--border);padding:2.25rem;border-radius:var(--radius-lg);display:grid;gap:1rem;width:min(360px,90vw);box-shadow:var(--shadow)}.login-card h1{margin:0;font-size:1.65rem;display:flex;gap:.5rem;align-items:center}.shell{max-width:960px;margin:0 auto;padding:1.5rem 1.25rem 4rem}.topbar{display:flex;align-items:center;gap:1rem;padding:.5rem 0 1.5rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.brand{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.15rem;letter-spacing:-.01em}.brand-emoji{font-size:1.35rem;display:inline-block;transform:rotate(-12deg);filter:drop-shadow(0 1px 0 rgba(0,0,0,.3))}.nav{display:flex;gap:.25rem;flex:1;margin-left:1rem}.nav a{color:var(--muted);text-decoration:none;padding:.4rem .85rem;border-radius:999px;transition:background .12s,color .12s}.nav a:hover{color:var(--text-soft)}.nav a.active{background:var(--card-hi);color:var(--text)}.home{display:grid;gap:1.25rem}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.4rem 1.4rem 1.6rem;box-shadow:var(--shadow-sm)}.card h2{margin:0 0 1rem;font-size:.95rem;color:var(--muted);font-weight:500;letter-spacing:.02em;text-transform:uppercase}.rings{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;align-items:center;justify-items:center}.ring{display:grid;gap:.5rem;justify-items:center}.ring-bg{stroke:var(--grid);stroke-width:14;fill:none}.ring-value{fill:var(--text);font-weight:700;font-size:26px;font-family:inherit}.ring-goal{fill:var(--muted);font-size:12px;font-family:inherit}.ring-label{color:var(--text-soft);font-size:.9rem}.ring-stat{display:grid;gap:.25rem;justify-items:center}.ring-stat .big{font-size:2.6rem;font-weight:700;color:var(--primary)}.ring-stat .small{color:var(--muted)}.chart-wrap{width:100%}.meals-list{display:grid;gap:1rem}.day-section{display:grid;gap:0}.day-section-header{display:flex;align-items:center;gap:.75rem;width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:.8rem 1.1rem;color:var(--text);font:inherit;font-weight:600;font-size:.95rem;text-align:left;cursor:pointer;position:sticky;top:0;z-index:10;box-shadow:var(--shadow-sm);transition:background .12s,border-color .12s}.day-section-header:hover{background:var(--card-hi)}.day-section-header[aria-expanded=true]{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent}.day-label{flex:1;min-width:0}.day-meta{display:flex;gap:.9rem;align-items:baseline;font-size:.85rem;flex-shrink:0}.day-count{color:var(--muted);font-weight:400}.day-cal{color:var(--accent-cal);font-weight:600}.day-pro{color:var(--accent-pro);font-weight:600}.day-chevron{font-size:1.1rem;color:var(--muted);display:inline-block;transform:rotate(90deg);transition:transform .2s ease;line-height:1}.day-chevron.open{transform:rotate(-90deg)}.day-meals{display:grid;gap:0;border:1px solid var(--border);border-top:none;border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg);overflow:hidden}.day-meals .meal-card{border:none;border-radius:0;border-top:1px solid var(--border);box-shadow:none}.day-meals .meal-card:first-child{border-top:none}.day-meals .meal-card:last-child{border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}@media (max-width: 600px){.day-count{display:none}.day-meta{gap:.55rem;font-size:.8rem}}.meal-card{display:grid;grid-template-columns:150px 1fr;gap:1.1rem;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem;box-shadow:var(--shadow-sm)}.meal-card .thumb{width:150px;height:150px;border-radius:var(--radius);object-fit:cover;background:var(--grid);cursor:zoom-in;transition:transform .2s ease,box-shadow .2s ease}.meal-card .thumb:hover{transform:scale(1.03);box-shadow:0 0 0 3px #bd93f98c,0 8px 24px #0006}.meal-card .body{display:grid;gap:.55rem;align-content:start}.meal-card header{display:grid;gap:.3rem}.meal-card .when{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;color:var(--muted);font-size:.85rem}.meal-card .badge{background:var(--card-hi);padding:.15rem .55rem;border-radius:999px;font-size:.7rem;color:var(--text-soft)}.meal-card .confidence{padding:.15rem .55rem;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.02em}.meal-card .confidence.high{background:#50fa7b2e;color:var(--accent-pro)}.meal-card .confidence.medium{background:#ffb86c33;color:var(--warn)}.meal-card .confidence.low{background:#f553;color:var(--danger)}.meal-card .totals{display:flex;gap:1.25rem;font-size:1rem;align-items:baseline}.meal-card .totals strong{font-size:1.55rem;color:var(--primary);margin-right:.2rem}.meal-card .caption{margin:0;color:var(--text-soft);font-style:italic}.meal-card .items{list-style:none;padding:0;margin:0;display:grid;gap:.3rem}.meal-card .items li{display:flex;justify-content:space-between;gap:1rem;font-size:.9rem}.meal-card .items .muted{color:var(--muted);font-size:.8rem}.meal-card footer{display:flex;gap:.5rem;margin-top:.25rem}@media (max-width: 600px){.meal-card{grid-template-columns:1fr}.meal-card .thumb{width:100%;height:220px}}.lb-backdrop{position:fixed;inset:0;background:#0a0b12e0;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:grid;place-items:center;padding:1.25rem;z-index:200;cursor:zoom-out;animation:lb-backdrop-in .22s ease-out both}.lb-img{max-width:min(92vw,960px);max-height:88vh;border-radius:var(--radius-lg);object-fit:contain;cursor:default;box-shadow:0 0 0 1px #ffffff12,0 0 60px #bd93f933,0 32px 80px #000000bf;animation:lb-img-in .35s cubic-bezier(.175,.885,.32,1.275) both}.lb-close{position:fixed;top:1rem;right:1rem;width:2.25rem;height:2.25rem;border-radius:999px;background:#44475ad9;border:1px solid var(--border);color:var(--text-soft);font-size:.95rem;display:grid;place-items:center;padding:0;cursor:pointer;animation:lb-backdrop-in .22s ease-out both;transition:background .15s,color .15s}.lb-close:hover{background:var(--card-hi);color:var(--text)}@keyframes lb-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes lb-img-in{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.drawer-backdrop{position:fixed;inset:0;background:#14151eb3;backdrop-filter:blur(3px);display:flex;justify-content:flex-end;z-index:50}.drawer{background:var(--card);border-left:1px solid var(--border);width:min(440px,100vw);height:100vh;padding:1.4rem;overflow-y:auto;overflow-x:hidden;display:grid;gap:.85rem;align-content:start;box-shadow:-16px 0 40px #00000080}.drawer header{display:flex;justify-content:space-between;align-items:center}.drawer .totals-row{display:flex;gap:1.25rem;font-size:1rem;padding:.6rem 0;border-bottom:1px solid var(--border);color:var(--text)}.drawer label{display:grid;gap:.3rem;font-size:.85rem;color:var(--muted)}.drawer label input{width:100%}.drawer h4{margin:.5rem 0 0;color:var(--text-soft)}.drawer .item-rows{display:grid;gap:.4rem}.drawer .item-row{display:grid;grid-template-columns:1.4fr repeat(3,1fr) auto;gap:.4rem}.drawer .item-row input{min-width:0;width:100%}.drawer footer{margin-top:.5rem;display:flex;justify-content:flex-end}@media (max-width: 600px){.drawer .item-row{grid-template-columns:1fr 1fr 1fr auto;grid-template-rows:auto auto;grid-template-areas:"name name name del" "port cal  prot del"}.drawer .item-row input:nth-child(1){grid-area:name}.drawer .item-row input:nth-child(2){grid-area:port}.drawer .item-row input:nth-child(3){grid-area:cal}.drawer .item-row input:nth-child(4){grid-area:prot}.drawer .item-row button{grid-area:del;align-self:center}.drawer footer button{width:100%;justify-content:center}}.stat-chips{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.75rem}.stat-chip{background:var(--card-hi);border-radius:var(--radius);padding:.9rem 1rem;display:grid;gap:.25rem}.stat-chip__value{font-size:1.65rem;font-weight:700;letter-spacing:-.02em}.stat-chip__label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.heatmap{display:grid;gap:.75rem}.heatmap-nav{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.heatmap-nav__left{display:flex;align-items:center;gap:.4rem}.heatmap-nav__month{font-weight:600;font-size:.95rem;min-width:8.75rem;text-align:center;display:inline-block}.heatmap-nav__status{width:1.25rem;display:flex;align-items:center;justify-content:center}.spinner{display:inline-block;width:22px;height:22px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spinner-rotate .7s linear infinite}.spinner--sm{width:14px;height:14px;border-width:2px}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.heatmap-toggle{display:flex;border:1px solid var(--border);border-radius:999px;overflow:hidden}.heatmap-toggle__btn{padding:.25rem .7rem;font-size:.72rem;font-weight:600;background:transparent;color:var(--muted);border:none;border-radius:0;cursor:pointer;transition:background .12s,color .12s}.heatmap-toggle__btn:hover:not(:disabled){filter:none;background:var(--border);color:var(--text-soft)}.heatmap-toggle__btn--active{background:var(--grid);color:var(--text)}.heatmap-toggle__btn--active:hover:not(:disabled){background:var(--grid)}.heatmap-dow-row{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:2px}.heatmap-dow{text-align:center;font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.heatmap-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.heatmap-cell{aspect-ratio:1;border-radius:5px;min-width:0}.heatmap-cell--l0{background:var(--bg)}.heatmap-cell--protein.heatmap-cell--l1{background:#50fa7b33}.heatmap-cell--protein.heatmap-cell--l2{background:#50fa7b8c}.heatmap-cell--protein.heatmap-cell--l3{background:#50fa7be6}.heatmap-cell--cal-ok{background:#50fa7b8c}.heatmap-cell--cal-warn{background:#ffb86c8c}.heatmap-cell--cal-over{background:#ff55558c}.heatmap-cell--filler{background:transparent}.heatmap-cell--today{outline:2px solid var(--primary);outline-offset:1px}.ratio-badge{font-size:.78rem;color:var(--muted);white-space:nowrap}.legend{display:flex;flex-wrap:wrap;gap:.6rem 1rem;margin-top:.7rem}.legend-item{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;color:var(--muted)}.legend-swatch{width:10px;height:10px;border-radius:3px;flex-shrink:0}.legend-swatch--cal-ok{background:#50fa7bbf}.legend-swatch--cal-warn{background:#ffb86cd9}.legend-swatch--cal-over{background:#ff5555bf}.legend-swatch--pro-l1{background:#50fa7b33}.legend-swatch--pro-l2{background:#50fa7b8c}.legend-swatch--pro-l3{background:#50fa7be6}.legend-swatch--pro-none{background:var(--bg);border:1px solid var(--border)}.legend-swatch--muted{background:var(--muted)}@media (max-width: 480px){.heatmap-grid,.heatmap-dow-row{gap:3px}.heatmap-nav__month{font-size:.85rem}.legend{gap:.4rem .7rem}.legend-item{font-size:.68rem}}.settings{display:grid;gap:1.25rem}.settings-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.85rem}.settings-form label{display:grid;gap:.3rem;font-size:.85rem;color:var(--muted)}.settings-form label select,.settings-form label input{width:100%}select{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:.55rem .8rem;border-radius:10px;font:inherit}select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #bd93f940}.settings-recommendation{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.75rem;margin-bottom:1rem}.settings-stat{background:var(--card-hi);border-radius:var(--radius);padding:.9rem 1rem;display:grid;gap:.25rem}.settings-stat__label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;display:inline-flex;align-items:center;gap:.3rem}.settings-stat__value{font-size:1.3rem;font-weight:700;letter-spacing:-.02em}.info-tooltip{position:relative;display:inline-flex}.info-tooltip__trigger{width:15px;height:15px;border-radius:50%;background:var(--card-hi);color:var(--muted);border:1px solid var(--border);font-size:.62rem;font-style:italic;font-weight:700;font-family:Georgia,Times New Roman,serif;line-height:1;padding:0;display:inline-flex;align-items:center;justify-content:center;cursor:help}.info-tooltip__trigger:hover:not(:disabled){filter:none;background:var(--border);color:var(--text-soft)}.info-tooltip__bubble{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);width:max-content;max-width:220px;background:var(--card-hi);border:1px solid var(--border);border-radius:8px;padding:.55rem .7rem;font-size:.72rem;font-weight:400;text-transform:none;letter-spacing:normal;color:var(--text-soft);text-align:left;line-height:1.4;box-shadow:var(--shadow-sm);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .12s ease,transform .12s ease;z-index:20}.info-tooltip:hover .info-tooltip__bubble,.info-tooltip__bubble--open{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.settings-override-toggle{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-soft);margin-bottom:.85rem}.settings-override-toggle input{width:auto}.settings-footer{display:flex;align-items:center;gap:.85rem;margin-top:1rem}.settings-saved{color:var(--accent-pro);font-size:.85rem;font-weight:600}.meals-mode-toggle{display:flex;border:1px solid var(--border);border-radius:999px;overflow:hidden;width:fit-content;margin-bottom:1rem}.meals-mode-toggle__btn{padding:.4rem 1rem;font-size:.82rem;font-weight:600;background:transparent;color:var(--muted);border:none;border-radius:0}.meals-mode-toggle__btn:hover:not(:disabled){filter:none;background:var(--border);color:var(--text-soft)}.meals-mode-toggle__btn--active{background:var(--grid);color:var(--text)}.meals-mode-toggle__btn--active:hover:not(:disabled){background:var(--grid)}.month-cal{display:grid;gap:.75rem}.month-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;transition:opacity .15s ease}.month-cal-grid--loading{opacity:.5;pointer-events:none}.month-cal-cell{position:relative;background:var(--card-hi);border:1px solid transparent;border-radius:8px;min-height:56px;min-width:0;padding:.3rem .2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.1rem;font-weight:400;transition:box-shadow .15s ease}.month-cal-cell:hover:not(:disabled){filter:none;background:var(--border)}.month-cal-cell--filler{background:transparent;border:none;cursor:default}.month-cal-cell--today{border-color:var(--primary)}.month-cal-cell--selected{outline:2px solid var(--primary);outline-offset:1px}.month-cal-cell--one-met{box-shadow:inset 0 0 0 1px #ffd764b3}.month-cal-cell--both-met{box-shadow:inset 0 0 0 1px #50fa7bd9,0 0 10px #50fa7b66}.month-cal-cell__badge{position:absolute;top:3px;right:4px;font-size:9px;line-height:1;letter-spacing:-1px}.month-cal-cell__badge--full{color:var(--accent-pro);text-shadow:0 0 5px rgba(80,250,123,.9)}.month-cal-cell__badge--partial{color:#ffd764;opacity:.85;font-size:7px;letter-spacing:normal}.month-cal-cell__day{font-size:.7rem;color:var(--muted)}.month-cal-cell__cal{font-size:.78rem;font-weight:700;color:var(--text-soft)}.month-cal-cell__cal--ok{color:var(--accent-pro)}.month-cal-cell__cal--warn{color:var(--warn)}.month-cal-cell__cal--over{color:var(--danger)}.month-cal-cell__pro{font-size:.68rem;color:var(--muted)}.month-cal-cell__pro--met{color:var(--accent-pro)}.month-cal-cell__empty{font-size:.85rem;color:var(--muted)}.legend-badge{position:static!important;display:inline-block;font-size:10px!important}@media (max-width: 480px){.month-cal-grid{gap:3px}.month-cal-cell{min-height:46px}.month-cal-cell__day{font-size:.62rem}.month-cal-cell__cal{font-size:.7rem}.month-cal-cell__pro{font-size:.6rem}}.day-view{display:grid;gap:0;margin-top:1.25rem}.day-view-header{display:flex;align-items:center;gap:.75rem;background:var(--card);border:1px solid var(--border);border-bottom:none;border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);padding:.8rem 1.1rem;font-weight:600;font-size:.95rem}.day-view .empty{border-top-left-radius:0;border-top-right-radius:0}
