/* ============================================================
   Meibel — pages.css (per-page overrides and section extras)
   ============================================================ */

/* ── Platform feature pages ──────────────────────────────── */
.mbl-feature-section { padding: 80px 0; }
.mbl-feature-section:nth-child(even) { background: var(--bg-dark-alt); }
.mbl-feature-section:nth-child(odd)  { background: var(--bg-dark); }
.mbl-feature-section .mbl-container {}

/* Entity types on redaction page */
.mbl-entity-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 32px;
}
.mbl-entity-chip {
  background: var(--bg-dark-alt);
  border: 1px solid var(--border-dark);
  border-radius: var(--radius);
  padding: 10px 14px;
  font-size: 12px;
  font-family: var(--font-mono);
  color: var(--fg-on-dark-2);
  display: flex;
  align-items: center;
  gap: 8px;
}
.mbl-entity-chip i { color: var(--accent); font-size: 11px; }
@media (max-width: 700px) { .mbl-entity-grid { grid-template-columns: repeat(2, 1fr); } }

/* Integration logos */
.mbl-integration-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
  align-items: center;
  justify-items: center;
}
.mbl-integration-item {
  background: var(--bg-dark-alt);
  border: 1px solid var(--border-dark);
  border-radius: var(--radius);
  padding: 14px 20px;
  width: 100%;
  text-align: center;
  font-size: 12px;
  font-family: var(--font-mono);
  color: var(--fg-on-dark-muted);
}
@media (max-width: 900px) { .mbl-integration-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px) { .mbl-integration-grid { grid-template-columns: repeat(2, 1fr); } }

/* Rate-limiting policy types */
.mbl-policy-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  margin-top: 28px;
}
.mbl-policy-table th {
  text-align: left;
  padding: 10px 16px;
  background: var(--bg-dark-deep);
  color: var(--fg-on-dark-2);
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-bottom: 1px solid var(--border-dark);
}
.mbl-policy-table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-dark);
  color: var(--fg-on-dark-2);
  line-height: 1.5;
}
.mbl-policy-table tr:hover td { background: rgba(255,255,255,0.02); }
.mbl-policy-table td:first-child { color: var(--fg-on-dark); font-family: var(--font-mono); font-weight: 500; }

/* Audit trail log field anatomy */
.mbl-log-field-list { display: flex; flex-direction: column; gap: 14px; margin-top: 24px; }
.mbl-log-field {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 16px;
  padding: 14px 16px;
  background: var(--bg-dark-alt);
  border: 1px solid var(--border-dark);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius);
}
.mbl-log-field__key {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  color: var(--accent-aa-on-dark);
}
.mbl-log-field__desc {
  font-size: 13px;
  color: var(--fg-on-dark-2);
  line-height: 1.5;
}
@media (max-width: 600px) { .mbl-log-field { grid-template-columns: 1fr; } }

/* Tenant isolation models */
.mbl-isolation-models { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 32px; }
.mbl-isolation-model {
  background: var(--bg-dark-alt);
  border: 1px solid var(--border-dark);
  border-radius: var(--radius-lg);
  padding: 24px;
}
.mbl-isolation-model__title { font-size: 15px; font-weight: 600; color: var(--fg-on-dark); margin-bottom: 10px; }
.mbl-isolation-model__desc { font-size: 13px; color: var(--fg-on-dark-2); line-height: 1.6; margin-bottom: 14px; }
.mbl-isolation-model__pros-cons { font-size: 12px; }
.mbl-isolation-model__pros-label { color: #86EFAC; font-family: var(--font-mono); }
.mbl-isolation-model__cons-label { color: #FCA5A5; font-family: var(--font-mono); }
.mbl-isolation-model__item { color: var(--fg-on-dark-muted); padding: 2px 0; }
@media (max-width: 700px) { .mbl-isolation-models { grid-template-columns: 1fr; } }

/* Query interface (audit trail) */
.mbl-query-bar {
  background: var(--bg-dark-deep);
  border: 1px solid var(--border-dark);
  border-radius: var(--radius);
  padding: 16px 20px;
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 24px;
}
.mbl-query-filter {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-family: var(--font-mono);
}
.mbl-query-filter__label { color: var(--fg-on-dark-muted); }
.mbl-query-filter__val {
  background: rgba(200,146,10,0.1);
  border: 1px solid rgba(200,146,10,0.2);
  border-radius: 4px;
  padding: 3px 8px;
  color: var(--accent-aa-on-dark);
  font-size: 12px;
  font-family: var(--font-mono);
}

/* ── Security page extras ────────────────────────────────── */
.mbl-pentest-box {
  background: var(--bg-amber-subtle);
  border: 1px solid rgba(200,146,10,0.2);
  border-left: 4px solid var(--accent);
  border-radius: var(--radius);
  padding: 20px 24px;
  margin-top: 32px;
}
.mbl-pentest-box__title { font-size: 15px; font-weight: 600; color: var(--fg-on-light); margin-bottom: 8px; }
.mbl-pentest-box__text { font-size: 14px; color: var(--fg-on-light-2); line-height: 1.6; }

/* Data handling callouts */
.mbl-data-points { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 24px; }
.mbl-data-point {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.mbl-data-point__icon { color: var(--accent-aa-on-light); font-size: 16px; margin-top: 2px; flex-shrink: 0; }
.mbl-data-point__text { font-size: 14px; color: var(--fg-on-light-2); line-height: 1.6; }
.mbl-data-point__text strong { color: var(--fg-on-light); display: block; margin-bottom: 2px; font-size: 13px; }
@media (max-width: 600px) { .mbl-data-points { grid-template-columns: 1fr; } }

/* ── About page (legacy stubs — real defs added below) ───── */

/* Founder section on about */
.mbl-founder-bio {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 48px;
  align-items: start;
  padding: 0;
}
@media (max-width: 700px) {
  .mbl-founder-bio { grid-template-columns: 1fr; }
}

/* ── Docs index cards ─────────────────────────────────────── */
.mbl-doc-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 48px; }
.mbl-doc-card {
  background: var(--bg-white);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: 24px;
  transition: box-shadow 0.2s, transform 0.2s;
}
.mbl-doc-card:hover { box-shadow: 0 6px 20px rgba(28,31,46,0.07); transform: translateY(-2px); }
.mbl-doc-card__icon { color: var(--accent-aa-on-light); font-size: 22px; margin-bottom: 12px; }
.mbl-doc-card__title { font-size: 15px; font-weight: 600; color: var(--fg-on-light); margin-bottom: 6px; }
.mbl-doc-card__desc { font-size: 13px; color: var(--fg-on-light-2); line-height: 1.55; margin-bottom: 12px; }
.mbl-doc-card__link { font-size: 12px; color: var(--accent-aa-on-light); font-weight: 500; display: flex; align-items: center; gap: 4px; }
.mbl-doc-card__link:hover { text-decoration: underline; }
@media (max-width: 700px) { .mbl-doc-cards { grid-template-columns: 1fr 1fr; } }
@media (max-width: 500px) { .mbl-doc-cards { grid-template-columns: 1fr; } }

/* API reference endpoint listing */
.mbl-endpoint { margin-bottom: 40px; }
.mbl-endpoint__header { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.mbl-endpoint__method {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 4px;
  text-transform: uppercase;
}
.mbl-endpoint__method--post { background: rgba(134,239,172,0.15); color: #86EFAC; }
.mbl-endpoint__method--get  { background: rgba(125,211,252,0.15); color: #7DD3FC; }
.mbl-endpoint__path { font-family: var(--font-mono); font-size: 14px; color: var(--fg-on-light); }
.mbl-endpoint__desc { font-size: 14px; color: var(--fg-on-light-2); line-height: 1.6; margin-bottom: 12px; }
.mbl-param-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.mbl-param-table th { text-align: left; padding: 8px 12px; background: var(--bg-light); font-weight: 600; color: var(--fg-on-light); border-bottom: 2px solid var(--border-light); }
.mbl-param-table td { padding: 8px 12px; border-bottom: 1px solid var(--border-light); color: var(--fg-on-light-2); }
.mbl-param-table td:first-child { font-family: var(--font-mono); color: var(--fg-on-light); }

/* ── Contact / request-access page ──────────────────────── */
.mbl-contact-layout {
  max-width: var(--container);
  margin: 0 auto;
  padding: 64px 24px;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: start;
}
.mbl-address-block {
  background: var(--bg-white);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: 28px;
}
.mbl-address-block__title { font-size: 16px; font-weight: 600; color: var(--fg-on-light); margin-bottom: 16px; }
.mbl-address-block__item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 14px;
}
.mbl-address-block__icon { color: var(--accent-aa-on-light); font-size: 14px; margin-top: 2px; flex-shrink: 0; }
.mbl-address-block__text { font-size: 14px; color: var(--fg-on-light-2); line-height: 1.5; }
.mbl-address-block__text a { color: var(--accent-aa-on-light); }
@media (max-width: 768px) { .mbl-contact-layout { grid-template-columns: 1fr; } }

/* Expect-list on request-access */
.mbl-expect-list { display: flex; flex-direction: column; gap: 16px; margin-top: 16px; }
.mbl-expect-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.mbl-expect-num {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 2px solid var(--accent);
  color: var(--accent-aa-on-light);
  font-size: 12px;
  font-weight: 700;
  font-family: var(--font-mono);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.mbl-expect-text { font-size: 14px; color: var(--fg-on-light-2); line-height: 1.55; padding-top: 4px; }

/* ── Status badges (success/error) ──────────────────────── */
.mbl-verdict--allowed {
  display: inline-block;
  background: rgba(134,239,172,0.15);
  color: #4ade80;
  border: 1px solid rgba(74,222,128,0.25);
  font-size: 11px;
  font-family: var(--font-mono);
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.mbl-verdict--redacted {
  display: inline-block;
  background: rgba(200,146,10,0.15);
  color: var(--accent-aa-on-dark);
  border: 1px solid rgba(200,146,10,0.25);
  font-size: 11px;
  font-family: var(--font-mono);
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.mbl-verdict--blocked {
  display: inline-block;
  background: rgba(252,165,165,0.15);
  color: #fca5a5;
  border: 1px solid rgba(252,165,165,0.25);
  font-size: 11px;
  font-family: var(--font-mono);
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ── Hero policy-gate SVG positioning ───────────────────── */
.mbl-hero-svg-wrap {
  width: 100%;
  min-height: 280px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── Platform overview feature grid ─────────────────────── */
.mbl-platform-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-top: 32px; }
.mbl-platform-item {
  background: var(--bg-dark-alt);
  border: 1px solid var(--border-dark);
  border-radius: var(--radius-lg);
  padding: 28px;
}
.mbl-platform-item__icon { color: var(--accent); font-size: 24px; margin-bottom: 14px; }
.mbl-platform-item__title { font-size: 17px; font-weight: 600; color: var(--fg-on-dark); margin-bottom: 8px; }
.mbl-platform-item__desc { font-size: 14px; color: var(--fg-on-dark-2); line-height: 1.6; }
.mbl-platform-item__link { display: inline-flex; align-items: center; gap: 4px; margin-top: 12px; font-size: 12px; font-weight: 500; color: var(--accent-aa-on-dark); }
.mbl-platform-item__link:hover { text-decoration: underline; }
@media (max-width: 700px) { .mbl-platform-grid { grid-template-columns: 1fr; } }

/* ── Success page message ─────────────────────────────────── */
.mbl-success-msg {
  background: rgba(134,239,172,0.1);
  border: 1px solid rgba(74,222,128,0.25);
  border-radius: var(--radius);
  padding: 14px 18px;
  font-size: 14px;
  color: #4ade80;
  display: none;
  margin-top: 12px;
}
.mbl-success-msg.visible { display: block; }

/* ── Pricing FAQ section ──────────────────────────────────── */
.mbl-pricing-wrapper { max-width: var(--container); margin: 0 auto; padding: 0 24px; }
.mbl-pricing-header { text-align: center; margin-bottom: 48px; }
.mbl-pricing-header h2 { color: var(--fg-on-light); margin-bottom: 10px; }
.mbl-pricing-header p { color: var(--fg-on-light-2); font-size: 16px; }

/* ── Sub-hero (pricing, contact, use-cases) ──────────────── */
.mbl-subhero {
  padding: 80px 0 64px;
}
.mbl-subhero--light { background: var(--bg-light); }
.mbl-subhero--dark  { background: var(--bg-dark); }

.mbl-subhero__inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.mbl-subhero__inner--centered {
  grid-template-columns: 1fr;
  max-width: 720px;
  text-align: center;
}
.mbl-subhero__eyebrow {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-family: var(--font-mono);
  color: var(--accent-aa-on-light);
  margin-bottom: 14px;
  display: block;
}
.mbl-subhero--dark .mbl-subhero__eyebrow { color: var(--accent-aa-on-dark); }
.mbl-subhero__h1 {
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 700;
  line-height: 1.1;
  color: var(--fg-on-light);
  margin-bottom: 16px;
}
.mbl-subhero--dark .mbl-subhero__h1 { color: var(--fg-on-dark); }
.mbl-subhero__h1--centered { max-width: 640px; margin-left: auto; margin-right: auto; }
.mbl-subhero__lede {
  font-size: 17px;
  color: var(--fg-on-light-2);
  line-height: 1.65;
  max-width: 520px;
}
.mbl-subhero--dark .mbl-subhero__lede { color: var(--fg-on-dark-2); }
.mbl-subhero__lede--centered { max-width: 600px; margin-left: auto; margin-right: auto; }
@media (max-width: 768px) { .mbl-subhero__inner { grid-template-columns: 1fr; gap: 32px; } }

/* ── Pricing tiers grid ───────────────────────────────────── */
.mbl-pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  align-items: stretch;
}
.mbl-pricing-tier {
  background: var(--bg-white);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.mbl-pricing-tier--featured {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(200,146,10,0.15), 0 8px 24px rgba(0,0,0,0.08);
}
.mbl-pricing-tier__badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-family: var(--font-mono);
  color: var(--fg-on-light-muted);
  background: var(--bg-light);
  border: 1px solid var(--border-light);
  border-radius: 4px;
  padding: 3px 10px;
  margin-bottom: 20px;
  width: fit-content;
}
.mbl-pricing-tier__badge--amber {
  color: var(--accent-aa-on-light);
  background: rgba(200,146,10,0.08);
  border-color: rgba(200,146,10,0.25);
}
.mbl-pricing-tier__price {
  margin-bottom: 14px;
  display: flex;
  align-items: baseline;
  gap: 4px;
}
.mbl-pricing-tier__amount {
  font-size: 40px;
  font-weight: 700;
  color: var(--fg-on-light);
  line-height: 1;
}
.mbl-pricing-tier__period {
  font-size: 13px;
  color: var(--fg-on-light-muted);
}
.mbl-pricing-tier__desc {
  font-size: 14px;
  color: var(--fg-on-light-2);
  line-height: 1.55;
  margin-bottom: 24px;
}
.mbl-pricing-tier__features {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
  margin-bottom: 28px;
}
.mbl-pricing-tier__features li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  color: var(--fg-on-light-2);
  line-height: 1.45;
}
.mbl-pricing-tier__features li i { color: #2A6B1F; font-size: 13px; margin-top: 2px; flex-shrink: 0; }
.mbl-pricing-tier--featured .mbl-pricing-tier__features li i { color: var(--accent-aa-on-light); }
@media (max-width: 900px) { .mbl-pricing-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .mbl-pricing-grid { grid-template-columns: 1fr; } }

/* ── Pricing comparison table ────────────────────────────── */
.mbl-pricing-compare-wrap { overflow-x: auto; margin-top: 32px; }
.mbl-pricing-compare {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}
.mbl-pricing-compare th {
  text-align: center;
  padding: 14px 16px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-family: var(--font-mono);
  color: var(--fg-on-light-muted);
  background: var(--bg-light);
  border-bottom: 2px solid var(--border-light);
}
.mbl-pricing-compare th:first-child { text-align: left; }
.mbl-pricing-compare td {
  padding: 11px 16px;
  border-bottom: 1px solid var(--border-light);
  color: var(--fg-on-light-2);
  text-align: center;
}
.mbl-pricing-compare td:first-child { text-align: left; color: var(--fg-on-light); }
.mbl-pricing-compare tr:hover td { background: var(--bg-light); }
.mbl-pricing-compare__group {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-family: var(--font-mono);
  color: var(--fg-on-light-muted) !important;
  background: var(--bg-card) !important;
  padding: 8px 16px !important;
}
.mbl-pricing-compare__featured {
  background: rgba(200,146,10,0.04) !important;
  font-weight: 500;
  border-left: 2px solid rgba(200,146,10,0.2);
  border-right: 2px solid rgba(200,146,10,0.2);
}

/* ── About: team grid ────────────────────────────────────── */
.mbl-team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 8px;
}
.mbl-team-card {
  background: var(--bg-white);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: 28px;
}
.mbl-team-card__portrait {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  overflow: hidden;
  margin-bottom: 14px;
  border: 2px solid var(--border-light);
  flex-shrink: 0;
}
.mbl-team-card__portrait img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.mbl-team-card__name { font-size: 16px; font-weight: 600; color: var(--fg-on-light); margin-bottom: 4px; }
.mbl-team-card__title { font-size: 12px; font-family: var(--font-mono); color: var(--accent-aa-on-light); margin-bottom: 10px; }
.mbl-team-card__bio { font-size: 13px; color: var(--fg-on-light-2); line-height: 1.6; }
@media (max-width: 700px) { .mbl-team-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 450px) { .mbl-team-grid { grid-template-columns: 1fr; } }

/* About: founder bio – updated with new class names */
.mbl-founder-bio__portrait {
  width: 240px;
  flex-shrink: 0;
}
.mbl-founder-bio__portrait img {
  width: 200px;
  height: 200px;
  border-radius: var(--radius-lg);
  object-fit: cover;
  border: 2px solid var(--border-light);
}
.mbl-founder-bio__content {}
.mbl-founder-bio__label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  font-family: var(--font-mono);
  color: var(--accent-aa-on-light);
  margin-bottom: 6px;
}
.mbl-founder-bio__name { font-size: 26px; font-weight: 700; color: var(--fg-on-light); margin-bottom: 4px; }
.mbl-founder-bio__title { font-size: 13px; color: var(--fg-on-light-muted); margin-bottom: 20px; }
.mbl-founder-bio__bio { font-size: 15px; color: var(--fg-on-light-2); line-height: 1.7; margin-bottom: 12px; }
.mbl-founder-bio__contact { margin-top: 16px; }
.mbl-founder-bio__contact-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: var(--accent-aa-on-light);
  font-weight: 500;
}
.mbl-founder-bio__contact-link:hover { text-decoration: underline; }

/* About: values grid - new class names */
.mbl-value-card {
  background: var(--bg-white);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: 28px;
}
.mbl-values-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.mbl-value-card__icon { color: var(--accent-aa-on-light); font-size: 22px; margin-bottom: 12px; }
.mbl-value-card__title { font-size: 16px; font-weight: 600; color: var(--fg-on-light); margin-bottom: 8px; }
.mbl-value-card__text { font-size: 14px; color: var(--fg-on-light-2); line-height: 1.65; }
@media (max-width: 700px) { .mbl-values-grid { grid-template-columns: 1fr; } }

/* About: scene / office photo */
.mbl-about-scene {
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
}
.mbl-about-scene__img {
  width: 100%;
  max-height: 360px;
  object-fit: cover;
  display: block;
  border-radius: var(--radius-lg);
}
.mbl-about-scene__caption {
  font-size: 12px;
  color: var(--fg-on-light-muted);
  margin-top: 10px;
  text-align: center;
  font-style: italic;
}

/* About hero SVG */
.mbl-about-svg {
  width: 100%;
  height: auto;
  max-width: 380px;
}

/* ── Contact form ────────────────────────────────────────── */
.mbl-contact-form { display: flex; flex-direction: column; gap: 16px; }
.mbl-contact-form__field { display: flex; flex-direction: column; gap: 6px; }
.mbl-contact-form__field label { font-size: 13px; font-weight: 500; color: var(--fg-on-light); }
.mbl-contact-form__field input,
.mbl-contact-form__field select,
.mbl-contact-form__field textarea {
  padding: 10px 14px;
  border: 1px solid var(--border-light);
  border-radius: var(--radius);
  background: var(--bg-white);
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--fg-on-light);
  transition: border-color 0.15s;
  width: 100%;
}
.mbl-contact-form__field input:focus,
.mbl-contact-form__field select:focus,
.mbl-contact-form__field textarea:focus {
  outline: none;
  border-color: var(--accent);
}
.mbl-contact-form__field textarea { resize: vertical; min-height: 100px; }
.mbl-contact-form__field select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234A5062' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 32px;
}
.mbl-contact-form__field select option { background: #fff; color: var(--fg-on-light); }

/* Contact reason cards */
.mbl-contact-reasons { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 40px; }
.mbl-contact-reason {
  background: var(--bg-white);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: 24px;
}
.mbl-contact-reason__icon { color: var(--accent-aa-on-light); font-size: 20px; margin-bottom: 10px; }
.mbl-contact-reason__title { font-size: 15px; font-weight: 600; color: var(--fg-on-light); margin-bottom: 8px; }
.mbl-contact-reason__text { font-size: 13px; color: var(--fg-on-light-2); line-height: 1.6; margin-bottom: 10px; }
.mbl-contact-reason__link { font-size: 13px; color: var(--accent-aa-on-light); font-weight: 500; }
.mbl-contact-reason__link:hover { text-decoration: underline; }
@media (max-width: 700px) { .mbl-contact-reasons { grid-template-columns: 1fr; } }

/* Address block row variant (contact page) */
.mbl-address-block__row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 14px;
  color: var(--fg-on-light-2);
  margin-bottom: 12px;
}
.mbl-address-block__row i { color: var(--accent-aa-on-light); font-size: 14px; margin-top: 2px; flex-shrink: 0; }
.mbl-address-block__row a { color: var(--accent-aa-on-light); }
.mbl-address-block__row a:hover { text-decoration: underline; }

/* ── Request-access form ──────────────────────────────────── */
.mbl-access-form { display: flex; flex-direction: column; gap: 16px; }
.mbl-access-form .mbl-contact-form__field { display: flex; flex-direction: column; gap: 6px; }
.mbl-access-form .mbl-contact-form__field label { font-size: 13px; font-weight: 500; color: var(--fg-on-light); }
.mbl-access-form .mbl-contact-form__field input,
.mbl-access-form .mbl-contact-form__field select,
.mbl-access-form .mbl-contact-form__field textarea {
  padding: 10px 14px;
  border: 1px solid var(--border-light);
  border-radius: var(--radius);
  background: var(--bg-white);
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--fg-on-light);
  transition: border-color 0.15s;
  width: 100%;
}
.mbl-access-form .mbl-contact-form__field input:focus,
.mbl-access-form .mbl-contact-form__field select:focus,
.mbl-access-form .mbl-contact-form__field textarea:focus {
  outline: none;
  border-color: var(--accent);
}

/* ── Blog hero ────────────────────────────────────────────── */
.mbl-blog-hero {
  background: var(--bg-dark);
  padding: 80px 0 64px;
}
.mbl-blog-hero__inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 24px;
}
.mbl-blog-hero .mbl-hero__eyebrow { color: var(--accent-aa-on-dark); }
.mbl-blog-hero .mbl-hero__h1 { color: var(--fg-on-dark); }
.mbl-blog-hero .mbl-hero__lede { color: var(--fg-on-dark-2); }

/* ── Blog grid + cards ────────────────────────────────────── */
.mbl-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.mbl-blog-card {
  background: var(--bg-white);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.2s, transform 0.2s;
}
.mbl-blog-card:hover { box-shadow: 0 6px 20px rgba(28,31,46,0.08); transform: translateY(-2px); }
.mbl-blog-card__img-link { display: block; overflow: hidden; }
.mbl-blog-card__img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
  transition: transform 0.3s;
}
.mbl-blog-card__img-link:hover .mbl-blog-card__img { transform: scale(1.03); }
.mbl-blog-card__body { padding: 20px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.mbl-blog-card__tags { display: flex; flex-wrap: wrap; gap: 6px; }
.mbl-blog-tag {
  font-size: 11px;
  font-family: var(--font-mono);
  font-weight: 500;
  background: rgba(200,146,10,0.08);
  color: var(--accent-aa-on-light);
  border: 1px solid rgba(200,146,10,0.2);
  border-radius: 4px;
  padding: 2px 8px;
}
.mbl-blog-card__title {
  font-size: 16px;
  font-weight: 600;
  color: var(--fg-on-light);
  line-height: 1.35;
  margin-top: 4px;
}
.mbl-blog-card__title a { color: inherit; }
.mbl-blog-card__title a:hover { color: var(--accent-aa-on-light); }
.mbl-blog-card__excerpt { font-size: 13px; color: var(--fg-on-light-2); line-height: 1.6; flex: 1; }
.mbl-blog-card__meta {
  display: flex;
  gap: 10px;
  font-size: 12px;
  color: var(--fg-on-light-muted);
  margin-top: 4px;
  flex-wrap: wrap;
}
.mbl-blog-card__meta time { color: var(--fg-on-light-muted); }
@media (max-width: 900px) { .mbl-blog-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .mbl-blog-grid { grid-template-columns: 1fr; } }

/* ── Blog article layout ──────────────────────────────────── */
.mbl-article-layout { background: var(--bg-white); }
.mbl-article-header {
  background: var(--bg-dark);
  padding: 64px 0 0;
}
.mbl-article-header__inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 24px 0;
}
.mbl-article-header__meta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.mbl-article-header__back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--fg-on-dark-muted);
  transition: color 0.15s;
}
.mbl-article-header__back:hover { color: var(--fg-on-dark); }
.mbl-article-header__back .mbl-blog-tag { margin-left: 4px; }
.mbl-article-header__h1 {
  font-size: clamp(24px, 3.5vw, 36px);
  font-weight: 700;
  line-height: 1.2;
  color: var(--fg-on-dark);
  margin-bottom: 20px;
}
.mbl-article-header__byline {
  display: flex;
  gap: 16px;
  align-items: center;
  font-size: 13px;
  color: var(--fg-on-dark-muted);
  flex-wrap: wrap;
  margin-bottom: 32px;
}
.mbl-article-header__byline time { color: var(--fg-on-dark-muted); }
.mbl-article-header__cover {
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  display: block;
  max-height: 380px;
  object-fit: cover;
}

/* Article body */
.mbl-article-body {
  max-width: 760px;
  margin: 0 auto;
  padding: 48px 24px 0;
  color: var(--fg-on-light);
  font-size: 16px;
  line-height: 1.75;
}
.mbl-article-body h2 { font-size: 22px; font-weight: 600; color: var(--fg-on-light); margin: 40px 0 14px; }
.mbl-article-body h3 { font-size: 18px; font-weight: 600; color: var(--fg-on-light); margin: 30px 0 10px; }
.mbl-article-body p { color: var(--fg-on-light-2); margin-bottom: 18px; }
.mbl-article-body ul, .mbl-article-body ol { margin-bottom: 18px; padding-left: 24px; color: var(--fg-on-light-2); }
.mbl-article-body li { margin-bottom: 6px; }
.mbl-article-body code { font-family: var(--font-mono); font-size: 13px; background: var(--bg-light); padding: 2px 6px; border-radius: 3px; color: var(--fg-on-light); }

/* Article footer */
.mbl-article-footer {
  max-width: 760px;
  margin: 0 auto;
  padding: 32px 24px 64px;
}
.mbl-article-footer__cta {
  background: var(--bg-light);
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  font-size: 14px;
  color: var(--fg-on-light-2);
  line-height: 1.6;
  margin-bottom: 32px;
}
.mbl-article-footer__cta a { color: var(--accent-aa-on-light); font-weight: 500; }
.mbl-article-footer__cta a:hover { text-decoration: underline; }
.mbl-article-footer__nav {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.mbl-article-footer__prev,
.mbl-article-footer__next {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--accent-aa-on-light);
  padding: 10px 16px;
  border: 1px solid var(--border-light);
  border-radius: var(--radius);
  background: var(--bg-white);
  transition: border-color 0.15s, background 0.15s;
}
.mbl-article-footer__prev:hover,
.mbl-article-footer__next:hover { border-color: var(--accent); background: rgba(200,146,10,0.04); }

/* ── Docs hero (dark) ────────────────────────────────────── */
.mbl-doc-hero {
  background: var(--bg-dark);
  padding: 72px 0 56px;
}
.mbl-doc-hero__inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 24px;
}
.mbl-doc-hero .mbl-hero__eyebrow { color: var(--accent-aa-on-dark); }
.mbl-doc-hero .mbl-hero__h1 { color: var(--fg-on-dark); }
.mbl-doc-hero .mbl-hero__lede { color: var(--fg-on-dark-2); }

/* Docs popular links grid */
.mbl-doc-links {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 8px;
}
.mbl-doc-link-group {}
.mbl-doc-link-group__title {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-family: var(--font-mono);
  color: var(--fg-on-light-muted);
  margin-bottom: 12px;
}
.mbl-doc-link-group ul { display: flex; flex-direction: column; gap: 8px; }
.mbl-doc-link-group a { font-size: 14px; color: var(--accent-aa-on-light); }
.mbl-doc-link-group a:hover { text-decoration: underline; }
@media (max-width: 700px) { .mbl-doc-links { grid-template-columns: 1fr; } }

/* Docs code blocks */
.mbl-code-block {
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border-dark);
  margin-bottom: 8px;
}
.mbl-code-block__header {
  background: var(--bg-dark-deep);
  padding: 8px 16px;
  border-bottom: 1px solid var(--border-dark);
  display: flex;
  align-items: center;
}
.mbl-code-block__label {
  font-size: 11px;
  font-family: var(--font-mono);
  font-weight: 500;
  color: var(--fg-on-dark-muted);
  letter-spacing: 0.04em;
}
.mbl-code-block__body {
  background: var(--bg-dark-alt);
  padding: 16px;
  margin: 0;
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.45;
  color: var(--fg-on-dark-2);
}
.mbl-section--dark .mbl-code-block,
.mbl-section--dark-alt .mbl-code-block { border-color: var(--border-dark); }
/* Syntax token colors */
.ck { color: #7DD3FC; }
.cv { color: #86EFAC; }
.cs { color: #FCA5A5; }
.cc { color: var(--fg-on-dark-muted); font-style: italic; }

/* Doc sidebar layout */
.mbl-doc-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: calc(100vh - var(--nav-h));
  align-items: start;
  max-width: var(--container);
  margin: 0 auto;
  padding: 40px 24px 80px;
  gap: 48px;
}
.mbl-doc-sidebar {
  position: sticky;
  top: calc(var(--nav-h) + 16px);
  padding: 0;
  max-height: calc(100vh - var(--nav-h) - 40px);
  overflow-y: auto;
}
.mbl-doc-sidebar__section { margin-bottom: 28px; }
.mbl-doc-sidebar__title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  font-family: var(--font-mono);
  color: var(--fg-on-light-muted);
  margin-bottom: 8px;
}
.mbl-doc-sidebar__links { display: flex; flex-direction: column; gap: 2px; }
.mbl-doc-sidebar__link {
  font-size: 13px;
  color: var(--fg-on-light-2);
  padding: 4px 8px;
  border-radius: 4px;
  transition: background 0.12s, color 0.12s;
  display: block;
}
.mbl-doc-sidebar__link:hover { background: var(--bg-light); color: var(--fg-on-light); }
.mbl-doc-sidebar__link--active { background: rgba(200,146,10,0.08); color: var(--accent-aa-on-light); font-weight: 500; }
.mbl-doc-content {
  min-width: 0;
  padding: 0;
}
.mbl-doc-breadcrumb {
  font-size: 13px;
  color: var(--fg-on-light-muted);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.mbl-doc-breadcrumb a { color: var(--accent-aa-on-light); }
.mbl-doc-breadcrumb a:hover { text-decoration: underline; }
.mbl-doc-h1 { font-size: 32px; font-weight: 700; color: var(--fg-on-light); margin-bottom: 16px; line-height: 1.15; }
.mbl-doc-h2 { font-size: 22px; font-weight: 600; color: var(--fg-on-light); margin: 36px 0 12px; line-height: 1.25; }
.mbl-doc-h3 { font-size: 17px; font-weight: 600; color: var(--fg-on-light); margin: 28px 0 10px; }
.mbl-doc-lead { font-size: 16px; color: var(--fg-on-light-2); line-height: 1.7; margin-bottom: 28px; }
.mbl-doc-content p { font-size: 14px; color: var(--fg-on-light-2); line-height: 1.7; margin-bottom: 16px; }
.mbl-doc-content ul, .mbl-doc-content ol { padding-left: 20px; color: var(--fg-on-light-2); margin-bottom: 16px; }
.mbl-doc-content li { font-size: 14px; margin-bottom: 6px; line-height: 1.6; }
.mbl-doc-content ul { list-style: disc; }
.mbl-doc-content ol { list-style: decimal; }
.mbl-doc-callout {
  border-radius: var(--radius);
  padding: 14px 18px;
  margin: 20px 0;
  border: 1px solid;
}
.mbl-doc-callout--info { background: rgba(125,211,252,0.08); border-color: rgba(125,211,252,0.25); }
.mbl-doc-callout--success { background: rgba(134,239,172,0.08); border-color: rgba(134,239,172,0.25); }
.mbl-doc-callout__title {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.mbl-doc-callout--info .mbl-doc-callout__title { color: #7DD3FC; }
.mbl-doc-callout--success .mbl-doc-callout__title { color: #86EFAC; }
.mbl-doc-callout ul { list-style: disc; padding-left: 20px; }
.mbl-doc-callout li { font-size: 13px; color: var(--fg-on-light-2); margin-bottom: 4px; }
.mbl-doc-nav {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--border-light);
  flex-wrap: wrap;
}
.mbl-doc-nav__prev,
.mbl-doc-nav__next {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--accent-aa-on-light);
  padding: 10px 16px;
  border: 1px solid var(--border-light);
  border-radius: var(--radius);
  background: var(--bg-white);
  transition: border-color 0.15s, background 0.15s;
}
.mbl-doc-nav__prev:hover, .mbl-doc-nav__next:hover { border-color: var(--accent); background: rgba(200,146,10,0.04); }
.mbl-doc-ol { padding-left: 20px; }
.mbl-doc-ol li { list-style: decimal; font-size: 14px; color: var(--fg-on-light-2); margin-bottom: 8px; line-height: 1.6; }
.mbl-doc-entity-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 12px; }
.mbl-doc-entity-group {
  background: var(--bg-light);
  border: 1px solid var(--border-light);
  border-radius: var(--radius);
  padding: 16px;
}
.mbl-doc-entity-group__title {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-family: var(--font-mono);
  color: var(--accent-aa-on-light);
  margin-bottom: 8px;
}
.mbl-doc-entity-group ul { list-style: none; }
.mbl-doc-entity-group li { font-size: 13px; font-family: var(--font-mono); color: var(--fg-on-light-2); padding: 3px 0; }
.mbl-inline-code {
  font-family: var(--font-mono);
  font-size: 12px;
  background: var(--bg-light);
  border: 1px solid var(--border-light);
  padding: 1px 6px;
  border-radius: 3px;
  color: var(--fg-on-light);
}
@media (max-width: 900px) {
  .mbl-doc-layout { grid-template-columns: 1fr; }
  .mbl-doc-sidebar { position: static; max-height: none; }
}
@media (max-width: 700px) { .mbl-doc-entity-grid { grid-template-columns: 1fr; } }

/* Endpoint badges for docs */
.mbl-endpoint { margin-bottom: 40px; padding-bottom: 32px; border-bottom: 1px solid var(--border-light); }
.mbl-endpoint:last-child { border-bottom: none; }
.mbl-endpoint__header { display: flex; align-items: center; gap: 12px; margin-bottom: 8px; flex-wrap: wrap; }
.mbl-endpoint__method {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.mbl-endpoint--post .mbl-endpoint__method { background: rgba(134,239,172,0.15); color: #4ade80; }
.mbl-endpoint--get  .mbl-endpoint__method { background: rgba(125,211,252,0.15); color: #7DD3FC; }
.mbl-endpoint--put  .mbl-endpoint__method { background: rgba(251,191,36,0.15); color: #FBBF24; }
.mbl-endpoint--delete .mbl-endpoint__method { background: rgba(252,165,165,0.15); color: #FCA5A5; }
.mbl-endpoint__path { font-family: var(--font-mono); font-size: 15px; font-weight: 600; color: var(--fg-on-light); }
.mbl-endpoint__label {
  font-size: 11px;
  font-family: var(--font-mono);
  background: var(--bg-light);
  border: 1px solid var(--border-light);
  color: var(--fg-on-light-muted);
  border-radius: 4px;
  padding: 2px 8px;
  font-weight: 500;
}
.mbl-endpoint__desc { font-size: 14px; color: var(--fg-on-light-2); line-height: 1.65; margin: 8px 0 16px; }

/* ── Auth pages (login / signup / reset) ─────────────────── */
.mbl-auth-page {
  margin: 0;
  padding: 0;
}
.mbl-auth-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 100vh;
  background: var(--bg-dark);
}
.mbl-auth-layout--centered {
  grid-template-columns: 1fr;
  justify-items: center;
  align-items: center;
  background: var(--bg-light);
  padding: 80px 24px;
}
.mbl-auth-brand {
  background: var(--bg-dark-alt);
  display: flex;
  flex-direction: column;
  padding: clamp(32px, 6vw, 72px);
  border-right: 1px solid var(--border-dark);
}
.mbl-auth-brand__logo {
  display: block;
  margin-bottom: 32px;
}
.mbl-auth-brand__tagline {
  font-size: 15px;
  color: var(--fg-on-dark-2);
  line-height: 1.6;
  max-width: 320px;
  margin-bottom: 40px;
}
.mbl-auth-brand__visual {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mbl-auth-brand__visual svg { width: 100%; max-width: 320px; height: auto; }
.mbl-auth-brand__feature-list { display: flex; flex-direction: column; gap: 16px; margin-top: 20px; }
.mbl-auth-brand__feature {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 14px;
  color: var(--fg-on-dark-2);
  line-height: 1.5;
}
.mbl-auth-brand__feature i { color: var(--accent-aa-on-dark); font-size: 14px; margin-top: 2px; flex-shrink: 0; }
.mbl-auth-card-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: clamp(32px, 6vw, 72px);
  background: var(--bg-dark);
}
.mbl-auth-card-wrap--solo {
  background: var(--bg-white);
  border-radius: var(--radius-lg);
  padding: 40px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
  width: 100%;
  max-width: 420px;
}
.mbl-auth-card {
  width: 100%;
  max-width: 380px;
  background: var(--bg-dark-alt);
  border: 1px solid var(--border-dark);
  border-radius: var(--radius-lg);
  padding: 36px;
}
.mbl-auth-card--light {
  background: var(--bg-white);
  border-color: var(--border-light);
}
.mbl-auth-card__h1 {
  font-size: 22px;
  font-weight: 700;
  color: var(--fg-on-dark);
  margin-bottom: 8px;
}
.mbl-auth-card--light .mbl-auth-card__h1 { color: var(--fg-on-light); }
.mbl-auth-card__sub {
  font-size: 14px;
  color: var(--fg-on-dark-muted);
  margin-bottom: 28px;
}
.mbl-auth-card--light .mbl-auth-card__sub { color: var(--fg-on-light-muted); }
.mbl-auth-card__sub a { color: var(--accent-aa-on-dark); }
.mbl-auth-card--light .mbl-auth-card__sub a { color: var(--accent-aa-on-light); }
.mbl-auth-form { display: flex; flex-direction: column; gap: 16px; }
.mbl-auth-form__field { display: flex; flex-direction: column; gap: 5px; }
.mbl-auth-form__field label { font-size: 13px; font-weight: 500; color: var(--fg-on-dark-2); }
.mbl-auth-card--light .mbl-auth-form__field label { color: var(--fg-on-light); }
.mbl-auth-form__field input {
  padding: 10px 14px;
  border: 1px solid var(--border-dark);
  border-radius: var(--radius);
  background: var(--bg-dark);
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--fg-on-dark);
  transition: border-color 0.15s;
  width: 100%;
}
.mbl-auth-card--light .mbl-auth-form__field input {
  background: var(--bg-light);
  border-color: var(--border-light);
  color: var(--fg-on-light);
}
.mbl-auth-form__field input:focus { outline: none; border-color: var(--accent); }
.mbl-auth-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.mbl-auth-demo-note {
  margin-top: 12px;
  background: rgba(200,146,10,0.08);
  border: 1px solid rgba(200,146,10,0.2);
  border-radius: var(--radius);
  padding: 12px 14px;
  font-size: 13px;
  color: var(--accent-aa-on-dark);
  display: flex;
  gap: 8px;
  align-items: flex-start;
  line-height: 1.55;
}
.mbl-auth-demo-note[hidden] { display: none; }
.mbl-auth-demo-note a { color: var(--accent-aa-on-dark); text-decoration: underline; }
.mbl-auth-legal {
  font-size: 12px;
  color: var(--fg-on-dark-muted);
  text-align: center;
  margin-top: 16px;
  max-width: 380px;
  line-height: 1.6;
}
.mbl-auth-card--light + .mbl-auth-legal { color: var(--fg-on-light-muted); }
.mbl-auth-legal a { color: var(--accent-aa-on-dark); }
.mbl-auth-card--light ~ .mbl-auth-legal a { color: var(--accent-aa-on-light); }
@media (max-width: 700px) {
  .mbl-auth-layout { grid-template-columns: 1fr; }
  .mbl-auth-brand { display: none; }
}

/* ── Legal pages ──────────────────────────────────────────── */
.mbl-legal-main {
  background: var(--bg-white);
  padding: 56px 0 80px;
}
.mbl-legal-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 48px;
  align-items: start;
}
.mbl-legal-toc {
  position: sticky;
  top: calc(var(--nav-h) + 16px);
  background: var(--bg-light);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: 20px;
}
.mbl-legal-toc__title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  font-family: var(--font-mono);
  color: var(--fg-on-light-muted);
  margin-bottom: 12px;
}
.mbl-legal-toc ul { display: flex; flex-direction: column; gap: 4px; }
.mbl-legal-toc a {
  font-size: 13px;
  color: var(--fg-on-light-2);
  display: block;
  padding: 4px 6px;
  border-radius: 4px;
  transition: color 0.12s, background 0.12s;
  line-height: 1.45;
}
.mbl-legal-toc a:hover { color: var(--accent-aa-on-light); background: var(--bg-card); }
.legal-article {
  min-width: 0;
}
.legal-header { margin-bottom: 40px; }
.legal-header h1 { font-size: 30px; font-weight: 700; color: var(--fg-on-light); margin-bottom: 10px; }
.legal-meta {
  font-size: 13px;
  color: var(--fg-on-light-muted);
  margin-bottom: 4px;
}
.legal-article h2 {
  font-size: 20px;
  font-weight: 600;
  color: var(--fg-on-light);
  margin: 36px 0 12px;
  padding-top: 8px;
  border-top: 1px solid var(--border-light);
}
.legal-article h3 {
  font-size: 16px;
  font-weight: 600;
  color: var(--fg-on-light);
  margin: 20px 0 8px;
}
.legal-article p {
  font-size: 14px;
  color: var(--fg-on-light-2);
  line-height: 1.75;
  margin-bottom: 14px;
}
.legal-article ul {
  padding-left: 20px;
  list-style: disc;
  margin-bottom: 14px;
}
.legal-article li {
  font-size: 14px;
  color: var(--fg-on-light-2);
  line-height: 1.65;
  margin-bottom: 6px;
}
.legal-article address {
  font-style: normal;
  font-size: 14px;
  color: var(--fg-on-light-2);
  line-height: 1.7;
}
.legal-article a { color: var(--accent-aa-on-light); }
.legal-article a:hover { text-decoration: underline; }
.legal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  margin: 16px 0 20px;
}
.legal-table th {
  text-align: left;
  padding: 10px 14px;
  background: var(--bg-light);
  font-weight: 600;
  color: var(--fg-on-light);
  border-bottom: 2px solid var(--border-light);
  border-top: 1px solid var(--border-light);
}
.legal-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-light);
  color: var(--fg-on-light-2);
  line-height: 1.55;
  vertical-align: top;
}
.legal-table tr:hover td { background: var(--bg-light); }
@media (max-width: 900px) { .mbl-legal-layout { grid-template-columns: 1fr; } .mbl-legal-toc { position: static; } }

/* ── Pricing toggle (label strip below hero) ─────────────── */
.mbl-pricing-toggle {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: center;
  margin-top: 24px;
}

/* ── Doc card metadata ───────────────────────────────────── */
.mbl-doc-card__meta {
  font-size: 11px;
  font-family: var(--font-mono);
  color: var(--fg-on-light-muted);
  margin-top: auto;
  padding-top: 12px;
}

/* ── Expect list heading (request-access) ────────────────── */
.mbl-expect-list__heading {
  font-size: 13px;
  font-weight: 600;
  color: var(--fg-on-light-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-family: var(--font-mono);
  margin-bottom: 12px;
}
.mbl-expect-item__num {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid var(--accent);
  color: var(--accent-aa-on-light);
  font-size: 12px;
  font-weight: 700;
  font-family: var(--font-mono);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.mbl-expect-item__text {
  font-size: 14px;
  color: var(--fg-on-light-2);
  line-height: 1.55;
  padding-top: 4px;
}

/* ── Section heading on dark bg variant ──────────────────── */
.mbl-section__heading--on-dark { color: var(--fg-on-dark); }
.mbl-section__subhead--on-dark { color: var(--fg-on-dark-2); }

/* ── Control grid for security page ──────────────────────── */
.mbl-control-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 24px;
}
.mbl-control-item {
  background: var(--bg-white);
  border: 1px solid var(--border-light);
  border-radius: var(--radius);
  padding: 18px 20px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.mbl-control-item__icon { color: var(--accent-aa-on-light); font-size: 15px; margin-top: 2px; flex-shrink: 0; }
.mbl-control-item__title { font-size: 14px; font-weight: 600; color: var(--fg-on-light); margin-bottom: 4px; }
.mbl-control-item__desc { font-size: 13px; color: var(--fg-on-light-2); line-height: 1.55; }
@media (max-width: 700px) { .mbl-control-grid { grid-template-columns: 1fr; } }
