/**
 * CCBI — Header & navbar responsive system
 * Mobile-first overrides; desktop (≥992px) unchanged except isolation.
 */

/* ═══════════════════════════════════════════════════════════════
   TOP CONTACT STRIP (.mh-strip)
═══════════════════════════════════════════════════════════════ */
@media (max-width: 991.98px) {
  .mh-strip {
    padding: 4px 0 !important;
  }

  .mh-strip .strip-inner {
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.35rem 0.5rem;
  }

  .mh-strip .ms-left,
  .mh-strip .ms-right {
    gap: 0.5rem 0.65rem;
    font-size: 0.62rem !important;
    flex-wrap: nowrap;
  }

  .mh-strip .ms-left i,
  .mh-strip .ms-right i {
    margin-right: 0.2rem;
  }
}

@media (max-width: 767.98px) {
  .mh-strip__item--email,
  .mh-strip__item--hours {
    display: none !important;
  }

  .mh-strip .ms-right .date-pt {
    display: none !important;
  }
}

@media (max-width: 575.98px) {
  .mh-strip .strip-inner {
    padding-left: 0;
    padding-right: 0;
  }

  .mh-strip .ms-left {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
  }

  .mh-strip__item--phone {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .mh-strip .ms-right {
    flex: 0 0 auto;
    flex-shrink: 0;
  }
}

@media (max-width: 374px) {
  .mh-strip .ms-right .soc {
    gap: 4px;
  }

  .mh-strip .ms-right .soc a {
    width: 26px;
    height: 26px;
    font-size: 0.75rem;
  }
}

/* ═══════════════════════════════════════════════════════════════
   MASTHEAD (logo / branding) — compact on tablet & mobile
═══════════════════════════════════════════════════════════════ */
@media (max-width: 991.98px) {
  .masthead {
    padding: 5px 0 !important;
    border-bottom-width: 2px;
  }

  .masthead .mh-inner {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 0.5rem 0.65rem !important;
    text-align: left;
  }

  .masthead .mh-logo {
    flex: 0 0 auto;
  }

  .masthead .mh-logo img {
    height: 38px !important;
    width: auto;
    max-width: 100%;
  }

  .masthead .mh-center {
    flex: 1 1 auto;
    min-width: 0;
    text-align: left !important;
  }

  .mh-headline {
    justify-content: flex-start !important;
    gap: 0.2rem 0.45rem !important;
    line-height: 1.15 !important;
  }

  .mh-name {
    font-size: 0.92rem !important;
    letter-spacing: 0.08em !important;
    line-height: 1.15 !important;
  }

  .mh-sub {
    font-size: 0.62rem !important;
    line-height: 1.2 !important;
  }

  .mh-rule {
    display: none !important;
  }

  .mh-tagline {
    display: none !important;
  }

  .masthead .mh-right {
    display: none !important;
  }
}

@media (max-width: 575.98px) {
  .masthead .mh-logo img {
    height: 34px !important;
  }

  .mh-name {
    font-size: 0.82rem !important;
  }

  .mh-sub {
    display: none !important;
  }
}

@media (max-width: 374px) {
  .masthead {
    padding: 4px 0 !important;
  }

  .masthead .mh-logo img {
    height: 30px !important;
  }

  .mh-name {
    font-size: 0.72rem !important;
    letter-spacing: 0.05em !important;
  }
}

html[dir='rtl'] .masthead .mh-inner {
  text-align: right;
}

html[dir='rtl'] .masthead .mh-center,
html[dir='rtl'] .mh-headline {
  text-align: right !important;
  justify-content: flex-end !important;
}

/* ═══════════════════════════════════════════════════════════════
   MAIN NAV — single toolbar row (mobile / tablet < 992px)
═══════════════════════════════════════════════════════════════ */
@media (max-width: 991.98px) {
  .main-nav {
    overflow-x: clip;
    overflow-y: visible;
  }

  .main-nav .container.main-nav__shell {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    align-content: flex-start;
    gap: 0;
    padding-left: 0;
    padding-right: 0;
    max-width: 100%;
    width: 100%;
  }

  .main-nav__build {
    display: contents;
  }

  /* Toolbar: hamburger + actions on ONE row */
  .main-nav__build .nav-inner {
    order: 1;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 0;
    min-height: 2.75rem;
    padding: 0.35rem 0 0.35rem 0.65rem !important;
  }

  .main-nav-mobile-label {
    display: none !important;
  }

  .main-nav__actions {
    order: 2;
    flex: 1 1 auto;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.3rem;
    min-width: 0;
    max-width: 100%;
    padding: 0.35rem 0.65rem 0.35rem 0 !important;
    margin: 0;
    position: static;
    border: none;
  }

  .main-nav__build > .container.d-lg-flex {
    display: none !important;
  }

  #mob-menu {
    order: 3;
    flex: 1 1 100%;
    width: 100%;
    max-width: 100%;
    display: none;
    margin: 0;
    padding: 0;
    border-top: 1px solid rgba(201, 168, 76, 0.22);
    background: rgba(0, 0, 0, 0.18);
    max-height: min(78dvh, calc(100dvh - var(--site-header-offset, 7rem)));
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  #mob-menu.is-open {
    display: block;
  }

  #mob-menu ul {
    display: flex !important;
    flex-direction: column !important;
    width: 100%;
    margin: 0;
    padding: 0.25rem 0 0.5rem;
    list-style: none;
  }

  #mob-menu ul li {
    width: 100%;
    display: block;
    flex-shrink: 0;
  }

  #mob-menu .main-nav-mobile-link,
  #mob-menu ul li a.main-nav-mobile-link {
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding: 0.7rem 1rem !important;
    white-space: normal;
    word-break: break-word;
    text-align: start;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    font-size: 0.72rem !important;
    letter-spacing: 0.1em !important;
  }

  #mob-menu ul li a::after {
    display: none !important;
  }

  #mob-menu .main-nav-mobile-group__label {
    display: block;
    padding: 0.75rem 1rem 0.25rem;
    font-family: 'Cinzel', serif;
    font-size: 0.55rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--gold-lt, #e2c46e);
  }

  #mob-menu .main-nav-mobile-group__item .main-nav-mobile-link {
    padding-inline-start: 1.35rem !important;
    font-size: 0.68rem !important;
  }

  /* Mobile menu footer: visit hours + ticket from masthead */
  .main-nav-mobile-footer {
    --mobile-cta-gold: #c9a84c;
    --mobile-cta-gold-hover: var(--gold-lt, #d4af5a);
    --mobile-cta-bg: var(--gold, #b8902a);
    --mobile-cta-bg-active: #a67f24;
    --mobile-cta-text: var(--charcoal, #1c1a17);
    --mobile-cta-focus-ring: var(--gold-pale, #f0e0a0);
    padding: 0.85rem 1rem 1rem;
    border-top: 1px solid rgba(201, 168, 76, 0.35);
    background: linear-gradient(
      180deg,
      rgba(27, 58, 45, 0.42) 0%,
      rgba(28, 26, 23, 0.55) 100%
    );
  }

  .main-nav-mobile-footer__label {
    display: block;
    font-family: 'Cinzel', serif;
    font-size: 0.55rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--gold-lt, #e2c46e);
    margin-bottom: 0.35rem;
  }

  .main-nav-mobile-footer__hours {
    font-family: 'Source Sans 3', sans-serif;
    font-size: 0.72rem;
    line-height: 1.45;
    color: rgba(248, 244, 238, 0.88);
    margin: 0 0 0.75rem;
  }

  /* Primary CTA — overrides global .btn-ticket maroon styles from enhance.css */
  .main-nav-mobile-footer .main-nav-mobile-cta.btn-ticket {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    width: 100%;
    max-width: 100%;
    min-height: 3rem;
    margin-top: 0 !important;
    padding: 0.85rem 1.15rem !important;
    font-family: 'Cinzel', serif !important;
    font-size: 0.68rem !important;
    font-weight: 600;
    letter-spacing: 0.14em !important;
    text-transform: uppercase;
    text-align: center;
    text-decoration: none !important;
    line-height: 1.2;
    box-sizing: border-box;
    border: 2px solid var(--mobile-cta-gold) !important;
    border-radius: 0.35rem;
    background: var(--mobile-cta-bg) !important;
    color: var(--mobile-cta-text) !important;
    box-shadow:
      0 2px 0 rgba(0, 0, 0, 0.25),
      0 4px 14px rgba(184, 144, 42, 0.35);
    transition:
      background 0.22s ease,
      border-color 0.22s ease,
      color 0.22s ease,
      box-shadow 0.22s ease,
      transform 0.15s ease;
    -webkit-tap-highlight-color: rgba(201, 168, 76, 0.45);
    touch-action: manipulation;
  }

  .main-nav-mobile-footer .main-nav-mobile-cta.btn-ticket i {
    font-size: 1.05rem;
    color: inherit;
    flex-shrink: 0;
  }

  .main-nav-mobile-footer .main-nav-mobile-cta.btn-ticket:hover {
    background: var(--mobile-cta-gold-hover) !important;
    border-color: var(--mobile-cta-gold-hover) !important;
    color: var(--mobile-cta-text) !important;
    box-shadow:
      0 3px 0 rgba(0, 0, 0, 0.2),
      0 6px 18px rgba(212, 175, 90, 0.45);
    transform: translateY(-1px);
  }

  .main-nav-mobile-footer .main-nav-mobile-cta.btn-ticket:active {
    background: var(--mobile-cta-bg-active) !important;
    border-color: var(--mobile-cta-gold) !important;
    color: var(--mobile-cta-text) !important;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.3);
    transform: translateY(0);
  }

  .main-nav-mobile-footer .main-nav-mobile-cta.btn-ticket:focus {
    outline: none;
  }

  .main-nav-mobile-footer .main-nav-mobile-cta.btn-ticket:focus-visible {
    outline: 3px solid var(--mobile-cta-focus-ring);
    outline-offset: 3px;
    border-color: var(--mobile-cta-gold-hover) !important;
  }

  @media (prefers-reduced-motion: reduce) {
    .main-nav-mobile-footer .main-nav-mobile-cta.btn-ticket {
      transition: background 0.01s, border-color 0.01s, color 0.01s;
    }

    .main-nav-mobile-footer .main-nav-mobile-cta.btn-ticket:hover,
    .main-nav-mobile-footer .main-nav-mobile-cta.btn-ticket:active {
      transform: none;
    }
  }

  /* Toolbar action buttons — uniform size */
  .nav-mob-btn,
  .nav-cart__link,
  .nav-user__link,
  .public-lang-switcher__trigger {
    min-height: 2.4rem;
    max-height: 2.4rem;
  }

  .nav-mob-btn {
    width: 2.4rem;
    min-width: 2.4rem;
    font-size: 1.1rem;
  }

  .nav-cart__link {
    width: 2.4rem;
    height: 2.4rem;
  }

  .main-nav__actions .nav-user__link {
    min-height: 2.4rem;
    height: 2.4rem;
    padding: 0 0.5rem;
    max-width: none;
    gap: 0.3rem;
  }

  .main-nav__actions .nav-user__text {
    position: static;
    width: auto;
    height: auto;
    margin: 0;
    padding: 0;
    clip: auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.52rem;
    max-width: 3.25rem;
  }

  .public-lang-switcher__trigger {
    padding: 0.3rem 0.45rem !important;
    gap: 0.3rem !important;
  }

  .public-lang-switcher__label {
    font-size: 0.5rem !important;
    max-width: 2.5rem;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .public-lang-switcher__flag {
    width: 20px !important;
    height: 14px !important;
  }

  .nav-cart-toast-host {
    top: 3.75rem;
    left: 0.65rem;
    right: 0.65rem;
  }

  html[dir='rtl'] .main-nav__build .nav-inner {
    padding: 0.35rem 0.65rem 0.35rem 0 !important;
  }

  html[dir='rtl'] .main-nav__actions {
    padding: 0.35rem 0 0.35rem 0.65rem !important;
    justify-content: flex-start;
  }
}

@media (max-width: 575.98px) {
  .main-nav__actions .nav-user__text {
    display: none;
  }

  .main-nav__actions .nav-user__link {
    width: 2.4rem;
    min-width: 2.4rem;
    padding: 0;
    justify-content: center;
  }

  .public-lang-switcher__label {
    display: none;
  }

  .public-lang-switcher__trigger {
    padding: 0.3rem !important;
  }
}

@media (max-width: 374px) {
  .main-nav__actions {
    gap: 0.2rem;
    padding-right: 0.45rem !important;
  }

  .main-nav__build .nav-inner {
    padding-left: 0.45rem !important;
  }
}

/* Body scroll lock when menu open */
@media (max-width: 991.98px) {
  body.main-nav-menu-open {
    overflow: hidden;
  }
}

/* Desktop: ensure mobile-only blocks stay hidden (no regression) */
@media (min-width: 992px) {
  .main-nav-mobile-footer,
  #mob-menu,
  .main-nav__build .nav-inner {
    display: none !important;
  }

  .main-nav__build > .container.d-lg-flex {
    display: flex !important;
  }
}
