/* === RESPONSIVE === */

/* Tablet */
@media (max-width: 1100px) {
  .site-header { padding: 0 32px; }
  .page-band { padding: 32px 32px; }
  .breadcrumb { padding: 12px 32px; }
  .main-content { padding: 28px 32px 28px !important; }
  .site-footer { padding: 56px 32px 28px; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 40px; }
}

/* Mobile landscape */
@media (max-width: 900px) {
  .site-header { padding: 0 24px; }
  .main-nav {
    display: none;
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    height: 100vh; height: 100dvh;
    background: #fff;
    flex-direction: column; align-items: stretch; justify-content: flex-start;
    gap: 0; z-index: 500;
    padding: 0 0 calc(40px + env(safe-area-inset-bottom, 0px));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    transform: translateX(100%);
    transition: transform .35s cubic-bezier(.4,.01,.165,.99);
  }
  .main-nav.open { display: flex; transform: translateX(0); }

  /* Mobile menu header — close button only */
  .mobile-menu-header {
    display: flex !important;
    align-items: center;
    justify-content: flex-end;
    padding: 8px 16px;
    border-bottom: none;
    flex-shrink: 0;
  }
  .mobile-menu-logo { display: none; }
  .mobile-menu-close {
    display: flex !important;
    align-items: center; justify-content: center;
    width: 30px; height: 30px;
    background: none; border: 1.5px solid rgba(21,87,176,.15);
    color: var(--text); cursor: pointer;
    transition: background .2s, color .2s;
    clip-path: polygon(0 0,calc(100% - 5px) 0,100% 5px,100% 100%,5px 100%,0 calc(100% - 5px));
  }
  .mobile-menu-close:hover {
    background: var(--sky); color: var(--blue);
  }
  .main-nav ul { flex-direction: column; gap: 0; align-items: stretch; }
  .main-nav li { display: flex; flex-direction: column; }
  /* Mobile sub-menus: show inline, full width, no card look */
  .main-nav .sub-menu,
  .main-nav ul ul,
  .main-nav li:hover > .sub-menu {
    display: flex !important;
    position: static !important;
    min-width: 100% !important;
    width: 100% !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    flex-direction: column !important;
    backdrop-filter: none !important;
    z-index: auto !important;
    border-radius: 0 !important;
  }
  .main-nav .sub-menu li {
    display: flex !important;
    width: 100% !important;
  }
  .main-nav .sub-menu a {
    padding: 8px 20px 8px 40px !important;
    font-size: 13px !important;
    color: var(--muted) !important;
    border-bottom: 1px solid #edf0f7 !important;
    text-align: left !important;
    width: 100% !important;
    display: block !important;
    background: transparent !important;
  }
  .main-nav .sub-menu a:hover {
    background: var(--sky) !important;
    color: var(--blue) !important;
  }
  .main-nav a {
    display: flex; align-items: center; gap: 8px;
    padding: 10px 20px;
    font-size: 14px; font-weight: 500;
    color: var(--text);
    border-bottom: 1px solid #edf0f7;
    width: 100%;
    transition: background .2s, color .2s;
  }
  .main-nav a:hover,
  .main-nav .current-menu-item > a,
  .main-nav .current_page_item > a {
    background: var(--sky); color: var(--blue);
  }
  .main-nav li a img.wp-smiley,
  .main-nav li a img[src*="emoji"] {
    display: inline; width: 16px; height: 16px;
  }
  .main-nav > a.btn-header {
    margin: 12px 16px 8px;
    padding: 14px 20px;
    display: flex; align-items: center; justify-content: center;
    background: var(--blue) !important; color: #fff !important;
    font-family: 'Outfit', sans-serif; font-weight: 700;
    font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase;
    border: none !important; border-bottom: none !important;
    clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
    flex-shrink: 0;
    width: auto;
    box-sizing: border-box;
  }
  .site-header > .btn-header { display: none; }
  .menu-toggle { display: flex; position: relative; z-index: 501; }
  .menu-toggle.active { display: none !important; }
  /* Offset mobile menu for WP admin bar */
  .admin-bar .main-nav { top: 46px; height: calc(100vh - 46px); height: calc(100dvh - 46px); }

  .page-band { padding: 28px 24px; }
  .page-title { font-size: 26px; }
  .breadcrumb { padding: 12px 24px; }
  .main-content { padding: 28px 24px 28px !important; }
  .site-footer { padding: 48px 24px 24px; }
  .footer-top { grid-template-columns: 1fr; gap: 32px; }
  .footer-bottom { flex-direction: column; gap: 8px; }
}

/* Mobile portrait */
@media (max-width: 480px) {
  .site-header { padding: 8px 20px 8px 12px; height: auto; min-height: 60px; }
  .logo-img { height: 48px !important; }
  .logo-name { font-size: 16px; letter-spacing: 2px; }
  .page-band { padding: 24px 20px; }
  .page-title { font-size: 22px; }
  .page-band-meta { flex-direction: column; gap: 8px; }
  .breadcrumb { padding: 10px 20px; }
  .main-content { padding: 28px 20px 28px !important; }
  .site-footer { padding: 40px 20px 20px; }
}
