/* GraMedica V2 Nav Integration
 * Grafts language-picker + mobile-drawer into V2's .gm-nav.
 * Load AFTER v2-tokens.css, v2-framework.css, translator.css.
 */

.gm-nav-inner { gap: 16px; }

.gm-nav-right {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;
}

.gm-nav-lang-slot .lang-picker__btn {
  background: transparent;
  border: 1px solid var(--gm-border, #E4E8EE);
  color: var(--gm-navy, #0D1B2A);
  padding: 8px 12px;
  border-radius: 6px;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.gm-nav-lang-slot .lang-picker__btn:hover {
  border-color: var(--gm-border-strong, #C8D1DB);
}

.gm-nav-mobile-toggle {
  display: none;
  background: none;
  border: none;
  padding: 8px;
  cursor: pointer;
  color: var(--gm-navy, #0D1B2A);
}
.gm-nav-mobile-toggle svg {
  width: 24px; height: 24px;
  stroke: currentColor; fill: none;
  stroke-width: 2; stroke-linecap: round;
}

@media (max-width: 860px) {
  .gm-nav-links { display: none !important; }
  .gm-nav .gm-nav-cta { display: none !important; }
  .gm-nav-lang-slot { display: none; }
  .gm-nav-mobile-toggle { display: inline-flex; align-items: center; justify-content: center; }
}

/* ── Mobile drawer ─────────────────────────────────────────── */
.mobile-drawer-overlay {
  position: fixed; inset: 0;
  background: rgba(13, 27, 42, 0.45);
  opacity: 0; visibility: hidden;
  transition: opacity 200ms ease, visibility 200ms ease;
  z-index: 998;
}
.mobile-drawer-overlay--open { opacity: 1; visibility: visible; }

.mobile-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(86vw, 360px);
  background: #FFFFFF;
  transform: translateX(100%);
  transition: transform 280ms cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 999;
  display: flex; flex-direction: column;
  box-shadow: -8px 0 32px rgba(13, 27, 42, 0.18);
}
.mobile-drawer--open { transform: translateX(0); }

.mobile-drawer__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid #E4E8EE;
}
.mobile-drawer__logo { height: 32px; width: auto; }
.mobile-drawer__close {
  background: none; border: none; padding: 8px; cursor: pointer;
  color: var(--gm-navy, #0D1B2A);
}
.mobile-drawer__close svg {
  width: 24px; height: 24px;
  stroke: currentColor; fill: none;
  stroke-width: 2; stroke-linecap: round;
}

.mobile-drawer__nav {
  padding: 16px 20px;
  flex: 1;
  overflow-y: auto;
}
.mobile-drawer__link {
  display: block;
  padding: 14px 0;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 16px;
  font-weight: 500;
  color: var(--gm-navy, #0D1B2A);
  text-decoration: none;
  border-bottom: 1px solid #F0F3F7;
  min-height: 48px;
}
.mobile-drawer__link:hover { color: var(--gm-primary-blue, #0071CA); }
.mobile-drawer__divider { height: 1px; background: #E4E8EE; margin: 12px 0; }

.mobile-drawer__footer {
  padding: 20px;
  border-top: 1px solid #E4E8EE;
  display: flex; flex-direction: column; gap: 12px;
}
.mobile-drawer__cta {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 12px 20px;
  background: var(--gm-primary-blue, #0071CA);
  color: #FFFFFF;
  text-decoration: none;
  border-radius: 6px;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-weight: 600;
  min-height: 48px;
}
body.mobile-drawer-open { overflow: hidden; }
