/* =========================================================================
   МЕНЮ · Гербергъ 1-го нумера — наследный гастро-стиль, адаптивный
   Палитра ресторана: пергамент + золото + бордо + зелёный. Меню из iiko.
   ========================================================================= */
@font-face{font-family:'Nizhegorodsky';src:url('../fonts/ST-Nizhegorodsky.ttf') format('truetype');font-display:swap}
:root{
  --paper:#f6efe1;--paper-2:#efe4cf;--card:#fffdf8;
  --ink:#2a2622;--ink-soft:#6a5b4c;--muted:#8b7a66;
  --green:#1e2a4a;--green-deep:#15203c;
  --burgundy:#7d1f2b;--burgundy-deep:#5e1620;
  --gold:#b8902f;--gold-soft:#cdaa55;--gold-deep:#9a7723;
  --line:rgba(40,38,34,.12);--gold-line:rgba(184,144,47,.4);
  --brand:'Nizhegorodsky','Playfair Display',serif;
  --display:'Playfair Display',Georgia,serif;
  --ui:'Forum','Playfair Display',serif;
  --body:'Spectral','PT Serif',Georgia,serif;
  --shadow:rgba(40,30,16,.18);--ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--body);font-size:17px;line-height:1.6;color:var(--ink);background:var(--paper);overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ===== шапка ===== */
.top{position:sticky;top:0;z-index:40;background:rgba(246,239,225,.95);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--gold-line)}
.top__bar{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px clamp(14px,3vw,28px)}
.top__brand{display:flex;align-items:center;gap:10px}
.top__brand img{height:64px;width:auto}
.top__cta{font-family:var(--ui);text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;color:#fff;
  background:var(--burgundy);border:1.5px solid var(--burgundy-deep);border-radius:5px;padding:.6em 1.2em;white-space:nowrap;transition:background .2s,transform .2s}
.top__cta:hover{background:var(--burgundy-deep);transform:translateY(-1px)}
/* строка поиска */
.search{max-width:1200px;margin:0 auto;padding:0 clamp(14px,3vw,28px) 8px}
.search input{width:100%;border:1.5px solid var(--gold-line);border-radius:999px;background:var(--card);
  font-family:var(--body);font-size:1rem;color:var(--ink);padding:.6em 1.1em}
.search input:focus{outline:none;border-color:var(--gold)}
/* навигация по категориям (в липкой шапке) */
.nav{border-top:1px solid var(--line)}
.nav__row{max-width:1200px;margin:0 auto;display:flex;gap:8px;overflow-x:auto;padding:9px clamp(14px,3vw,28px);scrollbar-width:none}
.nav__row::-webkit-scrollbar{display:none}
.nav__chip{flex:none;font-family:var(--ui);text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;color:var(--ink-soft);
  border:1.5px solid var(--gold-line);border-radius:999px;background:transparent;padding:.5em 1.05em;cursor:pointer;white-space:nowrap;transition:all .2s}
.nav__chip:hover{color:var(--burgundy)}
.nav__chip.on{background:var(--green);color:var(--paper);border-color:var(--green-deep)}

/* ===== заголовок страницы ===== */
.head{max-width:1200px;margin:0 auto;text-align:center;padding:clamp(26px,5vw,52px) clamp(14px,3vw,28px) clamp(10px,2vw,18px)}
.head .eyebrow{font-family:var(--ui);text-transform:uppercase;letter-spacing:.2em;font-size:.8rem;color:var(--gold-deep);margin-bottom:.7em}
.head h1{font-family:var(--display);font-weight:700;font-size:clamp(2.2rem,6vw,3.6rem);color:var(--burgundy);line-height:1.05}
.head__upd{color:var(--muted);font-size:.85rem;margin-top:.6em}
.flourish{display:block;margin:14px auto 0;width:150px;height:16px;color:var(--gold)}

/* ===== секции категорий ===== */
.cat{max-width:1200px;margin:0 auto;padding:clamp(22px,4vw,40px) clamp(14px,3vw,28px) 0;scroll-margin-top:132px}
.cat__h{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,3.6vw,2.2rem);color:var(--green-deep);
  display:flex;align-items:center;gap:14px;margin-bottom:18px}
.cat__h::after{content:"";flex:1;height:1px;background:var(--gold-line)}
.cat__note{color:var(--burgundy);font-size:.92rem;font-style:italic;margin:-8px 0 16px}

/* ===== сетка блюд ===== */
.dishes{display:grid;grid-template-columns:1fr 1fr;gap:13px}
@media(min-width:640px){.dishes{grid-template-columns:repeat(3,1fr);gap:16px}}
@media(min-width:980px){.dishes{grid-template-columns:repeat(4,1fr);gap:18px}}
.dish{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--gold-line);border-radius:16px;overflow:hidden;
  cursor:pointer;box-shadow:0 14px 30px -22px var(--shadow);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.dish:hover{transform:translateY(-4px);box-shadow:0 26px 46px -24px var(--shadow)}
.dish__media{position:relative;width:100%;aspect-ratio:1/1;background:var(--paper-2)}
.dish__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.dish__media--ph{display:grid;place-items:center;color:var(--gold-soft)}
.dish__media--ph svg{width:42px;height:42px;opacity:.7}
.dish__body{flex:1;display:flex;flex-direction:column;padding:12px 14px 14px}
.dish__name{font-family:var(--display);font-weight:600;font-size:1.04rem;color:var(--ink);line-height:1.22}
.dish__name small{font-weight:400;color:var(--muted);font-size:.8rem;font-family:var(--body)}
.dish__desc{color:var(--ink-soft);font-size:.86rem;line-height:1.4;margin-top:5px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.dish__price{margin-top:auto;padding-top:11px;font-family:var(--ui);font-weight:700;font-size:1.22rem;color:var(--burgundy)}
.dish__price small{font-weight:400;font-size:.82rem;color:var(--muted)}

/* модалка блюда */
.modal{position:fixed;inset:0;z-index:60;display:none;align-items:flex-end;justify-content:center;background:rgba(20,18,12,.6);backdrop-filter:blur(3px)}
.modal.open{display:flex;animation:mfade .2s}
@keyframes mfade{from{opacity:0}to{opacity:1}}
@media(min-width:640px){.modal{align-items:center;padding:20px}}
.modal__box{background:var(--card);width:100%;max-width:540px;max-height:94vh;overflow:auto;border-radius:22px 22px 0 0;animation:mup .3s var(--ease)}
@keyframes mup{from{transform:translateY(40px)}to{transform:none}}
@media(min-width:640px){.modal__box{border-radius:18px}}
.modal__media{position:relative;width:100%;aspect-ratio:4/3;background:var(--paper-2)}
.modal__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.modal__x{position:absolute;top:12px;right:12px;width:42px;height:42px;border-radius:50%;border:0;background:rgba(255,255,255,.94);
  color:var(--ink);font-size:1.5rem;line-height:1;cursor:pointer;box-shadow:0 6px 16px rgba(0,0,0,.25)}
.modal__body{padding:18px 22px 26px}
.modal__name{font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--burgundy);line-height:1.15}
.modal__meta{color:var(--muted);font-size:.9rem;margin-top:5px}
.modal__desc{color:var(--ink-soft);margin-top:13px;line-height:1.6;white-space:pre-line}
.modal__price{font-family:var(--ui);font-weight:700;font-size:1.7rem;color:var(--burgundy);margin-top:18px}
.modal__sizes{margin-top:14px;display:flex;flex-direction:column;gap:7px}
.modal__size{display:flex;justify-content:space-between;border-top:1px dotted var(--line);padding-top:7px}
.modal__size b{font-family:var(--ui);color:var(--burgundy)}
.modal__cta{display:inline-block;margin-top:20px;font-family:var(--ui);text-transform:uppercase;letter-spacing:.06em;font-size:.84rem;
  background:var(--burgundy);color:#fff;border:1.5px solid var(--burgundy-deep);border-radius:6px;padding:.75em 1.5em}

/* состояния */
.state{max-width:600px;margin:60px auto;text-align:center;color:var(--ink-soft);padding:0 20px}
.state h2{font-family:var(--display);color:var(--burgundy);margin-bottom:8px}
.empty{grid-column:1/-1;color:var(--muted);text-align:center;padding:20px}

/* подвал */
.foot{margin-top:40px;background:var(--green-deep);color:#cfe0d4;text-align:center;padding:30px 20px;font-size:.85rem}
.foot a{color:var(--gold-soft);font-weight:600}
.foot__row{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-bottom:10px}
.foot__warn{opacity:.7;margin-top:8px;font-size:.78rem}

.up{position:fixed;right:18px;bottom:18px;z-index:30;width:48px;height:48px;border-radius:50%;border:1.5px solid var(--gold-line);
  background:var(--green);color:var(--gold-soft);display:grid;place-items:center;cursor:pointer;opacity:0;pointer-events:none;
  transition:opacity .3s,transform .2s;box-shadow:0 10px 24px -12px var(--shadow)}
.up.show{opacity:1;pointer-events:auto}.up:active{transform:scale(.92)}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto}}
