.mobile-menu-toggle,
.mobile-submenu-toggle,
.mobile-nav-actions,
.footer-mobile-actions {
  display: none;
}

@media (max-width: 1100px) {
  html,
  body {
    max-width: 100%;
    overflow-x: clip;
  }

  .site-header {
    position: sticky !important;
    top: 0 !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    z-index: 1000 !important;
    width: 100% !important;
    background: rgba(5, 5, 5, 0.96) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: 0 10px 30px rgba(21, 22, 24, 0.18) !important;
    backdrop-filter: blur(14px) !important;
  }

  .header-inner {
    width: min(100% - 28px, var(--max, 1480px)) !important;
    min-height: 72px !important;
    padding: 10px 0 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 12px !important;
  }

  .brand {
    min-width: 0 !important;
    max-width: 190px !important;
    min-height: 52px !important;
    align-items: center !important;
  }

  .brand img {
    width: min(156px, 100%) !important;
    max-height: 48px !important;
  }

  .mobile-menu-toggle {
    min-width: 48px;
    min-height: 48px;
    padding: 0;
    display: inline-grid;
    place-items: center;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 12px;
    color: var(--white, #fff);
    background: rgba(255, 255, 255, 0.08);
    box-shadow: inset 0 1px rgba(255, 255, 255, 0.08), 0 8px 20px rgba(0, 0, 0, 0.16);
    cursor: pointer;
  }

  .mobile-menu-toggle span,
  .mobile-menu-toggle::before,
  .mobile-menu-toggle::after {
    content: "";
    width: 20px;
    height: 2px;
    grid-area: 1 / 1;
    background: currentColor;
    transition: transform 160ms ease, opacity 160ms ease;
  }

  .mobile-menu-toggle::before {
    transform: translateY(-6px);
  }

  .mobile-menu-toggle::after {
    transform: translateY(6px);
  }

  body.mobile-nav-open .mobile-menu-toggle span {
    opacity: 0;
  }

  body.mobile-nav-open .mobile-menu-toggle::before {
    transform: rotate(45deg);
  }

  body.mobile-nav-open .mobile-menu-toggle::after {
    transform: rotate(-45deg);
  }

  .header-actions {
    display: none !important;
  }

  body::before {
    content: "";
    position: fixed;
    inset: 72px 0 0;
    z-index: 998;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(8px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 300ms ease, visibility 0s linear 300ms;
  }

  body.mobile-nav-open::before {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: opacity 300ms ease;
  }

  .nav {
    box-sizing: border-box !important;
    position: fixed !important;
    top: 72px !important;
    right: 0 !important;
    bottom: 0 !important;
    left: auto !important;
    z-index: 999 !important;
    width: min(85vw, 400px) !important;
    max-width: calc(100vw - 16px) !important;
    height: calc(100vh - 72px) !important;
    height: calc(100dvh - 72px) !important;
    min-height: calc(100vh - 72px) !important;
    min-height: calc(100dvh - 72px) !important;
    max-height: calc(100dvh - 72px) !important;
    padding: 18px 14px max(24px, env(safe-area-inset-bottom)) !important;
    display: flex !important;
    flex-direction: column !important;
    flex-wrap: nowrap !important;
    align-content: start !important;
    align-items: stretch !important;
    gap: 7px !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    color: var(--black, #151618) !important;
    background: #fbfaf7 !important;
    border-top: 1px solid #eceae4 !important;
    border-left: 1px solid #e3e0d8 !important;
    box-shadow: -18px 0 54px rgba(21, 22, 24, 0.18) !important;
    transform: translate3d(104%, 0, 0) !important;
    visibility: hidden !important;
    pointer-events: none !important;
    will-change: transform !important;
    backface-visibility: hidden !important;
    transition:
      transform 400ms cubic-bezier(0.16, 1, 0.3, 1),
      visibility 0s linear 400ms !important;
  }

  body.mobile-nav-open .nav,
  .nav.is-mobile-open {
    transform: translate3d(0, 0, 0) !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transition: transform 400ms cubic-bezier(0.16, 1, 0.3, 1) !important;
  }

  body.mobile-nav-open {
    overflow-x: clip;
  }

  .nav > * {
    flex: 0 0 auto !important;
    opacity: 0 !important;
    transform: translate3d(0, 18px, 0) !important;
    transition:
      opacity 360ms ease,
      transform 400ms cubic-bezier(0.16, 1, 0.3, 1) !important;
  }

  body.mobile-nav-open .nav > *,
  .nav.is-mobile-open > * {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) !important;
  }

  body.mobile-nav-open .nav > :nth-child(1),
  .nav.is-mobile-open > :nth-child(1) {
    transition-delay: 90ms !important;
  }

  body.mobile-nav-open .nav > :nth-child(2),
  .nav.is-mobile-open > :nth-child(2) {
    transition-delay: 130ms !important;
  }

  body.mobile-nav-open .nav > :nth-child(3),
  .nav.is-mobile-open > :nth-child(3) {
    transition-delay: 170ms !important;
  }

  body.mobile-nav-open .nav > :nth-child(4),
  .nav.is-mobile-open > :nth-child(4) {
    transition-delay: 210ms !important;
  }

  body.mobile-nav-open .nav > :nth-child(5),
  .nav.is-mobile-open > :nth-child(5) {
    transition-delay: 250ms !important;
  }

  body.mobile-nav-open .nav > :nth-child(n + 6),
  .nav.is-mobile-open > :nth-child(n + 6) {
    transition-delay: 290ms !important;
  }

  .nav a,
  .nav button,
  .mobile-menu-toggle {
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }

  .nav a,
  .nav-campaign,
  .nav-trigger {
    width: 100% !important;
    min-height: 52px !important;
    padding: 0 15px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    color: var(--black, #151618) !important;
    opacity: 1 !important;
    font-size: clamp(1rem, 4.5vw, 1.22rem) !important;
    line-height: 1 !important;
    white-space: normal !important;
  }

  .nav > a,
  .nav > .nav-item > .nav-trigger,
  .nav-campaign {
    position: relative !important;
    border: 1px solid #ebe8e0 !important;
    border-radius: 6px !important;
    background: #f2f0ea !important;
    box-shadow: none !important;
  }

  .nav > a::before,
  .nav > .nav-item > .nav-trigger::before,
  .nav-campaign::before {
    content: none !important;
  }

  .nav > a::after,
  .nav-campaign::after {
    content: ">" !important;
    margin-left: auto !important;
    padding-left: 14px !important;
    color: #8a8780 !important;
    font-family: var(--body-font, "Cabin", Arial, sans-serif) !important;
    font-size: 1.08rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
  }

  .nav > a:active,
  .nav > .nav-item > .nav-trigger:active,
  .nav-campaign:active {
    background: #ebe8df !important;
    transform: translateX(-1px) !important;
  }

  .nav-campaign {
    color: var(--black, #151618) !important;
    background: #fff3b4 !important;
    border-color: #f0dd72 !important;
  }

  .nav-campaign::after {
    color: var(--black, #151618) !important;
  }

  .nav-item {
    width: 100% !important;
    min-height: 0 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 48px !important;
    align-items: stretch !important;
    align-content: start !important;
  }

  .nav-trigger::after {
    content: none !important;
  }

  .nav-item > .nav-trigger {
    grid-column: 1 / 2 !important;
    border-radius: 6px 0 0 6px !important;
  }

  .mobile-submenu-toggle {
    min-width: 48px;
    min-height: 52px;
    display: grid;
    place-items: center;
    border: 1px solid #ebe8e0;
    border-left: 0;
    border-radius: 0 6px 6px 0;
    color: var(--black, #151618);
    background: #f7f6f2;
    cursor: pointer;
  }

  .mobile-submenu-toggle span,
  .mobile-submenu-toggle span::before {
    content: "";
    width: 13px;
    height: 2px;
    grid-area: 1 / 1;
    background: currentColor;
    transition: transform 180ms ease;
  }

  .mobile-submenu-toggle span {
    display: grid;
    place-items: center;
  }

  .mobile-submenu-toggle span::before {
    display: block;
    transform: rotate(90deg);
  }

  .nav-item.is-submenu-open .mobile-submenu-toggle span::before {
    transform: rotate(0);
  }

  .nav-panel,
  .lessons-panel {
    grid-column: 1 / -1 !important;
    position: static !important;
    width: 100% !important;
    height: auto !important;
    max-height: none !important;
    padding: 0 !important;
    display: none !important;
    grid-template-columns: 1fr !important;
    gap: 0 !important;
    overflow: visible !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: none !important;
    color: var(--black, #151618) !important;
    background: #f7f6f2 !important;
    border: 1px solid #ebe8e0 !important;
    border-top: 0 !important;
    border-radius: 0 0 6px 6px !important;
    box-shadow: none !important;
    transition: none !important;
  }

  .nav-item.is-submenu-open .nav-panel,
  .nav-item.is-submenu-open .lessons-panel {
    display: grid !important;
  }

  .lesson-menu-col,
  .lessons-panel .lesson-menu-col {
    display: grid !important;
    grid-template-columns: 1fr !important;
    align-content: start !important;
    gap: 0 !important;
    min-width: 0 !important;
  }

  .lesson-menu-heading,
  .lessons-panel .lesson-menu-heading {
    min-height: 34px !important;
    padding: 14px 16px 7px !important;
    display: flex !important;
    align-items: end !important;
    color: #77736b !important;
    background: transparent !important;
    border-top: 1px solid #ebe8e0 !important;
    font-size: 0.74rem !important;
    font-weight: 950 !important;
    letter-spacing: 0 !important;
    text-transform: uppercase !important;
  }

  .nav-panel a,
  .lessons-panel a {
    width: 100% !important;
    min-height: 42px !important;
    padding: 0 16px !important;
    color: var(--black, #151618) !important;
    background: transparent !important;
    border: 0 !important;
    border-top: 1px solid #ebe8e0 !important;
    font-size: clamp(0.86rem, 3.5vw, 1rem) !important;
    line-height: 1 !important;
    white-space: normal !important;
  }

  .nav-panel a::before,
  .lessons-panel a::before {
    content: none !important;
  }

  .nav-panel a::after,
  .lessons-panel a::after {
    content: ">" !important;
    margin-left: auto !important;
    padding-left: 12px !important;
    color: #aaa69e !important;
    font-family: var(--body-font, "Cabin", Arial, sans-serif) !important;
    font-size: 0.95rem !important;
    font-weight: 900 !important;
  }

  .nav-panel a.nav-highlight-link,
  .lessons-panel a.nav-highlight-link {
    width: calc(100% - 24px) !important;
    min-height: 42px !important;
    margin: 8px 12px 12px !important;
    padding: 0 14px !important;
    justify-content: center !important;
    color: var(--black, #151618) !important;
    background: #fff3b4 !important;
    border: 1px solid rgba(21, 22, 24, 0.08) !important;
    border-radius: 6px !important;
  }

  .nav-new {
    margin-left: 8px !important;
    padding: 3px 6px !important;
    color: var(--black, #151618) !important;
    background: var(--yellow, #ffd800) !important;
    border-radius: 4px !important;
    font-size: 0.64em !important;
  }

  .mobile-nav-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin-top: 8px !important;
    padding-top: 14px !important;
    border-top: 1px solid #e3e0d8 !important;
  }

  .mobile-nav-actions .btn {
    min-height: 50px !important;
    padding: 0 12px !important;
    justify-content: center !important;
    font-size: clamp(1rem, 4.4vw, 1.22rem) !important;
  }

  .mobile-nav-actions .btn::before {
    content: none !important;
  }

  .mobile-nav-actions .btn-outline {
    color: var(--black, #151618) !important;
    border-color: #d8d5cd !important;
    border-radius: 6px !important;
    background: var(--white, #fff) !important;
  }

  .mobile-nav-actions .btn-primary {
    color: var(--black, #151618) !important;
    border-color: rgba(21, 22, 24, 0.1) !important;
    border-radius: 6px !important;
    background: #ffd800 !important;
  }

  .mobile-sticky {
    display: none !important;
  }

  .dynamic-locations {
    overflow: hidden !important;
  }

  .dynamic-locations-layout {
    gap: 26px !important;
  }

  .dynamic-location-grid {
    width: 100% !important;
    max-width: 100% !important;
    display: grid !important;
    grid-template-columns: none !important;
    grid-auto-flow: column !important;
    grid-auto-columns: minmax(272px, 82vw) !important;
    gap: 14px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scroll-snap-type: x mandatory !important;
    overscroll-behavior-inline: contain !important;
    padding: 0 14px 12px 0 !important;
    margin-right: -14px !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .dynamic-location-card {
    min-height: 310px !important;
    scroll-snap-align: start !important;
  }

  .dynamic-location-card .btn {
    width: 100% !important;
  }

  .calendar-impact {
    min-height: auto !important;
    padding-top: 104px !important;
  }

  .calendar-impact-grid {
    width: min(100% - 28px, var(--max, 1480px)) !important;
    min-height: 0 !important;
    gap: 28px !important;
  }

  .calendar-stats {
    min-height: 0 !important;
    display: grid !important;
    gap: 18px !important;
  }

  .calendar-count-label {
    position: static !important;
    display: block !important;
    margin: 0 0 2px !important;
    font-size: clamp(1.7rem, 7vw, 2.4rem) !important;
    line-height: 0.92 !important;
  }

  .calendar-stat {
    position: static !important;
    width: 100% !important;
    max-width: 100% !important;
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: start !important;
  }

  .calendar-stat b {
    font-size: clamp(4rem, 17vw, 6rem) !important;
    line-height: 0.78 !important;
  }

  .calendar-stat strong {
    font-size: clamp(1.75rem, 7vw, 2.55rem) !important;
    line-height: 0.9 !important;
  }

  .calendar-stat span {
    font-size: 0.96rem !important;
    line-height: 1.25 !important;
  }

  .countdown-panel {
    width: 100% !important;
    max-width: 100% !important;
    padding: 24px !important;
    overflow: hidden !important;
    background: linear-gradient(180deg, #252525 0%, #111 100%) !important;
  }

  .countdown-panel img {
    width: min(156px, 46vw) !important;
    max-width: 100% !important;
    height: auto !important;
  }

  .countdown-panel h3 {
    font-size: clamp(3rem, 11vw, 5rem) !important;
    line-height: 0.86 !important;
  }

  .countdown-grid {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }

  .countdown-unit {
    min-width: 0 !important;
    min-height: 112px !important;
    padding: 14px 8px !important;
  }

  .countdown-unit strong {
    font-size: clamp(2.7rem, 12vw, 4rem) !important;
  }

  .countdown-unit span {
    font-size: clamp(1.05rem, 4.8vw, 1.45rem) !important;
    white-space: normal !important;
  }

  .term-divider {
    min-height: 0 !important;
    display: block !important;
    padding: 18px 28px !important;
  }

  .term-divider::before,
  .term-divider::after {
    content: none !important;
  }

  .term-countdown {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }

  .term-countdown .countdown-unit {
    min-width: 0 !important;
    min-height: 82px !important;
    padding: 10px 8px !important;
    background: #f3f3ef !important;
    border: 1px solid #deded8 !important;
  }

  .term-countdown .countdown-unit + .countdown-unit {
    border-left: 1px solid #deded8 !important;
  }

  .term-countdown .countdown-unit strong {
    font-size: clamp(2.8rem, 13vw, 4.2rem) !important;
    line-height: 0.82 !important;
  }

  .term-countdown .countdown-unit span {
    margin-top: 4px !important;
    font-size: clamp(0.95rem, 4vw, 1.15rem) !important;
    line-height: 1 !important;
    white-space: normal !important;
  }

  .summer-camp .hero-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .summer-camp .hero-actions .btn {
    width: 100% !important;
    white-space: normal !important;
    text-align: center !important;
  }

  .hero-inner,
  .container,
  .footer-inner,
  .footer-bottom {
    max-width: calc(100vw - 28px) !important;
  }
}

@media (max-width: 760px) {
  main:has(#lesson-details) .hero {
    min-height: 74vh !important;
    background-color: #050505 !important;
    background-position: center center, 58% center !important;
    background-repeat: no-repeat !important;
    background-size: 100% 100%, auto 82% !important;
    background-blend-mode: screen !important;
  }

  main:has(#lesson-details) .hero::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
      linear-gradient(90deg, rgba(0, 0, 0, 0.44) 0%, rgba(0, 0, 0, 0.2) 46%, rgba(0, 0, 0, 0) 86%),
      linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.16) 100%);
    pointer-events: none;
  }

  main:has(#lesson-details) .hero::after {
    opacity: 0.34 !important;
  }

  main:has(#lesson-details) .hero-inner {
    min-height: 74vh !important;
    padding-top: 96px !important;
    padding-bottom: 34px !important;
    align-items: end !important;
  }

  main:has(#lesson-details) h1 {
    max-width: 86vw !important;
    font-size: clamp(3.8rem, 17vw, 6.6rem) !important;
  }

  main:has(#lesson-details) .hero-sub {
    max-width: 86vw !important;
    font-size: clamp(1rem, 4.2vw, 1.18rem) !important;
    line-height: 1.22 !important;
  }

  .site-footer {
    border-top-width: 8px !important;
  }

  .footer-inner,
  .footer-inner.footer-inner-compact {
    width: min(100% - 28px, 1480px) !important;
    padding: 30px 0 24px !important;
    display: grid !important;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr) !important;
    gap: 22px 20px !important;
    align-items: start !important;
  }

  .footer-brand {
    grid-column: 1 / 2 !important;
    gap: 10px !important;
  }

  .footer-mobile-actions {
    width: 100% !important;
    display: grid !important;
    gap: 8px !important;
    margin-top: 10px !important;
  }

  .footer-mobile-action {
    min-height: 42px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 10px !important;
    color: var(--white, #fff) !important;
    background: rgba(255, 255, 255, 0.07) !important;
    border: 1px solid rgba(255, 255, 255, 0.16) !important;
    border-radius: 14px !important;
    font-family: var(--display-font, "Bebas Neue", "Arial Narrow", Arial, sans-serif) !important;
    font-size: clamp(1rem, 4vw, 1.18rem) !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    text-align: center !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
  }

  .footer-mobile-action-primary {
    color: var(--black, #151618) !important;
    background: var(--yellow, #ffd800) !important;
    border-color: var(--yellow, #ffd800) !important;
  }

  .footer-logo img {
    width: min(180px, 100%) !important;
  }

  .footer-tagline {
    font-size: clamp(2.25rem, 13vw, 4.8rem) !important;
  }

  .footer-grid,
  .footer-grid.footer-grid-compact {
    grid-column: 2 / 3 !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  .footer-col h3,
  .footer-newsletter h3 {
    margin-bottom: 8px !important;
    font-size: clamp(1.18rem, 5.2vw, 1.65rem) !important;
  }

  .footer-links,
  .footer-highlight-links,
  .campus-list {
    gap: 7px !important;
    font-size: clamp(0.9rem, 3.7vw, 1.05rem) !important;
  }

  .footer-highlight-links {
    max-width: 100% !important;
  }

  .footer-highlight-links a,
  .footer-links a,
  .campus-list a {
    line-height: 1.05 !important;
    white-space: normal !important;
  }

  .campus-list li::before {
    width: 7px !important;
    height: 7px !important;
  }

  .footer-newsletter,
  .footer-newsletter.footer-newsletter-highlight {
    grid-column: 1 / -1 !important;
    padding: 18px !important;
    gap: 12px !important;
  }

  .footer-newsletter p {
    font-size: 0.95rem !important;
    line-height: 1.24 !important;
  }

  .newsletter-form {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }

  .newsletter-form input,
  .newsletter-form .btn {
    min-height: 48px !important;
  }

  .newsletter-form .btn {
    width: auto !important;
    padding: 0 16px !important;
  }

  .footer-bottom {
    width: min(100% - 28px, 1480px) !important;
    padding: 14px 0 22px !important;
    display: flex !important;
  }
}

@media (max-width: 420px) {
  main:has(#lesson-details) .hero {
    background-position: center center, 55% center !important;
    background-size: 100% 100%, auto 76% !important;
  }

  .footer-inner,
  .footer-inner.footer-inner-compact {
    grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr) !important;
    gap: 20px 16px !important;
  }

  .newsletter-form {
    grid-template-columns: 1fr !important;
  }

  .newsletter-form .btn {
    width: 100% !important;
  }
}

@media (min-width: 761px) and (max-width: 1100px) {
  .hero-inner {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.72fr) !important;
    gap: 34px !important;
    align-items: center !important;
  }

  .trial-panel {
    max-width: 420px !important;
  }

  .lesson-pathway-layout,
  .summer-camp-layout,
  .teachers-layout,
  .community-gallery-head,
  .dynamic-locations-layout {
    grid-template-columns: minmax(0, 0.9fr) minmax(320px, 1.1fr) !important;
    gap: 34px !important;
  }

  .lesson-pathway-menu,
  .lesson-grid-home,
  .pricing-grid,
  .teacher-preview-grid,
  .community-gallery-grid,
  .people-photo-grid,
  .news-grid,
  .campus-row {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .lesson-format-row,
  .camp-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .lesson-tile-home {
    min-height: 190px !important;
  }

  .price-card,
  .term-card,
  .fees-link-card,
  .campus-card {
    min-height: 360px !important;
  }

  .people-photo-grid.is-sound-bars,
  .community-gallery-grid.is-sound-bars {
    min-height: auto !important;
    align-items: stretch !important;
  }

  .people-photo-grid.is-sound-bars .people-photo-card,
  .community-gallery-grid.is-sound-bars .community-gallery-card {
    min-height: 330px !important;
  }

  .dynamic-location-grid {
    display: grid !important;
    grid-auto-flow: row !important;
    grid-auto-columns: initial !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px !important;
    overflow: visible !important;
    padding: 0 !important;
    margin-right: 0 !important;
    scroll-snap-type: none !important;
  }

  .dynamic-location-card {
    min-height: 330px !important;
  }

  .footer-inner,
  .footer-inner.footer-inner-compact {
    grid-template-columns: minmax(220px, 0.8fr) minmax(0, 1.2fr) !important;
  }

  .footer-newsletter,
  .footer-newsletter.footer-newsletter-highlight {
    grid-column: 1 / -1 !important;
  }
}

@media (min-width: 900px) and (max-width: 1100px) {
  .site-header {
    position: sticky !important;
  }

  .header-inner {
    min-height: 76px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 18px !important;
  }

  .mobile-menu-toggle {
    display: none !important;
  }

  .nav {
    position: static !important;
    inset: auto !important;
    z-index: auto !important;
    width: auto !important;
    max-width: none !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 0 !important;
    display: flex !important;
    flex: 1 1 auto !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 8px 12px !important;
    overflow: visible !important;
    color: var(--white, #fff) !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    transform: none !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  .nav > * {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  .nav a,
  .nav-campaign,
  .nav-trigger {
    width: auto !important;
    min-height: 36px !important;
    padding: 0 8px !important;
    color: var(--white, #fff) !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    font-size: 0.86rem !important;
    white-space: nowrap !important;
  }

  .nav-campaign {
    padding: 0 12px !important;
    color: var(--black, #151618) !important;
    background: var(--yellow, #ffd800) !important;
  }

  .nav > a::after,
  .nav-campaign::after,
  .nav-panel a::after,
  .lessons-panel a::after {
    content: none !important;
  }

  .nav-item {
    position: relative !important;
    width: auto !important;
    min-height: 36px !important;
    display: inline-flex !important;
    grid-template-columns: none !important;
    align-items: center !important;
  }

  .nav-item > .nav-trigger {
    grid-column: auto !important;
    border-radius: 0 !important;
  }

  .nav-trigger::after {
    content: " +" !important;
    margin-left: 2px !important;
    color: var(--yellow, #ffd800) !important;
  }

  .mobile-submenu-toggle,
  .mobile-nav-actions {
    display: none !important;
  }

  .nav-panel,
  .lessons-panel {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    width: 240px !important;
    max-height: calc(100vh - 90px) !important;
    padding: 0 !important;
    display: grid !important;
    overflow: auto !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transform: translateY(-8px) !important;
    color: var(--black, #151618) !important;
    background: #f7f6f2 !important;
    border: 1px solid #e5e2da !important;
    border-radius: 0 0 8px 8px !important;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.24) !important;
    transition: opacity 140ms ease, transform 140ms ease, visibility 140ms ease !important;
  }

  .nav-item:hover .nav-panel,
  .nav-item:focus-within .nav-panel,
  .nav-item:hover .lessons-panel,
  .nav-item:focus-within .lessons-panel {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: translateY(0) !important;
  }

  .nav-panel a,
  .lessons-panel a {
    width: 100% !important;
    min-height: 36px !important;
    padding: 0 14px !important;
    color: var(--black, #151618) !important;
    border-top: 1px solid #ebe8e0 !important;
    font-size: 0.86rem !important;
  }

  .lesson-menu-heading,
  .lessons-panel .lesson-menu-heading {
    min-height: 32px !important;
    padding: 12px 14px 6px !important;
    color: #77736b !important;
    font-size: 0.72rem !important;
  }
}

@media (min-width: 761px) and (max-width: 899px) {
  .lesson-pathway-layout,
  .summer-camp-layout,
  .teachers-layout,
  .community-gallery-head,
  .dynamic-locations-layout {
    grid-template-columns: 1fr !important;
  }

  .dynamic-location-grid,
  .people-photo-grid,
  .community-gallery-grid {
    width: 100% !important;
  }
}

@media (min-width: 900px) and (max-width: 1100px) {
  .dynamic-location-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (min-width: 1101px) {
  .mobile-menu-toggle {
    display: none !important;
  }
}
