:root{--bg: #f4f6f5;--bg-elev: #ffffff;--ink: #16201d;--ink-soft: #5a6b66;--ink-faint: #94a39e;--line: #e4e9e7;--primary: #0f766e;--primary-soft: #d7efec;--primary-ink: #0a544e;--accent: #f97316;--accent-soft: #ffe7d3;--good: #16a34a;--warn: #d97706;--bad: #dc2626;--kcal: #f97316;--protein: #2563eb;--carb: #ca8a04;--fat: #db2777;--radius: 18px;--radius-sm: 12px;--shadow: 0 1px 2px rgba(16, 32, 29, .04), 0 8px 24px rgba(16, 32, 29, .06);--shadow-soft: 0 1px 2px rgba(16, 32, 29, .04);--maxw: 720px;--safe-b: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:16px}a{color:var(--primary)}.app{max-width:var(--maxw);margin:0 auto;min-height:100vh;position:relative}.topbar{position:sticky;top:0;z-index:30;background:linear-gradient(180deg,var(--bg) 70%,transparent);padding:18px 18px 10px;display:flex;align-items:center;justify-content:space-between}.topbar h1{font-size:20px;margin:0;letter-spacing:-.02em}.topbar .sub{font-size:12.5px;color:var(--ink-faint);margin-top:2px}.topbar-icon{width:40px;height:40px;border-radius:12px;border:1px solid var(--line);background:var(--bg-elev);color:var(--ink-soft);display:grid;place-items:center;font-size:18px}.content{padding:4px 16px 110px}.nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--maxw);z-index:40;display:grid;grid-template-columns:repeat(6,1fr);background:#ffffffdb;backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-top:1px solid var(--line);padding:8px 6px calc(8px + var(--safe-b))}.nav button{border:0;background:none;color:var(--ink-faint);display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10.5px;font-weight:600;padding:4px 2px;border-radius:10px;transition:color .15s}.nav button .ic{font-size:20px;line-height:1}.nav button.active{color:var(--primary)}.card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:16px}.card+.card,.stack>*+*{margin-top:12px}.section-title{font-size:13px;font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;margin:22px 4px 10px}.section-title:first-child{margin-top:8px}.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.kpi{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:14px 15px;box-shadow:var(--shadow-soft);position:relative;overflow:hidden}.kpi .label{font-size:12px;color:var(--ink-faint);font-weight:600}.kpi .value{font-size:26px;font-weight:800;letter-spacing:-.03em;margin-top:6px}.kpi .value small{font-size:13px;font-weight:600;color:var(--ink-faint)}.kpi .delta{font-size:12px;font-weight:700;margin-top:3px}.kpi.hero{grid-column:1 / -1;background:linear-gradient(135deg,var(--primary),#115e59);border:0;color:#eafcf8}.kpi.hero .label{color:#b8e8e1}.kpi.hero .value{font-size:40px;color:#fff}.delta.up{color:var(--good)}.delta.down{color:var(--bad)}.delta.flat{color:var(--ink-faint)}.progress-wrap{display:flex;align-items:center;gap:16px}.bar{height:9px;background:var(--line);border-radius:99px;overflow:hidden}.bar>span{display:block;height:100%;border-radius:99px;background:var(--primary);transition:width .4s ease}.macros{display:grid;gap:10px}.macro-row{display:grid;grid-template-columns:64px 1fr auto;align-items:center;gap:10px;font-size:13px}.macro-row .mname{font-weight:700;color:var(--ink-soft)}.macro-row .mval{font-variant-numeric:tabular-nums;color:var(--ink-soft);font-weight:600}.macro-row .bar>span.kcal{background:var(--kcal)}.macro-row .bar>span.protein{background:var(--protein)}.macro-row .bar>span.carb{background:var(--carb)}.macro-row .bar>span.fat{background:var(--fat)}.field{display:block;margin-bottom:12px}.field>label,.lbl{display:block;font-size:12.5px;font-weight:600;color:var(--ink-soft);margin-bottom:5px}.input,.select,textarea.input{width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus,textarea.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:var(--radius-sm);border:1px solid var(--line);background:#fff;color:var(--ink);font-weight:700;font-size:14.5px;transition:transform .08s,background .15s}.btn:active{transform:scale(.98)}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.accent{background:var(--accent);border-color:var(--accent);color:#fff}.btn.ghost{background:transparent}.btn.block{width:100%}.btn.sm{padding:8px 12px;font-size:13px}.btn.danger{color:var(--bad);border-color:#f3c9c9;background:#fdedec}.list{display:flex;flex-direction:column}.list-item{display:flex;align-items:center;gap:12px;padding:12px 4px;border-bottom:1px solid var(--line)}.list-item:last-child{border-bottom:0}.list-item .li-main{flex:1;min-width:0}.list-item .li-title{font-weight:700;font-size:14.5px}.list-item .li-sub{font-size:12.5px;color:var(--ink-faint);margin-top:2px}.pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:99px;background:var(--primary-soft);color:var(--primary-ink);white-space:nowrap}.pill.kcal{background:var(--accent-soft);color:#9a3412}.tag-meal{font-size:11px;font-weight:700;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.04em}.icon-btn{width:34px;height:34px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--ink-soft);display:grid;place-items:center;font-size:16px}.icon-btn.del{color:var(--bad);border-color:#f3c9c9;background:#fdeded}.date-strip{display:flex;align-items:center;gap:8px;margin-bottom:4px}.date-strip .input{text-align:center;font-weight:700}.chart{width:100%}.chart svg{display:block;width:100%;height:auto}.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--ink-soft);margin-top:8px}.legend span{display:inline-flex;align-items:center;gap:6px}.dot{width:9px;height:9px;border-radius:99px;display:inline-block}.empty{text-align:center;color:var(--ink-faint);padding:28px 10px;font-size:14px}.hint{font-size:12.5px;color:var(--ink-faint);line-height:1.5}.toast{position:fixed;left:50%;bottom:calc(86px + var(--safe-b));transform:translate(-50%);background:var(--ink);color:#fff;padding:10px 16px;border-radius:99px;font-size:13.5px;font-weight:600;z-index:60;box-shadow:var(--shadow);animation:pop .2s ease}@keyframes pop{0%{opacity:0;transform:translate(-50%,6px)}}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:360px;text-align:center}.login-logo{width:60px;height:60px;border-radius:18px;margin:0 auto 14px;background:linear-gradient(135deg,var(--primary),#115e59);color:#fff;display:grid;place-items:center;font-size:30px}.muted{color:var(--ink-faint)}.center{text-align:center}.flex{display:flex;align-items:center;gap:10px}.spread{display:flex;align-items:center;justify-content:space-between;gap:10px}.grow{flex:1}.nowrap{white-space:nowrap}.mt8{margin-top:8px}.mt16{margin-top:16px}.tabular{font-variant-numeric:tabular-nums}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th{text-align:left;color:var(--ink-faint);font-weight:700;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;padding:6px 8px;border-bottom:1px solid var(--line)}.tbl td{padding:8px;border-bottom:1px solid var(--line)}.tbl tr:last-child td{border-bottom:0}.tbl .num{text-align:right;font-variant-numeric:tabular-nums}@media(min-width:560px){.kpi-grid{grid-template-columns:repeat(3,1fr)}.kpi.hero{grid-column:1 / -1}}
