/* MiraNext — site shell styles */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--mn-paper);
  color: var(--mn-ink);
  font-family: var(--mn-font-sans);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { display: block; max-width: 100%; }
a { color: inherit; }

/* ---------- DARK MODE ---------- */
body[data-theme="dark"] {
  --mn-paper: #050F1F;
  --mn-ink: #E5EBF3;
  --mn-muted: #95B0D3;
  --mn-rule: #13345F;
  --mn-surface: #081A30;
  --mn-surface-alt: #0B2545;
  --mn-surface-sunken: #050F1F;
  --mn-border-mid: #13345F;
  --mn-border-dark: #95B0D3;
  --mn-fg-1: #E5EBF3;
  --mn-fg-2: #C8D5E6;
  --mn-fg-3: #95B0D3;
  --mn-fg-4: #5E85BE;
  --mn-fg-brand: #E5EBF3;
  --mn-fg-on-brand: #FDFCF9;
  --mn-bg-canvas: #050F1F;
  --mn-bg-surface: #081A30;
  --mn-bg-sunken: #0B2545;
  --mn-bg-brand: #13345F;
  --mn-border-subtle: #13345F;
  --mn-border-default: #1D4578;
}

/* ---------- ACCENT TWEAK · Gold-emphasised ---------- */
body[data-accent="gold"] {
  --mn-fg-accent: var(--mn-gold-700);
  --mn-bg-accent: var(--mn-gold-500);
  --mn-fg-on-accent: #29200E;
  --mn-border-focus: var(--mn-gold-500);
  --mn-shadow-focus: 0 0 0 3px rgba(201, 168, 106, 0.35);
}

/* ---------- SHELL ---------- */
.shell { width: 100%; max-width: 1280px; margin: 0 auto; padding: 0 32px; }
.shell-wide { width: 100%; max-width: 1440px; margin: 0 auto; padding: 0 32px; }

/* Section rhythm */
section { position: relative; }
.section-pad { padding: 96px 0; }
.section-pad-sm { padding: 64px 0; }

/* ---------- KICKER ---------- */
.kicker {
  font-family: var(--mn-font-sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-fg-accent);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.kicker-num {
  display: inline-flex;
  font-variant-numeric: tabular-nums;
  color: var(--mn-fg-3);
  letter-spacing: 0.18em;
}
.kicker-num::after {
  content: "·";
  margin: 0 8px;
  color: var(--mn-fg-4);
}

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  height: 44px; padding: 0 22px;
  border-radius: 6px;
  font-family: var(--mn-font-sans);
  font-size: 14px; font-weight: 500; letter-spacing: 0.01em;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background 160ms var(--mn-ease-standard),
              border-color 160ms var(--mn-ease-standard),
              color 160ms var(--mn-ease-standard),
              transform 160ms var(--mn-ease-standard);
  text-decoration: none;
  white-space: nowrap;
}
.btn:focus-visible { outline: none; box-shadow: var(--mn-shadow-focus); }
.btn-primary { background: var(--mn-bg-accent); color: var(--mn-fg-on-accent); }
.btn-primary:hover { background: var(--mn-teal-800); }
body[data-accent="gold"] .btn-primary:hover { background: var(--mn-gold-700); }
.btn-navy { background: var(--mn-navy-800); color: #fff; }
.btn-navy:hover { background: var(--mn-navy-900); }
.btn-ghost {
  background: transparent;
  color: var(--mn-fg-1);
  border-color: var(--mn-border-default);
}
.btn-ghost:hover { background: var(--mn-surface-alt); border-color: var(--mn-border-strong); }
.btn-ghost-light {
  background: transparent;
  color: #fff;
  border-color: rgba(255,255,255,0.28);
}
.btn-ghost-light:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.5); }

.btn-sm { height: 36px; padding: 0 14px; font-size: 13px; }
.btn-lg { height: 52px; padding: 0 28px; font-size: 15px; }

/* ---------- LINK ARROW ---------- */
.linkarrow {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 14px; font-weight: 500;
  color: var(--mn-fg-accent);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 1px;
  transition: gap 160ms var(--mn-ease-standard);
}
.linkarrow:hover { gap: 10px; }

/* ---------- CARD ---------- */
.card {
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-subtle);
  border-radius: 10px;
  padding: 24px;
}
.card-flat {
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-subtle);
  border-radius: 10px;
}

/* ---------- HAIRLINES ---------- */
.hairline-gold { height: 1px; background: var(--mn-gold-500); border: 0; margin: 0; }
.hairline-teal { height: 1px; background: var(--mn-bg-accent); border: 0; margin: 0; }
.hairline-rule { height: 1px; background: var(--mn-rule); border: 0; margin: 0; }

/* ---------- NAV ---------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--mn-paper) 88%, transparent);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--mn-border-subtle);
}
.nav-inner {
  height: 68px;
  display: flex; align-items: center; justify-content: space-between;
}
.nav-left { display: flex; align-items: center; gap: 40px; }
.nav-logo { height: 28px; display: block; }
.nav-links { display: flex; gap: 28px; align-items: center; }
.nav-links a {
  font-size: 13.5px; font-weight: 500;
  color: var(--mn-fg-2);
  text-decoration: none;
  letter-spacing: 0.01em;
  transition: color 120ms;
}
.nav-links a:hover { color: var(--mn-fg-1); }
.nav-right { display: flex; align-items: center; gap: 14px; }

.lang-switch {
  display: inline-flex;
  border: 1px solid var(--mn-border-default);
  border-radius: 999px;
  padding: 2px;
  background: var(--mn-bg-surface);
}
.lang-switch button {
  appearance: none; border: 0; background: transparent;
  font: inherit; font-size: 11px; font-weight: 600;
  letter-spacing: 0.08em;
  width: 32px; height: 24px;
  border-radius: 999px;
  cursor: pointer;
  color: var(--mn-fg-3);
  transition: background 120ms, color 120ms;
}
.lang-switch button[aria-pressed="true"] {
  background: var(--mn-navy-800);
  color: #fff;
}
body[data-theme="dark"] .lang-switch button[aria-pressed="true"] { background: var(--mn-teal-700); }

/* ---------- HERO ---------- */
.hero {
  padding: 88px 0 96px;
  position: relative;
  overflow: hidden;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 72px;
  align-items: center;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 14px;
  margin-bottom: 24px;
}
.hero-eyebrow .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--mn-bg-accent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--mn-bg-accent) 24%, transparent);
}
.hero h1 {
  font-family: var(--mn-font-sans);
  font-size: clamp(44px, 5.4vw, 72px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  font-weight: 600;
  color: var(--mn-fg-brand);
  margin: 0 0 28px;
  text-wrap: balance;
}
.hero h1 em {
  font-style: normal;
  color: var(--mn-fg-accent);
}
.hero p.lede {
  font-size: 19px; line-height: 1.55;
  color: var(--mn-fg-2);
  margin: 0 0 36px;
  max-width: 560px;
  text-wrap: pretty;
}
.hero-ctas { display: flex; gap: 12px; align-items: center; }
.hero-meta {
  display: flex; gap: 32px;
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--mn-rule);
  flex-wrap: wrap;
}
.hero-meta > div { font-size: 13px; color: var(--mn-fg-3); }
.hero-meta b { color: var(--mn-fg-1); font-weight: 600; display: block; font-size: 18px; margin-bottom: 4px; font-variant-numeric: tabular-nums; }

/* hero variant: editorial — full-bleed navy bar */
.hero-editorial {
  background: var(--mn-navy-800);
  color: #fff;
  padding: 0;
}
.hero-editorial .hero {
  padding: 120px 0 100px;
}
.hero-editorial h1 { color: #fff; }
.hero-editorial h1 em { color: var(--mn-teal-500); }
body[data-accent="gold"] .hero-editorial h1 em { color: var(--mn-gold-300); }
.hero-editorial p.lede { color: var(--mn-navy-200); }
.hero-editorial .hero-meta { border-top-color: rgba(255,255,255,0.14); }
.hero-editorial .hero-meta > div { color: var(--mn-navy-200); }
.hero-editorial .hero-meta b { color: #fff; }
.hero-editorial .gold-edge {
  position: absolute; left: 0; top: 0; bottom: 0; width: 6px;
  background: var(--mn-gold-500);
}

/* hero device card (right column) */
.hero-device {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--mn-border-default);
  box-shadow: var(--mn-shadow-lg);
}
body[data-theme="dark"] .hero-device {
  background: var(--mn-navy-900);
  border-color: var(--mn-navy-700);
}
.hero-device-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 14px;
  background: var(--mn-surface-alt);
  border-bottom: 1px solid var(--mn-border-subtle);
  font-size: 12px;
  color: var(--mn-fg-3);
  font-family: var(--mn-font-mono);
}
.hero-device-bar .dots { display: flex; gap: 6px; }
.hero-device-bar .dots i { width: 10px; height: 10px; border-radius: 50%; background: var(--mn-grey-200); display: block; }
body[data-theme="dark"] .hero-device-bar .dots i { background: var(--mn-navy-700); }

/* hero variant: pipeline — animated flow */
.pipeline {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  align-items: stretch;
  padding: 20px;
}
.pipeline-step {
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-subtle);
  border-radius: 8px;
  padding: 16px 14px;
  display: flex; flex-direction: column; gap: 8px;
  position: relative;
  min-height: 110px;
}
.pipeline-step .pn {
  font-size: 10px; font-weight: 700; letter-spacing: 0.14em;
  color: var(--mn-fg-3);
  font-variant-numeric: tabular-nums;
}
.pipeline-step .pl {
  font-size: 13px; font-weight: 600;
  color: var(--mn-fg-1);
  line-height: 1.25;
}
.pipeline-step .pd {
  font-size: 11px; color: var(--mn-fg-3); line-height: 1.35;
}
.pipeline-step.active {
  border-color: var(--mn-bg-accent);
  background: color-mix(in srgb, var(--mn-bg-accent) 6%, var(--mn-bg-surface));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--mn-bg-accent) 14%, transparent);
}
.pipeline-step.active .pn { color: var(--mn-fg-accent); }
.pipeline-arrow {
  position: absolute; right: -10px; top: 50%; transform: translateY(-50%);
  width: 16px; height: 16px;
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
  color: var(--mn-fg-4);
}
.pipeline-step:last-child .pipeline-arrow { display: none; }

/* ---------- MODULE GRID ---------- */
.module-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}
.module-card {
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-subtle);
  border-radius: 12px;
  padding: 28px;
  display: flex; flex-direction: column;
  position: relative;
  min-height: 280px;
  overflow: hidden;
  transition: border-color 200ms, transform 200ms;
}
.module-card:hover { border-color: var(--mn-border-default); }
.module-card .mod-num {
  font-family: var(--mn-font-mono);
  font-size: 11px;
  color: var(--mn-fg-4);
  letter-spacing: 0.14em;
  margin-bottom: 16px;
  font-variant-numeric: tabular-nums;
}
.module-card h3 {
  font-size: 22px; font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--mn-fg-brand);
  margin: 0 0 8px;
}
.module-card .mod-tag {
  font-size: 11px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-fg-accent);
  margin-bottom: 10px;
}
.module-card p {
  font-size: 14.5px; line-height: 1.55;
  color: var(--mn-fg-2);
  margin: 0 0 20px;
}
.module-card .mod-bullets {
  list-style: none; padding: 0; margin: 0 0 20px;
  display: flex; flex-direction: column; gap: 6px;
}
.module-card .mod-bullets li {
  font-size: 13px; color: var(--mn-fg-2);
  display: flex; gap: 8px;
}
.module-card .mod-bullets li::before {
  content: "—"; color: var(--mn-fg-accent); font-weight: 600;
}
.module-card .mod-foot {
  margin-top: auto;
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 16px;
  border-top: 1px solid var(--mn-rule);
}
.module-card .mod-products {
  font-family: var(--mn-font-mono);
  font-size: 11px;
  color: var(--mn-fg-3);
  letter-spacing: 0.02em;
}

/* feature module sizing */
.module-card.span-7 { grid-column: span 7; }
.module-card.span-5 { grid-column: span 5; }
.module-card.span-6 { grid-column: span 6; }
.module-card.span-4 { grid-column: span 4; }
.module-card.span-12 { grid-column: span 12; }

/* feature module visual */
.module-card .mod-visual {
  margin-top: 16px;
  border-top: 1px solid var(--mn-rule);
  padding-top: 16px;
}

/* ---------- SECURITY STRIP ---------- */
.security-strip {
  background: var(--mn-navy-800);
  color: #fff;
  position: relative;
}
.security-strip::before {
  content: ""; position: absolute; left: 0; right: 0; top: 0;
  height: 1px; background: var(--mn-gold-500);
}
.security-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 80px;
  align-items: center;
}
.security-strip h2 {
  color: #fff;
  font-size: clamp(36px, 4vw, 56px);
  line-height: 1.04;
  letter-spacing: -0.025em;
  font-weight: 600;
  margin: 0 0 20px;
}
.security-strip h2 em { font-style: normal; color: var(--mn-teal-500); }
body[data-accent="gold"] .security-strip h2 em { color: var(--mn-gold-300); }
.security-strip .lede { color: var(--mn-navy-200); font-size: 18px; line-height: 1.55; max-width: 620px; margin: 0 0 28px; }
.cert-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px;
  overflow: hidden;
}
.cert-cell {
  background: var(--mn-navy-800);
  padding: 22px 20px;
}
.cert-cell .ckk {
  font-size: 10px; font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mn-teal-500);
  margin-bottom: 8px;
}
body[data-accent="gold"] .cert-cell .ckk { color: var(--mn-gold-300); }
.cert-cell .clbl {
  font-size: 16px; font-weight: 500; color: #fff;
}
.cert-cell .csmall {
  font-size: 12px; color: var(--mn-navy-300); margin-top: 4px;
}

/* ---------- PRICING ---------- */
.pricing-tabs {
  display: inline-flex;
  background: var(--mn-bg-sunken);
  border-radius: 999px;
  padding: 4px;
  margin-bottom: 32px;
}
.pricing-tabs button {
  appearance: none; border: 0; background: transparent;
  font: inherit; font-size: 13px; font-weight: 500;
  height: 34px; padding: 0 18px;
  border-radius: 999px;
  cursor: pointer;
  color: var(--mn-fg-3);
  transition: background 160ms, color 160ms;
}
.pricing-tabs button[aria-pressed="true"] {
  background: var(--mn-bg-surface);
  color: var(--mn-fg-1);
  box-shadow: var(--mn-shadow-sm);
}

.pricing-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  align-items: stretch;
}
.price-card {
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-subtle);
  border-radius: 12px;
  padding: 32px 28px;
  display: flex; flex-direction: column;
  position: relative;
}
.price-card.featured {
  border-color: var(--mn-bg-accent);
  background: var(--mn-bg-surface);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--mn-bg-accent) 14%, transparent);
}
.price-card .ppl {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 4px;
}
.price-card .pname {
  font-size: 13px; font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-fg-brand);
}
.price-card.featured .pname { color: var(--mn-fg-accent); }
.price-card .pflag {
  font-size: 10px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-fg-on-accent);
  background: var(--mn-bg-accent);
  padding: 4px 8px; border-radius: 999px;
}
.price-card h3 {
  font-size: 24px; font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--mn-fg-brand);
  margin: 0 0 6px;
}
.price-card .ptag {
  font-size: 14px; color: var(--mn-fg-3);
  margin-bottom: 24px;
  min-height: 42px;
}
.price-card .pamt {
  display: flex; align-items: baseline; gap: 6px;
  margin-bottom: 28px;
  font-variant-numeric: tabular-nums;
}
.price-card .pamt .pcur { font-size: 22px; color: var(--mn-fg-3); font-weight: 500; }
.price-card .pamt .pnum { font-size: 56px; font-weight: 600; letter-spacing: -0.025em; color: var(--mn-fg-brand); line-height: 1; }
.price-card .pamt .pper { font-size: 14px; color: var(--mn-fg-3); }
.price-card .pamt.no-num .pnum { font-size: 32px; }

.price-card ul {
  list-style: none; padding: 0; margin: 0 0 28px;
  display: flex; flex-direction: column; gap: 10px;
}
.price-card li {
  font-size: 14px; line-height: 1.5;
  color: var(--mn-fg-2);
  display: flex; gap: 10px;
}
.price-card li svg { flex-shrink: 0; color: var(--mn-fg-accent); margin-top: 2px; }
.price-card .price-cta {
  margin-top: auto;
  display: flex; flex-direction: column; gap: 6px;
}
.price-card .price-cta .btn { width: 100%; }
.price-card .pfine {
  font-size: 12px; color: var(--mn-fg-4); text-align: center;
}

/* pricing TABLE variant */
.price-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-subtle);
  border-radius: 12px;
  overflow: hidden;
  font-variant-numeric: tabular-nums;
}
.price-table th, .price-table td {
  padding: 14px 18px;
  text-align: left;
  font-size: 14px;
  border-bottom: 1px solid var(--mn-border-subtle);
}
.price-table thead th {
  background: var(--mn-bg-sunken);
  color: var(--mn-fg-brand);
  font-weight: 600;
  font-size: 13px;
}
.price-table thead th.col-feat { background: color-mix(in srgb, var(--mn-bg-accent) 8%, var(--mn-bg-surface)); }
.price-table tbody tr:last-child td { border-bottom: 0; }
.price-table .pt-hd {
  font-size: 11px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-fg-3);
  background: var(--mn-bg-sunken);
}
.price-table .pt-amt { font-weight: 600; color: var(--mn-fg-brand); font-size: 15px; }
.price-table .pt-yes { color: var(--mn-fg-accent); }
.price-table .pt-no { color: var(--mn-fg-4); }
.price-table tfoot td { background: var(--mn-bg-sunken); padding: 18px; }
.price-table tfoot .btn { width: 100%; }

/* pricing SLIDER variant */
.price-slider {
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-subtle);
  border-radius: 12px;
  padding: 36px 32px;
}
.price-slider .ps-head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
  align-items: end;
  margin-bottom: 28px;
}
.price-slider label {
  display: flex; flex-direction: column; gap: 8px;
  font-size: 13px; color: var(--mn-fg-2); font-weight: 500;
}
.price-slider input[type="range"] {
  width: 100%; appearance: none;
  height: 6px; border-radius: 999px;
  background: var(--mn-bg-sunken);
  outline: none;
}
.price-slider input[type="range"]::-webkit-slider-thumb {
  appearance: none; width: 20px; height: 20px; border-radius: 50%;
  background: var(--mn-bg-accent);
  border: 3px solid #fff;
  box-shadow: var(--mn-shadow-sm);
  cursor: pointer;
}
.price-slider .ps-readout {
  font-variant-numeric: tabular-nums;
  font-size: 13px; color: var(--mn-fg-3);
}
.price-slider .ps-readout b { color: var(--mn-fg-brand); font-weight: 600; font-size: 16px; margin-right: 4px; }
.price-slider .ps-modules {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px;
  margin: 24px 0;
  padding: 24px 0;
  border-top: 1px solid var(--mn-rule);
  border-bottom: 1px solid var(--mn-rule);
}
.price-slider .ps-mod {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 14px;
  border: 1px solid var(--mn-border-subtle);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color 120ms, background 120ms;
}
.price-slider .ps-mod:hover { border-color: var(--mn-border-default); }
.price-slider .ps-mod[aria-pressed="true"] {
  border-color: var(--mn-bg-accent);
  background: color-mix(in srgb, var(--mn-bg-accent) 6%, var(--mn-bg-surface));
}
.price-slider .ps-mod input { margin-top: 2px; accent-color: var(--mn-bg-accent); }
.price-slider .ps-mod .ps-mod-name { font-size: 14px; font-weight: 600; color: var(--mn-fg-1); }
.price-slider .ps-mod .ps-mod-price { font-size: 12px; color: var(--mn-fg-3); margin-top: 2px; font-variant-numeric: tabular-nums; }
.price-slider .ps-total {
  display: grid; grid-template-columns: 1fr auto auto; gap: 24px; align-items: center;
}
.price-slider .ps-total .ps-tot-label { font-size: 14px; color: var(--mn-fg-3); }
.price-slider .ps-total .ps-tot-amt { font-size: 36px; font-weight: 600; letter-spacing: -0.02em; color: var(--mn-fg-brand); font-variant-numeric: tabular-nums; }
.price-slider .ps-total .ps-tot-amt .pper { font-size: 14px; color: var(--mn-fg-3); font-weight: 400; margin-left: 4px; }

/* ---------- COMPARE ---------- */
.compare-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.compare-cell {
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-subtle);
  border-radius: 10px;
  padding: 28px;
}
.compare-cell.bad {
  background: color-mix(in srgb, #C0392B 4%, var(--mn-bg-surface));
  border-color: color-mix(in srgb, #C0392B 18%, var(--mn-border-subtle));
}
.compare-cell.good {
  background: color-mix(in srgb, var(--mn-bg-accent) 5%, var(--mn-bg-surface));
  border-color: color-mix(in srgb, var(--mn-bg-accent) 28%, var(--mn-border-subtle));
}
.compare-cell .ck {
  font-size: 11px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.compare-cell.bad .ck { color: #C0392B; }
.compare-cell.good .ck { color: var(--mn-fg-accent); }
.compare-cell h4 {
  font-size: 17px; font-weight: 600; line-height: 1.35;
  color: var(--mn-fg-brand);
  margin: 0 0 8px;
}
.compare-cell p { font-size: 14px; line-height: 1.55; color: var(--mn-fg-2); margin: 0; }

/* ---------- TESTIMONIAL ---------- */
.testi-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 24px;
}
.testi-feature {
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-subtle);
  border-radius: 12px;
  padding: 48px;
  display: flex; flex-direction: column; justify-content: space-between;
  min-height: 360px;
}
.testi-feature .quote {
  font-size: 28px; line-height: 1.35;
  letter-spacing: -0.015em;
  font-weight: 500;
  color: var(--mn-fg-brand);
  margin: 0 0 32px;
  text-wrap: pretty;
}
.testi-feature .quote::before { content: "\201E"; color: var(--mn-bg-accent); font-weight: 600; }
.testi-feature .quote::after { content: "\201C"; color: var(--mn-bg-accent); font-weight: 600; }
.testi-feature .author { display: flex; align-items: center; gap: 14px; }
.testi-feature .ava {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--mn-navy-800);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 14px;
}
.testi-feature .au-name { font-size: 14px; font-weight: 600; color: var(--mn-fg-1); }
.testi-feature .au-role { font-size: 13px; color: var(--mn-fg-3); }

.testi-side { display: flex; flex-direction: column; gap: 16px; }
.testi-mini {
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-subtle);
  border-radius: 12px;
  padding: 24px;
  flex: 1;
  display: flex; flex-direction: column;
}
.testi-mini .quote-sm {
  font-size: 16px; line-height: 1.45;
  color: var(--mn-fg-1); margin: 0 0 16px;
  font-weight: 500;
}
.testi-mini .meta { display: flex; align-items: center; gap: 10px; margin-top: auto; }
.testi-mini .meta .ava-sm {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--mn-teal-700); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 12px;
}
body[data-accent="gold"] .testi-mini .meta .ava-sm { background: var(--mn-gold-700); }
.testi-mini .meta .nm { font-size: 13px; font-weight: 600; color: var(--mn-fg-1); }
.testi-mini .meta .rl { font-size: 12px; color: var(--mn-fg-3); }

/* ---------- LOGO WALL ---------- */
.logo-wall {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  border: 1px solid var(--mn-border-subtle);
  border-radius: 12px;
  overflow: hidden;
  background: var(--mn-border-subtle);
}
.logo-wall .lw-cell {
  background: var(--mn-bg-surface);
  min-height: 108px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 20px 16px;
  text-align: center;
  transition: background 160ms ease;
}
.logo-wall .lw-cell.is-anchor {
  background: var(--mn-bg-surface);
  position: relative;
}
.logo-wall .lw-cell.is-anchor::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, var(--mn-fg-accent), var(--mn-teal-500, #14b8a6));
}
.logo-wall .lw-cell .lw-name {
  font-family: var(--mn-font-sans);
  font-weight: 600;
  font-size: 15px;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--mn-fg-2);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}
.logo-wall .lw-cell.is-anchor .lw-name {
  color: var(--mn-fg-brand);
}
.logo-wall .lw-cell .lw-tag {
  font-family: var(--mn-font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mn-fg-4);
  line-height: 1.3;
  white-space: nowrap;
}
.logo-wall .lw-cell.is-anchor .lw-tag {
  color: var(--mn-fg-accent);
  font-weight: 600;
}
.logo-wall .lw-cell .lw-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--mn-bg-accent);
  flex-shrink: 0;
}
.logo-wall .lw-cell svg { color: var(--mn-fg-3); opacity: 0.65; }

/* ---------- LOCATIONS ---------- */
.loc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
}
.loc-card {
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-subtle);
  border-radius: 12px;
  padding: 28px;
  position: relative;
}
.loc-card .lflag {
  font-family: var(--mn-font-mono);
  font-size: 11px; letter-spacing: 0.14em;
  color: var(--mn-fg-3);
  margin-bottom: 12px;
}
.loc-card h4 { font-size: 22px; font-weight: 600; color: var(--mn-fg-brand); margin: 0 0 6px; letter-spacing: -0.015em; }
.loc-card .lrole { font-size: 13px; color: var(--mn-fg-3); margin-bottom: 18px; }
.loc-card .laddr { font-size: 14px; line-height: 1.55; color: var(--mn-fg-2); }
.loc-card .laddr b { color: var(--mn-fg-1); font-weight: 600; }

.world-map {
  margin-top: 32px;
  border: 1px solid var(--mn-border-subtle);
  border-radius: 12px;
  background: var(--mn-bg-surface);
  padding: 32px;
  position: relative;
  overflow: hidden;
}

/* ---------- FAQ ---------- */
.faq-list { display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--mn-rule); }
.faq-item {
  border-bottom: 1px solid var(--mn-rule);
  padding: 24px 0;
  cursor: pointer;
}
.faq-item summary {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 18px; font-weight: 500;
  color: var(--mn-fg-brand);
  list-style: none;
  cursor: pointer;
  letter-spacing: -0.01em;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+";
  font-size: 24px; font-weight: 300;
  color: var(--mn-fg-3);
  transition: transform 200ms;
}
.faq-item[open] summary::after { content: "−"; }
.faq-item .ans {
  font-size: 15px; line-height: 1.6;
  color: var(--mn-fg-2);
  padding-top: 16px;
  max-width: 760px;
}

/* ---------- CTA FOOTER ---------- */
.cta-block {
  background: var(--mn-navy-800);
  color: #fff;
  border-radius: 16px;
  padding: 72px 64px;
  position: relative;
  overflow: hidden;
}
.cta-block::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
  background: var(--mn-gold-500);
}
.cta-block h2 {
  font-size: clamp(36px, 4vw, 56px);
  line-height: 1.04;
  letter-spacing: -0.025em;
  font-weight: 600;
  color: #fff;
  margin: 0 0 16px;
  max-width: 720px;
  text-wrap: balance;
}
.cta-block h2 em { font-style: normal; color: var(--mn-teal-500); }
body[data-accent="gold"] .cta-block h2 em { color: var(--mn-gold-300); }
.cta-block p { font-size: 17px; line-height: 1.55; color: var(--mn-navy-200); max-width: 580px; margin: 0 0 36px; }
.cta-block .cta-row { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.cta-block .cta-meta {
  margin-top: 36px; padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,0.14);
  display: flex; gap: 48px; flex-wrap: wrap;
}
.cta-block .cta-meta > div { font-size: 13px; color: var(--mn-navy-300); }
.cta-block .cta-meta b { color: #fff; font-weight: 600; display: block; font-size: 16px; margin-bottom: 2px; }

/* ---------- FOOTER ---------- */
footer.site-footer {
  border-top: 1px solid var(--mn-border-subtle);
  padding: 64px 0 32px;
  margin-top: 96px;
}
footer .footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 48px;
}
footer .ftcol h5 {
  font-size: 11px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-fg-3);
  margin: 0 0 16px;
}
footer .ftcol ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
footer .ftcol a { font-size: 14px; color: var(--mn-fg-2); text-decoration: none; }
footer .ftcol a:hover { color: var(--mn-fg-1); }
footer .ftcol p { font-size: 14px; line-height: 1.55; color: var(--mn-fg-3); margin: 0 0 16px; max-width: 320px; }
footer .ft-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 24px;
  border-top: 1px solid var(--mn-rule);
  font-size: 12px; color: var(--mn-fg-3);
  flex-wrap: wrap; gap: 16px;
}
footer .ft-bottom .ft-links { display: flex; gap: 24px; }
footer .ft-bottom a { color: inherit; text-decoration: none; }
footer .ft-bottom a:hover { color: var(--mn-fg-1); }

/* ---------- STRIPE CHECKOUT OVERLAY ---------- */
.checkout-overlay {
  position: fixed; inset: 0;
  background: rgba(11, 37, 69, 0.45);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 100;
  display: none;
  align-items: stretch; justify-content: center;
  padding: 24px;
}
.checkout-overlay.open { display: flex; }
.checkout-modal {
  background: var(--mn-bg-canvas);
  border-radius: 14px;
  width: 100%; max-width: 1080px;
  max-height: calc(100vh - 48px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  overflow: hidden;
  box-shadow: var(--mn-shadow-lg);
  border: 1px solid var(--mn-border-subtle);
}
.checkout-summary {
  background: var(--mn-navy-800);
  color: #fff;
  padding: 40px;
  overflow-y: auto;
}
.checkout-summary .csk {
  font-size: 11px; font-weight: 700; letter-spacing: 0.14em;
  color: var(--mn-teal-500); text-transform: uppercase;
  margin-bottom: 14px;
}
body[data-accent="gold"] .checkout-summary .csk { color: var(--mn-gold-300); }
.checkout-summary h3 { font-size: 28px; font-weight: 600; letter-spacing: -0.015em; margin: 0 0 8px; }
.checkout-summary .ct-tag { font-size: 14px; color: var(--mn-navy-200); margin-bottom: 32px; }
.checkout-summary .cline {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,0.1);
  font-size: 14px;
  font-variant-numeric: tabular-nums;
}
.checkout-summary .cline:first-of-type { border-top: 1px solid rgba(255,255,255,0.1); }
.checkout-summary .cline span:first-child { color: var(--mn-navy-200); }
.checkout-summary .ctotal {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-top: 24px; padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.2);
  font-variant-numeric: tabular-nums;
}
.checkout-summary .ctotal .lbl { font-size: 13px; color: var(--mn-navy-200); letter-spacing: 0.05em; text-transform: uppercase; }
.checkout-summary .ctotal .amt { font-size: 36px; font-weight: 600; letter-spacing: -0.02em; }
.checkout-summary .csec {
  margin-top: 32px;
  padding: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  font-size: 12px;
  color: var(--mn-navy-200);
  line-height: 1.55;
}
.checkout-form {
  background: var(--mn-bg-surface);
  padding: 40px;
  overflow-y: auto;
  position: relative;
}
.checkout-form .cstep {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 24px;
  font-size: 13px; color: var(--mn-fg-3);
}
.checkout-form .cstep-dot {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--mn-bg-accent);
  color: var(--mn-fg-on-accent);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 600;
}
.checkout-close {
  position: absolute; top: 16px; right: 16px;
  width: 36px; height: 36px;
  border-radius: 8px; border: 0;
  background: transparent;
  color: var(--mn-fg-3);
  font-size: 22px; cursor: pointer;
}
.checkout-close:hover { background: var(--mn-bg-sunken); color: var(--mn-fg-1); }
.checkout-form h3 { font-size: 22px; font-weight: 600; letter-spacing: -0.015em; margin: 0 0 6px; }
.checkout-form .lede-sm { font-size: 14px; color: var(--mn-fg-3); margin: 0 0 28px; }
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.field label { font-size: 12px; font-weight: 600; color: var(--mn-fg-2); letter-spacing: 0.04em; text-transform: uppercase; }
.field input, .field select {
  height: 44px; padding: 0 14px;
  border: 1px solid var(--mn-border-default);
  border-radius: 6px;
  background: var(--mn-bg-surface);
  font: inherit; font-size: 14px;
  color: var(--mn-fg-1);
  outline: none;
  transition: border-color 120ms, box-shadow 120ms;
}
.field input:focus, .field select:focus {
  border-color: var(--mn-border-focus);
  box-shadow: var(--mn-shadow-focus);
}
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.field-row-3 { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 12px; }
.cardfield {
  height: 48px;
  border: 1px solid var(--mn-border-default);
  border-radius: 6px;
  background: var(--mn-bg-surface);
  display: flex; align-items: center; padding: 0 14px;
  gap: 10px;
}
.cardfield input { flex: 1; border: 0; background: transparent; outline: none; height: 100%; font: inherit; font-size: 14px; color: var(--mn-fg-1); font-variant-numeric: tabular-nums; }
.stripe-mark {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--mn-fg-3);
  margin-top: 16px;
}
.stripe-mark svg { color: #635BFF; }

/* utility */
.text-balance { text-wrap: balance; }
.muted { color: var(--mn-fg-3); }
.tabular { font-variant-numeric: tabular-nums; }

/* ─── Mobile hamburger button + drawer ─────────────────────────────────── */
.nav-burger {
  display: none;
  background: transparent;
  border: 1px solid var(--mn-border-default);
  border-radius: 8px;
  width: 40px;
  height: 40px;
  padding: 0;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  color: var(--mn-fg-1);
}
.nav-burger:hover { background: var(--mn-bg-sunken); }
.nav-burger > span {
  display: block;
  width: 18px;
  height: 14px;
  position: relative;
}
.nav-burger > span > span {
  position: absolute;
  left: 0; right: 0;
  height: 2px;
  background: currentColor;
  border-radius: 1px;
  transition: transform 0.2s cubic-bezier(.4,0,.2,1), opacity 0.15s;
  transform-origin: center;
}
.nav-burger > span > span:nth-child(1) { top: 2px; }
.nav-burger > span > span:nth-child(2) { top: 6px; }
.nav-burger > span > span:nth-child(3) { top: 10px; }

.nav-drawer {
  position: fixed;
  top: 60px;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--mn-bg-surface);
  border-top: 1px solid var(--mn-border-subtle);
  padding: 24px 20px 32px;
  z-index: 40;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity 0.18s ease, transform 0.2s ease, visibility 0s linear 0.2s;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.nav-drawer.open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity 0.18s ease, transform 0.2s ease, visibility 0s linear 0s;
}
.nav-drawer-links {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.nav-drawer-links a {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--mn-fg-1);
  padding: 14px 0;
  border-bottom: 1px solid var(--mn-border-subtle);
  text-decoration: none;
}
.nav-drawer-links a:hover { color: var(--mn-fg-accent); }
.nav-drawer-cta {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: auto;
}
.nav-drawer-cta .btn { width: 100%; justify-content: center; }

@media (max-width: 1024px) {
  .hero-grid, .security-grid, .testi-grid { grid-template-columns: 1fr; gap: 40px; }
  .module-grid { grid-template-columns: repeat(6, 1fr); }
  .module-card.span-7, .module-card.span-5, .module-card.span-6 { grid-column: span 6; }
  .module-card.span-4 { grid-column: span 3; }
  .pricing-cards { grid-template-columns: 1fr; }
  .loc-grid { grid-template-columns: 1fr; }
  footer .footer-grid { grid-template-columns: repeat(2, 1fr); }
  .checkout-modal { grid-template-columns: 1fr; max-height: 90vh; }
  .compare-grid { grid-template-columns: 1fr; }
}

/* ─── MOBILE (≤ 768px / tablet portrait & phone) ───────────────────────── */
@media (max-width: 768px) {
  /* Shell padding tighter */
  .shell, .shell-wide { padding: 0 20px; }

  /* Section rhythm */
  .section-pad { padding: 64px 0; }
  .section-pad-sm { padding: 48px 0; }

  /* Nav: hide middle links and right-side auth on mobile, keep logo + lang + CTA */
  .nav-inner { height: 60px; gap: 12px; }
  .nav-left { gap: 16px; }
  .nav-links { display: none; }
  .nav-right { gap: 8px; }
  .nav-right .nav-signin { display: none; }       /* "Anmelden" (Sign in) — hide on mobile, surfaced in drawer */
  .nav-burger { display: inline-flex; }
  .btn { height: 40px; padding: 0 16px; font-size: 13px; }
  .btn-lg { height: 46px; padding: 0 18px; font-size: 14px; }
  .btn-sm { height: 32px; padding: 0 12px; font-size: 12px; }

  /* Hero: stack and tighten */
  .hero { padding: 56px 0 64px; }
  .hero-editorial .hero { padding: 72px 0 64px; }
  .hero h1 { font-size: clamp(30px, 8.5vw, 44px); margin-bottom: 18px; }
  .hero p.lede { font-size: 16px; margin-bottom: 24px; }
  .hero-ctas { flex-wrap: wrap; gap: 10px; }
  .hero-ctas .btn { flex: 1 1 auto; min-width: 0; }
  .hero-meta { gap: 20px; margin-top: 32px; padding-top: 20px; }
  .hero-meta > div { font-size: 12px; }
  .hero-meta b { font-size: 16px; }
  .hero-eyebrow { margin-bottom: 16px; flex-wrap: wrap; }
  .hero-eyebrow .kicker { font-size: 12px; flex-wrap: wrap; }

  /* Module grid → 1 col on tablet */
  .module-grid { grid-template-columns: 1fr; gap: 14px; }
  .module-card,
  .module-card.span-7,
  .module-card.span-5,
  .module-card.span-6,
  .module-card.span-4,
  .module-card.span-12 { grid-column: span 1; min-height: 0; padding: 22px; }
  .module-card h3 { font-size: 20px; }
  .module-card .mod-foot { flex-wrap: wrap; gap: 10px; }

  /* Pipeline */
  .pipeline { grid-template-columns: 1fr; gap: 8px; padding: 14px; }
  .pipeline-arrow { display: none !important; }

  /* Security strip */
  .security-strip h2 { font-size: clamp(26px, 6.5vw, 36px); }
  .security-strip .lede { font-size: 15px; }
  .cert-grid { grid-template-columns: 1fr; }
  .cert-cell { padding: 18px 18px; }

  /* Testimonials */
  .testi-feature { padding: 32px 26px; min-height: 0; }
  .testi-feature .quote { font-size: 22px; margin-bottom: 24px; }

  /* Logo wall */
  .logo-wall { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .logo-wall .lw-cell { min-height: 92px; padding: 14px 10px; gap: 6px; }
  .logo-wall .lw-cell .lw-name { font-size: 13.5px; }
  .logo-wall .lw-cell .lw-tag { font-size: 9.5px; letter-spacing: 0.08em; }

  /* Locations */
  .loc-grid { grid-template-columns: 1fr; }
  .loc-card { padding: 22px; }
  .loc-card h4 { font-size: 20px; }
  .world-map { padding: 20px; margin-top: 24px; }

  /* Pricing — tabs need to wrap; price-card paddings tighter */
  .pricing-tabs { flex-wrap: wrap; padding: 3px; gap: 0; }
  .pricing-tabs button { height: 30px; padding: 0 12px; font-size: 12px; }
  .price-card { padding: 26px 22px; }
  .price-card .pamt .pnum { font-size: 44px; }
  .price-card .pamt.no-num .pnum { font-size: 26px; }
  .price-slider { padding: 24px 18px; }
  .price-slider .ps-head { grid-template-columns: 1fr; gap: 16px; }
  .price-slider .ps-modules { grid-template-columns: 1fr; }
  .price-slider .ps-total { grid-template-columns: 1fr; gap: 12px; text-align: left; }
  .price-table { font-size: 13px; }
  .price-table th, .price-table td { padding: 10px 12px; font-size: 13px; }

  /* Pricing table & extra-pages compare-table — let them scroll horizontally rather than crush.
     No wrapper exists in JSX, so turn the table itself into a horizontally scrollable block.
     extra-pages sets inline min-width: 720, so override with !important. */
  .price-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .price-table,
  .compare-table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
    min-width: 0 !important;
  }
  .price-table thead, .price-table tbody, .price-table tfoot,
  .compare-table thead, .compare-table tbody, .compare-table tfoot {
    display: table;
    min-width: 100%;
    width: max-content;
  }

  /* Compare grid */
  .compare-grid { grid-template-columns: 1fr; }
  .compare-cell { padding: 22px; }

  /* FAQ */
  .faq-item summary { font-size: 16px; gap: 16px; }
  .faq-item .ans { font-size: 14px; }

  /* CTA block */
  .cta-block { padding: 44px 28px; border-radius: 12px; }
  .cta-block h2 { font-size: clamp(26px, 6.5vw, 36px); }
  .cta-block p { font-size: 15px; }
  .cta-block .cta-meta { gap: 24px; }

  /* Footer */
  footer.site-footer { padding: 48px 0 24px; margin-top: 56px; }
  footer .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px 24px; margin-bottom: 32px; }
  footer .ft-bottom { flex-direction: column; align-items: flex-start; gap: 12px; }
  footer .ft-bottom .ft-links { flex-wrap: wrap; gap: 16px 20px; }

  /* Checkout modal */
  .checkout-overlay { padding: 0; }
  .checkout-modal { max-height: 100vh; border-radius: 0; }
  .checkout-summary, .checkout-form { padding: 24px 20px; }
  .checkout-summary h3 { font-size: 22px; }
  .checkout-summary .ctotal .amt { font-size: 28px; }
  .field-row, .field-row-3 { grid-template-columns: 1fr; }

  /* Override inline grids set via style={{}} in component files.
     These need !important because inline style otherwise wins over external CSS.
     Components: booking-highlight, subpages, big-pages, middle, bottom, header. */
  .shell-wide > div[style*="grid-template-columns"],
  .shell-wide > div[style*="gridTemplateColumns"],
  .shell > div[style*="grid-template-columns"],
  .shell > div[style*="gridTemplateColumns"] {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }
  /* Generic catch for any inline grid container with multi-column template inside main content */
  main div[style*="grid-template-columns"][style*="fr"],
  section div[style*="grid-template-columns"][style*="fr"] {
    grid-template-columns: 1fr !important;
  }
  /* Restore: pricing internal grids (use class names not inline), header product tables (keep narrow), checkout-summary cline */
  main .pricing-cards { grid-template-columns: 1fr; }

  /* Inline-flex containers (pricing-page tabs, sub-page CTA rows) overflow on phone.
     Pricing tabs are styled via `display: inline-flex` inline — force wrap. */
  main div[style*="inline-flex"],
  section div[style*="inline-flex"] {
    flex-wrap: wrap !important;
    max-width: 100% !important;
  }
  /* Inline buttons inside inline-flex containers need to be allowed to shrink */
  main div[style*="inline-flex"] > .btn,
  section div[style*="inline-flex"] > .btn {
    flex: 0 1 auto;
    min-width: 0;
  }

  /* ─── Exemptions from the inline-grid catch-all ───────────────────────────
     The catch-all forces every inline `grid-template-columns` to 1fr. Most
     pages benefit, but a few internal tabular layouts must keep their
     column structure (the user would see them collapsed into a single
     unreadable column otherwise). For those we keep the grid intact and
     scroll horizontally instead. */
  main .matrix-inner > div[style*="grid-template-columns"],
  section .matrix-inner > div[style*="grid-template-columns"] {
    grid-template-columns: 2fr 1fr 1fr 1fr !important;
    min-width: 560px;
  }
  .matrix-scroll {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  .matrix-inner {
    min-width: 560px;
  }

  /* Sub-page "careers"/"blog" tabular rows in big-pages: 4-column rows
     (2.5fr 1.5fr 1fr 60px) become unreadable when stacked. Let the wrapper
     scroll horizontally and keep the row grid. */
  main a[style*="grid-template-columns"][style*="60px"],
  section a[style*="grid-template-columns"][style*="60px"] {
    grid-template-columns: 2fr 1fr 1fr 40px !important;
    min-width: 0;
    gap: 8px;
    font-size: 13px !important;
    padding: 18px 16px !important;
  }
  main a[style*="grid-template-columns"][style*="60px"] > span,
  section a[style*="grid-template-columns"][style*="60px"] > span {
    font-size: 12px !important;
    min-width: 0;
    overflow-wrap: break-word;
  }

  /* Security Onion: nested margins (up to 6 × 22 = 132px each side) crush
     the innermost layer on phones. The inset is set inline as a multiple
     of 22 (0/22/44/66/88/110/132). Override every variant via attribute
     selectors so the onion stays inside a 343px shell-wide container. */
  .mn-onion-stack > div[style*="margin-left: 22px"] { margin-left: 6px !important; margin-right: 6px !important; }
  .mn-onion-stack > div[style*="margin-left: 44px"] { margin-left: 12px !important; margin-right: 12px !important; }
  .mn-onion-stack > div[style*="margin-left: 66px"] { margin-left: 18px !important; margin-right: 18px !important; }
  .mn-onion-stack > div[style*="margin-left: 88px"] { margin-left: 24px !important; margin-right: 24px !important; }
  .mn-onion-stack > div[style*="margin-left: 110px"] { margin-left: 30px !important; margin-right: 30px !important; }
  .mn-onion-stack > div[style*="margin-left: 132px"] { margin-left: 36px !important; margin-right: 36px !important; }
  .mn-onion-stack > div { padding: 12px 14px !important; font-size: 12.5px !important; }
  .mn-onion-stack > div > span:last-child { display: none; } /* hide the tech tag on mobile to save horizontal space */

  /* Phone-bot 60-second flow: absolute connecting line at top:18 looks
     wrong once the steps stack vertically. Hide the connector line on
     mobile (it's an absolute-positioned div that's the FIRST CHILD of
     a grid with 6 1fr cols; the catch-all has already stacked the grid). */
  main section div[style*="grid-template-columns"][style*="repeat(6"]
    > div[style*="position: absolute"]:first-child,
  section div[style*="grid-template-columns"][style*="repeat(6"]
    > div[style*="position: absolute"]:first-child {
    display: none !important;
  }

  /* Timeline (company page): grid `repeat(N, 1fr)` stacks via catch-all.
     The absolute horizontal line that connects year-tiles should also
     hide on mobile, or it dangles across an empty top. */
  .mn-timeline > div[style*="position: absolute"] { display: none !important; }
  .mn-timeline-item { padding: 0 !important; margin-bottom: 28px; }

  /* Advisory cards (company page): keep avatar + content side-by-side but
     allow text to wrap freely; force the avatar to a tighter size. */
  .mn-advisory-card { padding: 20px !important; gap: 14px !important; }
  .mn-advisory-card > div:first-child {
    width: 56px !important;
    height: 56px !important;
    font-size: 20px !important;
  }

  /* Team card avatars: clamp the giant `aspectRatio: 1/1` block so each
     card doesn't dominate a 1-col stack. */
  .mn-team-card > div:first-child {
    max-height: 240px;
    aspect-ratio: auto !important;
    height: 200px;
  }

  /* PainPoints cards padding tighter on phones (inline padding 32 is heavy
     on a 343px viewport). */
  #pain-points article { padding: 22px !important; }
  #pain-points h3 { font-size: 18px !important; }

  /* Careers process timeline: hide the absolute horizontal connector when
     the 5-step grid stacks; restore a sensible vertical gap between steps. */
  .mn-careers-process-line { display: none !important; }
  .mn-careers-process { gap: 28px !important; }

  /* Careers + job-detail asymmetric 1fr/1.6fr layouts collapse via the
     catch-all but keep their inline 64px gap. That feels heavy on a phone —
     tighten to a section-rhythm value when stacked. */
  main section .shell-wide[style*="grid-template-columns"][style*="fr"] {
    gap: 32px !important;
  }
}

/* ─── SMALL MOBILE (≤ 480px / phone portrait) ──────────────────────────── */
@media (max-width: 480px) {
  /* Tighter shell */
  .shell, .shell-wide { padding: 0 16px; }

  /* Section rhythm */
  .section-pad { padding: 48px 0; }
  .section-pad-sm { padding: 36px 0; }

  /* Hero typography sized for ~375 viewport */
  .hero h1 { font-size: clamp(28px, 8vw, 34px); line-height: 1.08; }
  .hero p.lede { font-size: 15px; line-height: 1.5; }
  .hero-meta { gap: 14px 24px; }
  .hero-meta > div { font-size: 11px; }
  .hero-meta b { font-size: 14px; }

  /* Hero photo / device — let it breathe but never overflow */
  .hero-device { border-radius: 10px; }

  /* Nav — shrink logo */
  .nav-inner { height: 56px; }
  .nav-logo { height: 24px; }
  .nav-right { gap: 6px; }
  .lang-switch button { width: 28px; height: 22px; font-size: 10px; }

  /* Module cards — tighter */
  .module-card { padding: 20px; min-height: 0; }
  .module-card h3 { font-size: 19px; }
  .module-card p { font-size: 14px; }
  .module-card .mod-bullets li { font-size: 12.5px; }

  /* Security strip headline */
  .security-strip h2 { font-size: clamp(24px, 7vw, 30px); }

  /* Testimonial */
  .testi-feature { padding: 26px 22px; }
  .testi-feature .quote { font-size: 19px; line-height: 1.4; margin-bottom: 20px; }
  .testi-mini { padding: 20px; }

  /* Logo wall — keep 2 columns at phone widths; tighter cell + smaller text */
  .logo-wall { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .logo-wall .lw-cell { min-height: 84px; padding: 12px 10px; gap: 5px; }
  .logo-wall .lw-cell .lw-name { font-size: 13px; }
  .logo-wall .lw-cell .lw-tag {
    font-size: 9px;
    letter-spacing: 0.06em;
    /* on narrow screens, let the tag wrap rather than overflowing */
    white-space: normal;
  }

  /* Pricing card */
  .price-card { padding: 22px 20px; }
  .price-card h3 { font-size: 20px; }
  .price-card .pamt .pnum { font-size: 36px; }
  .price-card .pamt.no-num .pnum { font-size: 22px; }

  /* CTA block */
  .cta-block { padding: 36px 22px; }
  .cta-block h2 { font-size: clamp(22px, 6.5vw, 30px); }
  .cta-block .cta-row { flex-direction: column; align-items: stretch; }
  .cta-block .cta-row .btn { width: 100%; }
  .cta-block .cta-meta { gap: 18px; }

  /* Hero CTAs full width */
  .hero-ctas { flex-direction: column; align-items: stretch; }
  .hero-ctas .btn { width: 100%; }

  /* Footer 1-col on phone */
  footer .footer-grid { grid-template-columns: 1fr; gap: 28px; }

  /* Big sub-page H1s (used inline) — knock down via global rule on h1 inside section-pad */
  section.section-pad h1 { font-size: clamp(28px, 8.5vw, 36px) !important; line-height: 1.06 !important; }
  section.section-pad h2 { font-size: clamp(24px, 7vw, 30px) !important; }

  /* Booking highlight stat (+10 %) and similar large numeric tiles — shrink */
  .price-slider .ps-total .ps-tot-amt { font-size: 26px; }
  .checkout-summary .ctotal .amt { font-size: 24px; }

  /* Pricing matrix: tighten min-width and tab font on small phones */
  main .matrix-inner > div[style*="grid-template-columns"],
  section .matrix-inner > div[style*="grid-template-columns"] {
    min-width: 480px;
    font-size: 12px !important;
    padding: 12px 16px !important;
  }
  .matrix-inner { min-width: 480px; }

  /* Phone-bot test number: 38px monospace would clip on 360-380 viewports */
  main section div[style*="font-size: 38"] { font-size: 26px !important; }

  /* Big year on timeline shrinks further */
  .mn-timeline-item > div[style*="clamp(40px"] { font-size: 36px !important; }
}

/* ─── NAV LOGO ON TIGHT SCREENS ─────────────────────────────────────────── */
@media (max-width: 480px) {
  .nav-brand { gap: 8px !important; }
  .nav-logo-mark { width: 26px !important; height: 26px !important; }
  .nav-logo-text { font-size: 17px !important; letter-spacing: -0.02em !important; }
}
@media (max-width: 380px) {
  .nav-logo-text { font-size: 15px !important; }
}

/* ═══ CLICKDUMMY (interactive product tour) ═════════════════════════════ */

.clickdummy-page { --cd-bezel-bg: #0f1d2c; --cd-bezel-chrome: #1a2940; --cd-rail-w: 280px; }

/* Stage layout: rail + main */
.clickdummy-stage {
  display: grid;
  grid-template-columns: var(--cd-rail-w) minmax(0, 1fr);
  gap: 36px;
  align-items: start;
}
@media (max-width: 980px) {
  .clickdummy-stage { grid-template-columns: 1fr; }
}

/* ─── Desktop rail ────────────────────────────────────────────────────── */
.clickdummy-rail {
  position: sticky;
  top: 96px;
  max-height: calc(100vh - 120px);
  overflow-y: auto;
  padding: 24px 20px;
  border-radius: 18px;
  background: var(--mn-bg-sunken);
  border: 1px solid var(--mn-border-subtle);
}
@media (max-width: 980px) { .clickdummy-rail { display: none; } }

.clickdummy-rail-header { padding: 0 4px 12px; border-bottom: 1px solid var(--mn-border-subtle); margin-bottom: 14px; }
.clickdummy-progress { margin-top: 10px; height: 3px; background: var(--mn-border-subtle); border-radius: 2px; overflow: hidden; }
.clickdummy-progress-bar { height: 100%; background: linear-gradient(90deg, var(--mn-fg-accent), var(--mn-teal-500, #14b8a6)); transition: width 360ms cubic-bezier(.4,0,.2,1); }

.clickdummy-rail-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }

.clickdummy-rail-item {
  appearance: none;
  background: transparent;
  border: none;
  width: 100%;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  text-align: left;
  cursor: pointer;
  color: var(--mn-fg-2);
  transition: background 120ms, color 120ms, transform 120ms;
  position: relative;
}
.clickdummy-rail-item:hover { background: rgba(20, 184, 166, 0.06); color: var(--mn-fg-1); }
.clickdummy-rail-item.is-active {
  background: var(--mn-bg-canvas);
  color: var(--mn-fg-1);
  box-shadow: inset 3px 0 0 var(--mn-fg-accent);
  font-weight: 600;
}
.clickdummy-rail-item.is-done .clickdummy-rail-num { color: var(--mn-fg-accent); }
.clickdummy-rail-item.is-done .clickdummy-rail-num::after { content: " ✓"; font-size: 0.85em; }

.clickdummy-rail-num {
  font-family: var(--mn-font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  color: var(--mn-fg-3);
  flex-shrink: 0;
  padding-top: 2px;
  min-width: 22px;
}
.clickdummy-rail-item.is-active .clickdummy-rail-num { color: var(--mn-fg-accent); }

.clickdummy-rail-text { display: flex; flex-direction: column; gap: 1px; line-height: 1.3; }
.clickdummy-rail-module { font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--mn-fg-3); font-weight: 600; }
.clickdummy-rail-item.is-active .clickdummy-rail-module { color: var(--mn-fg-accent); }
.clickdummy-rail-chapter { font-size: 14px; }

/* ─── Mobile horizontal rail ──────────────────────────────────────────── */
.clickdummy-rail-mobile {
  display: none;
  position: sticky;
  top: 64px;
  z-index: 20;
  background: var(--mn-bg-canvas);
  border-bottom: 1px solid var(--mn-border-subtle);
  padding: 10px 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  white-space: nowrap;
  scrollbar-width: none;
}
.clickdummy-rail-mobile::-webkit-scrollbar { display: none; }
@media (max-width: 980px) {
  .clickdummy-rail-mobile { display: flex; gap: 8px; }
}

.clickdummy-pill {
  appearance: none;
  background: var(--mn-bg-sunken);
  border: 1px solid var(--mn-border-subtle);
  color: var(--mn-fg-2);
  padding: 8px 12px;
  border-radius: 100px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  cursor: pointer;
  scroll-snap-align: center;
  flex-shrink: 0;
  transition: all 160ms;
}
.clickdummy-pill.is-active {
  background: var(--mn-fg-accent);
  color: var(--mn-fg-on-accent);
  border-color: var(--mn-fg-accent);
}
.clickdummy-pill-num { font-family: var(--mn-font-mono); font-size: 11px; font-weight: 600; opacity: 0.7; }
.clickdummy-pill.is-active .clickdummy-pill-num { opacity: 1; }
.clickdummy-pill-label { font-weight: 600; }

/* ─── Main column ─────────────────────────────────────────────────────── */
.clickdummy-main { min-width: 0; }
.clickdummy-main-head { margin-bottom: 24px; }

.clickdummy-meta-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 14px;
  font-family: var(--mn-font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.clickdummy-counter {
  display: inline-flex;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 6px;
  background: var(--mn-bg-sunken);
  border: 1px solid var(--mn-border-subtle);
  font-variant-numeric: tabular-nums;
}

.clickdummy-module-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 100px;
  background: color-mix(in srgb, var(--chip) 12%, transparent);
  color: var(--chip);
  border: 1px solid color-mix(in srgb, var(--chip) 30%, transparent);
  font-weight: 600;
}
.clickdummy-module-dot {
  width: 8px;
  height: 8px;
  border-radius: 100px;
  background: var(--chip);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--chip) 20%, transparent);
  animation: cd-pulse 2s ease-in-out infinite;
}
@keyframes cd-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }

.clickdummy-chapter-label {
  color: var(--mn-fg-3);
  font-weight: 500;
}

.clickdummy-chapter-title {
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.08;
  letter-spacing: -0.025em;
  font-weight: 600;
  color: var(--mn-fg-brand);
  margin: 0 0 12px;
  text-wrap: balance;
}
.clickdummy-chapter-lede {
  font-size: 17px;
  line-height: 1.55;
  color: var(--mn-fg-2);
  margin: 0;
  max-width: 720px;
}

/* ─── Device bezel for screenshot ─────────────────────────────────────── */
.clickdummy-bezel {
  margin: 0;
  border-radius: 14px;
  background: var(--cd-bezel-bg);
  background: linear-gradient(160deg, var(--cd-bezel-bg) 0%, #16243a 100%);
  border: 1px solid #1f3151;
  box-shadow:
    0 32px 80px -32px rgba(15, 28, 52, 0.5),
    0 12px 28px -10px rgba(15, 28, 52, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  overflow: hidden;
  animation: cd-fade-in 360ms cubic-bezier(.4,0,.2,1);
}
@keyframes cd-fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.clickdummy-bezel-chrome {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: var(--cd-bezel-chrome);
  background: linear-gradient(180deg, #1d2c47 0%, #16243a 100%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}
.clickdummy-bezel-dot {
  width: 11px;
  height: 11px;
  border-radius: 100px;
  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.12);
}
.clickdummy-bezel-url {
  margin-left: 14px;
  padding: 3px 14px;
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.04);
  font-family: var(--mn-font-mono);
  font-size: 11px;
  color: rgba(255, 255, 255, 0.6);
  letter-spacing: 0.02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 60%;
}

.clickdummy-bezel-canvas {
  position: relative;
  background: #f7f8fa;
  overflow: hidden;
}
.clickdummy-screenshot {
  display: block;
  width: 100%;
  height: auto;
  animation: cd-fade-in 480ms cubic-bezier(.4,0,.2,1);
}

.clickdummy-bezel-note {
  padding: 10px 16px;
  background: rgba(255, 255, 255, 0.03);
  font-family: var(--mn-font-mono);
  font-size: 11px;
  color: rgba(255, 255, 255, 0.55);
  text-align: center;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}

/* ─── Annotation pins ─────────────────────────────────────────────────── */
.clickdummy-pin {
  position: absolute;
  width: 28px;
  height: 28px;
  margin: -14px 0 0 -14px;
  display: inline-block;
  z-index: 2;
  cursor: pointer;
  outline: none;
  animation: cd-pin-in 600ms cubic-bezier(.34,1.56,.64,1) backwards;
}
@keyframes cd-pin-in {
  from { opacity: 0; transform: scale(0.4); }
  to   { opacity: 1; transform: scale(1); }
}
.clickdummy-pin-dot {
  width: 28px;
  height: 28px;
  border-radius: 100px;
  background: var(--mn-fg-accent);
  color: var(--mn-fg-on-accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--mn-font-mono);
  font-size: 13px;
  font-weight: 700;
  box-shadow: 0 0 0 4px rgba(20, 184, 166, 0.25), 0 6px 16px -4px rgba(15, 28, 52, 0.35);
  position: relative;
}
.clickdummy-pin-dot::after {
  content: "";
  position: absolute;
  inset: -8px;
  border-radius: 100px;
  border: 2px solid var(--mn-fg-accent);
  animation: cd-pin-ring 2.2s ease-out infinite;
}
@keyframes cd-pin-ring {
  0%   { opacity: 0.8; transform: scale(0.8); }
  100% { opacity: 0;   transform: scale(1.6); }
}
.clickdummy-pin-tip {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: #0f1d2c;
  color: #fff;
  font-size: 12px;
  line-height: 1.35;
  padding: 8px 12px;
  border-radius: 8px;
  white-space: nowrap;
  max-width: 280px;
  white-space: normal;
  width: max-content;
  box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.4);
  opacity: 0;
  pointer-events: none;
  transition: opacity 160ms;
  z-index: 3;
}
.clickdummy-pin-tip[data-side="right"] { left: calc(100% + 14px); }
.clickdummy-pin-tip[data-side="left"]  { right: calc(100% + 14px); }
.clickdummy-pin-tip[data-side="top"]   { left: 50%; transform: translate(-50%, -100%) translateY(-14px); top: 0; }
.clickdummy-pin-tip[data-side="bottom"]{ left: 50%; transform: translate(-50%, 14px); top: 100%; }
.clickdummy-pin:hover .clickdummy-pin-tip,
.clickdummy-pin:focus .clickdummy-pin-tip { opacity: 1; }

/* Pins list (mobile + always visible) */
.clickdummy-pins-list {
  list-style: none;
  padding: 0;
  margin: 28px 0 0;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.clickdummy-pins-list li {
  display: flex;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 10px;
  background: var(--mn-bg-sunken);
  border: 1px solid var(--mn-border-subtle);
  font-size: 14px;
  color: var(--mn-fg-2);
  line-height: 1.45;
}
.clickdummy-pins-list-num {
  width: 22px;
  height: 22px;
  border-radius: 100px;
  background: var(--mn-fg-accent);
  color: var(--mn-fg-on-accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--mn-font-mono);
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
}

/* ─── Prev / Next nav ─────────────────────────────────────────────────── */
.clickdummy-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px solid var(--mn-border-subtle);
}
.clickdummy-nav-hint {
  font-family: var(--mn-font-mono);
  font-size: 11px;
  letter-spacing: 0.05em;
  color: var(--mn-fg-3);
  flex: 1;
  text-align: center;
}
@media (max-width: 640px) {
  .clickdummy-nav-hint { display: none; }
}
.clickdummy-nav-btn {
  appearance: none;
  background: var(--mn-bg-canvas);
  border: 1px solid var(--mn-border-default);
  color: var(--mn-fg-1);
  padding: 12px 22px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 160ms;
  text-decoration: none;
}
.clickdummy-nav-btn:hover:not(:disabled) {
  border-color: var(--mn-fg-accent);
  color: var(--mn-fg-accent);
  transform: translateY(-1px);
}
.clickdummy-nav-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.clickdummy-nav-next, .clickdummy-nav-cta {
  background: var(--mn-fg-accent);
  color: var(--mn-fg-on-accent);
  border-color: var(--mn-fg-accent);
}
.clickdummy-nav-next:hover:not(:disabled), .clickdummy-nav-cta:hover {
  background: var(--mn-teal-800, #115e59);
  border-color: var(--mn-teal-800, #115e59);
  color: var(--mn-fg-on-accent);
}

/* Dark theme adjustments */
[data-theme="dark"] .clickdummy-page { --cd-bezel-bg: #0a1424; --cd-bezel-chrome: #142035; }
[data-theme="dark"] .clickdummy-bezel-canvas { background: #1a1a1a; }

/* ═══ DEMO · HUBSPOT MEETINGS EMBED ═════════════════════════════════════ */

/* Brand-aligned header strip above the iframe */
.mn-meeting-strip {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  background: var(--mn-bg-sunken);
  border-bottom: 1px solid var(--mn-border-subtle);
  font-family: var(--mn-font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--mn-fg-3);
  flex-wrap: wrap;
}
.mn-meeting-strip strong { color: var(--mn-fg-1); }
.mn-meeting-strip-sep { color: var(--mn-fg-4); margin: 0 2px; }
.mn-meeting-strip-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--mn-fg-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--mn-fg-accent) 25%, transparent);
  animation: mn-meeting-pulse 2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes mn-meeting-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.55; transform: scale(0.92); }
}

.mn-meeting-mount { background: var(--mn-bg-surface); }

/* Iframe — full-bleed, fade-in once onLoad fires */
.mn-meeting-mount iframe {
  width: 100% !important;
  height: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  border: 0;
  display: block;
  opacity: 0;
  transition: opacity 360ms cubic-bezier(.4,0,.2,1) 60ms;
  z-index: 2;
}
.mn-meeting-mount[data-ready="1"] iframe { opacity: 1; }

/* Calendar-shaped loading skeleton (sits behind iframe, fades out on ready) */
.mn-meeting-skeleton {
  position: absolute;
  inset: 0;
  background: var(--mn-bg-surface);
  pointer-events: none;
  transition: opacity 280ms ease 60ms;
  z-index: 1;
  padding: 28px 32px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.mn-meeting-mount[data-ready="1"] .mn-meeting-skeleton { opacity: 0; }

.mn-meeting-sk-head { display: flex; gap: 16px; align-items: center; }
.mn-meeting-sk-avatar {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--mn-bg-sunken);
  flex-shrink: 0;
}
.mn-meeting-sk-lines { display: flex; flex-direction: column; gap: 8px; flex: 1; max-width: 320px; }
.mn-meeting-sk-line { height: 12px; background: var(--mn-bg-sunken); border-radius: 4px; }

.mn-meeting-sk-body {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 24px;
  flex: 1;
  min-height: 0;
}

.mn-meeting-sk-cal { display: flex; flex-direction: column; gap: 14px; }
.mn-meeting-sk-month {
  height: 18px;
  width: 140px;
  background: var(--mn-bg-sunken);
  border-radius: 4px;
}
.mn-meeting-sk-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;
}
.mn-meeting-sk-day {
  aspect-ratio: 1;
  background: var(--mn-bg-sunken);
  border-radius: 6px;
}

.mn-meeting-sk-slots { display: flex; flex-direction: column; gap: 10px; }
.mn-meeting-sk-slot {
  height: 38px;
  border-radius: 8px;
  background: var(--mn-bg-sunken);
  border: 1px solid var(--mn-border-subtle);
}

/* Subtle shimmer over all skeleton blocks */
.mn-meeting-skeleton .mn-meeting-sk-avatar,
.mn-meeting-skeleton .mn-meeting-sk-line,
.mn-meeting-skeleton .mn-meeting-sk-month,
.mn-meeting-skeleton .mn-meeting-sk-day,
.mn-meeting-skeleton .mn-meeting-sk-slot {
  position: relative;
  overflow: hidden;
}
.mn-meeting-skeleton .mn-meeting-sk-avatar::after,
.mn-meeting-skeleton .mn-meeting-sk-line::after,
.mn-meeting-skeleton .mn-meeting-sk-month::after,
.mn-meeting-skeleton .mn-meeting-sk-day::after,
.mn-meeting-skeleton .mn-meeting-sk-slot::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.55) 50%,
    transparent 100%
  );
  transform: translateX(-100%);
  animation: mn-meeting-shimmer 1.6s ease-in-out infinite;
}
@keyframes mn-meeting-shimmer {
  to { transform: translateX(100%); }
}

[data-theme="dark"] .mn-meeting-skeleton .mn-meeting-sk-avatar::after,
[data-theme="dark"] .mn-meeting-skeleton .mn-meeting-sk-line::after,
[data-theme="dark"] .mn-meeting-skeleton .mn-meeting-sk-month::after,
[data-theme="dark"] .mn-meeting-skeleton .mn-meeting-sk-day::after,
[data-theme="dark"] .mn-meeting-skeleton .mn-meeting-sk-slot::after {
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.06) 50%,
    transparent 100%
  );
}

/* Mobile: stack the skeleton vertically (cal on top, slots below) */
@media (max-width: 640px) {
  .mn-meeting-mount { height: 680px; }
  .mn-meeting-skeleton { padding: 20px; gap: 18px; }
  .mn-meeting-sk-body { grid-template-columns: 1fr; gap: 16px; }
  .mn-meeting-sk-slots { flex-direction: row; flex-wrap: wrap; }
  .mn-meeting-sk-slot { flex: 1 1 calc(50% - 6px); }
  .mn-meeting-strip { font-size: 10px; padding: 9px 16px; letter-spacing: 0.08em; }
}

/* ─── DEMO PAGE · 2-COL → 1-COL ─────────────────────────────────────────
   The demo page uses a sticky left aside + right scheduler. On narrow
   screens the 2-column grid was hard-coded inline, so the columns squashed
   into each other and the sticky aside z-stacked over the HubSpot iframe.
*/
.mn-demo-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 64px;
  align-items: start;
}
.mn-demo-aside { position: sticky; top: 100px; }

@media (max-width: 980px) {
  .mn-demo-grid { grid-template-columns: 1fr; gap: 32px; }
  .mn-demo-aside { position: static; top: auto; }
}

/* Phone: tighten the meeting card so HubSpot's iframe gets full bleed
   without 16-px gutters chewing into the calendar columns. */
@media (max-width: 640px) {
  .mn-demo-grid { gap: 24px; }
}

/* ─── HubSpot Forms embed (Demo · #demo) — map HubSpot's classes onto
   MiraNext design tokens so the embedded form is visually identical to
   our hand-styled inputs. Form schema/validation/consent are configured
   in HubSpot UI; this is purely visual. ─── */
.mn-hs-form-host {
  font-family: var(--mn-font-sans);
  color: var(--mn-fg-1);
}
.mn-hs-form-host form,
.mn-hs-form-host .hs-form {
  background: transparent;
  margin: 0;
}
.mn-hs-form-host fieldset {
  max-width: none !important;
  border: 0;
  padding: 0;
  margin: 0;
}
.mn-hs-form-host .hs-form-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}
.mn-hs-form-host .hs-form-field > label {
  font-size: 12px;
  font-weight: 600;
  color: var(--mn-fg-2);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.mn-hs-form-host .hs-form-required {
  color: var(--mn-fg-accent);
  margin-left: 2px;
}
.mn-hs-form-host .hs-field-desc {
  font-size: 12px;
  color: var(--mn-fg-3);
  margin: 4px 0 0;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 400;
}
.mn-hs-form-host .hs-input,
.mn-hs-form-host input[type="text"],
.mn-hs-form-host input[type="email"],
.mn-hs-form-host input[type="tel"],
.mn-hs-form-host input[type="number"],
.mn-hs-form-host input[type="url"],
.mn-hs-form-host select {
  height: 44px;
  padding: 0 14px;
  border: 1px solid var(--mn-border-default);
  border-radius: 6px;
  background: var(--mn-bg-surface);
  font-family: var(--mn-font-sans);
  font-size: 14px;
  color: var(--mn-fg-1);
  outline: none;
  transition: border-color 120ms, box-shadow 120ms;
  width: 100%;
  box-sizing: border-box;
}
.mn-hs-form-host textarea.hs-input,
.mn-hs-form-host textarea {
  height: auto;
  min-height: 96px;
  padding: 12px 14px;
  background: var(--mn-bg-canvas);
  resize: vertical;
  font-family: var(--mn-font-sans);
  font-size: 14px;
  color: var(--mn-fg-1);
  border: 1px solid var(--mn-border-default);
  border-radius: 6px;
  width: 100%;
  box-sizing: border-box;
  outline: none;
  transition: border-color 120ms, box-shadow 120ms;
}
.mn-hs-form-host .hs-input:focus,
.mn-hs-form-host input:focus,
.mn-hs-form-host select:focus,
.mn-hs-form-host textarea:focus {
  border-color: var(--mn-border-focus);
  box-shadow: var(--mn-shadow-focus);
}
.mn-hs-form-host .hs-input.invalid,
.mn-hs-form-host .hs-input.error,
.mn-hs-form-host .invalid.hs-input {
  border-color: #c53030;
}
.mn-hs-form-host .hs-error-msgs,
.mn-hs-form-host .hs-error-msg {
  list-style: none;
  margin: 6px 0 0;
  padding: 0;
  font-size: 12px;
  color: #c53030;
}
.mn-hs-form-host .hs-error-msgs label {
  color: #c53030;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 500;
}
.mn-hs-form-host .hs_submit,
.mn-hs-form-host .actions {
  margin-top: 24px;
}
.mn-hs-form-host .hs-button,
.mn-hs-form-host input[type="submit"],
.mn-hs-form-host button[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 48px;
  padding: 0 22px;
  border-radius: 6px;
  border: 1px solid transparent;
  background: var(--mn-bg-accent);
  color: var(--mn-fg-on-accent);
  font-family: var(--mn-font-sans);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: background 160ms var(--mn-ease-standard);
  -webkit-appearance: none;
  appearance: none;
}
.mn-hs-form-host .hs-button:hover,
.mn-hs-form-host input[type="submit"]:hover,
.mn-hs-form-host button[type="submit"]:hover {
  background: var(--mn-teal-800);
}
.mn-hs-form-host .hs-button:focus-visible,
.mn-hs-form-host input[type="submit"]:focus-visible {
  outline: none;
  box-shadow: var(--mn-shadow-focus);
}
.mn-hs-form-host .legal-consent-container {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--mn-border-subtle);
  font-size: 12px;
  color: var(--mn-fg-3);
  line-height: 1.5;
}
.mn-hs-form-host .legal-consent-container p,
.mn-hs-form-host .legal-consent-container span {
  font-size: 12px;
  color: var(--mn-fg-3);
  line-height: 1.5;
}
.mn-hs-form-host .legal-consent-container .hs-form-booleancheckbox-display,
.mn-hs-form-host .legal-consent-container label {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  font-size: 13px;
  color: var(--mn-fg-2);
  cursor: pointer;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 400;
}
.mn-hs-form-host .legal-consent-container input[type="checkbox"] {
  margin-top: 2px;
  accent-color: var(--mn-fg-accent);
  width: 16px;
  height: 16px;
}
.mn-hs-form-host .form-columns-2,
.mn-hs-form-host .form-columns-3 {
  display: grid;
  gap: 12px;
}
.mn-hs-form-host .form-columns-2 { grid-template-columns: 1fr 1fr; }
.mn-hs-form-host .form-columns-3 { grid-template-columns: 1fr 1fr 1fr; }
.mn-hs-form-host .form-columns-2 .hs-form-field,
.mn-hs-form-host .form-columns-3 .hs-form-field { width: 100% !important; }
@media (max-width: 640px) {
  .mn-hs-form-host .form-columns-2,
  .mn-hs-form-host .form-columns-3 { grid-template-columns: 1fr; }
}
.mn-hs-form-host .submitted-message,
.mn-hs-form-host .hs-submitted-message {
  text-align: center;
  padding: 32px 0;
  font-size: 15px;
  color: var(--mn-fg-2);
  line-height: 1.6;
}
.mn-hs-form-host .submitted-message h1,
.mn-hs-form-host .submitted-message h2,
.mn-hs-form-host .submitted-message h3,
.mn-hs-form-host .hs-submitted-message h1,
.mn-hs-form-host .hs-submitted-message h2,
.mn-hs-form-host .hs-submitted-message h3 {
  font-size: 22px;
  font-weight: 600;
  color: var(--mn-fg-brand);
  margin: 0 0 12px;
  letter-spacing: -0.015em;
}

/* ═══════════════════════════════════════════════════════════════════
   Platform Configurator (`#configurator`)
   Live scope-builder — modules + practice context + integrations
   on the left, sticky outcome panel on the right that updates as the
   user toggles inputs. DS-v4 teal accents, navy headings, paper bg.
   ═══════════════════════════════════════════════════════════════════ */

.mn-cfg-main {
  background: var(--mn-bg-canvas);
}

.mn-cfg-hero {
  padding-top: 120px;
  padding-bottom: 36px;
  background: var(--mn-bg-sunken);
  border-bottom: 1px solid var(--mn-border-subtle);
}
.mn-cfg-title {
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.04;
  letter-spacing: -0.025em;
  font-weight: 600;
  color: var(--mn-fg-brand);
  margin: 20px 0 20px;
  text-wrap: balance;
  max-width: 1100px;
}
.mn-cfg-title em {
  font-style: normal;
  color: var(--mn-fg-accent);
}
.mn-cfg-lede {
  font-size: 20px;
  line-height: 1.5;
  color: var(--mn-fg-2);
  max-width: 760px;
  margin: 0;
}

.mn-cfg-body {
  padding-top: 56px;
  padding-bottom: 96px;
}
.mn-cfg-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(360px, 1fr);
  gap: 48px;
  align-items: start;
}
@media (max-width: 1080px) {
  .mn-cfg-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

.mn-cfg-inputs {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.mn-cfg-step {
  border-top: 1px solid var(--mn-border-subtle);
  padding-top: 28px;
}
.mn-cfg-step:first-child { border-top: 0; padding-top: 0; }
.mn-cfg-step-head {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 20px;
}
.mn-cfg-step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 38px;
  padding: 0 10px;
  border-radius: 8px;
  background: var(--mn-fg-brand);
  color: #fff;
  font-family: var(--mn-font-mono, ui-monospace, monospace);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.mn-cfg-step-title {
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.2;
  letter-spacing: -0.015em;
  font-weight: 600;
  color: var(--mn-fg-brand);
  margin: 0 0 4px;
}
.mn-cfg-step-hint {
  font-size: 13px;
  color: var(--mn-fg-3);
  margin: 0;
  line-height: 1.5;
}

/* ─── Module cards ──────────────────────────────────────────────── */
.mn-cfg-module-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 720px) {
  .mn-cfg-module-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 440px) {
  .mn-cfg-module-grid { grid-template-columns: 1fr; }
}
.mn-cfg-mod {
  position: relative;
  display: flex;
  flex-direction: column;
  text-align: left;
  padding: 18px 18px 16px;
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-default);
  border-radius: 14px;
  cursor: pointer;
  transition: border-color 160ms ease, background 160ms ease, transform 160ms ease, box-shadow 160ms ease;
  font-family: inherit;
  min-height: 138px;
}
.mn-cfg-mod:hover {
  border-color: var(--mn-teal-500);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px -16px rgba(15, 28, 52, 0.18);
}
.mn-cfg-mod.is-on {
  background: var(--mn-teal-50);
  border-color: var(--mn-teal-700);
  box-shadow: inset 0 0 0 1px var(--mn-teal-700), 0 12px 28px -20px rgba(19, 181, 166, 0.55);
}
.mn-cfg-mod-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.mn-cfg-mod-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--mn-bg-sunken);
  color: var(--mn-fg-brand);
  font-family: var(--mn-font-mono, ui-monospace, monospace);
  font-size: 13px;
  font-weight: 600;
}
.mn-cfg-mod.is-on .mn-cfg-mod-icon {
  background: var(--mn-fg-brand);
  color: #fff;
}
.mn-cfg-mod-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 1px solid var(--mn-border-default);
  background: var(--mn-bg-surface);
  color: var(--mn-fg-3);
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
}
.mn-cfg-mod.is-on .mn-cfg-mod-check {
  background: var(--mn-teal-700);
  border-color: var(--mn-teal-700);
  color: #fff;
}
.mn-cfg-mod-name {
  font-size: 15px;
  line-height: 1.25;
  font-weight: 600;
  color: var(--mn-fg-brand);
  letter-spacing: -0.005em;
  margin-bottom: 4px;
}
.mn-cfg-mod-tag {
  font-size: 12px;
  line-height: 1.4;
  color: var(--mn-fg-3);
}

/* ─── Practice pills ───────────────────────────────────────────── */
.mn-cfg-field {
  margin-bottom: 18px;
}
.mn-cfg-field:last-child { margin-bottom: 0; }
.mn-cfg-field-label {
  display: block;
  font-family: var(--mn-font-mono, ui-monospace, monospace);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mn-fg-3);
  margin-bottom: 10px;
}
.mn-cfg-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.mn-cfg-pill {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-default);
  border-radius: 999px;
  color: var(--mn-fg-2);
  font-family: inherit;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 140ms ease, background 140ms ease, color 140ms ease;
}
.mn-cfg-pill:hover {
  border-color: var(--mn-teal-500);
  color: var(--mn-fg-brand);
}
.mn-cfg-pill.is-on {
  background: var(--mn-fg-brand);
  border-color: var(--mn-fg-brand);
  color: #fff;
}
.mn-cfg-pill-wide { min-width: 0; }

/* ─── Outcome panel (sticky right) ─────────────────────────────── */
.mn-cfg-outcome {
  position: sticky;
  top: 96px;
}
@media (max-width: 1080px) {
  .mn-cfg-outcome { position: static; }
}
.mn-cfg-outcome-card {
  background: var(--mn-fg-brand);
  color: var(--mn-fg-on-brand);
  border-radius: 16px;
  padding: 28px 28px 24px;
  box-shadow: 0 30px 80px -32px rgba(11, 37, 69, 0.55);
  border: 1px solid var(--mn-navy-700);
  position: relative;
  overflow: hidden;
}
.mn-cfg-outcome-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 100% 0%, rgba(19,181,166,0.18), transparent 55%),
    radial-gradient(circle at 0% 100%, rgba(201,168,106,0.10), transparent 50%);
  pointer-events: none;
}
.mn-cfg-outcome-card > * { position: relative; }
.mn-cfg-outcome-card .kicker {
  color: var(--mn-teal-300);
}
.mn-cfg-outcome-card .kicker-num {
  color: rgba(255,255,255,0.5);
}
.mn-cfg-outcome-title {
  font-size: clamp(24px, 2vw, 30px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: 600;
  color: #fff;
  margin: 4px 0 20px;
}

.mn-cfg-counters {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 0 0 18px;
  padding: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
}
.mn-cfg-counter {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
}
.mn-cfg-counter-v {
  font-size: 28px;
  line-height: 1;
  font-weight: 600;
  color: var(--mn-teal-300);
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.mn-cfg-counter-l {
  margin-top: 6px;
  font-family: var(--mn-font-mono, ui-monospace, monospace);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

.mn-cfg-punch {
  font-size: 15px;
  line-height: 1.5;
  color: var(--mn-navy-100);
  margin: 0 0 18px;
  text-wrap: balance;
}

.mn-cfg-effects {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 18px;
}
.mn-cfg-effect {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  padding: 6px 12px;
  background: rgba(19,181,166,0.16);
  border: 1px solid rgba(19,181,166,0.32);
  border-radius: 999px;
  font-size: 12px;
}
.mn-cfg-effect b {
  font-size: 13px;
  font-weight: 600;
  color: var(--mn-teal-300);
  letter-spacing: -0.005em;
}
.mn-cfg-effect span {
  color: rgba(255,255,255,0.78);
  letter-spacing: 0.02em;
}

.mn-cfg-caps {
  margin: 0 0 20px;
}
.mn-cfg-caps-label {
  font-family: var(--mn-font-mono, ui-monospace, monospace);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  margin-bottom: 10px;
}
.mn-cfg-caps-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mn-cfg-cap {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 12px;
  font-size: 13px;
  line-height: 1.45;
  color: rgba(255,255,255,0.88);
  animation: mnCfgCapIn 220ms ease-out both;
}
@keyframes mnCfgCapIn {
  from { opacity: 0; transform: translateY(4px); }
  to { opacity: 1; transform: none; }
}
.mn-cfg-cap-tag {
  font-family: var(--mn-font-mono, ui-monospace, monospace);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--mn-teal-300);
  align-self: start;
  padding-top: 1px;
}
.mn-cfg-cap-text {
  color: rgba(255,255,255,0.88);
}

.mn-cfg-empty-hint {
  font-size: 13px;
  color: rgba(255,255,255,0.55);
  font-style: italic;
  margin: 0 0 20px;
  padding: 14px;
  border: 1px dashed rgba(255,255,255,0.16);
  border-radius: 10px;
}

.mn-cfg-outcome-cta {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 4px;
}
.mn-cfg-outcome-cta .btn {
  width: 100%;
  justify-content: center;
}
.mn-cfg-outcome-cta .btn-ghost {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.22);
  color: rgba(255,255,255,0.88);
}
.mn-cfg-outcome-cta .btn-ghost:hover {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.32);
  color: #fff;
}
.mn-cfg-share-note {
  margin: 16px 0 0;
  font-size: 11px;
  line-height: 1.5;
  color: rgba(255,255,255,0.5);
  font-family: var(--mn-font-mono, ui-monospace, monospace);
  letter-spacing: 0.02em;
}

/* ─── Form (last step) ─────────────────────────────────────────── */
.mn-cfg-form {
  border: 1px solid var(--mn-border-default);
  border-radius: 14px;
  padding: 24px;
  background: var(--mn-bg-surface);
}
.mn-cfg-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.mn-cfg-input {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.mn-cfg-input-wide { grid-column: 1 / -1; }
.mn-cfg-input span {
  font-family: var(--mn-font-mono, ui-monospace, monospace);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mn-fg-3);
}
.mn-cfg-input input,
.mn-cfg-input textarea {
  font-family: inherit;
  font-size: 14px;
  line-height: 1.45;
  padding: 10px 12px;
  background: var(--mn-bg-canvas);
  color: var(--mn-fg-1);
  border: 1px solid var(--mn-border-default);
  border-radius: 8px;
  transition: border-color 140ms ease, box-shadow 140ms ease;
  resize: vertical;
}
.mn-cfg-input input:focus,
.mn-cfg-input textarea:focus {
  outline: none;
  border-color: var(--mn-teal-700);
  box-shadow: 0 0 0 3px rgba(19,181,166,0.18);
}
.mn-cfg-consent {
  font-size: 11px;
  line-height: 1.55;
  color: var(--mn-fg-3);
  margin: 14px 0 12px;
}
.mn-cfg-error {
  margin: 0 0 12px;
  padding: 10px 12px;
  background: var(--mn-critical-bg);
  color: var(--mn-critical-fg);
  border-radius: 8px;
  font-size: 13px;
}
.mn-cfg-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.mn-cfg-success {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 24px;
  background: var(--mn-success-bg);
  border: 1px solid var(--mn-success-fg);
  border-radius: 14px;
}
.mn-cfg-success-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--mn-success-fg);
  color: #fff;
  font-size: 22px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.mn-cfg-success-text {
  margin: 0;
  font-size: 15px;
  line-height: 1.5;
  color: var(--mn-success-fg);
}

@media (max-width: 720px) {
  .mn-cfg-form-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════
   Shared ContactForm — used by #configurator (Step 04) and #demo
   (Eckdaten tab). Custom form gated by Cloudflare Turnstile, submits
   via HubSpot Forms v3 Submissions API.
   ═══════════════════════════════════════════════════════════════════ */

.mn-cf-form {
  border: 1px solid var(--mn-border-default);
  border-radius: 14px;
  padding: 24px;
  background: var(--mn-bg-surface);
}
.mn-cf-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 640px) {
  .mn-cf-grid { grid-template-columns: 1fr; }
}
.mn-cf-input {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.mn-cf-input-wide { grid-column: 1 / -1; }
.mn-cf-input > span {
  font-family: var(--mn-font-mono, ui-monospace, monospace);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mn-fg-3);
}
.mn-cf-input input,
.mn-cf-input textarea {
  font-family: inherit;
  font-size: 14px;
  line-height: 1.45;
  padding: 10px 12px;
  background: var(--mn-bg-canvas);
  color: var(--mn-fg-1);
  border: 1px solid var(--mn-border-default);
  border-radius: 8px;
  transition: border-color 140ms ease, box-shadow 140ms ease;
  resize: vertical;
}
.mn-cf-input input:focus,
.mn-cf-input textarea:focus {
  outline: none;
  border-color: var(--mn-teal-700);
  box-shadow: 0 0 0 3px rgba(19,181,166,0.18);
}

.mn-cf-turnstile {
  margin: 16px 0 4px;
  min-height: 65px;
  display: flex;
  align-items: center;
}

.mn-cf-consent {
  font-size: 11px;
  line-height: 1.55;
  color: var(--mn-fg-3);
  margin: 14px 0 12px;
}

.mn-cf-error {
  margin: 0 0 12px;
  padding: 10px 12px;
  background: var(--mn-critical-bg);
  color: var(--mn-critical-fg);
  border-radius: 8px;
  font-size: 13px;
  line-height: 1.45;
}

.mn-cf-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.mn-cf-actions .btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.mn-cf-success {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 24px;
  background: var(--mn-success-bg);
  border: 1px solid var(--mn-success-fg);
  border-radius: 14px;
}
.mn-cf-success-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--mn-success-fg);
  color: #fff;
  font-size: 22px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.mn-cf-success-text {
  margin: 0 0 6px;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--mn-success-fg);
}
.mn-cf-success-sub {
  margin: 0;
  font-size: 13px;
  line-height: 1.5;
  color: var(--mn-fg-2);
}

/* ═══════════════════════════════════════════════════════════════════
   Newsroom inline charts — embedded via `::chart-<id>::` markdown directive.
   Currently: Doringer +14 % MRT chart in the MiraBook utilisation article.
   No absolute Y-axis numbers per editorial guideline.
   ═══════════════════════════════════════════════════════════════════ */

.mn-news-chart {
  margin: 28px 0 32px;
  padding: 22px 22px 18px;
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-subtle);
  border-radius: 12px;
  box-shadow: 0 10px 28px -20px rgba(11,37,69,0.18);
}
.mn-news-chart-head {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}
.mn-news-chart-kicker {
  font-family: var(--mn-font-mono, ui-monospace, monospace);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--mn-fg-accent);
}
.mn-news-chart-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--mn-fg-brand);
  letter-spacing: -0.005em;
}
.mn-news-chart-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 4px;
  font-size: 11px;
  color: var(--mn-fg-3);
}
.mn-news-chart-legend > span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.mn-news-chart-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 2px;
}
.mn-news-chart-dash {
  display: inline-block;
  width: 18px;
  height: 0;
  border-top: 2px dashed var(--mn-teal-700);
}
.mn-news-chart-foot {
  margin: 12px 0 0;
  font-family: var(--mn-font-mono, ui-monospace, monospace);
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--mn-fg-4);
  text-align: right;
}
@media (max-width: 640px) {
  .mn-news-chart { padding: 16px; }
  .mn-news-chart-legend { font-size: 10px; gap: 10px; }
}

/* ─────────────────── Newsletter subscribe form ──────────────────── */
.mn-subscribe {
  display: block;
}
.mn-subscribe-label {
  display: block;
  font-family: var(--mn-font-mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-fg-brand);
  margin-bottom: 8px;
}
.mn-subscribe-sub {
  font-size: 14px;
  line-height: 1.55;
  color: var(--mn-fg-2);
  margin: 0 0 14px;
}
.mn-subscribe-row {
  display: flex;
  gap: 8px;
  align-items: stretch;
  flex-wrap: wrap;
}
.mn-subscribe-input {
  flex: 1 1 220px;
  min-width: 200px;
  padding: 12px 14px;
  border: 1px solid var(--mn-border-default);
  border-radius: 8px;
  font-size: 14px;
  background: var(--mn-bg-surface);
  color: var(--mn-fg-1);
  font-family: inherit;
}
.mn-subscribe-input:focus {
  outline: none;
  border-color: var(--mn-fg-accent);
  box-shadow: 0 0 0 3px rgba(11, 138, 110, 0.12);
}
.mn-subscribe-input:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.mn-subscribe-btn {
  padding: 12px 22px;
  border: none;
  border-radius: 8px;
  background: var(--mn-bg-accent);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 160ms;
  font-family: inherit;
}
.mn-subscribe-btn:hover:not(:disabled) {
  background: var(--mn-fg-accent);
}
.mn-subscribe-btn:disabled {
  background: var(--mn-fg-3);
  cursor: not-allowed;
}
.mn-subscribe-fine {
  font-size: 12px;
  color: var(--mn-fg-3);
  margin: 10px 0 0;
  line-height: 1.5;
}
.mn-subscribe-err {
  font-size: 13px;
  color: #b91c1c;
  margin: 8px 0 0;
}
.mn-subscribe-success {
  font-size: 14px;
  line-height: 1.55;
  color: var(--mn-fg-brand);
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-fg-accent);
  border-radius: 8px;
  padding: 14px 16px;
  margin: 0;
}

/* Footer variant — tighter, smaller subheadings */
.mn-subscribe--footer .mn-subscribe-label {
  font-size: 11px;
  color: var(--mn-fg-2);
}
.mn-subscribe--footer .mn-subscribe-sub {
  font-size: 13px;
  margin-bottom: 10px;
}

/* Newsroom variant — slightly more presence */
.mn-subscribe--newsroom .mn-subscribe-label {
  font-size: 13px;
}
.mn-subscribe--newsroom .mn-subscribe-sub {
  font-size: 15px;
}

@media (max-width: 640px) {
  .mn-subscribe-row { flex-direction: column; }
  .mn-subscribe-input, .mn-subscribe-btn { width: 100%; }
}

/* ─────────────────── Webinar registration form ──────────────────── */
.mn-webinar {
  display: block;
  background: var(--mn-bg-surface);
  border: 1px solid var(--mn-border-default);
  border-radius: 12px;
  padding: 28px;
}
.mn-webinar-header {
  margin-bottom: 18px;
}
.mn-webinar-kicker {
  display: inline-block;
  font-family: var(--mn-font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  color: var(--mn-fg-accent);
  margin-bottom: 12px;
}
.mn-webinar-title {
  font-size: 22px;
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -0.015em;
  color: var(--mn-fg-brand);
  margin: 0 0 10px;
  text-wrap: balance;
}
.mn-webinar-meta {
  font-size: 14px;
  color: var(--mn-fg-2);
  margin: 0 0 0;
  line-height: 1.5;
}
.mn-webinar-row {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) minmax(180px, 2fr) auto;
  gap: 8px;
  margin-top: 14px;
}
.mn-webinar-input {
  padding: 12px 14px;
  border: 1px solid var(--mn-border-default);
  border-radius: 8px;
  font-size: 14px;
  background: var(--mn-bg-base);
  color: var(--mn-fg-1);
  font-family: inherit;
}
.mn-webinar-input:focus {
  outline: none;
  border-color: var(--mn-fg-accent);
  box-shadow: 0 0 0 3px rgba(11, 138, 110, 0.12);
}
.mn-webinar-input:disabled { opacity: 0.6; cursor: not-allowed; }
.mn-webinar-btn {
  padding: 12px 24px;
  border: none;
  border-radius: 8px;
  background: var(--mn-bg-accent);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  font-family: inherit;
  transition: background 160ms;
}
.mn-webinar-btn:hover:not(:disabled) { background: var(--mn-fg-accent); }
.mn-webinar-btn:disabled { background: var(--mn-fg-3); cursor: not-allowed; }
.mn-webinar-fine {
  font-size: 12px;
  color: var(--mn-fg-3);
  margin: 10px 0 0;
  line-height: 1.5;
}
.mn-webinar-err {
  font-size: 13px;
  color: #b91c1c;
  margin: 8px 0 0;
}
.mn-webinar--success {
  background: var(--mn-bg-surface);
  border-color: var(--mn-fg-accent);
}
.mn-webinar-success-headline {
  font-size: 18px;
  font-weight: 600;
  color: var(--mn-fg-brand);
  margin: 0 0 8px;
}
.mn-webinar-success-body {
  font-size: 14px;
  line-height: 1.55;
  color: var(--mn-fg-2);
  margin: 0 0 16px;
}
.mn-webinar-ics-btn {
  display: inline-block;
  padding: 10px 18px;
  border: 1px solid var(--mn-fg-accent);
  border-radius: 8px;
  color: var(--mn-fg-accent);
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
}
.mn-webinar-ics-btn:hover {
  background: var(--mn-fg-accent);
  color: #fff;
}

@media (max-width: 720px) {
  .mn-webinar-row { grid-template-columns: 1fr; }
  .mn-webinar-btn { width: 100%; }
}

/* ── Sticky webinar banner ─────────────────────────────────────────────── */
.mn-webinar-banner {
  position: sticky;
  top: 0;
  z-index: 90;
  background: linear-gradient(90deg, var(--mn-fg-brand) 0%, var(--mn-fg-accent) 100%);
  color: #fff;
  box-shadow: 0 2px 12px -4px rgba(15, 30, 60, 0.25);
}
.mn-webinar-banner-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 10px 24px;
  font-size: 14px;
  line-height: 1.4;
  flex-wrap: wrap;
}
.mn-webinar-banner-kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 3px 8px;
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.08);
  white-space: nowrap;
}
.mn-webinar-banner-body { flex: 1; min-width: 200px; }
.mn-webinar-banner-cta {
  color: #fff;
  font-weight: 700;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  white-space: nowrap;
}
.mn-webinar-banner-cta:hover { opacity: 0.85; }
.mn-webinar-banner-dismiss {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.35);
  color: #fff;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.mn-webinar-banner-dismiss:hover { background: rgba(255, 255, 255, 0.15); }

@media (max-width: 640px) {
  .mn-webinar-banner-inner { gap: 10px; padding: 10px 14px; font-size: 13px; }
  .mn-webinar-banner-kicker { font-size: 10px; }
}

/* ── Pörtschach booth landing page ─────────────────────────────────────── */
.mn-poertschach { background: var(--mn-bg-surface); }
.mn-poertschach-shell { max-width: 640px; margin: 0 auto; padding: 0 24px; }
.mn-poertschach-hero { padding: 56px 0 32px; }
.mn-poertschach-title {
  font-size: clamp(28px, 6vw, 40px);
  line-height: 1.15;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--mn-fg-brand);
  margin: 16px 0 12px;
}
.mn-poertschach-lede {
  font-size: 17px;
  line-height: 1.5;
  color: var(--mn-fg-2);
  margin: 0 0 24px;
}
.mn-poertschach-bullets {
  list-style: none;
  padding: 0;
  margin: 24px 0 0;
  display: grid;
  gap: 10px;
}
.mn-poertschach-bullets li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 15px;
  color: var(--mn-fg-1);
}
.mn-poertschach-bullet-icon {
  color: var(--mn-fg-accent);
  font-weight: 700;
  flex-shrink: 0;
}
.mn-poertschach-form-section {
  background: var(--mn-bg-sunken);
  padding: 40px 0 48px;
}
.mn-poertschach-form-title {
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--mn-fg-brand);
}
.mn-poertschach-form-sub {
  font-size: 14px;
  color: var(--mn-fg-2);
  margin: 0 0 20px;
}
.mn-poertschach-alt {
  padding: 40px 0 64px;
  text-align: center;
}
.mn-poertschach-alt-title {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--mn-fg-brand);
}
.mn-poertschach-alt-body {
  font-size: 14px;
  color: var(--mn-fg-2);
  margin: 0 0 20px;
  line-height: 1.5;
}
.mn-poertschach-meeting-btn { display: inline-block; }

@keyframes mn-spin { to { transform: rotate(360deg); } }
