/* Mailhook marketing theme — "refined dark technical".
   One accent (indigo, shared with the app dashboard), disciplined neutrals,
   Oxanium display + Space Mono code. This layer maps Tailwind utility classes
   to theme tokens so every marketing page recolors from one place. It only
   applies under [data-marketing-theme="cyberpunk"], set by the marketing layout. */
:root {
  --mh-bg-deep: #08090f;
  --mh-bg-surface: #0e1018;
  --mh-bg-elevated: #141723;
  --mh-bg-panel: rgba(20, 23, 35, 0.72);

  --mh-text-primary: #eef1f6;
  --mh-text-secondary: #9aa3b2;
  --mh-text-muted: #5c6473;

  --mh-border: rgba(255, 255, 255, 0.08);
  --mh-border-strong: rgba(255, 255, 255, 0.14);

  --mh-accent: #6366f1;
  --mh-accent-hover: #818cf8;
  --mh-accent-subtle: rgba(99, 102, 241, 0.12);
  --mh-accent-contrast: #ffffff;

  /* Syntax tones — used only inside code blocks. */
  --mh-code-cyan: #67e8f9;
  --mh-code-lime: #a3e635;
  --mh-code-muted: #6b7280;

  --mh-legal-bg: #15161d;
  --mh-legal-paper: #ece9e2;
  --mh-legal-text: #1a1a1a;
  --mh-legal-text-muted: #4a4a4a;

  --mh-font-display: 'Oxanium', 'Orbitron', system-ui, sans-serif;
  --mh-font-mono: 'Space Mono', 'JetBrains Mono', 'Fira Code', monospace;
  --mh-font-body: 'Inter', system-ui, -apple-system, sans-serif;

  --mh-shadow-card: 0 1px 2px rgba(0, 0, 0, 0.4), 0 1px 3px rgba(0, 0, 0, 0.5);
  --mh-shadow-pop: 0 12px 40px rgba(0, 0, 0, 0.55), 0 2px 8px rgba(0, 0, 0, 0.4);
  --mh-accent-glow: 0 0 0 1px rgba(99, 102, 241, 0.5), 0 10px 40px rgba(99, 102, 241, 0.22);
}

[data-marketing-theme="cyberpunk"] {
  background: var(--mh-bg-deep);
  color: var(--mh-text-primary);
  font-family: var(--mh-font-body);
}

/* --- Surface + text mappings -------------------------------------------- */
[data-marketing-theme="cyberpunk"] .bg-white { background: var(--mh-bg-surface) !important; }
[data-marketing-theme="cyberpunk"] .bg-gray-50 { background: var(--mh-bg-elevated) !important; }
[data-marketing-theme="cyberpunk"] .bg-gray-900 { background: var(--mh-bg-deep) !important; }

[data-marketing-theme="cyberpunk"] .text-gray-900 { color: var(--mh-text-primary) !important; }
[data-marketing-theme="cyberpunk"] .text-gray-600,
[data-marketing-theme="cyberpunk"] .text-gray-700 { color: var(--mh-text-secondary) !important; }
[data-marketing-theme="cyberpunk"] .text-gray-400,
[data-marketing-theme="cyberpunk"] .text-gray-500 { color: var(--mh-text-muted) !important; }
[data-marketing-theme="cyberpunk"] .text-gray-300 { color: var(--mh-text-secondary) !important; }

[data-marketing-theme="cyberpunk"] .text-white { color: var(--mh-accent-contrast) !important; }

/* --- Accent mappings ----------------------------------------------------- */
[data-marketing-theme="cyberpunk"] .text-indigo-600,
[data-marketing-theme="cyberpunk"] .text-indigo-500,
[data-marketing-theme="cyberpunk"] .text-indigo-700 { color: var(--mh-accent) !important; }

[data-marketing-theme="cyberpunk"] .text-indigo-200 { color: var(--mh-accent-hover) !important; }

[data-marketing-theme="cyberpunk"] .hover\:text-indigo-600:hover,
[data-marketing-theme="cyberpunk"] .hover\:text-indigo-500:hover { color: var(--mh-accent-hover) !important; }

[data-marketing-theme="cyberpunk"] .hover\:text-white:hover { color: var(--mh-accent-contrast) !important; }

[data-marketing-theme="cyberpunk"] .bg-indigo-600,
[data-marketing-theme="cyberpunk"] .bg-indigo-500 { background: var(--mh-accent) !important; }

[data-marketing-theme="cyberpunk"] .bg-indigo-50,
[data-marketing-theme="cyberpunk"] .bg-indigo-100 { background: var(--mh-accent-subtle) !important; }

[data-marketing-theme="cyberpunk"] .hover\:bg-indigo-500:hover,
[data-marketing-theme="cyberpunk"] .hover\:bg-indigo-400:hover { background: var(--mh-accent-hover) !important; }

/* Hero blobs / gradients -> faint accent tints. */
[data-marketing-theme="cyberpunk"] .from-indigo-200 { --tw-gradient-from: rgba(99, 102, 241, 0.18) !important; }
[data-marketing-theme="cyberpunk"] .to-indigo-400 { --tw-gradient-to: rgba(99, 102, 241, 0.10) !important; }
[data-marketing-theme="cyberpunk"] .from-indigo-100\/20 { --tw-gradient-from: rgba(99, 102, 241, 0.08) !important; }

/* --- Borders + dividers -------------------------------------------------- */
[data-marketing-theme="cyberpunk"] .border-gray-200,
[data-marketing-theme="cyberpunk"] .border-slate-200 { border-color: var(--mh-border) !important; }
[data-marketing-theme="cyberpunk"] .border-slate-300 { border-color: var(--mh-border-strong) !important; }

[data-marketing-theme="cyberpunk"] .ring-gray-200 { --tw-ring-color: var(--mh-border-strong) !important; }

[data-marketing-theme="cyberpunk"] .divide-gray-500\/10 > :not([hidden]) ~ :not([hidden]),
[data-marketing-theme="cyberpunk"] .divide-gray-900\/10 > :not([hidden]) ~ :not([hidden]) {
  border-color: var(--mh-border) !important;
}

[data-marketing-theme="cyberpunk"] .border-white\/10,
[data-marketing-theme="cyberpunk"] .border-indigo-400\/30 { border-color: var(--mh-border) !important; }

/* --- Shadows (tinted, subtle) ------------------------------------------- */
[data-marketing-theme="cyberpunk"] .shadow-sm { box-shadow: var(--mh-shadow-card) !important; }
[data-marketing-theme="cyberpunk"] .shadow-md { box-shadow: var(--mh-shadow-card) !important; }
[data-marketing-theme="cyberpunk"] .shadow-2xl { box-shadow: var(--mh-shadow-pop) !important; }
[data-marketing-theme="cyberpunk"] .hover\:shadow-md:hover { box-shadow: var(--mh-shadow-pop) !important; }

[data-marketing-theme="cyberpunk"] .hover\:bg-gray-50:hover,
[data-marketing-theme="cyberpunk"] .hover\:bg-gray-100:hover { background: var(--mh-bg-elevated) !important; }

[data-marketing-theme="cyberpunk"] .focus-visible\:outline-indigo-600:focus-visible,
[data-marketing-theme="cyberpunk"] .focus-visible\:outline-indigo-500:focus-visible,
[data-marketing-theme="cyberpunk"] .focus-visible\:outline-white:focus-visible {
  outline-color: var(--mh-accent) !important;
  box-shadow: var(--mh-accent-glow);
}

/* --- Wordmark ------------------------------------------------------------ */
.mh-wordmark {
  font-family: var(--mh-font-display);
  letter-spacing: 0.02em;
}

[data-marketing-theme="cyberpunk"] .mh-wordmark { color: var(--mh-text-primary) !important; }
[data-marketing-theme="legal"] .mh-wordmark { color: var(--mh-text-primary) !important; }

[data-marketing-theme="cyberpunk"] header svg.text-indigo-600,
[data-marketing-theme="cyberpunk"] header svg.text-indigo-500,
[data-marketing-theme="cyberpunk"] footer svg.text-indigo-500 {
  color: var(--mh-accent) !important;
}

/* --- Faint texture overlay (noise only) --------------------------------- */
.mh-bg-noise {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  opacity: 0.025;
}

@media (prefers-reduced-motion: reduce) {
  [data-marketing-theme="cyberpunk"] * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* --- Cards -------------------------------------------------------------- */
[data-marketing-theme="cyberpunk"] .rounded-2xl.border {
  background: var(--mh-bg-panel) !important;
  backdrop-filter: blur(10px);
  border-color: var(--mh-border) !important;
  box-shadow: var(--mh-shadow-card);
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

[data-marketing-theme="cyberpunk"] .rounded-2xl.border:hover {
  border-color: var(--mh-border-strong) !important;
  box-shadow: var(--mh-shadow-pop);
  transform: translateY(-2px);
}

[data-marketing-theme="cyberpunk"] .rounded-3xl {
  background: var(--mh-bg-panel) !important;
  backdrop-filter: blur(10px);
  border: 1px solid var(--mh-border) !important;
}

[data-marketing-theme="cyberpunk"] .rounded-3xl.relative.bg-gray-900 {
  background: linear-gradient(160deg, var(--mh-bg-elevated), var(--mh-bg-deep)) !important;
  border: 1px solid var(--mh-border-strong) !important;
  box-shadow: var(--mh-shadow-pop);
}

/* Pill badges -> subtle accent chip, no glow pulse. */
[data-marketing-theme="cyberpunk"] .rounded-full.bg-indigo-600,
[data-marketing-theme="cyberpunk"] .rounded-full.bg-indigo-100 {
  background: var(--mh-accent-subtle) !important;
  color: var(--mh-accent-hover) !important;
  border: 1px solid rgba(99, 102, 241, 0.3);
}

[data-marketing-theme="cyberpunk"] .rounded-lg.bg-indigo-600 {
  background: var(--mh-accent-subtle) !important;
  color: var(--mh-accent-hover) !important;
}

/* --- Code blocks (docs + landing code card) ----------------------------- */
[data-marketing-theme="cyberpunk"] pre.bg-gray-900,
[data-marketing-theme="cyberpunk"] .bg-gray-900 pre,
[data-marketing-theme="cyberpunk"] .rounded-lg.bg-gray-900,
[data-marketing-theme="cyberpunk"] .rounded-xl.bg-gray-900,
[data-marketing-theme="cyberpunk"] .rounded-2xl.bg-gray-900 {
  background: #06070d !important;
  border: 1px solid var(--mh-border);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

[data-marketing-theme="cyberpunk"] pre code,
[data-marketing-theme="cyberpunk"] .text-gray-300 code { font-family: var(--mh-font-mono); }

/* --- Buttons ------------------------------------------------------------ */
[data-marketing-theme="cyberpunk"] a.rounded-md.bg-indigo-600,
[data-marketing-theme="cyberpunk"] a.rounded-md.bg-indigo-500,
[data-marketing-theme="cyberpunk"] button.rounded-md.bg-indigo-600,
[data-marketing-theme="cyberpunk"] .mh-btn-primary {
  background: var(--mh-accent) !important;
  color: var(--mh-accent-contrast) !important;
  border: 1px solid transparent !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.4), 0 6px 20px rgba(99, 102, 241, 0.25);
  transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.1s ease;
}

[data-marketing-theme="cyberpunk"] a.rounded-md.bg-indigo-600:hover,
[data-marketing-theme="cyberpunk"] a.rounded-md.bg-indigo-500:hover,
[data-marketing-theme="cyberpunk"] button.rounded-md.bg-indigo-600:hover,
[data-marketing-theme="cyberpunk"] .mh-btn-primary:hover {
  background: var(--mh-accent-hover) !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.4), 0 10px 30px rgba(99, 102, 241, 0.35);
}

[data-marketing-theme="cyberpunk"] a.rounded-md.bg-indigo-600:active,
[data-marketing-theme="cyberpunk"] .mh-btn-primary:active { transform: translateY(1px); }

[data-marketing-theme="cyberpunk"] a.rounded-md.bg-white {
  background: var(--mh-accent-contrast) !important;
  color: var(--mh-accent) !important;
  border: 1px solid transparent !important;
  transition: background 0.2s ease, transform 0.1s ease;
}

[data-marketing-theme="cyberpunk"] a.rounded-md.bg-white:hover {
  background: #f1f2f6 !important;
  color: var(--mh-accent-hover) !important;
}

/* --- Mobile menu + dropdowns ------------------------------------------- */
[data-marketing-theme="cyberpunk"] .fixed.inset-y-0.right-0.bg-white {
  background: var(--mh-bg-surface) !important;
  border-left: 1px solid var(--mh-border);
  box-shadow: -16px 0 48px rgba(0, 0, 0, 0.6);
}

[data-marketing-theme="cyberpunk"] .absolute.right-0.bg-white {
  background: var(--mh-bg-elevated) !important;
  border: 1px solid var(--mh-border);
  box-shadow: var(--mh-shadow-pop);
}

/* --- Feature icons ------------------------------------------------------ */
[data-marketing-theme="cyberpunk"] svg.text-indigo-600[viewBox="0 0 20 20"] {
  color: var(--mh-accent) !important;
}

/* --- Header + footer --------------------------------------------------- */
[data-marketing-theme="cyberpunk"] header {
  background: rgba(8, 9, 15, 0.72);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--mh-border);
}

[data-marketing-theme="cyberpunk"] footer {
  background: var(--mh-bg-deep) !important;
  border-top: 1px solid var(--mh-border);
  position: relative;
  z-index: 10;
}

[data-marketing-theme="cyberpunk"] footer a:hover { color: var(--mh-accent-hover) !important; }

/* --- Typography -------------------------------------------------------- */
[data-marketing-theme="cyberpunk"] h1,
[data-marketing-theme="cyberpunk"] h2,
[data-marketing-theme="cyberpunk"] h3 { font-family: var(--mh-font-display); }

/* Kicker / eyebrow label -> mono uppercase accent. */
[data-marketing-theme="cyberpunk"] .text-base.font-semibold.leading-7.text-indigo-600 {
  font-family: var(--mh-font-mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: 0.72rem;
}

/* --- Legal theme (unchanged paper aesthetic) ---------------------------- */
[data-marketing-theme="legal"] {
  background: var(--mh-legal-bg);
  color: var(--mh-text-primary);
}

[data-marketing-theme="legal"] header {
  background: rgba(21, 22, 29, 0.95);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

[data-marketing-theme="legal"] header .text-gray-900,
[data-marketing-theme="legal"] header .text-gray-700 { color: var(--mh-text-primary) !important; }
[data-marketing-theme="legal"] header svg.text-indigo-600 { color: var(--mh-text-primary) !important; }
[data-marketing-theme="legal"] footer { background: var(--mh-bg-deep) !important; }
[data-marketing-theme="legal"] .bg-white { background: transparent !important; }

[data-marketing-theme="legal"] .bg-white > .mx-auto {
  background: var(--mh-legal-paper);
  color: var(--mh-legal-text);
  border-radius: 8px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3), 0 10px 40px rgba(0, 0, 0, 0.4);
  padding: 3rem;
  margin-top: 2rem;
  margin-bottom: 2rem;
}

[data-marketing-theme="legal"] .bg-white .text-gray-900 { color: var(--mh-legal-text) !important; }
[data-marketing-theme="legal"] .bg-white .text-gray-500 { color: var(--mh-legal-text-muted) !important; }

[data-marketing-theme="legal"] .prose {
  --tw-prose-body: var(--mh-legal-text);
  --tw-prose-headings: var(--mh-legal-text);
  --tw-prose-links: #0066cc;
  --tw-prose-bold: var(--mh-legal-text);
  --tw-prose-bullets: var(--mh-legal-text-muted);
  --tw-prose-counters: var(--mh-legal-text-muted);
}

[data-marketing-theme="legal"] .prose h2 { color: var(--mh-legal-text); font-family: var(--mh-font-body); }
[data-marketing-theme="legal"] .prose a { color: #0066cc; text-decoration: underline; }
[data-marketing-theme="legal"] .prose a:hover { color: #0044aa; }
[data-marketing-theme="legal"] .fixed.inset-y-0.right-0.bg-white { background: var(--mh-legal-paper) !important; }
[data-marketing-theme="legal"] .fixed.inset-y-0 .text-gray-900 { color: var(--mh-legal-text) !important; }
[data-marketing-theme="legal"] .fixed.inset-y-0 .hover\:bg-gray-50:hover { background: rgba(0, 0, 0, 0.05) !important; }

[data-marketing-theme="legal"] a.rounded-md.bg-indigo-600 {
  background: #333 !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2) !important;
}
[data-marketing-theme="legal"] a.rounded-md.bg-indigo-600:hover { background: #444 !important; }

/* --- Docs tabs --------------------------------------------------------- */
.mh-tab {
  border-color: transparent;
  color: #6b7280;
  transition: all 0.2s ease;
}
.mh-tab:hover { border-color: #d1d5db; color: #374151; }
.mh-tab.mh-tab-active,
.mh-tab[aria-selected="true"] { border-color: #4f46e5; color: #4f46e5; }

[data-marketing-theme="cyberpunk"] .mh-tab { border-color: transparent; color: var(--mh-text-muted); }
[data-marketing-theme="cyberpunk"] .mh-tab:hover { border-color: var(--mh-border-strong); color: var(--mh-text-secondary); }
[data-marketing-theme="cyberpunk"] .mh-tab.mh-tab-active,
[data-marketing-theme="cyberpunk"] .mh-tab[aria-selected="true"] {
  border-color: var(--mh-accent);
  color: var(--mh-accent-hover);
}

.mh-tab:focus-visible { outline: 2px solid #4f46e5; outline-offset: 2px; border-radius: 2px; }
[data-marketing-theme="cyberpunk"] .mh-tab:focus-visible {
  outline: 2px solid var(--mh-accent);
  outline-offset: 2px;
  border-radius: 2px;
}

/* --- Docs prose -------------------------------------------------------- */
[data-marketing-theme="cyberpunk"] .prose {
  --tw-prose-body: var(--mh-text-secondary);
  --tw-prose-headings: var(--mh-text-primary);
  --tw-prose-links: var(--mh-accent-hover);
  --tw-prose-bold: var(--mh-text-primary);
  --tw-prose-code: var(--mh-code-lime);
  --tw-prose-pre-bg: #06070d;
  --tw-prose-bullets: var(--mh-accent);
  --tw-prose-counters: var(--mh-accent);
}

[data-marketing-theme="cyberpunk"] .prose h2,
[data-marketing-theme="cyberpunk"] .prose h3 { font-family: var(--mh-font-display); color: var(--mh-text-primary); }
[data-marketing-theme="cyberpunk"] .prose a { color: var(--mh-accent-hover); text-decoration: none; }
[data-marketing-theme="cyberpunk"] .prose a:hover { text-decoration: underline; }

[data-marketing-theme="cyberpunk"] .prose code {
  font-family: var(--mh-font-mono);
  color: var(--mh-code-lime);
  background: var(--mh-bg-deep);
  padding: 0.125rem 0.375rem;
  border-radius: 0.25rem;
}

[data-marketing-theme="cyberpunk"] .prose pre {
  background: #06070d;
  border: 1px solid var(--mh-border);
}
[data-marketing-theme="cyberpunk"] .prose pre code { background: transparent; padding: 0; }
[data-marketing-theme="cyberpunk"] .prose ol > li::marker,
[data-marketing-theme="cyberpunk"] .prose ul > li::marker { color: var(--mh-accent); }

[data-marketing-theme="cyberpunk"] .ring-indigo-700\/10 { --tw-ring-color: rgba(99, 102, 241, 0.3) !important; }

/* =========================================================================
   Landing-page components (reusable across marketing pages)
   ====================================================================== */

/* Eyebrow / kicker chip. */
.mh-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.3rem 0.7rem;
  border-radius: 0.5rem;
  background: var(--mh-accent-subtle);
  border: 1px solid rgba(99, 102, 241, 0.28);
  color: var(--mh-accent-hover);
  font-family: var(--mh-font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.mh-kicker svg { color: var(--mh-accent); }

/* Metrics strip stat. */
.mh-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  border: 1px solid var(--mh-border);
  border-radius: 0.9rem;
  overflow: hidden;
  background: var(--mh-bg-panel);
  backdrop-filter: blur(8px);
}
.mh-stat { padding: 1.25rem 1.1rem; border-left: 1px solid var(--mh-border); }
.mh-stat:first-child { border-left: 0; }
.mh-stat-value {
  font-family: var(--mh-font-display);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--mh-text-primary);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.mh-stat-label {
  margin-top: 0.25rem;
  font-family: var(--mh-font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mh-text-muted);
}
@media (max-width: 640px) {
  .mh-stats { grid-template-columns: 1fr; }
  .mh-stat { border-left: 0; border-top: 1px solid var(--mh-border); }
  .mh-stat:first-child { border-top: 0; }
}

/* "How it works" step row. */
.mh-step { position: relative; padding-left: 3.25rem; }
.mh-step-num {
  position: absolute;
  left: 0;
  top: 0;
  width: 2.25rem;
  height: 2.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.6rem;
  background: var(--mh-accent-subtle);
  border: 1px solid rgba(99, 102, 241, 0.3);
  color: var(--mh-accent-hover);
  font-family: var(--mh-font-mono);
  font-weight: 700;
  font-size: 0.85rem;
}
.mh-step-title { font-family: var(--mh-font-display); font-weight: 600; color: var(--mh-text-primary); }
.mh-step-body { margin-top: 0.35rem; color: var(--mh-text-secondary); line-height: 1.65; }

/* Code/JSON card. */
.mh-codecard {
  background: #06070d;
  border: 1px solid var(--mh-border);
  border-radius: 0.9rem;
  box-shadow: var(--mh-shadow-pop);
  overflow: hidden;
  font-family: var(--mh-font-mono);
  font-size: 0.82rem;
  line-height: 1.7;
}
.mh-codecard-head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 0.9rem;
  border-bottom: 1px solid var(--mh-border);
  background: rgba(255, 255, 255, 0.02);
}
.mh-codecard-dot { width: 0.7rem; height: 0.7rem; border-radius: 9999px; background: rgba(255, 255, 255, 0.12); }
.mh-codecard-title { margin-left: 0.4rem; color: var(--mh-text-muted); font-size: 0.72rem; letter-spacing: 0.04em; }
.mh-codecard-badge {
  margin-left: auto;
  color: var(--mh-code-lime);
  font-size: 0.7rem;
  letter-spacing: 0.04em;
}
.mh-codecard-body { padding: 0.9rem 1rem; color: var(--mh-text-secondary); white-space: pre; overflow-x: auto; }
.mh-codecard-body .c-cmd { color: var(--mh-text-muted); }
.mh-codecard-body .c-key { color: var(--mh-code-cyan); }
.mh-codecard-body .c-str { color: var(--mh-code-lime); }
.mh-codecard-body .c-num { color: #f0abfc; }
.mh-codecard-body .c-punct { color: var(--mh-text-muted); }
.mh-codecard-body .c-ok { color: var(--mh-code-lime); }
.mh-codecard-foot {
  padding: 0.5rem 1rem;
  border-top: 1px solid var(--mh-border);
  color: var(--mh-text-muted);
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  display: flex;
  justify-content: space-between;
}

/* Bento feature tile. */
.mh-feature {
  padding: 1.5rem;
  border: 1px solid var(--mh-border);
  border-radius: 0.9rem;
  background: var(--mh-bg-panel);
  backdrop-filter: blur(8px);
  transition: border-color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
}
.mh-feature:hover {
  border-color: var(--mh-border-strong);
  transform: translateY(-2px);
  box-shadow: var(--mh-shadow-pop);
}
.mh-feature-icon {
  width: 2.25rem;
  height: 2.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.6rem;
  background: var(--mh-accent-subtle);
  color: var(--mh-accent-hover);
}
.mh-feature-title { margin-top: 0.9rem; font-family: var(--mh-font-display); font-weight: 600; color: var(--mh-text-primary); }
.mh-feature-body { margin-top: 0.4rem; color: var(--mh-text-secondary); line-height: 1.6; }

/* Final CTA band. */
.mh-cta {
  border: 1px solid var(--mh-border-strong);
  border-radius: 1.25rem;
  background:
    radial-gradient(120% 140% at 0% 0%, rgba(99, 102, 241, 0.22), transparent 55%),
    radial-gradient(120% 140% at 100% 100%, rgba(99, 102, 241, 0.12), transparent 55%),
    var(--mh-bg-elevated);
}

/* =========================================================================
   Pricing + security components
   ====================================================================== */

/* Small inline chip (compliance badges, table tags). */
.mh-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.2rem 0.6rem;
  border-radius: 9999px;
  background: var(--mh-accent-subtle);
  border: 1px solid rgba(99, 102, 241, 0.28);
  color: var(--mh-accent-hover);
  font-family: var(--mh-font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.04em;
  white-space: nowrap;
}
.mh-chip-warn {
  background: rgba(245, 158, 11, 0.12);
  border-color: rgba(245, 158, 11, 0.3);
  color: #fbbf24;
}
.mh-chip-muted {
  background: rgba(255, 255, 255, 0.04);
  border-color: var(--mh-border);
  color: var(--mh-text-muted);
}

/* Pricing plan card. */
.mh-plan {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 1.75rem;
  border: 1px solid var(--mh-border);
  border-radius: 1rem;
  background: var(--mh-bg-panel);
  backdrop-filter: blur(8px);
  box-shadow: var(--mh-shadow-card);
}
.mh-plan-featured {
  border-color: rgba(99, 102, 241, 0.5);
  box-shadow: 0 0 0 1px rgba(99, 102, 241, 0.4), 0 24px 70px rgba(99, 102, 241, 0.2);
}
.mh-plan-name { font-family: var(--mh-font-display); font-weight: 600; color: var(--mh-text-primary); }
.mh-plan-tagline { color: var(--mh-accent-hover); font-size: 0.8rem; font-family: var(--mh-font-mono); letter-spacing: 0.04em; }
.mh-plan-desc { color: var(--mh-text-secondary); font-size: 0.875rem; line-height: 1.6; }
.mh-plan-price {
  font-family: var(--mh-font-display);
  font-weight: 700;
  font-size: 2.5rem;
  color: var(--mh-text-primary);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
}

/* "Most popular" ribbon. */
.mh-badge {
  position: absolute;
  top: -0.85rem;
  left: 50%;
  transform: translateX(-50%);
  padding: 0.25rem 0.8rem;
  border-radius: 9999px;
  background: var(--mh-accent);
  color: var(--mh-accent-contrast);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  white-space: nowrap;
  box-shadow: 0 6px 20px rgba(99, 102, 241, 0.4);
}

/* Comparison table. */
.mh-compare { width: 100%; border-collapse: collapse; }
.mh-compare th,
.mh-compare td { padding: 0.9rem 1rem; text-align: center; font-size: 0.875rem; border-bottom: 1px solid var(--mh-border); color: var(--mh-text-secondary); }
.mh-compare th:first-child,
.mh-compare td:first-child { text-align: left; }
.mh-compare thead th {
  font-family: var(--mh-font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mh-text-muted);
  border-bottom: 1px solid var(--mh-border-strong);
  vertical-align: bottom;
}
.mh-compare thead th .price { display: block; margin-top: 0.25rem; font-family: var(--mh-font-body); text-transform: none; letter-spacing: 0; font-size: 0.78rem; color: var(--mh-text-secondary); }
.mh-compare tbody tr:hover { background: rgba(255, 255, 255, 0.02); }
.mh-compare .row-label { color: var(--mh-text-primary); font-weight: 500; }
.mh-compare .col-featured { background: var(--mh-accent-subtle); color: var(--mh-accent-hover); font-weight: 600; }
.mh-compare thead .col-featured { color: var(--mh-accent-hover); }
.mh-compare .x-mark { color: var(--mh-text-muted); opacity: 0.5; }
.mh-compare-num { font-variant-numeric: tabular-nums; }

/* FAQ items. */
.mh-faq-item { border-top: 1px solid var(--mh-border); }
.mh-faq-item:last-child { border-bottom: 1px solid var(--mh-border); }
.mh-faq-q { font-family: var(--mh-font-display); font-weight: 600; color: var(--mh-text-primary); padding-top: 1.5rem; }
.mh-faq-a { color: var(--mh-text-secondary); margin-top: 0.5rem; padding-bottom: 1.5rem; line-height: 1.65; }

/* =========================================================================
   Contact page components
   ====================================================================== */

/* Form inputs. */
.mh-input,
.mh-select,
.mh-textarea {
  display: block;
  width: 100%;
  padding: 0.55rem 0.85rem;
  border: 1px solid var(--mh-border-strong);
  border-radius: 0.5rem;
  background: rgba(255, 255, 255, 0.03);
  color: var(--mh-text-primary);
  font-size: 0.875rem;
  line-height: 1.6;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.mh-input::placeholder,
.mh-textarea::placeholder { color: var(--mh-text-muted); }
.mh-input:focus,
.mh-select:focus,
.mh-textarea:focus {
  border-color: var(--mh-accent);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2);
}
.mh-select { appearance: none; cursor: pointer; }
.mh-textarea { resize: vertical; }
.mh-label {
  display: block;
  margin-bottom: 0.5rem;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--mh-text-primary);
}

/* Flash alerts. */
.mh-alert {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem 1.15rem;
  border-radius: 0.65rem;
  border: 1px solid;
}
.mh-alert-success {
  background: rgba(52, 211, 153, 0.08);
  border-color: rgba(52, 211, 153, 0.3);
  color: #6ee7b7;
}
.mh-alert-error {
  background: rgba(248, 113, 113, 0.08);
  border-color: rgba(248, 113, 113, 0.3);
  color: #fca5a5;
}
.mh-alert-icon { flex-shrink: 0; width: 1.25rem; height: 1.25rem; margin-top: 0.1rem; }

