/* ============================================================
   Marketing site UI kit — layout styles (Dispatch)
   Depends on ../../colors_and_type.css + ../../components.css
   ============================================================ */
* { box-sizing: border-box; }
html, body { margin: 0; background: var(--ink); }
body { font-family: var(--sans); color: var(--text-1); }
.mk-app { overflow-x: hidden; }
.mk-wrap { max-width: 1080px; margin: 0 auto; padding: 0 40px; }

/* ---------- NAV ---------- */
.mk-nav { position: sticky; top: 0; z-index: 50; transition: background .2s ease, border-color .2s ease; border-bottom: 0.5px solid transparent; }
.mk-nav--scrolled { background: rgba(10,13,11,0.72); backdrop-filter: blur(14px); border-bottom: 0.5px solid rgba(255,255,255,0.08); }
.mk-nav__inner { max-width: 1080px; margin: 0 auto; padding: 14px 40px; display: flex; align-items: center; gap: 28px; }
.mk-nav__brand { display: flex; align-items: center; }
.mk-nav__brand img { height: 30px; width: auto; }
.mk-nav__links { display: flex; gap: 26px; margin-left: 12px; }
.mk-nav__link { background: none; border: none; cursor: pointer; font-family: var(--sans); font-size: 14px; color: var(--text-3); transition: color .15s ease; }
.mk-nav__link:hover { color: var(--text-1); }
.mk-nav__cta { margin-left: auto; padding: 10px 18px; font-size: 14px; }

/* ---------- HERO ---------- */
.mk-hero { position: relative; padding: 86px 0 64px; }
.mk-hero__glow { top: -30px; }
.mk-hero__inner { position: relative; z-index: 1; max-width: 1080px; margin: 0 auto; padding: 0 40px; }
.mk-hero__title { margin: 18px 0 0; font-size: 62px; line-height: 1.02; }
.mk-hero__lead { max-width: 620px; margin: 22px 0 0; }
.mk-hero__actions { display: flex; align-items: center; gap: 8px; margin-top: 30px; }
.mk-hero__strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin-top: 44px; padding: 22px 28px; }
.mk-stat { padding: 0 8px; }
.mk-stat + .mk-stat { border-left: 0.5px solid rgba(255,255,255,0.10); padding-left: 28px; }
.mk-stat__fig { font-size: 26px; }
.mk-stat__cap { font-family: var(--sans); font-size: 13px; color: var(--text-3); margin-top: 6px; }
.mk-hero__live { margin-top: 26px; max-width: 460px; }

/* ---------- GENERIC SECTION ---------- */
.mk-section { position: relative; max-width: 1080px; margin: 0 auto; padding: 64px 40px; }
.mk-section__title { margin: 16px 0 0; max-width: 720px; }

/* ---------- MODEL ---------- */
.mk-model { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 34px; }
.mk-model__item { background: var(--gold-fill-08); }
.mk-model__t { font-family: var(--sans); font-weight: 600; font-size: 17px; color: var(--text-1); }
.mk-model__d { font-family: var(--sans); font-size: 14px; line-height: 1.6; color: var(--text-2); margin-top: 8px; }

/* ---------- ENGINE ---------- */
.mk-engine { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 34px; }
.mk-engine__t { font-family: var(--sans); font-weight: 600; font-size: 18px; color: var(--text-1); }
.mk-engine__d { font-family: var(--sans); font-size: 14px; line-height: 1.6; color: var(--text-3); margin-top: 6px; }

/* ---------- PROOF ---------- */
.mk-proof { overflow: hidden; }
.mk-proof__glow { right: -120px; bottom: -160px; }
.mk-proof__inner { position: relative; z-index: 1; }
.mk-proof__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 34px; }
.mk-proofcard { padding: 26px 26px; }
.mk-proofcard__fig { font-size: 34px; }
.mk-proofcard__cap { font-family: var(--sans); font-size: 14px; color: var(--text-3); margin-top: 10px; }
.mk-casestudy { margin-top: 16px; padding: 30px 32px; }
.mk-casestudy__label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; color: var(--gold-deep); }
.mk-casestudy__quote { font-family: var(--sans); font-size: 20px; line-height: 1.55; color: var(--text-1); margin: 14px 0 0; max-width: 760px; }

/* ---------- CTA ---------- */
.mk-cta { position: relative; padding: 80px 0; overflow: hidden; }
.mk-cta__glow { top: 0; }
.mk-cta__inner { position: relative; z-index: 1; max-width: 1080px; margin: 0 auto; padding: 0 40px; }
.mk-cta__title { margin: 16px 0 0; max-width: 720px; }
.mk-cta__lead { max-width: 560px; margin: 18px 0 0; }
.mk-cta__actions { display: flex; gap: 10px; margin-top: 28px; }

/* ---------- FOOTER ---------- */
.mk-footer { border-top: 0.5px solid rgba(255,255,255,0.08); }
.mk-footer__inner { max-width: 1080px; margin: 0 auto; padding: 30px 40px; display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.mk-footer__logo { height: 24px; width: auto; }
.mk-footer__meta { display: flex; gap: 10px; align-items: center; font-family: var(--sans); font-size: 13px; color: var(--text-4); flex-wrap: wrap; }
.mk-footer__dot { color: var(--text-4); opacity: .5; }

/* ---------- MODAL ---------- */
.mk-modal { position: fixed; inset: 0; z-index: 100; background: rgba(6,8,7,0.66); backdrop-filter: blur(6px); display: flex; align-items: center; justify-content: center; padding: 24px; }
.mk-modal__card { position: relative; width: 460px; max-width: 100%; overflow: hidden; padding: 34px 34px 30px; }
.mk-modal__glow { top: -90px; }
.mk-modal__close { position: absolute; top: 16px; right: 18px; background: none; border: none; color: var(--text-3); font-size: 14px; cursor: pointer; z-index: 2; transition: color .15s ease; }
.mk-modal__close:hover { color: var(--text-1); }
.mk-modal__body { position: relative; z-index: 1; }
.mk-modal__title { margin: 12px 0 0; }
.mk-modal__lead { font-family: var(--sans); font-size: 14px; line-height: 1.6; color: var(--text-3); margin: 8px 0 22px; }
.mk-field { display: block; margin-bottom: 16px; }
.mk-field__label { display: block; font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; color: var(--text-4); margin-bottom: 7px; text-transform: uppercase; }
.mk-input { width: 100%; font-family: var(--sans); font-size: 15px; color: var(--text-1); background: rgba(255,255,255,0.04); border: 0.5px solid rgba(255,255,255,0.16); border-radius: var(--r-button); padding: 11px 13px; outline: none; transition: border-color .15s ease, background .15s ease; }
.mk-input:focus { border-color: var(--gold-border); background: rgba(255,255,255,0.06); }
.mk-input--area { resize: none; line-height: 1.5; }
.mk-modal__next { width: 100%; justify-content: center; }
.mk-modal__row { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.mk-modal__done { text-align: center; }
.mk-modal__check { width: 48px; height: 48px; margin: 4px auto 4px; border-radius: 50%; background: var(--gold-fill-12); border: 0.5px solid var(--gold-border); color: var(--gold); font-size: 22px; display: flex; align-items: center; justify-content: center; }
.mk-modal__summary { margin: 18px 0 22px; text-align: left; }
.mk-modal__sumrow { display: flex; justify-content: space-between; font-family: var(--sans); font-size: 14px; color: var(--text-2); }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 860px) {
  .mk-nav__links { display: none; }
  .mk-hero__title { font-size: 44px; }
  .mk-hero__strip, .mk-model, .mk-engine, .mk-proof__stats { grid-template-columns: 1fr; }
  .mk-stat + .mk-stat { border-left: none; padding-left: 8px; }
}
