:root{--bg: #f4f6f4;--card: #ffffff;--green: #2e7d32;--green-dark: #1b5e20;--text: #1c1c1c;--muted: #6b7280;--border: #e3e6e3}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}.app{max-width:720px;margin:0 auto;padding-bottom:3rem}.topbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--green);color:#fff}.topbar h1{font-size:1.15rem;margin:0}.user-switch select{padding:.25rem;border-radius:6px}.tabs{display:flex;gap:.25rem;padding:.5rem;position:sticky;top:0;background:var(--bg);z-index:5;overflow-x:auto}.tab{flex:1;padding:.5rem;border:none;border-radius:8px;background:#e7ece7;cursor:pointer;white-space:nowrap}.tab.active{background:var(--green);color:#fff}.content{padding:0 1rem}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1rem;margin:.75rem 0}h2{margin:.5rem 0}h3,h4{margin:0 0 .5rem}.meal-title{text-transform:capitalize}.row{display:flex;align-items:center}.row.gap{gap:.5rem;flex-wrap:wrap}.row.spread{justify-content:space-between}.grow{flex:1}input,select,button{font-size:1rem;padding:.5rem;border-radius:8px;border:1px solid var(--border)}.qty{width:70px}button{cursor:pointer;background:#e7ece7}button.primary{background:var(--green);color:#fff;border-color:var(--green)}button.primary:hover{background:var(--green-dark)}.link{background:none;border:none;color:var(--green);text-decoration:underline;padding:0}.link.danger{color:#c0392b}.hint{color:var(--muted);font-size:.9rem}.log-list{list-style:none;padding:0;margin:0}.log-list li{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.log-list li:last-child{border-bottom:none}.log-list li.log-item{display:block}.log-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;cursor:pointer}.caret{display:inline-block;width:1rem;color:var(--muted)}.log-name{flex:1;min-width:7rem}.log-actions{display:inline-flex;align-items:center;flex-wrap:wrap;justify-content:flex-end;gap:.5rem .75rem}.log-actions .cal{color:var(--muted);font-size:.9rem;white-space:nowrap}.macros-detail{display:flex;flex-wrap:wrap;gap:.75rem;padding:.4rem 0 .2rem 1rem;color:var(--muted);font-size:.85rem}.qty-editor{display:inline-flex;align-items:center;gap:.25rem}.qty-editor .step{width:1.9rem;height:1.9rem;padding:0;line-height:1;font-size:1.1rem;border-radius:6px}.qty-editor .qty{width:3.5rem;text-align:center;padding:.35rem .25rem}.qty-wrap{display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap}.qty-label{color:var(--muted);font-size:.85rem}.macro{margin:.5rem 0}.macro-head{display:flex;justify-content:space-between;font-size:.9rem;margin-bottom:.25rem}.macro-track{height:8px;background:#e7ece7;border-radius:4px;overflow:hidden}.macro-fill{height:100%;background:var(--green)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.form-grid .full{grid-column:1 / -1}.form-grid label{display:flex;flex-direction:column;font-size:.9rem;gap:.25rem}.scanner{width:100%;border-radius:8px;background:#000}.primary.full{width:100%}.footer{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem 1rem 2rem;color:var(--muted);font-size:.85rem}.footer a{color:var(--green)}.footer .version{font-variant-numeric:tabular-nums}
