/* Mobile overrides for Direction A.
   Inline React styles need !important to win specificity. */

/* Safety net: never allow horizontal scroll from rogue elements */
html, body { overflow-x: hidden; max-width: 100vw; }

/* ============================================================
   MOBILE — under 760px
   ============================================================ */
@media (max-width: 760px) {

  /* ---------- Containers & section padding ---------- */
  .dirA .container,
  .dirA .container-tight { padding: 0 20px !important; }

  .dirA section[style*="padding: 120px 0"],
  .dirA section[style*="padding:120px 0"] { padding: 64px 0 !important; }
  .dirA section[style*="padding: 96px 0"],
  .dirA section[style*="padding:96px 0"]  { padding: 56px 0 !important; }
  .dirA section[style*="padding: 88px 0"]  { padding: 48px 0 !important; }
  .dirA section[style*="padding: 72px 0"]  { padding: 44px 0 !important; }
  .dirA section[style*="padding: 112px 0"] { padding: 64px 0 !important; }

  /* ---------- Grid collapses ---------- */
  /* Two-column grids and most multi-col layouts → single column */
  .dirA [style*="grid-template-columns: 1fr 1fr"],
  .dirA [style*="grid-template-columns: 1.05fr 1fr"],
  .dirA [style*="grid-template-columns: 1.2fr 1fr"],
  .dirA [style*="grid-template-columns: 1.4fr 1fr"],
  .dirA [style*="grid-template-columns: 1fr 1.1fr"],
  .dirA [style*="grid-template-columns: 1fr 1.2fr"],
  .dirA [style*="grid-template-columns: 1fr 1.3fr"],
  .dirA [style*="grid-template-columns: 1fr 1.4fr"],
  .dirA [style*="grid-template-columns: 1fr 2fr"],
  .dirA [style*="grid-template-columns: 2fr 1fr"],
  .dirA [style*="minmax(0, 1.05fr) minmax(0, 1fr)"],
  .dirA [style*="minmax(0, 1.2fr) minmax(0, 1fr)"],
  .dirA [style*="minmax(0, 1fr) minmax(0, 1.1fr)"],
  .dirA [style*="minmax(0, 1fr) minmax(0, 1fr)"],
  .dirA [style*="grid-template-columns: repeat(3,"],
  .dirA [style*="200px 1fr"],
  .dirA [style*="120px 1fr"],
  .dirA [style*="180px 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  /* 4-up stat strip → 2-up */
  .dirA section > .container > div[style*="grid-template-columns: repeat(4,"],
  .dirA section > div.container > div[style*="grid-template-columns: repeat(4,"] {
    grid-template-columns: 1fr 1fr !important;
  }
  .dirA section > .container > div[style*="grid-template-columns: repeat(4,"] > div,
  .dirA section > div.container > div[style*="grid-template-columns: repeat(4,"] > div {
    border-right: none !important;
    border-bottom: 1px solid var(--a-rule) !important;
    padding: 20px 16px !important;
  }

  /* Three-up cards: remove right borders, add bottom rules */
  .dirA [style*="grid-template-columns: repeat(3,"] > div {
    border-right: none !important;
    border-bottom: 1px solid var(--a-rule) !important;
  }
  .dirA [style*="grid-template-columns: repeat(3,"] > div:last-child { border-bottom: none !important; }

  /* Five-up timeline → stacked */
  .dirA [style*="grid-template-columns: repeat(5,"] {
    grid-template-columns: 1fr !important;
  }
  .dirA [style*="grid-template-columns: repeat(5,"] > div {
    border-right: none !important;
    border-bottom: 1px solid var(--a-rule) !important;
    min-height: auto !important;
  }
  .dirA [style*="grid-template-columns: repeat(5,"] > div:last-child { border-bottom: none !important; }

  /* ---------- Typography ---------- */
  .dirA h1 { font-size: clamp(40px, 11vw, 56px) !important; line-height: 1.05 !important; }
  .dirA h2 { font-size: clamp(32px, 9vw, 44px) !important; line-height: 1.08 !important; }
  .dirA h3 { font-size: 22px !important; line-height: 1.2 !important; }
  .dirA p { font-size: 16px !important; }
  .dirA .serif { font-size: 36px !important; }

  .dirA span.serif[style*="font-size: 48px"],
  .dirA span.serif[style*="font-size: 56px"],
  .dirA span.serif[style*="font-size: 44px"],
  .dirA div.serif[style*="font-size: 44px"],
  .dirA div.serif[style*="font-size: 48px"],
  .dirA div.serif[style*="font-size: 56px"] {
    font-size: 36px !important;
    min-width: auto !important;
  }

  /* ---------- Cards & padding ---------- */
  .dirA .card,
  .dirA .card-bare { padding: 20px !important; }
  .dirA [style*="padding: 40px"],
  .dirA [style*="padding: 32px"] { padding: 20px !important; }
  .dirA [style*="padding: 28px"] { padding: 18px !important; }

  .dirA [style*="gap: 80px"],
  .dirA [style*="gap: 64px"],
  .dirA [style*="gap: 48px"],
  .dirA [style*="gap: 40px"] { gap: 24px !important; }

  /* ---------- Buttons ---------- */
  .dirA .btn { width: 100%; justify-content: center; padding: 14px 18px !important; }
  .dirA [style*="display: flex"][style*="gap: 12px"],
  .dirA [style*="display: flex"][style*="gap: 14px"] { flex-wrap: wrap !important; }

  /* ---------- Hero stat row ---------- */
  .dirA [style*="repeat(3,"][style*="border-top"] { grid-template-columns: 1fr 1fr !important; }

  /* ============================================================
     HERO LIVE-DEMO: Mobile-specific simplified layout
     - Hide the email pre (too cramped on phones)
     - Show just the context trace + quote output, full width
     - Add a small note pointing to /demos for the full thing
     ============================================================ */

  /* Hide the email pre pane on phone */
  .dirA section.bp-grid pre.mono { display: none !important; }

  /* The first inner child of the demo grid that contained the email — hide it entirely */
  .dirA section.bp-grid > .container > div[style*="border: 1px solid var(--a-rule)"][style*="background: var(--a-bg-2)"]
    > div[style*="display: grid"]
    > div:first-child {
    display: none !important;
  }

  /* Right pane (trace + output) now takes full width */
  .dirA section.bp-grid > .container > div[style*="border: 1px solid var(--a-rule)"][style*="background: var(--a-bg-2)"]
    > div[style*="display: grid"] {
    grid-template-columns: 1fr !important;
  }

  /* Context trace rows: tighter column for sys label */
  .dirA section.bp-grid div[style*="72px 1fr 16px"] {
    grid-template-columns: 56px 1fr 14px !important;
    gap: 10px !important;
    font-size: 12px !important;
  }
  .dirA section.bp-grid div[style*="72px 1fr 16px"] > span:nth-child(2) {
    word-break: break-word;
    line-height: 1.45;
  }

  /* Quote draft summary: stack vertically */
  .dirA section.bp-grid div[style*="grid-template-columns: 1fr 1fr"][style*="gap: 24px"] {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  /* Hero demo panes padding */
  .dirA section.bp-grid div[style*="padding: 16px 18px"],
  .dirA section.bp-grid div[style*="padding: 14px 18px"],
  .dirA section.bp-grid div[style*="padding: 18px 18px 8px"] {
    padding: 16px !important;
  }

  /* Sourced + elapsed footer row inside output: stack */
  .dirA section.bp-grid div[style*="border-top: 1px solid var(--a-rule)"][style*="justify-content: space-between"] {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }

  /* ---------- Form ---------- */
  .dirA form[style*="grid-template-columns: 1fr 1fr"] { grid-template-columns: 1fr !important; }

  /* ---------- Footer ---------- */
  .dirA footer [style*="grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr"] {
    grid-template-columns: 1fr 1fr !important;
    gap: 24px !important;
  }
  .dirA footer [style*="grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr"] > div:first-child {
    grid-column: 1 / -1 !important;
  }
  .dirA footer [style*="justify-content: space-between"][style*="padding-top: 24px"] {
    flex-direction: column !important;
    gap: 8px !important;
    align-items: flex-start !important;
  }

  /* ---------- Misc ---------- */
  .dirA .bp-grid { background-image: none; }
  .dirA section [style*="aspect-ratio: 1.05 / 1"] { aspect-ratio: 1 / 1 !important; }
}

/* ============================================================
   NAV — hamburger only on real mobile widths
   ============================================================ */
@media (max-width: 720px) {
  .dirA nav.desktop-nav { display: none !important; }
  .dirA .nav-ctas-desktop { display: none !important; }
  .dirA .nav-mobile-trigger { display: inline-flex !important; }
  .dirA .nav-link { padding: 12px 0 !important; }
}
@media (min-width: 721px) {
  .dirA .nav-mobile-trigger { display: none !important; }
  .dirA .mobile-drawer { display: none !important; }
}

/* Refined hamburger button — small, borderless, 3-line icon */
.dirA .nav-mobile-trigger {
  align-items: center;
  justify-content: center;
  background: transparent !important;
  border: none !important;
  padding: 8px !important;
  margin-right: -8px;
  color: var(--a-fg);
  cursor: pointer;
  width: 40px;
  height: 40px;
}
.dirA .nav-mobile-trigger svg { display: block; }

/* Mobile drawer */
.dirA .mobile-drawer {
  position: fixed; inset: 0; z-index: 100;
  background: var(--a-bg);
  display: flex; flex-direction: column;
  padding: 20px 24px 32px;
  transform: translateY(-100%);
  transition: transform .25s ease;
}
.dirA .mobile-drawer.open { transform: translateY(0); }
.dirA .mobile-drawer .drawer-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 24px;
}
.dirA .mobile-drawer a.drawer-link {
  display: block;
  padding: 18px 0;
  font-size: 24px;
  color: var(--a-fg);
  border-bottom: 1px solid var(--a-rule);
  font-family: "Instrument Serif", serif;
  letter-spacing: -0.01em;
}
.dirA .mobile-drawer a.drawer-link:hover { color: var(--a-accent); }
.dirA .mobile-drawer .drawer-ctas {
  margin-top: auto; display: flex; flex-direction: column;
  gap: 12px; padding-top: 24px;
}
.dirA .mobile-drawer .drawer-ctas .btn { width: 100%; justify-content: center; }

/* ============================================================
   STICKY HEADER on mobile — make fully opaque, no transparency
   ============================================================ */
@media (max-width: 760px) {
  .dirA header[style*="position: sticky"] {
    background: var(--a-bg) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-bottom: 1px solid var(--a-rule) !important;
  }
}

/* ============================================================
   COMPARISON TABLE — allow horizontal scroll
   ============================================================ */
@media (max-width: 720px) {
  .dirA [style*="grid-template-columns: 1.6fr repeat(4,"] {
    grid-template-columns: 1.6fr repeat(4, minmax(110px, 1fr)) !important;
  }
}
