/* Global responsive safety net for all public/admin pages */

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

img,
video,
iframe {
  max-width: 100%;
}

table {
  width: 100%;
}

/* Tablet/Desktop compact layout */
@media (max-width: 1200px) {
  .main-header {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .main-header-box {
    width: 100% !important;
    max-width: min(1380px, calc(100% - 8px)) !important;
  }

  .header-inner {
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 10px 12px !important;
  }

  .header-logo {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
  }

  .header-logo img {
    max-height: 72px !important;
    width: auto !important;
    height: auto !important;
  }

  .header-right {
    width: 100% !important;
    margin: 6px 0 0 0 !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 8px 12px !important;
  }

  .header-social {
    width: 100% !important;
    justify-content: center !important;
    gap: 8px !important;
  }

  .header-social a {
    margin-right: 0 !important;
    font-size: 1.35rem !important;
  }

  .header-contact {
    width: 100% !important;
    justify-content: center !important;
    gap: 6px 10px !important;
    font-size: 1rem !important;
    text-align: center !important;
  }

  .header-nav-bottom {
    flex-wrap: wrap !important;
    white-space: normal !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 0 12px 12px 12px !important;
  }

  .header-nav-bottom a,
  .nav-dropdown-toggle {
    font-size: 0.96rem !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
  }

  .nav-dropdown-menu {
    right: auto !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    min-width: min(320px, 92vw) !important;
    max-width: 92vw !important;
  }
}

/* Tablet/mobile layout */
@media (max-width: 1024px) {
  .top-hero {
    height: auto !important;
    min-height: 0 !important;
    padding-bottom: 16px !important;
  }

  .top-hero-content {
    height: auto !important;
  }

  .hero-search-floating,
  .hero-filters-floating {
    position: static !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    width: min(100%, calc(100% - 24px)) !important;
    max-width: min(1380px, calc(100% - 24px)) !important;
    margin: 14px auto 0 auto !important;
  }

  .content-area,
  .page-content {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .hero-inner {
    margin-top: 14px !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .hero-split {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .hero-media {
    transform: none !important;
    min-height: auto !important;
  }

  .hero-video {
    transform: none !important;
    max-height: none !important;
  }

  .hero-card {
    width: 100% !important;
    max-width: 100% !important;
    min-height: auto !important;
    margin: 0 auto !important;
    transform: none !important;
    padding: 24px 18px !important;
  }

  .right-blank,
  .page-video-back {
    display: none !important;
  }

  .filters-panel,
  .section-card {
    padding: 16px !important;
    border-radius: 14px !important;
  }

  .iframe-wrap iframe {
    min-height: 420px !important;
  }

  .cards-grid,
  .cards-grid-fixed {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* Mobile layout */
@media (max-width: 768px) {
  .main-header {
    padding: 10px 10px 0 10px !important;
  }

  .main-header-box {
    border-radius: 12px !important;
  }

  .header-logo img {
    max-height: 60px !important;
  }

  .header-social a {
    font-size: 1.2rem !important;
  }

  .header-contact {
    font-size: 0.92rem !important;
    flex-direction: column !important;
    align-items: center !important;
  }

  .header-contact div {
    white-space: normal !important;
    word-break: break-word !important;
  }

  .header-nav-bottom {
    padding: 0 10px 10px 10px !important;
    gap: 6px !important;
  }

  .header-nav-bottom a,
  .nav-dropdown-toggle {
    font-size: 0.9rem !important;
    padding: 4px 8px !important;
  }

  .hero-title {
    font-size: 1.45rem !important;
    line-height: 1.25 !important;
  }

  .hero-text {
    font-size: 0.95rem !important;
  }

  .info-bar,
  .pagination-wrap {
    gap: 8px !important;
  }

  .pagination {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }

  .pagination-buttons {
    width: 100% !important;
    justify-content: space-between !important;
  }

  .cards-grid,
  .cards-grid-fixed {
    grid-template-columns: 1fr !important;
  }

  .footer-pre {
    padding: 28px 0 !important;
  }

  .footer-title {
    font-size: 1.2rem !important;
  }

  .footer-bottom {
    text-align: center !important;
  }

  .footer-social {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 8px !important;
  }

  .footer-social a {
    margin-right: 0 !important;
  }
}

/* Very small screens */
@media (max-width: 480px) {
  main,
  .page,
  .page-content,
  .content-area {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  .hero-card {
    padding: 18px 14px !important;
    border-radius: 16px !important;
  }

  .iframe-wrap iframe {
    min-height: 340px !important;
  }

  .nav-dropdown-menu {
    min-width: min(280px, 92vw) !important;
  }
}

