/* Responsive — burger at 991px, minimum width 300px */

@media (max-width: 991px) {
  .burger {
    display: inline-flex;
  }

  .header-end {
    display: contents;
  }

  .header-row {
    grid-template-columns: 1fr auto auto;
    grid-template-areas:
      "logo burger icons"
      "contact contact contact";
    gap: var(--space-sm);
  }

  .logo {
    grid-area: logo;
  }

  /* Ne foglaljon rács-cellát és ne „lógjon ki” a menü: a lap csak .is-open után látszik */
  .nav-wrap {
    position: fixed;
    grid-column: 1;
    grid-row: 1;
    width: 0;
    height: 0;
    max-width: 0;
    max-height: 0;
    margin: 0;
    padding: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: 0;
    align-self: start;
    justify-self: start;
  }

  .burger {
    grid-area: burger;
    justify-self: end;
  }

  .header-right {
    grid-area: icons;
    justify-self: end;
  }

  .header-contact {
    grid-area: contact;
    justify-self: stretch;
    max-width: none;
    margin-top: 0;
    padding: 0.35rem 0.4rem 0.35rem 0.55rem;
    border-top: 1px solid var(--color-line);
    border-radius: 14px;
    flex-wrap: nowrap;
    justify-content: space-between;
    gap: 0.35rem;
  }

  .header-contact a[href^="tel"] {
    flex: 1 1 auto;
    min-width: 0;
    padding: 0.45rem 0.5rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    border-radius: 10px;
  }

  .header-contact:not(:has(.btn--primary)):not(:has(.btn--ghost)) a[href^="tel"] {
    border-radius: 10px;
  }

  .header-contact .btn--primary,
  .header-contact .btn--ghost {
    flex: 0 0 auto;
    margin: 0.1rem 0.1rem 0.1rem 0;
    padding: 0.48rem 0.9rem;
  }

  /* Zárva: display none (a pill .nav-wrap .main-nav { display:flex } felülírása) */
  /* Nyitott menü: a teljes fejléc + fiók a legfelső rétegen (modálok, süti sáv fölött) */
  body.nav-open .site-header {
    z-index: 100000;
  }

  body.nav-open .nav-wrap {
    overflow: visible;
    pointer-events: none;
  }

  /* A sor a háttér fölé kerül (a backdrop a header-row után van a DOM-ban) */
  body.nav-open .header-row {
    position: relative;
    z-index: 100003;
  }

  .nav-wrap .main-nav {
    display: none;
    position: fixed;
    inset: 0 0 0 auto;
    width: min(320px, 88vw);
    height: 100vh;
    padding: calc(var(--header-h) + 1rem) var(--space-lg) var(--space-lg);
    background: var(--color-surface);
    border: none;
    border-left: 1px solid var(--color-line);
    border-radius: 0;
    box-shadow: -12px 0 40px rgba(12, 59, 46, 0.15);
    z-index: 1;
    pointer-events: none;
  }

  .nav-wrap .main-nav.is-open {
    display: block;
    pointer-events: auto;
  }

  .main-nav a {
    display: block;
    font-size: 1.05rem;
    padding: 0.5rem 0;
    margin-bottom: var(--space-md);
  }

  .main-nav a:last-child {
    margin-bottom: 0;
  }

  .mobile-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(10, 20, 18, 0.45);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition);
    z-index: 100001;
  }

  .mobile-backdrop.is-open {
    opacity: 1;
    pointer-events: auto;
  }

  body.nav-open {
    overflow: hidden;
  }

  .filters {
    position: static;
  }

  /* Footer: kisebb fizetési ikonok tableten / mobilnézetben */
  .payment-row {
    gap: 0.5rem 0.7rem;
    padding: 0.5rem 0.7rem;
  }

  .payment-row img {
    height: 22px;
    width: auto;
  }
}

@media (max-width: 600px) {
  .site-header .header-right .icon-btn {
    width: 34px;
    height: 34px;
  }

  .site-header .header-right .icon-btn svg {
    width: 16px;
    height: 16px;
  }

  .hero {
    min-height: 70vh;
  }

  .hero__intro {
    padding: 1.1rem 1rem 1.25rem;
  }

  .search-panel__head {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
  }

  .cookie-inner {
    border-radius: var(--radius);
  }
}

/* Minimum viewport 300px — fluid typography and tight spacing */
@media (max-width: 380px) {
  .container {
    width: min(1180px, 100% - 1rem);
  }

  .hero__content {
    width: min(1180px, 100% - 1rem);
  }

  .header-row {
    gap: var(--space-xs);
  }

  .btn {
    padding: 0.55rem 1rem;
    font-size: 0.85rem;
  }

  .section {
    padding-block: var(--space-lg);
  }

  .payment-row img {
    height: 18px;
  }

  .payment-row {
    gap: 0.4rem 0.55rem;
    padding: 0.45rem 0.6rem;
  }
}

@media (min-width: 300px) {
  html {
    min-width: 300px;
  }
}

