/* ===== Стройность — дизайн-система (app-shell) ===== */
:root{
  --bg:#f8f7f2; --surface:#ffffff; --sidebar:#fcfbf7;
  --ink:#232b26; --muted:#828a82; --line:#ede9e0;
  --green:#23795c; --green-2:#3aa379; --green-soft:#e9f5ee; --green-tint:#f3faf6;
  --gold:#c9a227; --coral:#d9775a; --sea:#39b6ab; --sea-d:#2a9c92; --sea-soft:#e9f7f5;
  --r:20px; --r-sm:13px; --shadow:0 3px 16px rgba(30,40,34,.05); --shadow-lg:0 14px 40px rgba(30,40,34,.10);
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none !important}   /* атрибут hidden всегда скрывает (перебивает display:flex) */
html,body{height:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
h2,h3{font-family:var(--serif);font-weight:600;letter-spacing:-.01em;line-height:1.15}
a{color:inherit}
b{font-weight:600}

.app{display:flex;min-height:100dvh}

/* ===== SIDEBAR ===== */
.sidebar{width:264px;flex:none;background:var(--sidebar);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:18px 14px;position:sticky;top:0;height:100dvh;z-index:40}
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px}
.brand-mark{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--green),var(--green-2));
  display:flex;align-items:center;justify-content:center;font-size:21px;box-shadow:0 4px 12px rgba(31,111,84,.3)}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text b{font-family:var(--serif);font-size:18px}
.brand-text span{font-size:11.5px;color:var(--muted)}
.nav{display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto}
.nav-label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:600;margin:16px 10px 6px}
.nav-item{display:flex;align-items:center;gap:11px;width:100%;border:none;background:transparent;cursor:pointer;
  padding:10px 11px;border-radius:11px;font-size:14.5px;font-weight:500;color:var(--ink);font-family:inherit;transition:.15s;text-align:left}
.nav-item .ni{font-size:17px;width:22px;text-align:center}
.nav-item em{margin-left:auto;font-style:normal;font-size:12px;font-weight:700;background:var(--green-soft);color:var(--green);border-radius:9px;padding:1px 8px}
.nav-item:hover{background:#f3f1ea}
.nav-item.active{background:var(--green-soft);color:var(--green);font-weight:600}
.side-foot{padding:12px 8px 4px;border-top:1px solid var(--line);margin-top:8px}
.lang{display:inline-flex;background:#f1efe8;border-radius:10px;padding:3px;margin-bottom:12px}
.lang-btn{border:none;background:transparent;font-weight:700;font-size:12.5px;padding:6px 14px;border-radius:8px;cursor:pointer;color:var(--muted)}
.lang-btn.active{background:#fff;color:var(--green);box-shadow:0 1px 4px rgba(0,0,0,.08)}
.docs{display:flex;flex-direction:column;gap:6px}
.docs a{font-size:12.5px;color:var(--muted);text-decoration:none}
.docs a:hover{color:var(--green)}

.overlay{display:none;position:fixed;inset:0;background:rgba(20,26,22,.45);z-index:35}

/* ===== MAIN ===== */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:14px;padding:14px 22px;
  background:rgba(246,244,238,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.burger{display:none;border:none;background:transparent;font-size:22px;cursor:pointer;color:var(--ink)}
.back{border:none;background:var(--surface);border:1px solid var(--line);width:38px;height:38px;border-radius:11px;font-size:20px;cursor:pointer;color:var(--ink);box-shadow:var(--shadow);transition:.15s}
.back:hover{background:var(--green-soft);color:var(--green)}
/* SLIDERS (движки) */
label.rng{position:relative}
label.rng .rng-v{position:absolute;right:0;top:0;font-size:15px;font-weight:700;color:var(--green)}
label.rng input[type=range]{width:100%;margin:8px 0 16px;accent-color:var(--green);height:6px}
.crumb{font-family:var(--serif);font-size:20px;font-weight:600;flex:1}
.season-chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--line);
  border-radius:30px;padding:6px 14px;font-size:13px;font-weight:600;color:var(--green)}
.content{padding:30px 24px 70px;max-width:880px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:30px}
.view{display:flex;flex-direction:column;gap:30px;animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ===== PANELS ===== */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--shadow)}
.panel h3{font-size:19px;margin-bottom:14px}
.panel-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.panel-head h3{margin:0}
.accent-panel{background:linear-gradient(135deg,var(--green-tint),#fff)}
.muted{color:var(--muted);font-size:13.5px}

/* ===== LANDING HERO ===== */
.lp-hero{position:relative;border-radius:26px;overflow:hidden;min-height:400px;display:flex;align-items:flex-end;box-shadow:var(--shadow-lg)}
.lp-hero-bg{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(15,40,30,.18),rgba(12,32,24,.74)),
  url('/assets/img/hero.jpg');
  background-size:cover;background-position:center;transform:scale(1.02)}
.lp-hero-in{position:relative;z-index:2;color:#fff;padding:42px 38px}
.eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:600;opacity:.92;margin-bottom:14px}
.lp-hero-in h2{font-family:var(--serif);font-size:clamp(30px,5vw,46px);font-weight:700;color:#fff}
.hero-sub{margin-top:14px;max-width:560px;font-size:16px;line-height:1.55;opacity:.95}
.hero-actions{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}
.hero-badges{display:flex;gap:18px;margin-top:22px;flex-wrap:wrap;font-size:13.5px;opacity:.95;font-weight:500}

/* ===== BUTTONS ===== */
.btn{font-family:inherit;font-weight:600;font-size:15px;border:none;border-radius:12px;padding:12px 20px;cursor:pointer;transition:.16s;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn.lg{padding:15px 26px;font-size:16px}
.btn.big{width:100%;padding:16px;font-size:16px;margin-top:6px}
.btn.primary{background:var(--green);color:#fff;box-shadow:0 6px 16px rgba(31,111,84,.28)}
.btn.primary:hover{background:#1a5d47;transform:translateY(-1px)}
.btn.soft{background:var(--green-soft);color:var(--green)}
.btn.soft:hover{background:#daeee1}
.btn.glass{background:rgba(255,255,255,.16);color:#fff;border:1px solid rgba(255,255,255,.4);backdrop-filter:blur(6px)}
.btn.glass:hover{background:rgba(255,255,255,.26)}
.btn:active{transform:scale(.98)}

/* ===== LANDING SECTIONS ===== */
.lp-section{display:flex;flex-direction:column;gap:16px}
.lp-eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:11.5px;font-weight:700;color:var(--green-2)}
.lp-h3{font-size:26px}
.solve-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.solve{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:var(--shadow);cursor:pointer;transition:.16s}
.solve:hover{transform:translateY(-3px);border-color:var(--green-2);box-shadow:var(--shadow-lg)}
.solve-ic{font-size:26px;margin-bottom:10px}
.solve b{display:block;font-size:15.5px;margin-bottom:6px}
.solve p{color:var(--muted);font-size:14px}
.solve-more{display:inline-block;margin-top:10px;font-size:13px;font-weight:700;color:var(--green)}
.art-read p{color:#4b4b54;line-height:1.7;margin-bottom:10px;font-size:15.5px}

/* JOURNEY */
.journey{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.jcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.jimg{height:150px;background-size:cover;background-position:center;position:relative}
.jimg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.08))}
.jimg[data-img="start"]{background-image:url('/assets/img/start.jpg')}
.jimg[data-img="mid"]{background-image:url('/assets/img/mid.jpg')}
.jimg[data-img="goal"]{background-image:url('/assets/img/goal.jpg')}
.jweek{display:inline-block;margin:14px 16px 0;font-size:12px;font-weight:700;color:var(--green);background:var(--green-soft);border-radius:20px;padding:3px 12px;width:fit-content}
.jcard b{font-family:var(--serif);font-size:18px;margin:10px 16px 0}
.jcard p{color:var(--muted);font-size:13.5px;margin:6px 16px 18px}

/* STEPS */
.steps{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.step{text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px 18px 18px 20px;
  cursor:pointer;box-shadow:var(--shadow);transition:.16s;position:relative;display:flex;flex-direction:column;gap:4px}
.step:hover{transform:translateY(-2px);border-color:var(--green-2)}
.step-n{position:absolute;top:16px;right:18px;width:30px;height:30px;border-radius:50%;background:var(--green-soft);
  color:var(--green);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:15px}
.step b{font-size:16px}
.step small{color:var(--muted);font-size:13px;max-width:88%}

/* BOT CTA */
.btn.tg{background:#229ED9;color:#fff;box-shadow:0 6px 16px rgba(34,158,217,.32)}
.btn.tg:hover{background:#1b8dc4}
.btn.light{background:#fff;color:var(--green)}
.bot-cta{background:linear-gradient(165deg,var(--green-tint),#fff);border:1px solid var(--line);border-radius:24px;padding:40px 32px;text-align:center;color:var(--ink);box-shadow:var(--shadow);position:relative;overflow:hidden}
.bot-cta .bot-emoji{font-size:38px;margin-bottom:8px}
.bot-cta h3{color:var(--green);font-size:24px;margin-bottom:10px}
.bot-cta p{max-width:560px;margin:0 auto 20px;color:var(--muted);line-height:1.6}
.bot-feats{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-top:20px;font-size:13.5px;font-weight:600;color:var(--green)}
/* CTA */
.lp-cta{background:linear-gradient(165deg,var(--green-tint),#fff);border:1px solid var(--line);border-radius:24px;padding:44px 32px;text-align:center;color:var(--ink);box-shadow:var(--shadow)}
.lp-cta h3{color:var(--green);font-size:24px;margin-bottom:20px}
.lp-cta .btn.glass{background:var(--green);color:#fff;border:none;box-shadow:0 6px 16px rgba(31,111,84,.22)}
.lp-cta .btn.glass:hover{background:#1a5d47}
.lp-cta .btn.light{background:#fff;color:var(--green);border:1px solid var(--line)}
.cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
/* SIDEBAR BOT */
.side-bot{display:flex;align-items:center;justify-content:center;gap:8px;background:#229ED9;color:#fff;text-decoration:none;
  border-radius:11px;padding:11px;font-weight:600;font-size:14px;margin-bottom:12px;transition:.15s}
.side-bot:hover{background:#1b8dc4}

/* ===== FORM ===== */
label{display:block;font-size:13px;color:var(--muted);margin-bottom:5px;font-weight:600}
.field-label{font-size:13px;color:var(--muted);font-weight:600;margin:4px 0 8px}
input,select,textarea{width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:var(--r-sm);
  font-size:15px;font-family:inherit;background:#fff;color:var(--ink);margin-bottom:14px;transition:.15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--green-2);box-shadow:0 0 0 3px var(--green-soft)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.kcal-row{font-weight:600;color:var(--ink);font-size:15px}
.beta{background:var(--coral);color:#fff;font-size:10px;padding:1px 7px;border-radius:8px;vertical-align:middle;font-weight:700}

/* MACROS */
.macros{display:flex;gap:12px;margin:4px 0 16px}
.macro{flex:1;text-align:center;background:var(--green-tint);border-radius:var(--r-sm);padding:14px 4px}
.ring{width:56px;height:56px;margin:0 auto 7px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;border:4px solid var(--green-2);background:#fff}
.macro.f .ring{border-color:var(--gold)} .macro.c .ring{border-color:#3b82f6}
.macro small{display:block;color:var(--muted);font-size:12px} .macro b{font-size:14px}
.sliders label{display:flex;align-items:center;gap:12px;margin-bottom:10px;font-weight:600;color:var(--ink)}
.sliders input[type=range]{margin:0;flex:1;accent-color:var(--green)}
.ok{color:var(--green);font-weight:700;font-size:14px} .ok.bad{color:#c0392b}

/* WATER */
.water-panel{background:linear-gradient(135deg,#eaf6fb,#f4fbfd)}
.water-val{font-family:var(--serif);font-size:30px;font-weight:700;color:#0e7aa8;margin:2px 0 8px}

/* FRIDGE */
.fridge-input{display:flex;gap:10px;align-items:flex-start}
.fridge-input input{flex:1} .fridge-input .btn{flex:none;margin-bottom:14px}
.scan-btn{display:flex;align-items:center;justify-content:center;gap:9px;background:#fff;border:1.5px dashed var(--green-2);
  color:var(--green);border-radius:var(--r-sm);padding:14px;font-weight:600;cursor:pointer;margin-bottom:16px}
.scan-btn:hover{background:var(--green-tint)}
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{background:var(--green-tint);border:1px solid var(--line);border-radius:30px;padding:8px 13px;font-size:14px;display:flex;align-items:center;gap:7px;animation:fade .25s}
.chip .x{cursor:pointer;color:var(--muted);font-weight:700;margin-left:3px}
.chip .x:hover{color:#c0392b}
.hint{margin-top:12px}

/* SEGMENTS */
.seg{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.seg-i{flex:1;min-width:84px;background:#f3f1ea;border:1.5px solid transparent;border-radius:11px;padding:11px 8px;
  font-size:14px;font-weight:600;cursor:pointer;color:var(--ink);font-family:inherit;transition:.15s}
.seg-i:hover{background:#ece9e0}
.seg-i.active{background:var(--green);color:#fff;box-shadow:0 4px 12px rgba(31,111,84,.25)}
.toggle{display:flex;align-items:center;gap:9px;font-weight:600;color:var(--ink);margin-bottom:16px}
.toggle input{width:auto;margin:0;accent-color:var(--green)}

/* STAT / QUICK (unused-safe) */
.recbox{margin-top:16px;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:16px;animation:fade .35s}
.recbox p{line-height:1.55}.recbox ul{margin:10px 0 0 18px;line-height:1.75}
.wtip{margin-top:12px;background:#eaf6fb;color:#0e7aa8;border-radius:10px;padding:9px 13px;font-weight:600;font-size:14px}

/* CATALOG */
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:6px}
.cat-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px;cursor:pointer;display:flex;gap:13px;align-items:center;transition:.16s;box-shadow:var(--shadow)}
.cat-card:hover{transform:translateY(-3px);border-color:var(--green-2);box-shadow:var(--shadow-lg)}
.cc-emoji{font-size:32px;flex:none}
.cc-body{display:flex;flex-direction:column;gap:3px;min-width:0}
.cc-body b{font-size:14.5px;line-height:1.2}.cc-body small{color:var(--muted);font-size:11.5px}
.cc-have{font-size:11.5px;font-weight:700;color:var(--muted)}.cc-have.ok{color:var(--green)}

.meals-note{font-size:12.5px;color:var(--muted);background:var(--green-tint);border-radius:10px;padding:9px 12px;margin:-4px 0 14px;line-height:1.4}
/* NEXT ACTIONS (что дальше) */
.next-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.next-act{text-align:left;background:var(--green-tint);border:1.5px solid transparent;border-radius:14px;padding:16px;cursor:pointer;transition:.16s;display:flex;flex-direction:column;gap:4px;font-family:inherit}
.next-act:hover{transform:translateY(-3px);border-color:var(--green-2);background:#fff;box-shadow:var(--shadow)}
.next-act span{font-size:26px}
.next-act b{font-size:15px;color:var(--ink)}
.next-act small{color:var(--muted);font-size:12px}
@media(max-width:680px){.next-grid{grid-template-columns:1fr}}
/* PSYCHOLOGY */
.side-psy{display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--sea),var(--sea-d));color:#fff;text-decoration:none;border-radius:11px;padding:11px;font-weight:600;font-size:13.5px;margin-bottom:8px;transition:.15s}
.side-psy:hover{filter:brightness(1.07)}
.psy-teaser{background:linear-gradient(135deg,var(--sea-soft),#f3fbfa);border:1px solid #cdeeea;border-radius:24px;padding:32px 28px;text-align:center;box-shadow:var(--shadow)}
.psy-teaser-ic{font-size:38px;margin-bottom:8px}
.psy-teaser h3{font-size:24px;margin-bottom:10px}
.psy-teaser p{max-width:620px;margin:0 auto 18px;color:#3f5b57;line-height:1.6}
.psy-teaser-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.psy{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-lg)}
.psy-photo{position:relative;height:300px;background-image:url('/assets/img/psy.jpg'),url('/assets/img/goal.jpg');background-size:cover;background-position:center top;display:flex;align-items:flex-end}
.psy-author{width:100%;padding:30px 24px 16px;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.6));color:#fff;display:flex;flex-direction:column;gap:2px}
.psy-author b{font-family:var(--serif);font-size:22px;line-height:1.1}
.psy-author span{font-size:12.5px;opacity:.92;letter-spacing:.01em}
.psy-credo{font-size:16px;color:var(--ink);font-weight:500;line-height:1.55;margin:8px 0 14px;max-width:640px}
.psy-body{padding:30px 28px}
/* ОТЗЫВЫ */
.rev-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.rev-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px}
.rev-stars{color:var(--gold);font-size:15px;letter-spacing:2px}
.rev-card p{color:#4b4b54;line-height:1.6;font-size:14.5px;flex:1}
.rev-name{font-family:var(--serif);font-size:16px;margin-top:4px}
.rev-role{font-size:12.5px;color:var(--muted)}
/* СОГЛАСИЕ */
.consent{display:flex;align-items:flex-start;gap:9px;margin-top:14px;font-size:13px;color:var(--muted);line-height:1.45;cursor:pointer}
.consent input{margin-top:2px;width:18px;height:18px;accent-color:var(--green);flex:none}
.consent a{color:var(--green);text-decoration:underline}
.consent-hl{background:var(--green-soft);border-radius:10px;padding:8px;margin-left:-8px;margin-right:-8px;transition:background .3s}
.psy-body h2{font-size:clamp(26px,4vw,34px);margin:6px 0 6px}
.psy-lead{font-size:18px;color:var(--ink);font-weight:600;margin:8px 0 18px;line-height:1.5}
.psy-body h3{font-size:20px;margin:22px 0 8px;color:var(--green)}
.psy-body p{color:#4b4b54;line-height:1.7;margin-bottom:8px;max-width:640px}
.psy-cta{margin-top:26px;background:linear-gradient(135deg,var(--sea),var(--sea-d));border-radius:18px;padding:26px;text-align:center;color:#fff}
.psy-cta h3{color:#fff;margin:0 0 8px} .psy-cta p{color:rgba(255,255,255,.95);max-width:520px;margin:0 auto 16px}
.psy-cta .btn.primary{background:#fff;color:var(--sea-d)}
/* CATALOG → TELEGRAM HOOK */
.cat-tg{display:block;margin-top:16px;background:linear-gradient(135deg,#229ED9,#1b8dc4);color:#fff;border-radius:16px;padding:18px 20px;text-decoration:none;box-shadow:0 8px 20px rgba(34,158,217,.3);transition:.16s}
.cat-tg:hover{transform:translateY(-2px)}
.cat-tg b{display:block;font-size:16px;margin-bottom:4px}
.cat-tg span{font-size:13.5px;opacity:.95}
/* RATE */
.rate-panel{text-align:center}
.stars{font-size:34px;letter-spacing:6px;margin:10px 0 16px;cursor:pointer;color:#d8d2c4}
.stars span{transition:.12s} .stars span:hover{transform:scale(1.15)}
.stars span.on{color:var(--gold)}
/* PRODUCT CARDS (холодильник с фото) */
.chips{gap:12px}
.pcard{width:120px;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);position:relative;animation:fade .25s}
.pc-img{height:80px;background-size:cover;background-position:center;display:flex;align-items:flex-end;justify-content:flex-start}
.pc-img span{font-size:20px;background:rgba(255,255,255,.85);border-radius:8px;padding:1px 5px;margin:5px}
.pcard b{display:block;font-size:13px;font-weight:600;padding:8px 10px 10px;line-height:1.25}
.pcard .x{position:absolute;top:5px;right:6px;cursor:pointer;color:#fff;background:rgba(0,0,0,.45);width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px}
.pcard .x:hover{background:#c0392b}

/* ARTICLES */
.art-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
.art-card{display:flex;gap:13px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px;text-decoration:none;color:inherit;box-shadow:var(--shadow);transition:.16s}
.art-card:hover{transform:translateY(-3px);border-color:var(--green-2);box-shadow:var(--shadow-lg)}
.art-emoji{font-size:28px;flex:none}
.art-src{display:inline-block;font-size:11px;font-weight:700;color:var(--green);background:var(--green-soft);border-radius:8px;padding:1px 8px;margin-bottom:5px}
.art-card b{display:block;font-size:14.5px;line-height:1.25;margin-bottom:4px}
.art-card p{font-size:12.5px;color:var(--muted);line-height:1.4}

/* PRICING */
.pricing{background:#fff;border:2px solid var(--green-2);border-radius:24px;padding:34px 28px;text-align:center;box-shadow:var(--shadow-lg);position:relative}
.price-badge{display:inline-block;background:var(--green);color:#fff;font-weight:700;font-size:13px;border-radius:20px;padding:5px 16px;margin-bottom:12px}
.pricing h3{font-size:24px;margin-bottom:8px}
.price-amount{font-family:var(--serif);font-size:30px;font-weight:700;color:var(--green);margin-bottom:8px}
.pricing p{color:var(--muted);max-width:480px;margin:0 auto 18px;font-size:14px}

/* RECIPE PHOTO */
.r-photo{height:190px;background-size:cover;background-position:center;border-radius:22px 22px 0 0;display:flex;align-items:flex-end}
.r-emoji{font-size:30px;background:rgba(255,255,255,.9);border-radius:12px;padding:4px 10px;margin:14px}
/* Плашка без стокового фото еды (чтобы картинка не противоречила составу, напр. хлеб на кето) */
.r-photo--plain{height:120px;background:linear-gradient(135deg,#2f8f6b,#1f6f54);align-items:center;justify-content:center}
.r-photo--plain .r-emoji{font-size:54px;background:transparent;margin:0;padding:0;filter:drop-shadow(0 4px 10px rgba(0,0,0,.25))}

/* ===== MODAL ===== */
.modal{position:fixed;inset:0;background:rgba(20,26,22,.5);display:flex;align-items:center;justify-content:center;z-index:60;padding:16px}
.sheet{background:#fff;width:100%;max-width:540px;max-height:90dvh;overflow-y:auto;border-radius:22px;position:relative;animation:pop .25s}
@keyframes pop{from{transform:translateY(20px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.close{position:absolute;top:14px;right:14px;background:#fff;border:1px solid var(--line);width:36px;height:36px;border-radius:50%;font-size:17px;cursor:pointer;z-index:2;box-shadow:var(--shadow)}
.r-head{padding:24px 24px 6px}.r-head h3{font-size:25px}.r-head .desc{color:var(--muted);margin-top:5px}
.r-badges{display:flex;gap:8px;margin:14px 0;flex-wrap:wrap}
.r-badge{background:var(--green-tint);border:1px solid var(--line);border-radius:20px;padding:6px 12px;font-size:13px;font-weight:600}
.nutri{display:flex;gap:8px;padding:0 24px;margin:8px 0 16px}
.nutri .n{flex:1;text-align:center}
.nutri .nv{width:60px;height:60px;border-radius:50%;margin:0 auto 5px;display:flex;align-items:center;justify-content:center;font-weight:700;border:4px solid #ddd;font-size:13px;background:#fff}
.nutri .n.k .nv{border-color:var(--gold)}.nutri .n.p .nv{border-color:var(--green-2)}.nutri .n.f .nv{border-color:var(--coral)}.nutri .n.c .nv{border-color:#3b82f6}
.nutri small{color:var(--muted);font-size:12px}
.have{margin:0 24px 16px;padding:11px 14px;border-radius:12px;font-weight:600;font-size:14px}
.have.ok{background:var(--green-soft);color:var(--green)}.have.no{background:#fdecec;color:#c0392b}
.sec{padding:0 24px;margin-bottom:18px}.sec h4{font-size:16px;margin-bottom:10px}.sec ol{padding-left:18px;line-height:1.8}
.ing-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line);font-size:15px}
.fb{padding:18px 24px 24px;border-top:1px solid var(--line);margin-top:6px}
.fb p{font-weight:600;margin-bottom:10px}
.fb-btns{display:flex;gap:12px;margin-bottom:12px}
.fb-btns button{font-size:24px;width:62px;padding:9px;background:#f3f1ea;border:none;border-radius:12px;cursor:pointer}
.fb-btns button.sel{background:var(--green-soft);box-shadow:0 0 0 2px var(--green)}
/* DAY MENU */
.day{padding:0 24px;display:flex;flex-direction:column;gap:12px}
.day-meal{background:var(--green-tint);border-radius:14px;padding:15px}
.dm-head{display:flex;justify-content:space-between;font-weight:700}.dm-head span{color:var(--coral)}
.dm-title{font-family:var(--serif);font-size:17px;margin:5px 0}
.dm-ing{font-size:13px;color:var(--muted);margin-top:7px}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:13px 22px;border-radius:12px;font-size:14px;z-index:99;box-shadow:var(--shadow-lg);animation:fade .3s}
.spin{display:inline-block;width:15px;height:15px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;animation:rot .7s linear infinite;vertical-align:-2px;margin-right:7px}
@keyframes rot{to{transform:rotate(360deg)}}

/* ===== MOBILE ===== */
@media(max-width:860px){
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:transform .28s ease;box-shadow:var(--shadow-lg)}
  .sidebar.open{transform:none}
  .overlay.show{display:block}
  .burger{display:block}
  .solve-grid,.steps{grid-template-columns:1fr}
  .journey{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:1fr}
  .content{padding:18px 16px 50px}
  .lp-hero-in{padding:30px 22px}
  .foot-cols{grid-template-columns:1fr 1fr}
}

/* ===== ПОДВАЛ ===== */
.site-foot{margin-top:10px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:30px 26px 18px;box-shadow:var(--shadow)}
.foot-cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:26px}
.foot-col h4{font-family:var(--serif);font-size:15px;margin-bottom:12px;color:var(--ink)}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.foot-col li,.foot-col a{font-size:13.5px;color:var(--muted);text-decoration:none;line-height:1.4}
.foot-col a:hover{color:var(--green)}
.foot-logo{display:flex;align-items:center;gap:9px;margin-bottom:10px}
.foot-logo .brand-mark{width:34px;height:34px;font-size:18px}
.foot-logo b{font-family:var(--serif);font-size:17px}
.foot-about{font-size:13.5px;color:var(--muted);line-height:1.55;max-width:280px}
.foot-social a,.foot-docs a{font-weight:500}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-top:24px;padding-top:16px;border-top:1px solid var(--line);font-size:12.5px;color:var(--muted)}
@media(max-width:540px){.foot-cols{grid-template-columns:1fr;gap:22px}}
