html{color:#e2e8f0;-webkit-font-smoothing:antialiased;background:#0a0f1e;font-family:system-ui,-apple-system,sans-serif}body{margin:0}#root{width:100%;min-height:100svh}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0f1e;--surface:#0f172a;--card:#1e293b;--border:#334155;--text:#e2e8f0;--muted:#94a3b8;--accent:#6366f1;--radius:10px}html,body,#root{background:var(--bg);height:100%;color:var(--text);font-family:system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.5}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.app-title{color:var(--accent);letter-spacing:.5px;font-size:1.1rem;font-weight:700}.app-nav{gap:4px;display:flex}.nav-btn{color:var(--muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;padding:6px 12px;font-size:.85rem;transition:all .15s}.nav-btn:hover{color:var(--text);background:var(--card)}.nav-btn.active{color:var(--text);background:var(--card);border-color:var(--border)}.app-main{flex:1;width:100%;max-width:640px;margin:0 auto;padding:16px}.page{flex-direction:column;gap:20px;display:flex}.input-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:10px;padding:16px;display:flex}.input-row{gap:8px;display:flex}.input-value{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:7px;outline:none;flex:1;min-width:0;padding:10px 12px;font-size:1rem;transition:border-color .15s}.input-value:focus{border-color:var(--accent)}.input-select{background:var(--bg);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:7px;outline:none;flex-shrink:0;padding:10px 8px;font-size:.85rem}.btn-send{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:7px;padding:11px;font-size:.95rem;font-weight:600;transition:opacity .15s}.btn-send:hover{opacity:.85}.btn-send:disabled{opacity:.5;cursor:not-allowed}.status{font-size:.85rem}.status.ok{color:#22c55e}.status.err{color:#ef4444}.summary-cards{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}@media (width>=480px){.summary-cards{grid-template-columns:repeat(4,1fr)}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:12px}.card-clickable{cursor:pointer}.card-clickable:hover{border-color:var(--accent)}.card-title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:.7rem}.card-value{font-size:1.15rem;font-weight:700}.card-sub{margin-top:2px;font-size:.75rem}.card-hint{color:var(--muted);margin-top:4px;font-size:.65rem}.range-tabs,.metric-tabs{flex-wrap:wrap;gap:4px;display:flex}.tab-btn{background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:pointer;border-bottom:2px solid #0000;border-radius:6px 6px 0 0;padding:6px 12px;font-size:.82rem;transition:all .15s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--text);background:var(--card)}.chart-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px}.chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 4px 8px}.chart-empty{text-align:center;color:var(--muted);padding:40px 0;font-size:.9rem}.chart-empty-sm{text-align:center;color:var(--muted);padding:20px 0;font-size:.85rem}.balance-legend{color:var(--muted);flex-wrap:wrap;justify-content:center;gap:16px;margin-top:8px;font-size:.75rem;display:flex}.daily-log{flex-direction:column;gap:12px;display:flex}.log-day{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px}.log-date{color:var(--muted);text-transform:capitalize;margin-bottom:8px;font-size:.8rem;font-weight:600}.log-entries{flex-wrap:wrap;gap:6px;display:flex}.log-badge{white-space:nowrap;border-radius:20px;padding:3px 9px;font-size:.8rem}.log-badge.metric{color:#93c5fd;background:#1e3a5f}.log-badge.sport{color:#86efac;background:#14532d}.log-badge.extra{color:#fca5a5;background:#4c1d1d}.log-empty{text-align:center;color:var(--muted);padding:30px;font-size:.9rem}.section-title{color:var(--text);font-size:1.1rem;font-weight:700}.sub-title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:.9rem;font-weight:600}.resume-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:8px;padding:14px;display:flex}.mini-charts{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}@media (width>=480px){.mini-charts{grid-template-columns:repeat(3,1fr)}}.mini-chart-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:8px 4px 4px}.mini-chart-title{text-align:center;margin-bottom:4px;font-size:.75rem;font-weight:600}.text-summary{flex-direction:column;gap:8px;display:flex}.ts-row{background:var(--card);border-radius:8px;flex-direction:column;gap:6px;padding:10px 12px;display:flex}.ts-date{color:var(--muted);font-size:.8rem;font-weight:600}.ts-cols{flex-wrap:wrap;gap:8px;font-size:.82rem;display:flex}.ts-tags{flex-wrap:wrap;gap:5px;display:flex}.gate-overlay{background:var(--bg);z-index:100;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.gate-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:14px;width:280px;padding:32px 24px;display:flex}.gate-title{color:var(--accent);text-align:center;margin-bottom:4px;font-size:1.3rem;font-weight:700}.balance-bar-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:8px;padding:14px;display:flex}.balance-bar-header{justify-content:space-between;align-items:baseline;display:flex}.balance-bar-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.82rem;font-weight:700}.balance-bar-target{color:var(--muted);font-size:.78rem}.balance-bar-track{background:var(--card);border-radius:6px;height:12px;position:relative;overflow:hidden}.balance-bar-fill{border-radius:6px;height:100%;transition:width .3s,background .3s}.balance-bar-overflow{background:#ef444466;border-radius:0 6px 6px 0;height:100%;position:absolute;top:0;right:0}.balance-marker{opacity:.6;z-index:1;background:#f59e0b;width:2px;position:absolute;top:0;bottom:0}.balance-bar-footer{justify-content:space-between;align-items:baseline;font-size:.88rem;display:flex}.balance-bar-diff{font-size:.78rem}.balance-zones{flex-wrap:wrap;justify-content:space-between;gap:4px;font-size:.72rem;display:flex}.kcal-hint{color:var(--muted);margin-top:-8px;font-size:.82rem}.kcal-tabs{flex-wrap:wrap;gap:6px;display:flex}.kcal-tab{background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:pointer;white-space:nowrap;border-radius:20px;padding:5px 12px;font-size:.8rem;transition:all .15s}.kcal-tab:hover{color:var(--text)}.kcal-tab.active{color:var(--text);background:var(--card);border-color:var(--accent)}.food-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}@media (width>=480px){.food-grid{grid-template-columns:repeat(3,1fr)}}.food-item{background:var(--surface);border:1px solid var(--border);border-radius:8px;transition:border-color .15s;overflow:hidden}.food-item.selected{border-color:var(--accent)}.food-item.sport-item{border-color:#1a3a1a}.food-item.sport-item.selected{border-color:#22c55e}.food-btn{cursor:pointer;text-align:left;background:0 0;border:none;flex-direction:column;gap:3px;width:100%;padding:10px;display:flex}.food-btn:hover{background:#ffffff08}.food-label{color:var(--text);font-size:.78rem;line-height:1.3}.food-kcal{font-size:.75rem;font-weight:700}.food-kcal.pos{color:#f59e0b}.food-kcal.neg{color:#22c55e}.food-counter{justify-content:space-between;align-items:center;gap:8px;padding:4px 10px 8px;display:flex}.counter-btn{background:var(--card);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:26px;height:26px;font-size:1rem;line-height:1;display:flex}.counter-btn:hover{background:var(--border)}.counter-val{color:var(--accent);font-size:.85rem;font-weight:700}.kcal-summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:12px;padding:16px;display:flex;position:sticky;bottom:12px}.kcal-summary-title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:700}.kcal-empty{color:var(--muted);text-align:center;padding:8px 0;font-size:.85rem}.kcal-list{flex-direction:column;gap:5px;max-height:180px;list-style:none;display:flex;overflow-y:auto}.kcal-list-item{justify-content:space-between;align-items:center;gap:8px;font-size:.82rem;display:flex}.kcal-item-label{color:var(--text);flex:1}.kcal-item-val{flex-shrink:0;font-weight:700}.kcal-totals{border-top:1px solid var(--border);flex-direction:column;gap:5px;padding-top:10px;display:flex}.kcal-total-row{color:var(--muted);justify-content:space-between;font-size:.85rem;display:flex}.kcal-total-row.total-line{color:var(--text);border-top:1px solid var(--border);margin-top:4px;padding-top:6px;font-size:1rem}.pos{color:#ef4444}.neg{color:#22c55e}.kcal-actions{gap:10px;display:flex}.btn-reset{background:var(--card);border:1px solid var(--border);color:var(--muted);cursor:pointer;border-radius:7px;padding:10px 14px;font-size:.85rem}.btn-reset:hover{color:var(--text)}.loading{text-align:center;color:var(--muted);padding:20px}.error{text-align:center;color:#ef4444;background:#1a0808;border-radius:8px;padding:12px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
