:root{color:#172118;background:#f4fbf1;font-family:PingFang SC,Microsoft YaHei,-apple-system,BlinkMacSystemFont,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 20% 0%,rgba(41,190,104,.16),transparent 28rem),linear-gradient(180deg,#f6fcf4,#eef9ef)}button,textarea{font:inherit}button{cursor:pointer}.app-shell{width:min(1180px,100%);margin:0 auto;padding:28px 18px 52px}.hero-panel{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:24px}.eyebrow{margin:0 0 10px;color:#16a85b;font-size:13px;font-weight:900}h1,h2,h3,p{margin:0}h1{font-size:clamp(34px,7vw,58px);line-height:1.05;letter-spacing:0}.hero-copy{max-width:580px;margin-top:14px;color:#6f7f70;font-size:16px;line-height:1.7}.ai-badge{display:grid;flex:0 0 96px;width:96px;height:96px;place-items:center;border-radius:50%;background:#172118;color:#fff;box-shadow:0 20px 44px #17211829}.ai-badge strong{align-self:end;font-size:27px}.ai-badge span{align-self:start;color:#ffffffb8;font-size:12px}.workspace{display:grid;grid-template-columns:minmax(0,450px) minmax(0,1fr);gap:22px;align-items:start}.left-column,.result-panel{display:grid;gap:18px}.right-column{position:sticky;top:18px}.card,.macro-card{border:1px solid rgba(48,98,56,.08);border-radius:18px;background:#fffffff0;box-shadow:0 18px 50px #24472a14}.input-card{padding:24px}.section-head{margin-bottom:16px}.section-head h2,.favorites-head h2,.card h3{font-size:22px;line-height:1.3}.section-head p,.favorites-head p,.empty-card p,.card-note,.freezer-head p,.result-empty p{margin-top:6px;color:#748174;font-size:14px;line-height:1.55}textarea{width:100%;min-height:230px;resize:vertical;border:0;border-radius:16px;outline:none;padding:18px;background:#f8fbf6;color:#172118;font-size:16px;line-height:1.6}textarea::placeholder{color:#9aa79a}.example-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.example-chip{min-height:36px;border:0;border-radius:999px;padding:0 14px;background:#edf8f1;color:#238451;font-size:13px;font-weight:800}.serving-block{margin-top:24px}.serving-label{margin-bottom:12px;color:#314236;font-size:16px;font-weight:800}.serving-options{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.serving-pill{display:flex;align-items:center;justify-content:center;height:46px;border:0;border-radius:999px;background:#eef6ed;color:#60705f;font-size:15px;font-weight:900}.serving-pill.active{background:#172118;color:#fff}.primary-button,.like-button{display:flex;align-items:center;justify-content:center;min-height:54px;border:0;border-radius:999px;font-weight:900}.primary-button{width:100%;margin-top:24px;background:#19b15f;color:#fff;box-shadow:0 16px 30px #19b15f38}.primary-button:disabled{background:#a7d9bb;box-shadow:none;cursor:wait}.error-box{margin-top:14px;border-radius:14px;padding:12px 14px;background:#fff1e8;color:#a14b13;font-size:14px;line-height:1.5}.favorites-section{display:grid;gap:12px}.favorites-head{display:flex;align-items:center;justify-content:space-between}.favorites-head span{border-radius:999px;padding:7px 12px;background:#e9f8ee;color:#18884b;font-size:13px;font-weight:900}.empty-card,.favorite-card,.result-empty{padding:20px}.empty-card strong{display:block;margin-bottom:6px;font-size:18px}.favorite-list{display:grid;gap:10px}.favorite-card{width:100%;border:0;text-align:left}.favorite-card span{display:block;color:#172118;font-size:17px;font-weight:900}.favorite-card small{display:block;margin-top:8px;color:#687765;font-size:13px;line-height:1.4}.result-empty{min-height:420px;display:flex;flex-direction:column;justify-content:center}.result-empty span{color:#16a85b;font-size:13px;font-weight:900}.result-empty h2{max-width:520px;margin-top:14px;font-size:clamp(28px,5vw,44px);line-height:1.15}.card-dark{border-radius:22px;padding:26px;background:#172118;color:#fff;box-shadow:0 20px 50px #1721182e}.result-hero span{display:inline-flex;border-radius:999px;padding:8px 12px;background:#ffffff1f;color:#a9efbf;font-size:13px;font-weight:900}.result-hero h2{margin-top:18px;font-size:clamp(28px,4vw,42px);line-height:1.18}.result-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.result-tags small{border-radius:999px;padding:8px 11px;background:#ffffff1a;color:#ffffffc2;font-size:12px}.macro-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.macro-card{min-height:104px;padding:18px}.macro-card span{color:#7b8878;font-size:13px;font-weight:900}.macro-card strong{display:block;margin-top:12px;font-size:19px;line-height:1.25}.result-actions{display:grid;grid-template-columns:1fr 128px;gap:12px}.result-actions .primary-button{margin-top:0}.like-button{background:#fff;color:#172118;box-shadow:0 14px 34px #24472a12}.like-button.active{background:#e9f8ee;color:#19a85b}.card{padding:22px}.item-list{display:grid;margin-top:14px}.item-row{display:grid;grid-template-columns:10px 1fr;gap:12px;padding:12px 0;border-bottom:1px solid #edf2ea}.item-row:last-child{border-bottom:0}.item-row i{width:9px;height:9px;margin-top:10px;border-radius:50%;background:#19b15f}.item-row span,.step p,.replacement-list p{color:#263329;font-size:15px;line-height:1.65}.freezer-head{display:flex;justify-content:space-between;gap:16px}.status{flex:0 0 auto;height:36px;border-radius:999px;padding:0 14px;line-height:36px;font-size:13px}.status.ok{background:#e4f8eb;color:#168f4d}.status.warn{background:#fff1dc;color:#b36a15}.chip-row{display:flex;flex-wrap:wrap;gap:9px;margin-top:16px}.warn-chip{border-radius:999px;padding:8px 11px;background:#fff4e6;color:#a96011;font-size:13px}.replacement-list{display:grid;gap:10px;margin-top:16px}.replacement-list p{border-radius:14px;padding:12px 14px;background:#f3faf4}.steps{display:grid;gap:10px;margin-top:16px}.step{display:grid;grid-template-columns:34px 1fr;gap:12px}.step span{width:34px;height:34px;border-radius:50%;background:#172118;color:#fff;font-size:13px;font-weight:900;line-height:34px;text-align:center}@media(max-width:860px){.app-shell{padding:24px 14px 44px}.workspace{grid-template-columns:1fr}.right-column{position:static}.macro-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:520px){.hero-panel{align-items:flex-start}.ai-badge{flex-basis:78px;width:78px;height:78px}.ai-badge strong{font-size:22px}.ai-badge span{font-size:11px}.input-card,.card,.card-dark{padding:20px;border-radius:18px}textarea{min-height:210px}.serving-options{gap:8px}.serving-pill{height:42px;font-size:14px}.result-actions{grid-template-columns:1fr}}
