/* ===================================================================
   U CHOVATELŮ — responsive.css
   All media queries. Mobile-first breakpoints.
   =================================================================== */

/* ─── LARGE DESKTOP 1920px+ ──────────────────────────────────────── */
@media (min-width: 1920px) {
  .container { max-width: 1600px; }
  body { font-size: 17px; }
  section, .menu-categories, .about, .popular, .values,
  .gallery, .testimonials, .faq, .footer {
    padding-top: 120px;
    padding-bottom: 120px;
  }
  .hero-content { max-width: 800px; }
  .values-grid { grid-template-columns: repeat(4, 1fr); gap: 30px; }
  .gallery-item { width: 420px; height: 320px; }
}

/* ─── WIDE DESKTOP 1440px+ ───────────────────────────────────────── */
@media (min-width: 1440px) {
  .container { max-width: 1360px; }
  .navbar { padding: 24px 0; }
  .navbar.scrolled { padding: 14px 0; }
}

/* ─── TABLET LANDSCAPE up to 1279px ─────────────────────────────── */
@media (max-width: 1279px) {
  .container { max-width: 960px; padding: 0 32px; }
  .values-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .footer-inner { grid-template-columns: 1fr 1fr; gap: 40px; }
  .counters-grid { grid-template-columns: repeat(3, 1fr); }
  .counter-item:nth-child(3) { border-right: none; }
  .counter-item:nth-child(4), .counter-item:nth-child(5) { border-top: 1px solid var(--c-border); }
}

@media (max-width: 1100px) {
  .about-inner { gap: 48px; }
  .faq-inner { gap: 48px; }
}

/* ─── TABLET PORTRAIT 1023px ──────────────────────────────────────── */
@media (max-width: 1023px) {
  html { font-size: 15px; }

  .container { padding: 0 28px; }

  /* Navbar */
  .nav-links { display: none; }
  .nav-phone { display: none; }
  .nav-actions .btn { display: none; }
  .hamburger { display: flex; }

  /* Hero */
  .hero-content { max-width: 100%; padding-top: 110px; padding-bottom: 80px; }
  .hero-title { font-size: clamp(2.2rem, 6vw, 3.6rem); }
  .hero-stats { gap: 0; }
  .hero-stat { padding: 0 20px; }
  .hero-stat:first-child { padding-left: 0; }
  .hero-scroll-hint { display: none; }
  .hero-br { display: none; }

  /* Menu */
  .menu-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }

  /* About */
  .about-inner { grid-template-columns: 1fr; gap: 48px; }
  .about-images { max-width: 520px; margin: 0 auto; }

  /* Popular */
  .popular-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }

  /* Values */
  .values-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }

  /* Counters */
  .counters-grid { grid-template-columns: repeat(2, 1fr); }
  .counter-item { border-right: none; border-bottom: 1px solid var(--c-border); }
  .counter-item:nth-child(odd) { border-right: 1px solid var(--c-border); }
  .counter-item:last-child { border-bottom: none; }

  /* Chef / Garden */
  .chef-philosophy { padding: 80px 0; }

  /* FAQ */
  .faq-inner { grid-template-columns: 1fr; gap: 40px; }
  .faq-inner .section-header { position: static; text-align: center; margin-bottom: 32px; }
  .faq-inner .section-header .section-label::before,
  .faq-inner .section-header .section-label::after { display: none; }

  /* Footer */
  .footer-inner { grid-template-columns: 1fr 1fr; gap: 36px; }
}

/* ─── SMALL TABLET / LARGE PHONE 767px ──────────────────────────── */
@media (max-width: 767px) {
  html { font-size: 15px; }
  section, .menu-categories, .about, .popular, .values,
  .gallery, .testimonials, .faq {
    padding-top: 72px;
    padding-bottom: 72px;
  }
  .footer { padding-top: 64px; }

  /* Intro strip */
  .intro-strip-inner {
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 12px;
    padding: 0 4px;
  }
  .intro-strip-item {
    padding: 4px 12px;
    font-size: 12.5px;
  }
  .intro-strip-sep { display: none; }

  /* Menu */
  .menu-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
  .menu-card-img-wrap { height: 180px; }

  /* Popular */
  .popular-grid { grid-template-columns: 1fr; gap: 16px; }
  .dish-img-wrap { height: 220px; }

  /* Testimonials */
  .testimonials-grid { grid-template-columns: 1fr; gap: 16px; }

  /* Gallery */
  .gallery-item { width: 280px; height: 210px; }

  /* Counters */
  .counters-grid { grid-template-columns: repeat(2, 1fr); }
  .counter-item { padding: 14px 20px; }
  .counter-num { font-size: 1.8rem; }

  /* Footer */
  .footer-inner { grid-template-columns: 1fr; gap: 32px; }
  .footer-bottom-inner { flex-direction: column; gap: 12px; text-align: center; }

  /* Hero stats */
  .hero-stats {
    flex-wrap: wrap;
    gap: 16px;
  }
  .hero-stat { padding: 0; }
  .hero-stat-divider { display: none; }

  /* Mobile CTA bar */
  .mobile-sticky-cta {
    display: flex;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    z-index: 900;
    background: var(--c-base);
    border-top: 1px solid var(--c-border);
    padding: 10px 16px;
    gap: 10px;
    box-shadow: 0 -4px 20px rgba(0,0,0,0.5);
  }
  .mobile-cta-phone {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    flex: 1;
    background: rgba(255,255,255,0.06);
    border: 1px solid var(--c-border-mid);
    color: var(--c-cream);
    font-size: 14px; font-weight: 600;
    padding: 13px 16px;
    border-radius: var(--r-pill);
    transition: background 0.2s ease;
  }
  .mobile-cta-phone svg { width: 16px; height: 16px; color: var(--c-blue-light); }
  .mobile-cta-phone:hover { background: rgba(255,255,255,0.1); }
  .mobile-cta-reserve {
    display: flex; align-items: center; justify-content: center;
    flex: 2;
    background: var(--c-blue);
    color: var(--c-cream);
    font-size: 14px; font-weight: 700;
    padding: 13px 16px;
    border-radius: var(--r-pill);
    box-shadow: var(--shadow-btn);
    transition: background 0.2s ease;
  }
  .mobile-cta-reserve:hover { background: var(--c-blue-light); }

  /* Body padding for sticky bar */
  body { padding-bottom: 76px; }
}

/* ─── PHONE 480px ────────────────────────────────────────────────── */
@media (max-width: 479px) {
  html { font-size: 14.5px; }
  .container { padding: 0 18px; }

  /* Hero */
  .hero-content { padding-top: 96px; padding-bottom: 70px; }
  .hero-title { font-size: clamp(1.9rem, 8.5vw, 2.6rem); }
  .hero-sub { font-size: 14px; }
  .hero-actions { flex-direction: column; }
  .btn-hero-primary, .btn-hero-outline { width: 100%; text-align: center; }
  .hero-badge { font-size: 10px; }

  /* Menu */
  .menu-grid { grid-template-columns: 1fr; }
  .menu-card-img-wrap { height: 200px; }

  /* About */
  .about-img-secondary { right: 0; bottom: 0; width: 52%; }

  /* Values */
  .values-grid { grid-template-columns: 1fr; }

  /* Footer */
  .footer-legal { flex-direction: column; gap: 10px; text-align: center; }

  /* Section header */
  .section-label::before, .section-label::after { width: 16px; }
}

/* ─── SMALL PHONE 375px ──────────────────────────────────────────── */
@media (max-width: 374px) {
  html { font-size: 14px; }
  .hero-title { font-size: 1.75rem; }
  .section-title { font-size: 1.5rem; }
}

/* ─── TOUCH DEVICE — disable hover transforms ─────────────────────── */
@media (hover: none) {
  .menu-card:hover { transform: none; }
  .dish-card:hover { transform: none; }
  .value-card:hover { transform: none; }
  .testi-card:hover { transform: none; }
  .gallery-item:hover { transform: none; }
}

/* ─── CONCERTS ───────────────────────────────────────────────────── */
@media (max-width: 767px) {
  .concerts {
    min-height: auto;
    padding: 72px 0 56px;
    align-items: flex-start;
  }

  .concerts-bg img {
    object-position: 70% center;
  }

  .concerts-overlay {
    background: linear-gradient(to bottom, rgba(6,14,7,0.78) 0%, rgba(6,14,7,0.65) 50%, rgba(6,14,7,0.88) 100%);
  }

  .concerts-panel {
    padding: 0;
    max-width: 100%;
  }

  .concerts-title { font-size: 1.85rem; }

  .concerts-details {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .concerts-detail {
    flex-direction: column;
    gap: 8px;
    padding: 12px;
  }

  .concerts-cta-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .concerts-scroll-badge { display: none; }
}

@media (min-width: 768px) and (max-width: 1023px) {
  .concerts-panel {
    max-width: 520px;
    padding: 48px 24px 48px 0;
  }
  .concerts-details { grid-template-columns: 1fr 1fr; }
}
