/* mobile-menu.css */
.mobile-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,.4);
  z-index: calc(var(--z-drawer) - 1);
  backdrop-filter: blur(2px);
}
.mobile-overlay.active { display: block; }
.mobile-menu {
  position: fixed;
  top: 0; left: 0;
  width: min(320px, 88vw);
  height: 100vh;
  background: white;
  z-index: var(--z-drawer);
  transform: translateX(-100%);
  transition: transform var(--ease-slow);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  box-shadow: var(--shadow-2xl);
}
.mobile-menu.open { transform: translateX(0); }
.mobile-menu-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-4) var(--sp-5);
  border-bottom: var(--border);
  position: sticky;
  top: 0;
  background: white;
  z-index: 2;
}
.mobile-menu-footer {
  padding: var(--sp-4) var(--sp-5);
  border-top: var(--border);
  margin-top: auto;
}
.mobile-nav { padding: var(--sp-3) 0; flex: 1; }
.mobile-nav-section { margin-bottom: var(--sp-2); }
.mobile-nav-section-title,
.mobile-nav-category-title {
  padding: var(--sp-3) var(--sp-5) var(--sp-2);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--primary);
  border-bottom: 1px solid var(--gray-100);
  margin-bottom: var(--sp-1);
}
.mobile-nav-link {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: 12px var(--sp-5);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--gray-700);
  text-decoration: none;
  transition: all var(--ease);
}
.mobile-nav-link:hover { background: var(--gray-50); color: var(--primary); }
.mobile-nav-link .icon { font-size: 18px; width: 24px; text-align: center; }
.mobile-nav-accordion-item {
  border-bottom: 1px solid var(--gray-100);
}
.mobile-nav-accordion-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
}
.mobile-nav-accordion-trigger .mobile-nav-link {
  flex: 1;
  padding-right: var(--sp-2);
}
.mobile-nav-accordion-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  margin-right: var(--sp-3);
  color: var(--gray-400);
  transition: transform var(--ease);
}
.mobile-nav-accordion-trigger[aria-expanded="true"] .mobile-nav-accordion-arrow {
  transform: rotate(180deg);
}
.mobile-nav-accordion-panel {
  display: none;
}
.mobile-nav-accordion-panel.open {
  display: block;
}
.mobile-nav-subgroup {
  display: grid;
  gap: 2px;
  margin: 2px 0 var(--sp-2);
  padding: 0 var(--sp-4) 0 calc(var(--sp-5) + 10px);
  border-left: 1px solid var(--gray-100);
}
.mobile-nav-subgroup.mobile-nav-subgroup-static {
  margin-top: -2px;
}
.mobile-nav-subgroup.mobile-nav-subgroup-nested {
  margin: -2px 0 4px 14px;
  padding-left: 8px;
}
.mobile-nav-subgroup.mobile-nav-subgroup-nested .mobile-nav-link.mobile-nav-link-sub {
  font-size: 12px;
  color: var(--gray-500);
  padding-top: 8px;
  padding-bottom: 8px;
}
.mobile-nav-subgroup:empty {
  display: none;
}
.mobile-nav-subgroup-title {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--gray-400);
  padding: var(--sp-2) var(--sp-3) 2px;
}
.mobile-nav-link.mobile-nav-link-sub {
  gap: var(--sp-2);
  padding: 10px var(--sp-3);
  font-size: var(--text-xs);
  font-weight: 600;
  border-radius: var(--r-md);
}
.mobile-nav-link.mobile-nav-link-sub .icon {
  width: 20px;
  font-size: 15px;
}
.mobile-nav-link.cta { background: var(--primary); color: white; margin: var(--sp-3) var(--sp-4); border-radius: var(--r-md); justify-content: center; }
.mobile-nav-link.cta:hover { background: var(--primary-dark); color: white; }

/* ── Mobile Menu Arama Eklentisi ─────────────────────────────── */
/* (header.css'teki .mobile-search-wrap stilleri yeterli,
    bu dosyada sadece transition düzeltmesi) */

.mobile-menu {
  /* display:none yerine transform kullan (JS bunu değiştiriyor) */
  display: flex !important;
  transform: translateX(-100%);
  transition: transform 0.28s ease;
}
.mobile-menu.open { transform: translateX(0); }

/* Overlay geçiş */
.mobile-overlay {
  opacity: 0;
  transition: opacity 0.28s ease;
  pointer-events: none;
}
.mobile-overlay.active {
  opacity: 1;
  pointer-events: auto;
}

/* Drawer shell içinde kaldığı için (--z-sticky: 300) mobil alt nav (400) ve çerez bandı üstte kalıp
   menü link tıklamalarını çalıyordu. Menü açıkken shell'i yükselt + alt katmanlara tıklamayı kapat. */
body.tbm-mobile-menu-open .tbm-header-shell {
  z-index: 10040 !important;
}
body.tbm-mobile-menu-open .mobile-bottom-nav,
body.tbm-mobile-menu-open .cookie-banner {
  pointer-events: none;
}