@import url("colors_and_type.css");

/* ─────────────────────────────────────────────────────────────
   SimplyBooked — Branding Landing Page
   Marketing page for prospective customers.
   ───────────────────────────────────────────────────────────── */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg-page);
  color: var(--fg-primary);
  font-family: var(--font-sans);
  overflow-x: hidden;
}

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

/* ── Top marketing nav ─────────────────────────────────── */
.mk-nav {
  position: sticky; top: 0; z-index: 40;
  display: flex; align-items: center;
  height: 64px; padding: 0 2rem;
  background: rgba(246, 250, 254, 0.85);
  backdrop-filter: none;
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur) var(--easing), background var(--dur) var(--easing);
}
.mk-nav.scrolled {
  background: rgba(246, 250, 254, 0.95);
  border-bottom: 1px solid var(--border-subtle);
}
.mk-nav__brand {
  display: flex; align-items: center; gap: .6rem;
  font-family: var(--font-bold); color: var(--main-color);
  font-size: 1.05rem; text-decoration: none;
}
.mk-nav__logo {
  width: 32px; height: 32px; border-radius: 7px;
  background: var(--gradient-primary-135);
  display: grid; place-items: center;
  color: #fff; font-family: var(--font-bold); font-size: .8rem;
  box-shadow: var(--shadow-sm);
}
.mk-nav__links { display: flex; gap: .25rem; margin-left: auto; align-items: center; }
.mk-nav__link {
  padding: .5rem .9rem; color: var(--fg-secondary);
  font-family: var(--font-medium); font-size: .88rem;
  text-decoration: none; border-radius: var(--radius-pill);
  transition: color var(--dur) var(--easing), background var(--dur) var(--easing);
}
.mk-nav__link:hover { color: var(--main-color); background: var(--bg-hover); }
.mk-nav__cta {
  margin-left: .5rem;
  padding: .55rem 1.25rem;
  background: var(--gradient-primary);
  color: #fff; font-family: var(--font-bold); font-size: .85rem;
  border-radius: var(--radius-pill);
  text-decoration: none;
  white-space: nowrap;
  box-shadow: var(--shadow-sm);
  transition: all var(--dur) var(--easing);
}
.mk-nav__cta:hover { opacity: .92; transform: translateY(-1px); box-shadow: var(--shadow-md); }

/* ── Section scaffolding ─────────────────────────────── */
.wrap { max-width: 1200px; margin: 0 auto; padding: 0 2rem; }
.section { padding: 6rem 0; position: relative; }
.section--tight { padding: 4rem 0; }

.eyebrow {
  font-family: var(--font-bold); font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: .12em;
  color: var(--main-color);
  margin: 0 0 1rem;
}

.h-display {
  font-family: var(--font-bold); font-weight: 900;
  font-size: clamp(2.2rem, 5vw, 3.75rem);
  line-height: 1.05; letter-spacing: -.02em;
  color: var(--fg-primary); margin: 0;
  text-wrap: balance;
}
.h-section {
  font-family: var(--font-bold); font-weight: 900;
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  line-height: 1.1; letter-spacing: -.015em;
  color: var(--fg-primary); margin: 0;
  text-wrap: balance;
}
.lede {
  font-family: var(--font-sans); font-size: 1.125rem;
  color: var(--fg-secondary); line-height: 1.55; margin: 0;
  max-width: 42rem; text-wrap: pretty;
}

/* ── Hero ──────────────────────────────────────────────── */
.hero {
  padding: 4.5rem 0 5rem;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(800px 400px at 15% 10%, rgba(0, 52, 134, .08), transparent 60%),
    radial-gradient(700px 500px at 85% 30%, rgba(0, 32, 89, .06), transparent 60%);
  pointer-events: none;
}
.hero__inner {
  position: relative;
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: 4rem; align-items: center;
}
.hero__copy { display: flex; flex-direction: column; gap: 1.5rem; }
.hero__eyebrow-pill {
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .4rem .85rem .4rem .4rem;
  background: #fff;
  border: 1.5px solid var(--border-subtle);
  border-radius: var(--radius-pill);
  font-family: var(--font-medium); font-size: .8rem;
  color: var(--fg-secondary);
  box-shadow: var(--shadow-sm);
}
.hero__eyebrow-pill .dot {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--gradient-primary-135);
  box-shadow: inset 0 0 0 2px #fff;
}
.hero__cta-row { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: .5rem; }

.hero__signals {
  display: flex; gap: 2.5rem; margin-top: 1.5rem;
  padding-top: 1.5rem; border-top: 1px solid var(--border-subtle);
}
.hero__signal-num {
  font-family: var(--font-bold); font-size: 1.65rem; color: var(--main-color); line-height: 1;
}
.hero__signal-lbl {
  font-family: var(--font-sans); font-size: .8rem; color: var(--fg-tertiary); margin-top: .35rem;
}

/* ── Buttons (reuse dashboard vocabulary) ──────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .85rem 1.75rem; border-radius: var(--radius-pill);
  font-family: var(--font-bold); font-size: var(--fs-md);
  border: none; cursor: pointer; text-decoration: none;
  white-space: nowrap;
  transition: all var(--dur) var(--easing);
}
.btn--primary {
  background: var(--gradient-primary); color: #fff;
  box-shadow: var(--shadow-lg);
}
.btn--primary:hover { transform: translateY(-1px); opacity: .95; }
.btn--primary:active { transform: scale(.97); }
.btn--secondary {
  background: transparent; color: var(--fg-secondary);
  border: 1.5px solid var(--border-color);
}
.btn--secondary:hover { color: var(--main-color); border-color: var(--main-color); background: #fff; }
.btn--ghost {
  background: transparent; color: var(--main-color);
  padding: .7rem 1.1rem;
}
.btn--ghost:hover { background: var(--bg-hover); }
.btn--sm { padding: .55rem 1.15rem; font-size: .85rem; }

/* ── Hero showcase stack ─────────────────────────────── */
.hero__showcase {
  position: relative;
  min-height: 620px;
}
.phone-card, .desktop-card {
  position: absolute;
  background: #fff;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  border: 1px solid var(--border-subtle);
}
/* Phone layer */
.phone-card {
  width: 260px; height: 560px;
  right: 0; top: 0;
  border-radius: 36px;
  padding: 10px;
  background: #1a1c1e;
  box-shadow: 0 30px 60px -10px rgb(0 0 0 / 30%), 0 18px 36px -12px rgb(0 0 0 / 25%);
  z-index: 3;
}
.phone-card__notch {
  position: absolute; top: 22px; left: 50%; transform: translateX(-50%);
  width: 90px; height: 24px; border-radius: 14px;
  background: #000; z-index: 4;
}
.phone-card__screen {
  width: 100%; height: 100%; border-radius: 28px;
  overflow: hidden; background: var(--bg-page);
  position: relative;
}

/* Desktop layer */
.desktop-card {
  width: 540px; height: 560px;
  left: 0; bottom: 0;
  transform: rotate(-2deg);
  padding: 0;
  z-index: 2;
}
.desktop-card__bar {
  display: flex; align-items: center; gap: .35rem;
  padding: .6rem .85rem; background: #eef1f5;
  border-bottom: 1px solid var(--border-subtle);
}
.desktop-card__bar span {
  width: 10px; height: 10px; border-radius: 50%;
  background: #d0d5dd;
}
.desktop-card__bar span:nth-child(1) { background: #ff5f57; }
.desktop-card__bar span:nth-child(2) { background: #febc2e; }
.desktop-card__bar span:nth-child(3) { background: #28c840; }
.desktop-card__url {
  margin-left: 1rem; flex: 1;
  background: #fff; border-radius: var(--radius-pill);
  padding: .35rem .8rem;
  font-family: var(--font-medium); font-size: .72rem; color: var(--fg-tertiary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.desktop-card__body { padding: 0; height: calc(100% - 36px); overflow: hidden; position: relative; }
.desktop-card__body::-webkit-scrollbar { display: none; }

/* Tenant chip floating labels */
.tenant-tag {
  position: absolute; z-index: 5;
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .5rem .85rem; background: #fff;
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-md);
  font-family: var(--font-bold); font-size: .78rem;
  color: var(--fg-primary);
  border: 1px solid var(--border-subtle);
}
.tenant-tag__swatch {
  width: 14px; height: 14px; border-radius: 50%;
  box-shadow: inset 0 0 0 2px #fff, 0 0 0 1px rgba(0,0,0,.05);
}
.tenant-tag--a { top: -12px; left: -8px; }
.tenant-tag--b { bottom: 6px; right: -10px; }

/* ── Tenant color themes (reused across page) ───────── */
.theme-meridian {
  --main-color: #002059;
  --secondary-color: #003486;
}
.theme-vogel {
  --main-color: #b14a2f;   /* terracotta */
  --secondary-color: #d97556;
}
.theme-evergreen {
  --main-color: #0f5c3a;
  --secondary-color: #1c7d51;
}
.theme-studio {
  --main-color: #3f2b7a;
  --secondary-color: #6246b3;
}

/* ── Mini preview components (used throughout) ───────── */
.mp-topbar {
  display: flex; align-items: center;
  height: 52px; padding: 0 .85rem;
  background: var(--bg-page);
  border-bottom: 1px solid var(--border-subtle);
}
.mp-topbar__logo {
  width: 28px; height: 28px; border-radius: 6px;
  background: var(--gradient-primary-135);
  color: #fff; display: grid; place-items: center;
  font-family: var(--font-bold); font-size: .7rem;
  flex-shrink: 0;
}
.mp-topbar__name {
  margin-left: .55rem; font-family: var(--font-bold); font-size: .8rem;
  color: var(--main-color);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mp-topbar__links { display: flex; gap: .6rem; margin-left: auto; }
.mp-topbar__link {
  font-family: var(--font-medium); font-size: .72rem;
  color: var(--fg-secondary); padding: .3rem 0;
  position: relative;
}
.mp-topbar__link.active {
  color: var(--fg-primary); font-family: var(--font-bold);
}
.mp-topbar__link.active::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -8px;
  height: 2px; background: var(--secondary-color); border-radius: 2px;
}
.mp-topbar__avatar {
  margin-left: .75rem;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--bg-muted); color: var(--main-color);
  display: grid; place-items: center;
  font-family: var(--font-bold); font-size: .6rem;
}

.mp-banner {
  margin: .75rem; height: 88px; border-radius: var(--radius-lg);
  position: relative; overflow: hidden;
  background: linear-gradient(120deg,
    color-mix(in oklab, var(--main-color) 70%, #666),
    color-mix(in oklab, var(--secondary-color) 40%, #eee));
}
.mp-banner::after {
  content: ""; position: absolute; inset: 0;
  background: var(--gradient-overlay-dark);
}
.mp-banner h3 {
  position: absolute; bottom: .75rem; left: 1rem;
  color: #fff; font-family: var(--font-bold); font-size: 1rem;
  text-shadow: 0 1px 3px rgb(0 0 0 / 25%);
  margin: 0; z-index: 1;
}

.mp-rcard {
  margin: .75rem; padding: .7rem .75rem;
  background: #fff; border: 1.5px solid #e8e8e8;
  border-radius: var(--radius-md);
  display: flex; align-items: center; gap: .65rem;
}
.mp-rcard__icon {
  width: 34px; height: 34px; border-radius: var(--radius-sm);
  background: #f0f4ff; color: var(--main-color);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.mp-rcard__thumb {
  width: 40px; height: 40px; border-radius: var(--radius-sm);
  background: var(--bg-muted) center/cover no-repeat;
  flex-shrink: 0;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.04);
}
.mp-rcard__text { flex: 1; min-width: 0; }
.mp-rcard__name {
  font-family: var(--font-bold); font-size: .82rem; color: var(--fg-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mp-rcard__time {
  font-family: var(--font-sans); font-size: .7rem; color: var(--fg-tertiary);
  display: flex; align-items: center; gap: .3rem; margin-top: .15rem;
}
.mp-rcard__dismiss {
  width: 1.4rem; height: 1.4rem; border-radius: 50%; border: none;
  background: var(--danger-bg); color: var(--danger-soft);
  font-size: .9rem; line-height: 1; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

/* Create-a-booking flow (desktop mock) */
.mp-hero {
  margin: .6rem .75rem;
  height: 96px; border-radius: var(--radius-md);
  background: #eef1f5 center/cover no-repeat;
  position: relative; overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.04);
}
.mp-hero::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.55));
}
.mp-hero h3 {
  position: absolute; bottom: .6rem; left: .9rem;
  color: #fff; font-family: var(--font-bold); font-size: 1rem;
  text-shadow: 0 1px 3px rgb(0 0 0 / 35%);
  margin: 0; z-index: 1;
}
.mp-form {
  padding: 0 .9rem .9rem;
  display: flex; flex-direction: column; gap: .7rem;
}
.mp-form__group { display: flex; flex-direction: column; gap: .35rem; }
.mp-eyebrow {
  font-family: var(--font-bold); font-size: .72rem;
  color: var(--main-color);
}
.mp-chip-row { display: flex; flex-wrap: wrap; gap: .3rem; }
.mp-chip {
  padding: .28rem .65rem; border-radius: var(--radius-pill);
  background: #fff; border: 1.5px solid var(--border-color);
  font-family: var(--font-medium); font-size: .7rem; color: var(--fg-secondary);
  white-space: nowrap;
}
.mp-chip.is-selected {
  background: var(--main-color); border-color: var(--main-color);
  color: #fff; font-family: var(--font-bold);
}
.mp-slot-grid {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .35rem;
}
.mp-slot {
  padding: .5rem .25rem; border-radius: var(--radius-md);
  background: #fff; border: 1.5px solid var(--border-color);
  font-family: var(--font-bold); font-size: .75rem; color: var(--fg-primary);
  text-align: center;
  display: inline-flex; align-items: center; justify-content: center; gap: .3rem;
}
.mp-slot.is-selected {
  background: var(--main-color); border-color: var(--main-color); color: #fff;
}
.mp-slot.is-selected [data-lucide] svg { width: 11px; height: 11px; }
.mp-slot.is-unavailable {
  color: var(--fg-muted); background: var(--bg-page);
  border-style: dashed; text-decoration: line-through; opacity: .6;
}
.mp-room {
  display: flex; align-items: center; gap: .6rem;
  padding: .5rem .65rem; border-radius: var(--radius-md);
  background: #fff; border: 1.5px solid var(--border-color);
  margin-bottom: .3rem;
}
.mp-room.is-selected {
  border-color: var(--main-color);
  background: color-mix(in oklab, var(--main-color) 6%, #fff);
  box-shadow: inset 0 0 0 1px var(--main-color);
}
.mp-room__thumb {
  width: 36px; height: 36px; border-radius: var(--radius-sm);
  background: var(--bg-muted) center/cover no-repeat;
  flex-shrink: 0;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.05);
}
.mp-room__text { flex: 1; min-width: 0; }
.mp-room__name {
  font-family: var(--font-bold); font-size: .78rem; color: var(--fg-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mp-room__alias {
  font-family: var(--font-medium); color: var(--fg-tertiary); font-weight: 400;
}
.mp-room__sub {
  font-family: var(--font-sans); font-size: .66rem; color: var(--fg-tertiary);
  margin-top: .1rem;
}
.mp-room__check {
  color: var(--main-color); flex-shrink: 0;
}
.mp-room__check svg { width: 16px; height: 16px; stroke-width: 2.5; }
.mp-book-fab {
  position: absolute; bottom: .9rem; left: 50%; transform: translateX(-50%);
  padding: .55rem 1.15rem; border-radius: var(--radius-pill);
  background: var(--main-color); color: #fff;
  font-family: var(--font-bold); font-size: .78rem;
  box-shadow: 0 12px 28px -10px rgba(0,0,0,.4), 0 6px 14px -6px rgba(0,0,0,.25);
  display: inline-flex; align-items: center; gap: .3rem;
  white-space: nowrap; z-index: 5;
}
.mp-book-fab svg { width: 14px; height: 14px; }

.mp-mini-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: .55rem 1.1rem; border-radius: var(--radius-pill);
  font-family: var(--font-bold); font-size: .75rem;
  border: none; cursor: pointer; text-decoration: none;
  background: var(--gradient-primary); color: #fff;
  box-shadow: var(--shadow-sm);
}

/* Phone-embedded mini-app */
.phone-app { display: flex; flex-direction: column; height: 100%; font-family: var(--font-sans); }
.phone-app__status {
  display: flex; align-items: center; justify-content: space-between;
  padding: .8rem 1.25rem .35rem;
  font-family: var(--font-bold); font-size: .7rem; color: var(--fg-primary);
}
.phone-app__status-icons { display: flex; gap: .25rem; font-size: .65rem; }
.phone-app__header {
  display: flex; align-items: center; gap: .5rem;
  padding: .3rem .9rem .6rem;
}
.phone-app__logo {
  width: 22px; height: 22px; border-radius: 4px;
  background: var(--gradient-primary-135);
  display: grid; place-items: center;
  color: #fff; font-family: var(--font-bold); font-size: .6rem;
}
.phone-app__orgname {
  font-family: var(--font-bold); font-size: .8rem; color: var(--main-color);
}
.phone-app__scroll {
  flex: 1; overflow: hidden;
  background: var(--bg-page);
  display: flex; flex-direction: column;
}
.phone-app__tabbar {
  display: flex; padding: .5rem .5rem calc(.5rem + env(safe-area-inset-bottom));
  background: #fff; border-top: 1px solid var(--border-subtle);
  gap: .25rem;
}
.phone-app__tab {
  flex: 1; display: flex; flex-direction: column; align-items: center; gap: .2rem;
  padding: .35rem 0 .15rem;
  font-family: var(--font-medium); font-size: .58rem;
  color: var(--fg-tertiary);
}
.phone-app__tab.active { color: var(--main-color); font-family: var(--font-bold); }
.phone-app__tab [data-lucide] { font-size: 1.05rem; }
.phone-app__tab [data-lucide] svg { width: 18px; height: 18px; stroke-width: 2; }

.phone-app__title {
  font-family: var(--font-bold); font-size: 1rem;
  color: var(--fg-primary); margin: .75rem .85rem .25rem;
}
.phone-app__sub {
  font-family: var(--font-sans); font-size: .7rem;
  color: var(--fg-tertiary); margin: 0 .85rem .5rem;
}

.phone-fab {
  position: absolute; bottom: 72px; left: 50%; transform: translateX(-50%);
  padding: .55rem 1.2rem; border-radius: var(--radius-pill);
  background: var(--gradient-primary); color: #fff;
  font-family: var(--font-bold); font-size: .75rem;
  box-shadow: var(--shadow-fab);
  display: inline-flex; align-items: center; gap: .35rem;
  white-space: nowrap;
}

/* ── Section 2 — The swap (token → rendered) ─────────── */
.swap {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 3.5rem;
  align-items: center;
}
.swap__tokens {
  background: #fff; border-radius: var(--radius-xl);
  padding: 1.75rem; box-shadow: var(--shadow-md);
  border: 1px solid var(--border-subtle);
}
.swap__tokens h4 {
  font-family: var(--font-bold); font-size: .7rem;
  text-transform: uppercase; letter-spacing: .12em;
  color: var(--fg-muted); margin: 0 0 1rem;
}
.token-row { display: flex; align-items: center; gap: .8rem; padding: .65rem 0; border-bottom: 1px dashed var(--border-subtle); }
.token-row:last-child { border-bottom: none; }
.token-row__label {
  width: 88px; font-family: var(--font-bold); font-size: .68rem;
  color: var(--fg-muted); text-transform: uppercase; letter-spacing: .08em;
}
.token-row__value {
  flex: 1; font-family: var(--font-medium); font-size: .85rem;
  color: var(--fg-primary);
  display: flex; align-items: center; gap: .6rem;
}
.token-swatch {
  width: 22px; height: 22px; border-radius: 6px;
  box-shadow: inset 0 0 0 2px #fff, 0 0 0 1.5px var(--border-color);
  flex-shrink: 0;
}
.token-logo {
  width: 30px; height: 30px; border-radius: 7px;
  background: var(--gradient-primary-135);
  display: grid; place-items: center;
  color: #fff; font-family: var(--font-bold); font-size: .75rem;
  flex-shrink: 0;
}

.token-row__mono { font-family: ui-monospace, Menlo, monospace; font-size: .8rem; color: var(--fg-secondary); }

.swap__arrow {
  display: none;
}

/* Result grid — 2 tenants rendered with the same components */
.swap__results {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem;
}
.tenant-frame {
  background: #fff; border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--border-subtle);
  overflow: hidden;
  display: flex; flex-direction: column;
}
.tenant-frame__chrome {
  display: flex; align-items: center; gap: .35rem;
  padding: .55rem .75rem;
  background: #f3f5f8;
  border-bottom: 1px solid var(--border-subtle);
}
.tenant-frame__chrome span {
  width: 8px; height: 8px; border-radius: 50%; background: #d0d5dd;
}
.tenant-frame__chrome span:nth-child(1) { background: #ff5f57; }
.tenant-frame__chrome span:nth-child(2) { background: #febc2e; }
.tenant-frame__chrome span:nth-child(3) { background: #28c840; }
.tenant-frame__chrome-url {
  margin-left: .6rem; font-family: var(--font-medium); font-size: .7rem;
  color: var(--fg-tertiary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.tenant-frame__body { padding: 0; }

/* ── Features grid ──────────────────────────────────── */
.features {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
  margin-top: 3rem;
}
.feature-card {
  background: #fff; border-radius: var(--radius-xl);
  padding: 1.75rem;
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column; gap: .85rem;
  transition: transform var(--dur) var(--easing), box-shadow var(--dur) var(--easing);
}
.feature-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}
.feature-card__icon {
  width: 44px; height: 44px; border-radius: var(--radius-md);
  background: var(--bg-muted);
  color: var(--main-color);
  display: grid; place-items: center;
  font-size: 1.4rem;
}
.feature-card h3 {
  font-family: var(--font-bold); font-size: 1.05rem;
  color: var(--fg-primary); margin: 0;
}
.feature-card p {
  font-family: var(--font-sans); font-size: .9rem;
  color: var(--fg-secondary); line-height: 1.5; margin: 0;
}

/* ── Customization panel (mock admin settings) ─────── */
.settings {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 2.5rem; align-items: stretch;
}
.settings__panel {
  background: #fff; border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--border-subtle);
  overflow: hidden;
  display: flex; flex-direction: column;
}
.settings__panel-head {
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--border-subtle);
  display: flex; align-items: baseline; justify-content: space-between;
}
.settings__panel-head h4 {
  font-family: var(--font-bold); font-size: 1rem; color: var(--fg-primary); margin: 0;
}
.settings__panel-head .crumb {
  font-family: var(--font-medium); font-size: .75rem; color: var(--fg-tertiary);
}
.settings__body { padding: 1.5rem; display: flex; flex-direction: column; gap: 1.5rem; }

.field-row { display: flex; flex-direction: column; gap: .35rem; }
.field-row .label {
  font-family: var(--font-bold); font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: .08em; color: var(--fg-muted);
}
.field-row .hint {
  font-family: var(--font-sans); font-size: .75rem; color: var(--fg-tertiary);
  margin-top: .1rem;
}
.fake-input {
  padding: .7rem .85rem;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--bg-page);
  font-family: var(--font-sans); font-size: var(--fs-md);
  color: var(--fg-primary);
  display: flex; align-items: center; justify-content: space-between; gap: .5rem;
}
.fake-input--focus { border-color: var(--main-color); }
.fake-input__suffix {
  font-family: var(--font-medium); font-size: .78rem; color: var(--fg-tertiary);
}

.upload-row {
  display: flex; align-items: center; gap: 1rem;
  padding: .9rem 1rem;
  background: var(--bg-page);
  border: 1.5px dashed var(--border-color);
  border-radius: var(--radius-md);
}
.upload-row__preview {
  width: 56px; height: 56px; border-radius: 10px;
  background: var(--gradient-primary-135);
  display: grid; place-items: center;
  color: #fff; font-family: var(--font-bold); font-size: 1.1rem;
  flex-shrink: 0;
  box-shadow: var(--shadow-sm);
}
.upload-row__meta { flex: 1; }
.upload-row__meta b {
  font-family: var(--font-bold); font-size: .85rem; color: var(--fg-primary);
  display: block;
}
.upload-row__meta span {
  font-family: var(--font-sans); font-size: .75rem; color: var(--fg-tertiary);
  display: block; margin-top: .15rem;
}
.upload-row__btn {
  padding: .45rem .9rem; border-radius: var(--radius-pill);
  background: #fff; border: 1.5px solid var(--border-color);
  font-family: var(--font-bold); font-size: .75rem; color: var(--fg-secondary);
  cursor: pointer;
}

/* Color picker mock */
.color-pickers { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.color-pick {
  display: flex; align-items: center; gap: .75rem;
  padding: .6rem .7rem;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-md);
  background: var(--bg-page);
}
.color-pick__swatch {
  width: 36px; height: 36px; border-radius: 8px;
  box-shadow: inset 0 0 0 2px #fff, 0 0 0 1.5px var(--border-color);
  flex-shrink: 0;
}
.color-pick__info { flex: 1; min-width: 0; }
.color-pick__label {
  font-family: var(--font-bold); font-size: .68rem;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--fg-muted);
}
.color-pick__hex {
  font-family: ui-monospace, Menlo, monospace; font-size: .85rem;
  color: var(--fg-primary); margin-top: .1rem;
}

/* Palette swatch strip — shows computed variants */
.palette-strip {
  display: flex; gap: .3rem; margin-top: .75rem;
  padding-top: .9rem; border-top: 1px dashed var(--border-subtle);
}
.palette-strip__swatch {
  flex: 1; height: 36px; border-radius: 6px;
  position: relative; overflow: hidden;
}
.palette-strip__swatch::after {
  content: attr(data-label); position: absolute; bottom: 3px; left: 5px;
  font-family: var(--font-bold); font-size: .55rem; color: rgba(255,255,255,.9);
  letter-spacing: .05em; text-transform: uppercase;
}
.palette-strip__swatch.light::after { color: var(--fg-secondary); }

/* Domain field — split */
.domain-row {
  display: flex; align-items: stretch;
  border: 1.5px solid var(--border-color); border-radius: var(--radius-sm);
  overflow: hidden; background: var(--bg-page);
}
.domain-row input {
  flex: 1; padding: .7rem .85rem; border: none; outline: none;
  background: transparent;
  font-family: var(--font-sans); font-size: var(--fs-md); color: var(--fg-primary);
}
.domain-row__suffix {
  display: inline-flex; align-items: center; padding: 0 .9rem;
  background: var(--bg-muted);
  font-family: var(--font-medium); font-size: .85rem; color: var(--fg-secondary);
  border-left: 1px solid var(--border-subtle);
}
.domain-row__tag {
  display: inline-flex; align-items: center; padding: 0 .75rem;
  background: #eef6ef; color: #0f7a3e;
  font-family: var(--font-bold); font-size: .7rem;
  gap: .3rem;
  border-left: 1px solid var(--border-subtle);
}

/* Typography picker */
.type-pick-row { display: flex; gap: .6rem; flex-wrap: wrap; }
.type-pick {
  flex: 1; min-width: 0;
  padding: .85rem 1rem;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-md);
  background: #fff;
  cursor: pointer;
  text-align: left;
  transition: all var(--dur) var(--easing);
}
.type-pick.is-selected {
  border-color: var(--main-color);
  background: var(--bg-selected-tint);
  box-shadow: inset 0 0 0 .5px var(--main-color);
}
.type-pick__name {
  font-family: var(--font-bold); font-size: .85rem;
  color: var(--fg-primary);
  display: flex; align-items: center; justify-content: space-between;
}
.type-pick__sample {
  font-size: 1.35rem; margin-top: .4rem;
  color: var(--fg-primary); letter-spacing: -.01em;
  line-height: 1;
}
.type-pick__meta {
  font-family: var(--font-sans); font-size: .7rem; color: var(--fg-tertiary);
  margin-top: .3rem;
}

.settings__preview-wrap {
  background: var(--bg-page);
  border-radius: var(--radius-xl);
  border: 1px solid var(--border-subtle);
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: var(--shadow-md);
}
.settings__preview-head {
  padding: .85rem 1.25rem;
  background: #fff;
  border-bottom: 1px solid var(--border-subtle);
  display: flex; align-items: center; gap: .75rem;
  font-family: var(--font-bold); font-size: .78rem; color: var(--fg-tertiary);
  text-transform: uppercase; letter-spacing: .08em;
}
.settings__preview-head .pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--main-color); box-shadow: 0 0 0 3px rgb(0 32 89 / 15%);
}
.settings__preview-body { flex: 1; padding: 0; }

/* ── Showcase — screens row ────────────────────────── */
.screens {
  display: grid;
  grid-template-columns: 1.15fr .85fr 1fr;
  gap: 1.5rem;
  align-items: end;
}
.screens__card {
  background: #fff; border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--border-subtle);
  overflow: hidden;
}
.screens__label {
  display: flex; align-items: center; justify-content: space-between;
  padding: .8rem 1rem;
  border-top: 1px solid var(--border-subtle);
  background: #fff;
}
.screens__label b {
  font-family: var(--font-bold); font-size: .82rem; color: var(--fg-primary);
}
.screens__label span {
  font-family: var(--font-medium); font-size: .7rem; color: var(--fg-tertiary);
}

/* Mini login card */
.mini-login {
  padding: 1.5rem 1.25rem;
  background: var(--bg-page);
  min-height: 320px;
  display: flex; align-items: center; justify-content: center;
}
.mini-login__card {
  width: 100%; max-width: 230px;
  background: #fff; border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  padding: 1.25rem 1rem; text-align: center;
}
.mini-login__logo {
  width: 40px; height: 40px; border-radius: 9px;
  background: var(--gradient-primary-135);
  margin: 0 auto .6rem;
  display: grid; place-items: center; color: #fff;
  font-family: var(--font-bold); font-size: .95rem;
}
.mini-login h4 {
  font-family: var(--font-bold); font-size: 1rem;
  color: var(--main-color); margin: 0 0 .15rem;
}
.mini-login p {
  font-family: var(--font-sans); font-size: .7rem;
  color: var(--fg-tertiary); margin: 0 0 .85rem;
}
.mini-login__field {
  background: var(--bg-page); border: 1.5px solid var(--border-color);
  border-radius: var(--radius-sm); padding: .55rem .7rem;
  font-size: .72rem; color: var(--fg-muted); text-align: left;
  margin-bottom: .5rem;
}
.mini-login__btn {
  width: 100%; padding: .6rem 0; margin-top: .2rem;
  background: var(--gradient-primary);
  color: #fff; border-radius: var(--radius-pill);
  font-family: var(--font-bold); font-size: .8rem;
  box-shadow: var(--shadow-sm);
  border: none;
}
.mini-login__foot {
  font-family: var(--font-sans); font-size: .66rem; color: var(--fg-tertiary);
  margin-top: .75rem;
}
.mini-login__foot a {
  color: var(--main-color); text-decoration: none; font-family: var(--font-bold);
}

/* Mini booking flow */
.mini-booking {
  padding: .75rem;
  min-height: 340px;
}
.mini-booking .chip-row { display: flex; flex-wrap: wrap; gap: .3rem; margin-bottom: .65rem; }
.mini-booking .chip {
  padding: .3rem .7rem; border-radius: var(--radius-pill);
  background: #fff; border: 1.5px solid var(--border-color);
  font-family: var(--font-bold); font-size: .7rem;
  color: var(--fg-secondary);
}
.mini-booking .chip.is-selected {
  background: var(--main-color); color: #fff; border-color: var(--main-color);
}
.mini-booking__eyebrow {
  font-family: var(--font-bold); font-size: .58rem;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--fg-muted); margin: .35rem 0 .4rem;
}
.mini-slot-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: .35rem;
}
.mini-slot {
  padding: .45rem 0; border-radius: var(--radius-md);
  background: #fff; color: var(--main-color);
  font-family: var(--font-bold); font-size: .66rem;
  text-align: center;
  display: inline-flex; align-items: center; justify-content: center; gap: .15rem;
}
.mini-slot.is-selected {
  background: var(--main-color); color: #fff;
  transform: scale(1.03); box-shadow: var(--shadow-sm);
}
.mini-slot.is-unavailable {
  background: #fff; border: 1.5px dashed var(--border-color);
  opacity: .35;
}
.mini-res-row {
  display: flex; align-items: center; gap: .5rem;
  padding: .45rem .55rem; border-radius: var(--radius-md);
  border: 1.5px solid var(--border-color); background: #fff;
  margin-bottom: .35rem;
}
.mini-res-row.is-selected {
  border-color: var(--main-color); background: var(--bg-selected-tint);
}
.mini-res-row__icon {
  width: 26px; height: 26px; border-radius: 6px;
  background: var(--bg-muted); color: var(--main-color);
  display: grid; place-items: center; font-size: .7rem;
  flex-shrink: 0;
}
.mini-res-row__name {
  font-family: var(--font-bold); font-size: .72rem; color: var(--fg-primary);
}
.mini-res-row__sub {
  font-family: var(--font-sans); font-size: .62rem; color: var(--fg-tertiary);
}
.mini-res-row .tick {
  margin-left: auto; color: var(--main-color); font-size: .75rem;
}

/* ── Tenants gallery ───────────────────────────────── */
.gallery {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.25rem;
  margin-top: 2.5rem;
}
.gallery__card {
  background: #fff; border-radius: var(--radius-xl);
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: transform var(--dur) var(--easing), box-shadow var(--dur) var(--easing);
}
.gallery__card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.gallery__hero {
  height: 90px; position: relative; overflow: hidden;
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--main-color) 85%, #000 0%),
    color-mix(in oklab, var(--secondary-color) 65%, #fff 10%));
}
.gallery__logo {
  position: absolute; left: 1rem; bottom: -18px;
  width: 48px; height: 48px; border-radius: 11px;
  background: #fff; display: grid; place-items: center;
  border: 2px solid #fff;
  box-shadow: var(--shadow-md);
  color: var(--main-color); font-family: var(--font-bold); font-size: 1.1rem;
}
.gallery__body {
  padding: 1.65rem 1rem 1.1rem;
}
.gallery__name {
  font-family: var(--font-bold); font-size: .95rem; color: var(--fg-primary); margin: 0;
}
.gallery__meta {
  font-family: var(--font-sans); font-size: .73rem; color: var(--fg-tertiary);
  margin: .1rem 0 .75rem;
}
.gallery__swatch-row { display: flex; gap: .3rem; }
.gallery__swatch {
  flex: 1; height: 18px; border-radius: 4px;
}

/* ── CTA band ──────────────────────────────────────── */
.cta {
  background: var(--gradient-primary-135);
  color: #fff;
  border-radius: var(--radius-xl);
  padding: 3.5rem 3rem;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  align-items: center;
  gap: 2rem;
  box-shadow: var(--shadow-lg);
  position: relative; overflow: hidden;
}
.cta::before {
  content: ""; position: absolute; right: -120px; top: -120px;
  width: 340px; height: 340px; border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,.08), transparent 70%);
}
.cta::after {
  content: ""; position: absolute; left: -80px; bottom: -100px;
  width: 280px; height: 280px; border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,.06), transparent 70%);
}
.cta h2 {
  position: relative;
  font-family: var(--font-bold); font-weight: 900;
  font-size: clamp(1.75rem, 3vw, 2.25rem); line-height: 1.1;
  color: #fff; margin: 0; letter-spacing: -.015em;
  text-wrap: balance;
}
.cta p {
  position: relative;
  font-family: var(--font-sans); font-size: 1rem; color: rgba(255,255,255,.82);
  margin: .85rem 0 0; max-width: 34rem;
}
.cta__actions {
  position: relative;
  display: flex; flex-direction: column; gap: .75rem; align-items: stretch;
}
.cta__btn-primary {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .95rem 2rem; border-radius: var(--radius-pill);
  background: #fff; color: var(--main-color);
  font-family: var(--font-bold); font-size: 1rem;
  text-decoration: none; border: none; cursor: pointer;
  box-shadow: 0 8px 24px rgb(0 0 0 / 20%);
  transition: all var(--dur) var(--easing);
}
.cta__btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgb(0 0 0 / 25%); }
.cta__btn-secondary {
  display: inline-flex; align-items: center; justify-content: center; gap: .35rem;
  padding: .75rem 1.5rem; border-radius: var(--radius-pill);
  background: transparent; color: #fff;
  border: 1.5px solid rgba(255,255,255,.35);
  font-family: var(--font-bold); font-size: .9rem;
  text-decoration: none; cursor: pointer;
  transition: all var(--dur) var(--easing);
}
.cta__btn-secondary:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.6); }

/* ── Footer ───────────────────────────────────────── */
.foot {
  padding: 4rem 0 3rem;
  border-top: 1px solid var(--border-subtle);
  background: #fff;
}
.foot__grid {
  display: grid;
  grid-template-columns: 1.3fr repeat(3, 1fr);
  gap: 2.5rem;
}
.foot__brand { display: flex; flex-direction: column; gap: 1rem; }
.foot__logo { display: flex; align-items: center; gap: .6rem; }
.foot__logo-mark {
  width: 32px; height: 32px; border-radius: 7px;
  background: var(--gradient-primary-135);
  display: grid; place-items: center;
  color: #fff; font-family: var(--font-bold); font-size: .85rem;
}
.foot__logo b { font-family: var(--font-bold); font-size: 1rem; color: var(--main-color); }
.foot__tagline { font-family: var(--font-sans); font-size: .85rem; color: var(--fg-tertiary); max-width: 18rem; line-height: 1.55; }
.foot__col h5 {
  font-family: var(--font-bold); font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--fg-muted); margin: 0 0 .9rem;
}
.foot__col a {
  display: block; padding: .3rem 0;
  font-family: var(--font-medium); font-size: .85rem;
  color: var(--fg-secondary); text-decoration: none;
}
.foot__col a:hover { color: var(--main-color); }
.foot__bottom {
  margin-top: 3rem; padding-top: 1.5rem;
  border-top: 1px solid var(--border-subtle);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-sans); font-size: .8rem; color: var(--fg-tertiary);
}

/* ── Email preview ─────────────────────────────── */
.email-preview {
  background: #fff; border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.email-preview__head {
  padding: .75rem 1rem; background: var(--bg-muted);
  border-bottom: 1px solid var(--border-subtle);
  font-family: var(--font-medium); font-size: .75rem; color: var(--fg-tertiary);
}
.email-preview__head b { color: var(--fg-primary); font-family: var(--font-bold); }
.email-preview__body { padding: 1.25rem 1.25rem 1.5rem; }
.email-preview__banner {
  height: 6px; background: var(--gradient-primary); border-radius: 3px; margin-bottom: 1rem;
}
.email-preview__logo {
  width: 38px; height: 38px; border-radius: 8px;
  background: var(--gradient-primary-135);
  display: grid; place-items: center;
  color: #fff; font-family: var(--font-bold); font-size: .9rem;
  margin-bottom: .75rem;
}
.email-preview h5 {
  font-family: var(--font-bold); font-size: 1rem; color: var(--fg-primary); margin: 0 0 .5rem;
}
.email-preview p {
  font-family: var(--font-sans); font-size: .8rem; color: var(--fg-secondary);
  line-height: 1.55; margin: 0 0 .75rem;
}
.email-preview__cta {
  display: inline-flex; padding: .55rem 1.1rem;
  background: var(--gradient-primary); color: #fff;
  border-radius: var(--radius-pill);
  font-family: var(--font-bold); font-size: .75rem;
}
.email-preview__foot {
  margin-top: 1rem; padding-top: .85rem;
  border-top: 1px solid var(--border-subtle);
  font-family: var(--font-sans); font-size: .7rem; color: var(--fg-muted);
}

/* ── Tenant cycle (hero headline) ────────────── */
.tenant-cycle {
  display: block;
  position: relative;
  min-height: 1.05em;
  overflow: visible;
  white-space: nowrap;
}
.tenant-cycle__word {
  display: inline-block;
  color: var(--main-color);
  white-space: nowrap;
  transition: opacity .32s var(--easing), transform .32s var(--easing), color .32s var(--easing);
  will-change: opacity, transform;
}
.tenant-cycle__word.is-out {
  opacity: 0;
  transform: translateY(-12px);
}
.tenant-cycle__word.is-in {
  animation: tenantIn .4s var(--easing);
}
@keyframes tenantIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Pricing ─────────────────────────────────────── */
.pricing {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
  margin-top: 3rem;
  align-items: stretch;
}
.price-card {
  background: #fff;
  border-radius: var(--radius-xl);
  border: 1px solid var(--border-subtle);
  padding: 2rem 1.75rem 1.75rem;
  display: flex; flex-direction: column; gap: 1.25rem;
  box-shadow: var(--shadow-sm);
  position: relative;
  transition: transform var(--dur) var(--easing), box-shadow var(--dur) var(--easing);
}
.price-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.price-card.is-featured {
  background: var(--gradient-role-card);
  border-color: transparent;
  color: #fff;
  box-shadow: var(--shadow-lg);
  transform: translateY(-8px);
}
.price-card.is-featured:hover { transform: translateY(-10px); }
.price-card__badge {
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  padding: .35rem .85rem; background: #fff; color: var(--main-color);
  border-radius: var(--radius-pill);
  font-family: var(--font-bold); font-size: .7rem;
  letter-spacing: .08em; text-transform: uppercase;
  box-shadow: var(--shadow-md);
}
.price-card__name {
  font-family: var(--font-bold); font-size: 1.05rem;
  color: var(--main-color);
  text-transform: uppercase; letter-spacing: .08em;
}
.price-card.is-featured .price-card__name { color: #fff; opacity: .85; }
.price-card__desc {
  font-family: var(--font-sans); font-size: .9rem;
  color: var(--fg-tertiary); line-height: 1.5;
  margin-top: -.65rem;
}
.price-card.is-featured .price-card__desc { color: rgba(255,255,255,.78); }
.price-card__price {
  display: flex; align-items: baseline; gap: .25rem;
  padding: .25rem 0 1rem;
  border-bottom: 1px solid var(--border-subtle);
}
.price-card.is-featured .price-card__price { border-color: rgba(255,255,255,.15); }
.price-card__price-amt {
  font-family: var(--font-bold); font-weight: 900;
  font-size: 3rem; line-height: 1; letter-spacing: -.02em;
  color: var(--fg-primary);
}
.price-card.is-featured .price-card__price-amt { color: #fff; }
.price-card__price-per {
  font-family: var(--font-medium); font-size: .9rem;
  color: var(--fg-tertiary);
}
.price-card.is-featured .price-card__price-per { color: rgba(255,255,255,.7); }
.price-card__features {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: .65rem;
  flex: 1;
}
.price-card__features li {
  display: flex; align-items: flex-start; gap: .6rem;
  font-family: var(--font-sans); font-size: .9rem;
  color: var(--fg-secondary); line-height: 1.4;
}
.price-card.is-featured .price-card__features li { color: rgba(255,255,255,.88); }
.price-card__features li .tick {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--bg-muted); color: var(--main-color);
  display: grid; place-items: center; flex-shrink: 0;
  margin-top: .1rem;
}
.price-card__features li .tick i { width: 11px; height: 11px; }
.price-card__features li .tick svg { width: 11px; height: 11px; }
.price-card.is-featured .price-card__features li .tick {
  background: rgba(255,255,255,.15); color: #fff;
}
.price-card__features li b {
  color: var(--fg-primary); font-family: var(--font-bold);
}
.price-card.is-featured .price-card__features li b { color: #fff; }
.price-card__cta {
  display: inline-flex; align-items: center; justify-content: center; gap: .4rem;
  padding: .85rem 1.25rem;
  border-radius: var(--radius-pill);
  background: transparent; color: var(--main-color);
  border: 1.5px solid var(--main-color);
  font-family: var(--font-bold); font-size: .9rem;
  text-decoration: none; cursor: pointer;
  transition: all var(--dur) var(--easing);
}
.price-card__cta:hover {
  background: var(--main-color); color: #fff;
}
.price-card.is-featured .price-card__cta {
  background: #fff; color: var(--main-color); border-color: #fff;
}
.price-card.is-featured .price-card__cta:hover {
  background: rgba(255,255,255,.88);
}
.price-note {
  text-align: center; margin-top: 2rem;
  font-family: var(--font-sans); font-size: .85rem; color: var(--fg-tertiary);
}
.price-note b { font-family: var(--font-bold); color: var(--fg-secondary); }

/* ── Contact ─────────────────────────────────────── */
.contact {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 3rem;
  align-items: start;
  margin-top: 2.5rem;
}
.contact__info { display: flex; flex-direction: column; gap: 1.25rem; }
.contact__point {
  display: flex; gap: 1rem; align-items: flex-start;
  padding: 1.1rem 1.25rem;
  background: #fff; border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-sm);
}
.contact__point-icon {
  width: 40px; height: 40px; border-radius: var(--radius-sm);
  background: var(--bg-muted); color: var(--main-color);
  display: grid; place-items: center; flex-shrink: 0;
  font-size: 1.2rem;
}
.contact__point b {
  display: block; font-family: var(--font-bold);
  font-size: .9rem; color: var(--fg-primary);
}
.contact__point span, .contact__point a {
  display: block; margin-top: .2rem;
  font-family: var(--font-sans); font-size: .85rem;
  color: var(--fg-secondary); text-decoration: none;
}
.contact__point a:hover { color: var(--main-color); }

.contact__form {
  background: #fff; border-radius: var(--radius-xl);
  padding: 2rem;
  border: 1px solid var(--border-subtle);
  box-shadow: var(--shadow-md);
  display: flex; flex-direction: column; gap: 1.1rem;
}
.contact__form h3 {
  font-family: var(--font-bold); font-size: 1.15rem;
  color: var(--fg-primary); margin: 0 0 .25rem;
}
.contact__form p {
  font-family: var(--font-sans); font-size: .88rem;
  color: var(--fg-tertiary); margin: 0 0 .5rem;
}
.contact__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.contact__field { display: flex; flex-direction: column; gap: .35rem; }
.contact__field label {
  font-family: var(--font-bold); font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: .08em; color: var(--fg-muted);
}
.contact__field input,
.contact__field select,
.contact__field textarea {
  padding: .75rem .9rem;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-sm);
  background: var(--bg-page);
  font-family: var(--font-sans); font-size: var(--fs-md);
  color: var(--fg-primary);
  outline: none;
  transition: border-color var(--dur) var(--easing);
}
.contact__field textarea { resize: vertical; min-height: 110px; }
.contact__field input:focus,
.contact__field select:focus,
.contact__field textarea:focus { border-color: var(--main-color); }
.contact__consent {
  display: flex; align-items: flex-start; gap: .55rem;
  font-family: var(--font-sans); font-size: .8rem;
  color: var(--fg-tertiary); line-height: 1.5;
}
.contact__consent input { margin-top: .2rem; accent-color: var(--main-color); }
.contact__consent a { color: var(--main-color); text-decoration: none; font-family: var(--font-bold); }

/* ── Legal doc pages ──────────────────────────── */
.legal {
  max-width: 48rem; margin: 0 auto; padding: 4rem 2rem 6rem;
}
.legal__back {
  display: inline-flex; align-items: center; gap: .35rem;
  font-family: var(--font-medium); font-size: .85rem;
  color: var(--fg-tertiary); text-decoration: none;
  margin-bottom: 2rem;
}
.legal__back:hover { color: var(--main-color); }
.legal h1 {
  font-family: var(--font-bold); font-weight: 900;
  font-size: 2.5rem; line-height: 1.1; letter-spacing: -.02em;
  color: var(--fg-primary); margin: 0 0 .5rem;
}
.legal__updated {
  font-family: var(--font-medium); font-size: .85rem;
  color: var(--fg-tertiary); margin: 0 0 2.5rem;
}
.legal h2 {
  font-family: var(--font-bold); font-weight: 900;
  font-size: 1.35rem; color: var(--fg-primary);
  margin: 2.5rem 0 .75rem;
}
.legal p, .legal li {
  font-family: var(--font-sans); font-size: 1rem;
  color: var(--fg-secondary); line-height: 1.7;
  margin: 0 0 .85rem;
}
.legal ul { padding-left: 1.25rem; margin: 0 0 .85rem; }
.legal a { color: var(--main-color); font-family: var(--font-bold); text-decoration: none; }
.legal a:hover { text-decoration: underline; }
.legal strong, .legal b { color: var(--fg-primary); font-family: var(--font-bold); }

/* ── Responsive ─────────────────────────────────── */
@media (max-width: 900px) {
  .pricing { grid-template-columns: 1fr; max-width: 420px; margin-left: auto; margin-right: auto; }
  .price-card.is-featured { transform: none; }
  .price-card.is-featured:hover { transform: translateY(-3px); }
  .contact { grid-template-columns: 1fr; gap: 2rem; }
  .contact__row { grid-template-columns: 1fr; }
}
@media (max-width: 980px) {
  .hero__inner { grid-template-columns: 1fr; gap: 3rem; }
  .hero__showcase { min-height: 460px; }
  .swap { grid-template-columns: 1fr; gap: 2rem; }
  .settings { grid-template-columns: 1fr; }
  .features { grid-template-columns: 1fr 1fr; }
  .screens { grid-template-columns: 1fr; }
  .gallery { grid-template-columns: 1fr 1fr; }
  .cta { grid-template-columns: 1fr; padding: 2.5rem 2rem; text-align: left; }
  .cta__actions { flex-direction: row; flex-wrap: wrap; }
  .foot__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .section { padding: 4rem 0; }
  .wrap { padding: 0 1.25rem; }
  .mk-nav { padding: 0 1.25rem; }
  .mk-nav__links > .mk-nav__link { display: none; }
  .features { grid-template-columns: 1fr; }
  .gallery { grid-template-columns: 1fr; }
  .foot__grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .hero__showcase { min-height: 620px; }
  .desktop-card { width: 100%; transform: none; position: relative; left: auto; bottom: auto; }
  .phone-card { position: relative; top: auto; right: auto; margin: 1.5rem auto 0; }
  .swap__results { grid-template-columns: 1fr; }
  .hero__signals { flex-wrap: wrap; gap: 1.5rem; }
}
