/* =========================================================
   Restaurace Na Tumovce — responsive.css
   Mobile-first media queries (min-width).
   ========================================================= */

/* ---------- <768px base adjustments (mobile first) ---------- */
body { font-size: 15px; }

.container { padding: 0 20px; }

/* Nav */
.nav__inner { padding: 0 20px; gap: 16px; }
.nav__links { display: none; }
.nav__phone { display: none; }
.nav__cta { display: none; }
.nav__burger { display: inline-flex; }

/* Hero */
.hero { padding: 120px 0 72px; }
.hero__title { font-size: clamp(2.2rem, 10vw, 3.4rem); }
.hero__sub { font-size: 1rem; margin-bottom: 28px; }
.hero__cta { gap: 10px; }
.hero__cta .btn--lg { padding: 14px 22px; font-size: 0.92rem; flex: 1; }
.hero__meta { gap: 12px; font-size: 0.84rem; }
.hero__scroll { display: none; }

section { padding: 64px 0; }

/* Story */
.story__grid { grid-template-columns: 1fr; gap: 40px; }
.story__media { min-height: 360px; order: -1; }
.story__fig--front { top: 20px; left: 40px; right: 0; height: 300px; }
.story__fig--back { width: 180px; height: 140px; }
.story__fig--inset { width: 120px; height: 120px; right: 10px; bottom: -20px; border-width: 4px; }
.stats { flex-wrap: wrap; gap: 20px 28px; }
.stat__num { font-size: 2rem; }

/* Pillars */
.pillars__grid { grid-template-columns: 1fr; gap: 16px; }
.pillars__head { margin-bottom: 40px; }
.pillar { padding: 28px 24px; }

/* Beers */
.beers__grid { grid-template-columns: 1fr; gap: 40px; }
.beers__media { order: -1; }
.beers__fig { aspect-ratio: 4 / 3; }
.menu-row { gap: 10px; }
.menu-row__name { font-size: 1.05rem; }
.menu-row__price { font-size: 1.1rem; }

/* Kitchen */
.dishes { grid-template-columns: 1fr; gap: 20px; }
.kitchen__head { margin-bottom: 40px; }

/* Gallery */
.gallery__grid {
  grid-template-columns: repeat(2, 1fr);
  grid-auto-rows: 160px;
  grid-auto-flow: dense;
  gap: 10px;
}
.gallery__item--tall { grid-row: span 2; }
.gallery__item--wide { grid-column: span 2; }

/* Contact */
.contact__grid { grid-template-columns: 1fr; gap: 36px; }
.contact__map { min-height: 300px; }
.contact__phone { font-size: 1.4rem; }

/* Reserve */
.reserve { padding: 72px 0; }
.reserve__card { padding: 36px 24px 28px; }
.res-form__row { grid-template-columns: 1fr; gap: 14px; }
.res-form__row:has(.field:nth-child(3)) { grid-template-columns: 1fr; }

/* Footer */
.footer { padding-top: 48px; }
.footer__grid { grid-template-columns: 1fr; gap: 36px; padding-bottom: 36px; }
.footer__bar-inner { justify-content: center; text-align: center; }

/* ---------- ≥480px (sm) ---------- */
@media (min-width: 480px) {
  .container { padding: 0 24px; }
  .nav__inner { padding: 0 24px; }

  .gallery__grid { grid-auto-rows: 180px; }
}

/* ---------- ≥768px (md — tablet) ---------- */
@media (min-width: 768px) {
  .container { padding: 0 32px; }
  .nav__inner { padding: 0 32px; }

  .hero { padding: 140px 0 80px; }
  .hero__title { font-size: clamp(2.8rem, 6vw, 4.2rem); }
  .hero__sub { font-size: 1.08rem; }
  .hero__cta .btn--lg { flex: 0 0 auto; padding: 16px 30px; }
  .hero__scroll { display: inline-flex; }

  section { padding: 80px 0; }

  .story__grid { grid-template-columns: 1fr 1fr; gap: 48px; }
  .story__media { order: 0; min-height: 460px; }
  .story__fig--front { top: 50px; left: 110px; height: 380px; }
  .story__fig--back { width: 240px; height: 190px; }
  .story__fig--inset { width: 160px; height: 160px; }

  .pillars__grid { grid-template-columns: repeat(3, 1fr); gap: 20px; }

  .beers__grid { grid-template-columns: 1fr 1fr; gap: 48px; }
  .beers__media { order: 0; }
  .beers__fig { aspect-ratio: 4 / 5; }

  .dishes { grid-template-columns: repeat(2, 1fr); gap: 24px; }

  .gallery__grid { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 200px; }

  .contact__grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .contact__map { min-height: 420px; }

  .reserve { padding: 96px 0; }
  .reserve__card { padding: 48px 44px 40px; }
  .res-form__row { grid-template-columns: 1fr 1fr; }
  .res-form__row:has(.field:nth-child(3)) { grid-template-columns: 1fr 1fr 1fr; }

  .footer__grid { grid-template-columns: 1.6fr 1fr 1.2fr; gap: 40px; }
}

/* ---------- ≥1024px (lg — full desktop) ---------- */
@media (min-width: 1024px) {
  body { font-size: 16px; }

  .nav__burger { display: none; }
  .nav__links { display: flex; }
  .nav__cta { display: inline-flex; }
  .nav__phone { display: inline-flex; }

  .hero { padding: 160px 0 96px; }
  .hero__title { font-size: clamp(3.4rem, 5.5vw, 4.8rem); }

  section { padding: 96px 0; }

  .story__grid { grid-template-columns: 5fr 7fr; gap: 64px; }
  .story__media { min-height: 520px; }
  .story__fig--front { top: 60px; left: 140px; height: 440px; }
  .story__fig--back { width: 300px; height: 230px; }
  .story__fig--inset { width: 200px; height: 200px; }

  .beers__grid { gap: 64px; }

  .dishes { grid-template-columns: repeat(3, 1fr); gap: 26px; }

  .gallery__grid { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 220px; }

  .contact__grid { grid-template-columns: 5fr 6fr; gap: 56px; }
  .contact__map { min-height: 520px; }

  .reserve__card { padding: 52px 52px 44px; }

  .footer__grid { grid-template-columns: 2fr 1fr 1.2fr; gap: 56px; }
}

/* ---------- ≥1280px (xl) ---------- */
@media (min-width: 1280px) {
  .container { padding: 0 40px; max-width: 1200px; }
  .nav__inner { padding: 0 40px; max-width: 1200px; }

  .beers__grid { gap: 72px; }
  .dishes { gap: 28px; }
}

/* ---------- ≥1440px (2xl) ---------- */
@media (min-width: 1440px) {
  .container, .nav__inner { max-width: 1360px; }

  .hero__title { font-size: clamp(3.8rem, 5vw, 5.4rem); }

  section { padding: 112px 0; }

  .story__grid { gap: 80px; }
}

/* ---------- ≥1920px (3xl) ---------- */
@media (min-width: 1920px) {
  body { font-size: 17px; }
  .container, .nav__inner { max-width: 1600px; padding: 0 48px; }

  section { padding: 128px 0; }

  .h2 { font-size: clamp(2.2rem, 3vw, 3.2rem); }

  .hero__title { font-size: clamp(4.4rem, 4.5vw, 6rem); }
  .hero__sub { font-size: 1.22rem; max-width: 720px; }

  .dish__name { font-size: 1.4rem; }
  .menu-row__name { font-size: 1.25rem; }
  .menu-row__price { font-size: 1.38rem; }
}

/* ---------- ≥2560px (4xl) ---------- */
@media (min-width: 2560px) {
  body { font-size: 18px; }
  .container, .nav__inner { max-width: 2000px; }

  section { padding: 160px 0; }
}
