/* NutriGuide MVP — эстетика «велнес-консьерж»: бумага, травяной, терракота. */
:root{
  --paper:#F4EDDF; --card:#FCFAF3; --ink:#211D17; --mist:#8C8273; --line:#E3D8C2;
  --herb:#233E2D; --herb-2:#335C40; --herb-soft:#E7EEE4; --clay:#C0573A;
  --clay-soft:#F3E2D7; --gold:#B8923F; --ok:#3E7A4E; --radius:20px;
  --shadow:0 1px 2px rgba(33,29,23,.05),0 12px 32px -16px rgba(33,29,23,.28);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:"Manrope",system-ui,sans-serif;color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;overscroll-behavior:none;
}
.app{max-width:480px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;
  background:radial-gradient(120% 80% at 100% 0%,#EDE3CE 0%,rgba(237,227,206,0) 50%),var(--paper);
  position:relative}

/* шапка */
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:calc(env(safe-area-inset-top) + 14px) 20px 12px}
.brand{font-family:"Playfair Display",serif;font-size:20px;font-weight:700}
.brand b{color:var(--clay)} .brand .leaf{margin-right:4px}
.profile-mini{background:var(--card);border:1px solid var(--line);width:38px;height:38px;
  border-radius:50%;font-size:16px;cursor:pointer}

/* вьюхи */
main{flex:1;padding:4px 20px 96px}
.view{display:none;animation:fade .4s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.view-title{font-family:"Playfair Display",serif;font-size:25px;font-weight:700;margin:6px 0 6px}
.muted{color:var(--mist);font-size:14px;line-height:1.5}

/* герой */
.hero{margin:8px 0 18px}
.hero-eyebrow{font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--clay);margin-bottom:8px}
.hero h1{font-family:"Playfair Display",serif;font-weight:700;font-size:30px;line-height:1.1;margin-bottom:10px}
.hero h1 i{color:var(--herb-2)}

/* кнопка скана */
.scan-btn{width:100%;border:none;cursor:pointer;font-family:inherit;font-weight:800;font-size:17px;
  color:#F4EDDF;background:linear-gradient(155deg,var(--herb),#19301f);padding:20px;border-radius:var(--radius);
  box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;gap:10px;transition:transform .15s}
.scan-btn:active{transform:scale(.98)}
.scan-btn .cam{font-size:22px}
.or{text-align:center;color:var(--mist);font-size:12px;margin:14px 0;font-weight:600}
.paste{display:flex;gap:8px}
.paste input{flex:1;font-family:inherit;font-size:15px;padding:13px 14px;border-radius:14px;border:1.5px solid var(--line);background:#fff}
.paste input:focus{outline:none;border-color:var(--herb-2)}
.paste button{border:none;background:var(--herb);color:#F4EDDF;font-size:18px;width:50px;border-radius:14px;cursor:pointer}

.profile-chip{margin:16px 0 0;font-size:12.5px;color:var(--mist)}
.profile-chip b{color:var(--herb)}

/* поиск конкретного блюда */
.lookup-block{margin-top:18px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px}
.lookup-title{font-weight:800;font-size:13px;letter-spacing:.02em;margin-bottom:10px}
.lookup{display:flex;gap:8px}
.lookup input{flex:1;font-family:inherit;font-size:15px;padding:12px 14px;border-radius:13px;border:1.5px solid var(--line);background:#fff}
.lookup input:focus{outline:none;border-color:var(--herb-2)}
.lookup button{border:none;background:var(--herb);color:#F4EDDF;font-weight:700;font-size:13px;padding:0 16px;border-radius:13px;cursor:pointer;white-space:nowrap}
.verdict{display:inline-block;font-size:12px;font-weight:800;padding:5px 11px;border-radius:20px;margin-top:10px}
.verdict.good{background:var(--herb-soft);color:var(--herb)}
.verdict.bad{background:var(--clay-soft);color:var(--clay)}
.verdict.neutral{background:#efe7d3;color:var(--gold)}
.lookup-hint{font-size:12px;color:var(--mist);margin-top:10px;line-height:1.45}
.detail{margin-top:12px;border-top:1px solid var(--line);padding-top:12px}
.detail .dnm{font-weight:700;font-size:15.5px}
.detail .dmeta{font-size:12px;color:var(--mist);margin-top:3px}
.detail .dsost{font-size:13px;color:var(--ink);margin-top:9px;line-height:1.5}
.detail .dsost b{color:var(--mist);font-weight:700}
.detail .add{margin-top:12px;width:100%;border:1.5px solid var(--line);background:transparent;color:var(--herb);font-family:inherit;font-weight:700;font-size:13px;padding:9px;border-radius:12px;cursor:pointer}
.detail.added .add{background:var(--herb);color:#F4EDDF;border-color:var(--herb)}

/* результат */
.place-head{margin:20px 0 6px}
.place-head .kicker{font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--clay)}
.place-head h3{font-family:"Playfair Display",serif;font-size:24px;font-weight:700;margin-top:2px}
.place-head .sub{font-size:12.5px;color:var(--mist);margin-top:2px}
.subhead{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--mist);margin:18px 0 10px}

.dish{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:14px 16px;margin-bottom:11px}
.dish.lead{border:1.5px solid var(--herb-2);box-shadow:var(--shadow)}
.dish .top{display:flex;justify-content:space-between;gap:10px;align-items:baseline}
.dish .nm{font-weight:700;font-size:15px;line-height:1.25}
.dish .pr{font-weight:800;color:var(--herb);font-size:14px;white-space:nowrap}
.dish .meta{font-size:11.5px;color:var(--mist);margin-top:3px}
.dish .desc{font-size:12.5px;color:var(--mist);margin-top:7px;line-height:1.45;max-height:3.5em;overflow:hidden}
.dish .why{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.why .pos{font-size:11px;font-weight:700;background:var(--herb-soft);color:var(--herb);padding:4px 9px;border-radius:13px}
.why .neg{font-size:11px;font-weight:700;background:var(--clay-soft);color:var(--clay);padding:4px 9px;border-radius:13px}
.dish .add{margin-top:11px;width:100%;border:1.5px solid var(--line);background:transparent;color:var(--herb);
  font-family:inherit;font-weight:700;font-size:13px;padding:9px;border-radius:12px;cursor:pointer}
.dish .add:active{background:var(--herb-soft)}
.dish.added .add{background:var(--herb);color:#F4EDDF;border-color:var(--herb)}

.avoid{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:11px 14px;
  border:1px dashed #e7b9a7;border-radius:13px;margin-bottom:9px;background:#fbf1ec}
.avoid .nm{font-weight:700;font-size:13.5px}
.avoid small{color:#a8543c;font-size:11px}

/* заглушка / сообщения */
.stub,.note{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;text-align:center;margin-top:16px}
.stub-ic{font-size:40px}
.stub h3{font-family:"Playfair Display",serif;font-size:20px;margin:10px 0 8px}
.stub p{color:var(--mist);font-size:14px;line-height:1.5;margin-bottom:6px}
.note{text-align:left}
.note b{color:var(--clay)}

/* профиль */
.conditions{margin:14px 0}
.cond{display:flex;align-items:center;gap:12px;background:var(--card);border:1.5px solid var(--line);
  border-radius:15px;padding:14px 16px;margin-bottom:10px;cursor:pointer;transition:border-color .2s}
.cond.on{border-color:var(--herb-2);background:var(--herb-soft)}
.cond .box{width:22px;height:22px;border-radius:7px;border:2px solid var(--line);display:grid;place-items:center;flex-shrink:0;font-size:13px;color:transparent}
.cond.on .box{background:var(--herb);border-color:var(--herb);color:#fff}
.cond .lbl{font-weight:700;font-size:14.5px}
.disclaimer{font-size:11.5px;color:var(--mist);line-height:1.5;margin-top:10px}

/* история */
.manual-add{display:flex;gap:8px;margin:12px 0 6px}
.manual-add input{flex:1;font-family:inherit;font-size:15px;padding:12px 14px;border-radius:13px;border:1.5px solid var(--line);background:#fff}
.manual-add input:focus{outline:none;border-color:var(--herb-2)}
.manual-add button{border:none;background:var(--herb);color:#F4EDDF;font-size:20px;width:48px;border-radius:13px;cursor:pointer}
.hint-row{font-size:11.5px;color:var(--mist);margin-bottom:14px}
.hist-day{font-size:12px;font-weight:800;color:var(--mist);margin:16px 0 8px;letter-spacing:.04em}
.hist-item{display:flex;justify-content:space-between;align-items:center;gap:10px;background:var(--card);
  border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin-bottom:8px}
.hist-item .nm{font-weight:700;font-size:14px}
.hist-item .src{font-size:11px;color:var(--mist);margin-top:2px}
.hist-item .del{background:none;border:none;color:var(--mist);font-size:16px;cursor:pointer}
.empty{text-align:center;color:var(--mist);font-size:14px;padding:40px 10px}

/* таббар */
.tabbar{position:fixed;left:0;right:0;bottom:0;max-width:480px;margin:0 auto;display:flex;
  background:rgba(252,250,243,.95);backdrop-filter:blur(10px);border-top:1px solid var(--line);
  padding:8px 6px calc(env(safe-area-inset-bottom) + 8px)}
.tab{flex:1;background:none;border:none;cursor:pointer;font-family:inherit;font-size:11px;font-weight:700;
  color:var(--mist);display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px}
.tab span{font-size:20px;filter:grayscale(1);opacity:.6}
.tab.active{color:var(--herb)} .tab.active span{filter:none;opacity:1}

/* камера */
.camera{position:fixed;inset:0;background:#000;z-index:100;display:none;align-items:center;justify-content:center}
.camera.on{display:flex}
.camera video{width:100%;height:100%;object-fit:cover}
.camera-frame{position:absolute;width:62vw;max-width:280px;aspect-ratio:1;border:3px solid rgba(255,255,255,.9);
  border-radius:24px;box-shadow:0 0 0 100vmax rgba(0,0,0,.45)}
.camera-hint{position:absolute;bottom:14%;color:#fff;font-weight:700;font-size:15px;text-shadow:0 1px 4px rgba(0,0,0,.6)}
.camera-close{position:absolute;top:calc(env(safe-area-inset-top) + 16px);right:18px;width:42px;height:42px;
  border-radius:50%;border:none;background:rgba(255,255,255,.9);font-size:18px;cursor:pointer}

.spinner{text-align:center;color:var(--mist);font-size:14px;padding:24px}
