: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)}.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}.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)}.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}}.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;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 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 footer{margin-top:.5rem;display:flex;justify-content:flex-end}
