/* LORDLY. — premium marketing site
   Brand: deep oxblood + crimson · clean Inter typography · LORDLY. with full stop dot */

:root {
  --primary: #3A0E14;
  --primary-light: #5C1820;
  --primary-dark: #1F0608;
  --accent: #B73344;
  --accent-light: #D85565;
  --accent-deep: #7A1422;
  --accent-vibrant: #9A1C2C;

  --bg: #FFFFFF;
  --bg-soft: #FFF7F8;
  --surface: #FFFFFF;
  --surface-2: #FBE9EA;
  --surface-tinted: #FDECEC;

  --text: #1F0608;
  --text-2: #5C2227;
  --text-3: #8B5A5F;
  --text-on-dark: #FFFFFF;
  --text-on-dark-2: rgba(255,255,255,.74);
  --text-on-dark-3: rgba(255,255,255,.50);

  --border: #EBD3D6;
  --border-strong: #D4B0B5;
  --divider: #F1DDDF;

  --success: #0F8A6A;
  --warning: #C06A0A;
  --error:   #DC2626;

  --grad-1: linear-gradient(135deg, #7A1422 0%, #B73344 50%, #9A1C2C 100%);
  --grad-2: linear-gradient(180deg, #1F0608 0%, #3A0E14 60%, #5C1820 100%);
  --grad-vision: linear-gradient(135deg, #3A0E14 0%, #7A1422 40%, #B73344 100%);
  --grad-soft: linear-gradient(180deg, #FFF 0%, #FFF7F8 100%);

  --shadow-1: 0 1px 2px rgba(58,14,20,.04), 0 2px 8px rgba(58,14,20,.04);
  --shadow-2: 0 4px 14px rgba(58,14,20,.07), 0 12px 30px rgba(58,14,20,.06);
  --shadow-3: 0 18px 50px rgba(58,14,20,.18), 0 40px 80px rgba(31,6,8,.2);

  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 20px;
  --r-2xl: 24px;
  --r-3xl: 32px;
  --r-full: 9999px;

  --container: 1200px;

  /* Single typeface — clean, premium, no curvy serif */
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-display: 'Inter', -apple-system, sans-serif;
  --font-italic: 'Instrument Serif', Georgia, serif; /* used ONLY for italic emphasis */

  --ease: cubic-bezier(.2,.7,.2,1);
  --t-fast: 160ms;
  --t-med: 240ms;
  --t-slow: 420ms;
}

/* ───────── Base ───────── */
*,*::before,*::after { box-sizing: border-box; }
html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  overflow-x: clip;
  max-width: 100vw;
  width: 100%;
}
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  overflow-x: clip;
  max-width: 100vw;
  width: 100%;
  position: relative;
  font-family: var(--font);
  font-size: 16px;
  line-height: 1.55;
  font-feature-settings: 'cv11', 'ss01', 'ss03';
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { display: block; max-width: 100%; }
section { position: relative; overflow: hidden; max-width: 100vw; }
main { overflow-x: hidden; max-width: 100vw; }
.container { max-width: min(var(--container), 100%); }
* { min-width: 0; }
a { color: inherit; text-decoration: none; transition: color var(--t-fast) var(--ease); }
a:hover { color: var(--accent); }
button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }

.container { max-width: var(--container); margin: 0 auto; padding: 0 28px; }
@media (max-width: 520px) {
  .container { padding: 0 18px; }
}
.skip { position:absolute; left:-9999px; top:auto; }
.skip:focus { left:16px; top:16px; background:var(--primary); color:#fff; padding:10px 14px; border-radius:8px; z-index:1000; }

/* ───────── Brand wordmark with full stop dot ───────── */
.brand { display: inline-flex; align-items: center; gap: 12px; }
.brand__chip {
  width: 40px; height: 40px;
  display: grid; place-items: center;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: var(--shadow-1);
  /* Subtle pulse to match the dot — keeps the brand mark "alive" */
  animation: brandPulse 2.6s ease-in-out infinite;
}
.brand__chip img { width: 30px; height: 30px; object-fit: contain; }
.brand__word {
  font-family: var(--font);
  font-weight: 700;
  font-size: 18px;
  letter-spacing: .14em;
  color: var(--text);
  display: inline-flex;
  align-items: center;       /* vertically center the dot with the wordmark */
  gap: 4px;
}
.brand__dot {
  display: inline-block;
  width: 9px; height: 9px;
  border-radius: 50%;
  /* Same red as the logo (LORDLY brand red ≈ #E2231A) — vibrant, not the deep accent */
  background: #E5251B;
  margin-left: 3px;
  align-self: center;        /* in-line vertically with the chip */
  position: relative;
  box-shadow: 0 0 0 0 rgba(229,37,27,0);
  animation: brandPulse 2.6s ease-in-out infinite;
}
.brand__dot--inline { vertical-align: middle; transform: none; }
.brand__dot--small { width: 6px; height: 6px; }
.brand__dot--light { background: #fff; box-shadow: 0 0 0 0 rgba(255,255,255,0); animation-name: brandPulseLight; }

/* Synchronised pulse — chip + dot breathe together */
@keyframes brandPulse {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(229,37,27,0);
  }
  50% {
    transform: scale(1.06);
    box-shadow: 0 0 0 6px rgba(229,37,27,.14);
  }
}
@keyframes brandPulseLight {
  0%, 100% { transform: scale(1);    box-shadow: 0 0 0 0 rgba(255,255,255,0); }
  50%      { transform: scale(1.06); box-shadow: 0 0 0 6px rgba(255,255,255,.18); }
}
.brand__chip {
  /* keep chip pulse subtler — half the scale of the dot */
  animation-name: brandChipPulse;
}
@keyframes brandChipPulse {
  0%, 100% { transform: scale(1);    box-shadow: var(--shadow-1); }
  50%      { transform: scale(1.04); box-shadow: 0 6px 18px rgba(229,37,27,.18), var(--shadow-1); }
}

/* ───────── A.I chip (matches the app's Vision · A.I mark) ───────── */
.ai-chip {
  display: inline-flex;
  align-items: center;
  font-size: .68em;
  font-weight: 700;
  letter-spacing: .04em;
  color: var(--accent);
  background: #fff;
  border: 1.4px solid var(--accent);
  padding: 1px 6px;
  border-radius: 5px;
  margin-left: 4px;
  vertical-align: middle;
  line-height: 1;
}
.ai-chip--lg {
  font-size: .55em;
  padding: 4px 10px;
  border-width: 2px;
  border-radius: 8px;
  margin-left: 10px;
}
.eyebrow--light .ai-chip,
.display--light .ai-chip,
.lede--light .ai-chip {
  color: #fff;
  background: transparent;
  border-color: rgba(255,255,255,.6);
}

/* ───────── Eyebrow / type ───────── */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--accent-deep);
  background: none;
  padding: 0 0 0 0;
  border: none;
  border-radius: 0;
  margin-bottom: 4px;
}
.eyebrow::before {
  content: '';
  display: inline-block;
  width: 28px; height: 1px;
  background: linear-gradient(90deg, #C8932F 0%, #E5B96A 100%);
  flex: none;
}
.section__head--center .eyebrow { display: inline-flex; }
.section__head--center .eyebrow::after {
  content: '';
  display: inline-block;
  width: 28px; height: 1px;
  background: linear-gradient(90deg, #E5B96A 0%, #C8932F 100%);
  flex: none;
}
.eyebrow--light {
  color: rgba(255,255,255,.85);
  background: none;
  border-color: transparent;
  backdrop-filter: none;
}
.eyebrow--light::before,
.eyebrow--light::after {
  background: linear-gradient(90deg, rgba(229,185,106,.9) 0%, rgba(200,147,47,.4) 100%);
}
.eyebrow__sep { opacity: .4; margin: 0 2px; }
.eyebrow__soon {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--accent-deep);
  font-weight: 600;
}
.eyebrow__soon::before {
  content: '';
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--warning);
  box-shadow: 0 0 0 3px rgba(192,106,10,.18);
}
@media (max-width: 600px) {
  .eyebrow__sep, .eyebrow__soon { display: none; }
}
.dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--text-3);
}
.dot--live {
  background: #2BD17E;
  box-shadow: 0 0 0 3px rgba(43,209,126,.18);
  animation: live 2s ease-in-out infinite;
}
@keyframes live { 50% { box-shadow: 0 0 0 6px rgba(43,209,126,.05); } }

.display, h1, h2, h3 {
  font-family: var(--font-display);
  letter-spacing: -.035em;
  line-height: 1.04;
  color: var(--text);
  margin: 0;
}
.display {
  font-size: clamp(36px, 4.8vw, 60px);
  font-weight: 600;
  margin: 16px 0 18px;
  /* keep each headline line intact — soft wraps were splitting "Replace the agent." */
  white-space: nowrap;
}
@media (max-width: 520px) { .display { white-space: normal; font-size: clamp(34px, 9vw, 44px); } }
.display em {
  font-family: var(--font-italic);
  font-style: italic;
  color: var(--accent);
  font-weight: 400;
  letter-spacing: -.02em;
}
.display--light { color: #fff; }
h2 { font-size: clamp(26px, 2.8vw, 38px); font-weight: 600; margin-bottom: 16px; letter-spacing: -.025em; line-height: 1.1; }
@media (min-width: 1024px) {
  .section__head h2,
  .section__head--center h2 {
    white-space: nowrap;
  }
}
h3 { font-size: clamp(18px, 1.6vw, 22px); font-weight: 600; margin-bottom: 10px; letter-spacing: -.02em; }
h4 { font-family: var(--font); font-size: 12px; font-weight: 600; letter-spacing: 1.4px; text-transform: uppercase; color: var(--text-3); margin: 0 0 14px; }
p { margin: 0 0 14px; color: var(--text-2); }
.lede { font-size: clamp(16px, 1.3vw, 18px); color: var(--text-2); max-width: 56ch; line-height: 1.55; }
.lede--light { color: var(--text-on-dark-2); }
.section__head { margin: 0 0 56px; max-width: 720px; }
.section__head--center { margin-left:auto; margin-right:auto; text-align: center; }
.section__head--center .lede,
.section__head--center .section__lede { margin-left: auto; margin-right: auto; }
.section__lede { color: var(--text-2); font-size: 17px; margin-top: 14px; }

/* ───────── Buttons ───────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  border-radius: var(--r-lg);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: -.005em;
  transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  white-space: nowrap;
  user-select: none;
  position: relative;
  border: 1px solid transparent;
}
.btn:active { transform: scale(.97); }
.btn--lg { padding: 16px 26px; font-size: 16px; border-radius: var(--r-lg); }
.btn--full { width: 100%; justify-content: center; }

.btn--primary {
  color: #fff;
  background: var(--grad-1);
  box-shadow: 0 8px 22px rgba(154,28,44,.28), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn--primary:hover {
  box-shadow: 0 14px 36px rgba(154,28,44,.4), inset 0 1px 0 rgba(255,255,255,.22);
  color: #fff;
  transform: translateY(-1px);
}

.btn--outline {
  color: var(--text);
  background: var(--surface);
  border-color: var(--border-strong);
}
.btn--outline:hover { border-color: var(--accent); color: var(--accent); background:#fff; }

.btn--ghost { color: var(--text); background: transparent; }
.btn--ghost:hover { color: var(--accent); background: var(--surface-tinted); }

/* ───────── Nav ───────── */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.78);
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.nav.is-scrolled { border-bottom-color: var(--divider); background: rgba(255,255,255,.94); }
.nav__inner { display: flex; align-items: center; justify-content: space-between; height: 76px; gap: 24px; }
.nav__links { display: flex; gap: 28px; font-size: 14.5px; font-weight: 500; color: var(--text-2); }
.nav__links a { position: relative; }
.nav__links a::after {
  content:''; position:absolute; left:0; right:0; bottom:-6px; height:2px;
  background: var(--accent); transform: scaleX(0); transform-origin:left;
  transition: transform var(--t-med) var(--ease);
}
.nav__links a:hover { color: var(--text); }
.nav__links a:hover::after { transform: scaleX(1); }
.nav__cta { display: flex; align-items: center; gap: 10px; }
.nav__burger { display: none; width: 40px; height: 40px; border-radius: 10px; border: 1px solid var(--border); background: #fff; padding: 10px; }
.nav__burger span { display:block; height:2px; background: var(--text); margin: 4px 0; border-radius:1px; }
.nav__mobile { display:none; flex-direction: column; gap: 14px; padding: 16px 28px 28px; border-bottom:1px solid var(--divider); background: #fff; }
.nav__mobile a { font-size: 17px; color: var(--text); padding: 6px 0; }
@media (max-width: 980px) {
  .nav__links, .nav__cta { display: none; }
  .nav__burger { display: block; }
  .nav__mobile.is-open { display: flex; }
}

/* ───────── Hero ───────── */
.hero {
  position: relative; overflow: hidden;
  padding: clamp(60px, 8vw, 120px) 0 clamp(60px, 8vw, 100px);
  background:
    radial-gradient(900px 400px at 80% -10%, #FBE9EA 0%, transparent 60%),
    radial-gradient(700px 600px at -10% 110%, #FDECEC 0%, transparent 55%),
    var(--bg);
}
.hero__bg { position: absolute; inset: 0; pointer-events: none; }
.hero__grain {
  position:absolute; inset:0;
  background-image: radial-gradient(rgba(58,14,20,.03) 1px, transparent 1px);
  background-size: 4px 4px;
  mask-image: radial-gradient(circle at 50% 40%, #000 0%, transparent 80%);
  -webkit-mask-image: radial-gradient(circle at 50% 40%, #000 0%, transparent 80%);
}
.hero__orb { position: absolute; border-radius: 50%; filter: blur(60px); opacity:.45; }
.hero__orb--1 { width: 460px; height: 460px; left: -120px; top: -120px; background: radial-gradient(circle, #F5D6DB, transparent 60%); }
.hero__orb--2 { width: 520px; height: 520px; right: -180px; bottom: -180px; background: radial-gradient(circle, #D85565, transparent 60%); opacity: .25; }

.hero__inner {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 64px;
  align-items: center;
  position: relative;
}
.hero__cta { display: flex; gap: 12px; flex-wrap: wrap; margin: 24px 0 22px; }
.trust { list-style:none; padding:0; margin: 18px 0 0; display:flex; flex-wrap:wrap; gap: 18px; color: var(--text-3); font-size: 13px; font-weight: 500; }
.trust li { display:inline-flex; align-items:center; gap:6px; }
.trust svg { color: var(--success); }

@media (max-width: 980px) {
  .hero__inner { grid-template-columns: 1fr; gap: 48px; }
  .hero__hero-mark { order: -1; }
  .hero__estate { order: -1; }
}
@media (max-width: 520px) {
  .hero { padding: 80px 0 60px; }
  .hero__cta { gap: 10px; }
  .hero__cta .btn { width: 100%; justify-content: center; }
  .trust { gap: 10px 14px; font-size: 12px; }
  .eyebrow { gap: 10px; font-size: 9.5px; letter-spacing: 2px; flex-wrap: wrap; }
  .eyebrow__sep, .eyebrow__soon { display: none; }
}

/* ───────── Splash-style hero mark (matches app splash screen) ───────── */
.hero__hero-mark,
.hero__estate { display: flex; justify-content: center; }

/* ───────── Hero residence ───────── */
.estate-hero {
  position: relative;
  width: min(560px, 100%);
  aspect-ratio: 4/5;
  margin: 0;
  border-radius: 22px;
  overflow: visible;
  isolation: isolate;
}
.estate-hero__img {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  border-radius: 22px;
  box-shadow:
    0 30px 60px rgba(31,6,8,.18),
    0 12px 24px rgba(31,6,8,.10),
    0 0 0 1px rgba(31,6,8,.04);
  z-index: 1;
}
.estate-hero__img::after {
  content: '';
  position: absolute; inset: 0;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(31,6,8,0) 40%, rgba(31,6,8,.55) 100%);
}
.estate-hero__plate {
  position: absolute;
  left: 26px; bottom: 22px;
  z-index: 2;
  color: #fff;
  display: flex; flex-direction: column; gap: 8px;
  text-shadow: 0 1px 2px rgba(0,0,0,.3);
}
.estate-hero__line {
  width: 36px; height: 1px;
  background: linear-gradient(90deg, #E5B96A, transparent);
}
.estate-hero__location {
  font-size: 10.5px; font-weight: 600; letter-spacing: 2.6px; text-transform: uppercase;
  color: #E5B96A;
}
.estate-hero__title {
  font-family: var(--font-italic);
  font-style: italic;
  font-size: 28px;
  font-weight: 400;
  letter-spacing: -.01em;
  color: #fff;
}

/* Floating LORDLY app cards */
.estate-card {
  position: absolute;
  z-index: 3;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(31,6,8,.06);
  border-radius: 14px;
  padding: 14px 16px;
  box-shadow:
    0 1px 0 rgba(255,255,255,.6) inset,
    0 14px 30px rgba(31,6,8,.16),
    0 4px 10px rgba(31,6,8,.08);
  font-size: 12.5px;
  color: var(--text);
  animation: estateCardFloat 6s ease-in-out infinite;
}
@keyframes estateCardFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}
.estate-card--rent {
  top: 8%; right: -22px;
  width: 215px;
  animation-delay: 0s;
}
.estate-card--rent .estate-card__row {
  display: flex; align-items: center; gap: 8px;
  font-size: 10.5px; font-weight: 600; letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--text-3);
}
.estate-card__dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #2F7A5E;
  box-shadow: 0 0 0 3px rgba(47,122,94,.18);
}
.estate-card__amt {
  font-size: 22px; font-weight: 700; letter-spacing: -.02em;
  color: var(--text);
  margin: 6px 0 4px;
}
.estate-card__sub {
  font-size: 11.5px; color: var(--text-3); font-weight: 500;
}
.estate-card--ai {
  top: 44%; left: -26px;
  width: 240px;
  animation-delay: 1.5s;
}
.estate-card--ai .estate-card__pill {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 10.5px; font-weight: 700; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--accent-deep);
  margin-bottom: 8px;
}
.estate-card--ai p {
  font-size: 13px; line-height: 1.45; color: var(--text);
  margin: 0;
}
.estate-card--tier {
  bottom: 14%; right: -10px;
  display: flex; align-items: center; gap: 12px;
  background: linear-gradient(135deg, #FFFEFB 0%, #FFF6E4 100%);
  border-color: rgba(200,147,47,.30);
  animation-delay: 3s;
}
.estate-card__crown {
  width: 32px; height: 32px;
  border-radius: 8px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, #E5B96A 0%, #C8932F 100%);
  color: #2A1206;
  box-shadow: 0 4px 10px rgba(168,119,30,.28), 0 1px 0 rgba(255,255,255,.4) inset;
}
.estate-card--tier .estate-card__lbl {
  font-size: 10px; font-weight: 600; letter-spacing: 1.6px; text-transform: uppercase;
  color: var(--text-3);
}
.estate-card__tier {
  font-family: var(--font-italic);
  font-style: italic;
  font-size: 16px;
  font-weight: 400;
  color: #2A1206;
  letter-spacing: -.005em;
}

@media (max-width: 980px) {
  .estate-hero { aspect-ratio: 5/4; max-width: 520px; }
  .estate-card--rent { right: 8px; }
  .estate-card--ai { left: 8px; }
  .estate-card--tier { right: 8px; bottom: 10%; }
}
@media (max-width: 520px) {
  .estate-hero { aspect-ratio: 4/5; max-width: 100%; }
  .estate-hero__title { font-size: 22px; }
  .estate-card { transform: scale(.82); }
  .estate-card--rent { top: 4%; right: 8px; transform-origin: top right; width: 180px; }
  .estate-card--ai { top: 42%; left: 8px; transform-origin: top left; width: 200px; }
  .estate-card--tier { right: 8px; bottom: 6%; transform-origin: bottom right; }
}

/* ───────── Ecosystem (animated logo moment) ───────── */
.ecosystem {
  background:
    radial-gradient(800px 400px at 50% 0%, #FFF5F6 0%, transparent 60%),
    var(--bg);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.ecosystem__inner {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  align-items: center;
  gap: 56px;
}
.ecosystem__copy { max-width: none; }
.ecosystem__copy h2 {
  margin: 12px 0 16px;
  font-size: clamp(22px, 1.9vw, 28px);
  letter-spacing: -.015em;
  white-space: nowrap;
  overflow: visible;
}
@media (max-width: 980px) {
  .ecosystem__copy h2 { white-space: normal; font-size: clamp(24px, 5.8vw, 30px); }
}
.ecosystem__copy h2 em {
  font-family: var(--font-italic);
  font-style: italic;
  font-weight: 400;
  color: var(--accent-deep);
}
.ecosystem__mark { display: flex; justify-content: center; }
.ecosystem .splash { width: min(460px, 88vw); }
@media (max-width: 980px) {
  .ecosystem__inner { grid-template-columns: 1fr; gap: 24px; text-align: center; }
  .ecosystem__copy { max-width: 100%; margin: 0 auto; }
  .ecosystem .splash { width: min(380px, 80vw); margin: 0 auto; }
}
.splash {
  position: relative;
  width: min(520px, 92vw);
  aspect-ratio: 1;
}

/* Center logo — red roof, transparent (white background dropped via mix-blend-mode) */
.splash__logo {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 32%;
  aspect-ratio: 1;
  display: grid; place-items: center;
  z-index: 3;
  animation: splashFloat 6s ease-in-out infinite;
}
.splash__logo img {
  width: 100%; height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 14px 28px rgba(154,28,44,.30));
}
@keyframes splashFloat {
  0%, 100% { transform: translate(-50%, -50%) translateY(0); }
  50%      { transform: translate(-50%, -50%) translateY(-6px); }
}

/* Dust cloud — three counter-rotating layers form a spiraling AI intelligence cloud */
.splash__dust {
  position: absolute;
  inset: -25%;          /* extend beyond logo for an expansive cloud */
  pointer-events: none;
  z-index: 0;
}
.splash__dust-ring {
  position: absolute; inset: 0;
  transform-origin: center;
  animation: dustSpiral var(--ring-dur, 60s) linear infinite;
  animation-direction: var(--ring-dir, normal);
}
@keyframes dustSpiral { to { transform: rotate(360deg); } }
.splash__dust span {
  position: absolute;
  border-radius: 50%;
  background: var(--dust-c, var(--accent-light));
  opacity: var(--dust-o, .4);
  animation: dustDrift var(--dust-d, 8s) ease-in-out infinite;
  animation-delay: var(--dust-delay, 0s);
}
@keyframes dustDrift {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50%      { transform: translate(var(--dust-x, 10px), var(--dust-y, -10px)) scale(var(--dust-s, 1.15)); }
}

/* Spiraling icon chips around the logo */
.splash__satellites { position: absolute; inset: 0; }
/* track ⊃ spoke ⊃ chip
   Track rotates the whole ring. Spokes are pinned at center with a fixed initial angle.
   Chips sit at the end of each spoke and counter-rotate so the icon stays upright. */
.splash__sat-track {
  position: absolute;
  inset: 0;
  animation: trackRotate var(--track-dur, 28s) linear infinite;
}
.splash__sat-spoke {
  position: absolute;
  left: 50%; top: 50%;
  width: 0; height: 0;
  transform: rotate(var(--spoke-angle, 0deg));
}
.splash__sat-chip {
  position: absolute;
  width: 56px; height: 56px;
  left: -28px;             /* center over spoke */
  bottom: var(--sat-r, 200px); /* push UP from spoke origin by radius */
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  display: grid; place-items: center;
  color: var(--accent);
  box-shadow: 0 8px 24px rgba(58,14,20,.10), 0 2px 6px rgba(58,14,20,.06);
  animation: trackRotate var(--track-dur, 28s) linear infinite reverse;
}
.splash__sat-chip svg { width: 22px; height: 22px; }
.splash__sat-track .satellite svg { width: 22px; height: 22px; }
@keyframes trackRotate { to { transform: rotate(360deg); } }
@keyframes satCounter  { to { transform: rotate(-360deg); } }

@media (max-width: 600px) {
  .splash { width: min(380px, 92vw); }
  .splash__sat-chip { width: 44px; height: 44px; left: -22px; }
  .splash__sat-chip svg { width: 18px; height: 18px; }
}

/* ───────── Stats ───────── */
.stats {
  padding: 0; background: var(--bg-soft);
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}
.stats__grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  padding: 32px 28px;
}
@media (max-width: 720px) { .stats__grid { grid-template-columns: repeat(2, 1fr); gap: 24px 0; } }
.stat { display: flex; flex-direction: column; gap: 4px; padding: 0 24px; border-left: 1px solid var(--divider); }
.stat:first-child { border-left: 0; }
@media (max-width: 720px) { .stat { padding: 0 16px; border-left: 0; } }
.stat strong { font-size: clamp(22px, 2.4vw, 30px); font-weight: 700; letter-spacing: -.025em; color: var(--text); }
.stat span { font-size: 12px; color: var(--text-3); font-weight: 500; }

/* ───────── Sections ───────── */
section { padding: clamp(72px, 9vw, 120px) 0; }
.grid { display:grid; gap: 20px; }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1100px) { .grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 980px) { .grid--3 { grid-template-columns: 1fr; } }
@media (max-width: 600px) { .grid--4 { grid-template-columns: 1fr; } }

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
  padding: 28px;
  transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease), border-color var(--t-med) var(--ease);
  position: relative;
  overflow: hidden;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); border-color: var(--accent-light); }

/* Features */
.feature__icon {
  width: 52px; height: 52px;
  display: grid; place-items: center;
  background: var(--surface-tinted);
  color: var(--accent);
  border-radius: var(--r-lg);
  margin-bottom: 18px;
  border: 1px solid var(--border);
}
.feature__icon svg { width: 22px; height: 22px; }

/* ───────── Vision A.I (dark section) ───────── */
.vision {
  background: var(--grad-2);
  color: var(--text-on-dark);
  position: relative; overflow: hidden;
}
.vision::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(700px 500px at 90% 10%, rgba(183,51,68,.5), transparent 60%),
    radial-gradient(500px 400px at 0% 100%, rgba(122,20,34,.5), transparent 60%);
}
.vision__inner { position: relative; display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 980px) { .vision__inner { grid-template-columns: 1fr; gap: 40px; } }
.vision h2 { color: #fff; }
.vision p { color: var(--text-on-dark-2); }
.vision__brand {
  display: inline-flex; align-items: baseline;
  font-family: var(--font-italic);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -.02em;
  color: #fff;
}
.vision__list { list-style: none; padding: 0; margin: 28px 0 0; display: grid; gap: 18px; }
.vision__list li { display: grid; grid-template-columns: 36px 1fr; gap: 14px; align-items: start; }
.vision__list svg {
  width: 22px; height: 22px;
  color: #fff;
  padding: 7px;
  background: rgba(255,255,255,.08);
  border-radius: var(--r-md);
  border: 1px solid rgba(255,255,255,.15);
  width: 36px; height: 36px;
  box-sizing: border-box;
}
.vision__list strong { display: block; color: #fff; font-weight: 600; margin-bottom: 2px; }
.vision__list span { color: var(--text-on-dark-2); font-size: 14.5px; line-height: 1.5; }

/* ───────── Atomic AI icon — clean, inline next to "Meet LORDLY AI" ─────────
   Three elliptical orbits, three electrons, single glowing core. No eye. */
.vision__heading {
  display: inline-flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}
.atom {
  position: relative;
  display: inline-block;
  width: 72px; height: 72px;
  vertical-align: middle;
  flex-shrink: 0;
}
.atom__halo {
  position: absolute; inset: 18%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(216,85,101,.45) 0%, rgba(122,20,34,.18) 50%, transparent 75%);
  filter: blur(4px);
  animation: atomBreathe 3.4s ease-in-out infinite;
}
.atom__core {
  position: absolute;
  left: 50%; top: 50%;
  width: 14px; height: 14px;
  margin: -7px 0 0 -7px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #fff 0%, #FBE9EA 35%, #D85565 90%);
  box-shadow: 0 0 0 3px rgba(255,255,255,.10), 0 0 18px rgba(216,85,101,.65);
  z-index: 3;
  animation: atomBreathe 3.4s ease-in-out infinite;
}
@keyframes atomBreathe {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.12); }
}

/* Three orbits, each with its own ellipse rotation + spinning animation */
.atom__orbit {
  position: absolute; inset: 0;
  border: 1.2px solid rgba(255,255,255,.35);
  border-radius: 50%;
  animation: atomOrbit var(--o-dur, 5s) linear infinite;
}
.atom__orbit--1 {
  --o-dur: 5s;
  --o-base: rotate(0deg) scaleY(.40);
}
.atom__orbit--2 {
  --o-dur: 6.5s;
  --o-base: rotate(60deg) scaleY(.40);
  animation-direction: reverse;
}
.atom__orbit--3 {
  --o-dur: 8s;
  --o-base: rotate(-60deg) scaleY(.40);
}
@keyframes atomOrbit {
  from { transform: var(--o-base) rotate(0deg); }
  to   { transform: var(--o-base) rotate(360deg); }
}

/* Electron — pinned to the right edge of its orbit; parent rotation moves it. */
.atom__electron {
  position: absolute;
  top: 50%; left: 100%;
  width: 7px; height: 7px;
  margin: -3.5px 0 0 -3.5px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 0 1.5px rgba(255,255,255,.18), 0 0 10px rgba(255,255,255,.6);
}

@media (prefers-reduced-motion: reduce) {
  .atom__orbit, .atom__halo, .atom__core { animation: none !important; }
}

/* AI conversation demo */
.ai-conv {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--r-2xl);
  padding: 22px;
  backdrop-filter: blur(12px);
  display: grid; gap: 14px;
}
.ai-conv__msg {
  border-radius: var(--r-xl);
  padding: 16px 18px;
  max-width: 90%;
}
.ai-conv__msg p { color: inherit; margin: 0; font-size: 14.5px; line-height: 1.55; }
.ai-conv__msg--user {
  background: rgba(255,255,255,.10);
  color: #fff;
  margin-left: auto;
  border-bottom-right-radius: 6px;
}
.ai-conv__msg--ai {
  background: #fff;
  color: var(--text);
  border-bottom-left-radius: 6px;
  box-shadow: 0 8px 24px rgba(0,0,0,.2);
}
.ai-conv__msg--ai p { color: var(--text-2); }
.ai-conv__msg--ai p strong { color: var(--text); font-weight: 600; }
.ai-conv__pill {
  display: inline-flex; align-items: center;
  font-size: 11px; font-weight: 600; letter-spacing: .8px; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
}
.ai-conv__actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.ai-conv__chip {
  font-size: 12.5px; font-weight: 500;
  padding: 8px 14px;
  border-radius: var(--r-full);
  background: var(--accent); color: #fff;
  border: 1px solid var(--accent);
  transition: background var(--t-fast) var(--ease);
}
.ai-conv__chip:hover { background: var(--accent-deep); }
.ai-conv__chip--ghost { background: var(--surface-tinted); color: var(--accent); }
.ai-conv__chip--ghost:hover { background: var(--surface-2); color: var(--accent-deep); }
.ai-conv__meta {
  display: block;
  font-size: 11px;
  color: rgba(255,255,255,.5);
  margin-top: 6px;
}
.ai-conv__sub {
  font-size: 13px !important;
  color: var(--text-3) !important;
  margin: 8px 0 0 !important;
}
.ai-conv__msg--escalate {
  border: 1px solid var(--accent-light);
  box-shadow: 0 0 0 4px rgba(183,51,68,.10), 0 8px 24px rgba(0,0,0,.2);
}
.ai-conv__quotes {
  margin: 10px 0 6px;
  display: grid; gap: 8px;
}
.ai-conv__quote {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  font-size: 13px;
}
.ai-conv__quote > div:first-child {
  color: var(--text-2);
  font-weight: 500;
}
.ai-conv__quote > div:first-child strong { color: var(--text); font-weight: 600; }
.ai-conv__quote--win {
  background: linear-gradient(135deg, #FBE9EA, #FDECEC);
  border-color: var(--accent-light);
  position: relative;
}
.ai-conv__price {
  font-size: 16px; font-weight: 700;
  color: var(--text);
  letter-spacing: -.02em;
  white-space: nowrap;
}
.ai-conv__price span {
  display: block;
  font-size: 10px; font-weight: 400;
  color: var(--text-3);
  letter-spacing: 0;
}
.ai-conv__rec {
  position: absolute; top: -8px; left: 12px;
  font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  background: var(--accent); color: #fff;
  padding: 3px 8px; border-radius: var(--r-full);
}

/* ───────── Estates (luxury property strip) ───────── */
.estates { background: var(--bg-soft); }
.estates__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  grid-template-rows: 360px;
  gap: 12px;
}
@media (max-width: 980px) { .estates__grid { grid-template-columns: 1fr 1fr; grid-template-rows: 280px 280px; } }
@media (max-width: 600px) { .estates__grid { grid-template-columns: 1fr; grid-template-rows: repeat(4, 240px); } }

.estate {
  position: relative;
  margin: 0;
  border-radius: var(--r-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-1);
  cursor: pointer;
  transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease);
}
.estate:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); }
.estate__img {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  background-color: var(--primary-dark);
  transition: transform var(--t-slow) var(--ease);
}
.estate:hover .estate__img { transform: scale(1.06); }
.estate figcaption {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 20px 22px;
  color: #fff;
  z-index: 2;
}
.estate__tag {
  display: inline-block;
  font-size: 10px; font-weight: 700; letter-spacing: 1.4px; text-transform: uppercase;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.22);
  padding: 4px 10px;
  border-radius: var(--r-full);
  margin-bottom: 8px;
  backdrop-filter: blur(6px);
  color: #fff;
}
.estate h3 { color: #fff; font-size: 18px; margin: 0 0 4px; }
.estate p { color: rgba(255,255,255,.78); font-size: 13px; margin: 0; }

/* ───────── Roles ───────── */
.role-tabs {
  display:flex; gap: 6px;
  background: var(--surface-tinted);
  padding: 6px;
  border-radius: var(--r-full);
  border: 1px solid var(--border);
  width: fit-content;
  margin: 0 auto 40px;
}
.role-tab {
  padding: 10px 22px;
  border-radius: var(--r-full);
  font-weight: 500;
  font-size: 14px;
  color: var(--text-2);
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.role-tab.is-active { background: var(--grad-1); color:#fff; box-shadow: var(--shadow-1); }
.role-panel { background: linear-gradient(180deg, var(--bg-soft), #fff); border:1px solid var(--border); border-radius: var(--r-3xl); padding: clamp(28px, 5vw, 56px); }
.role-panel h3 { font-size: clamp(24px, 3vw, 34px); }
.check { list-style: none; padding: 0; margin: 18px 0 24px; display: grid; gap: 0; }
.check li {
  position: relative;
  padding: 14px 0 14px 32px;
  color: var(--text-2);
  font-size: 15px;
  line-height: 1.55;
  letter-spacing: -.005em;
  border-bottom: 1px solid rgba(58,14,20,.06);
  transition: padding-left var(--t-med) var(--ease), color var(--t-med) var(--ease);
}
.check li:last-child { border-bottom: none; }
.check li:first-child { padding-top: 8px; }
.check li::before {
  content: '';
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%);
  width: 22px; height: 12px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 12' fill='none' stroke='%23C8932F' stroke-width='1' stroke-linecap='round' stroke-linejoin='round'><circle cx='1.5' cy='6' r='1.2' fill='%23C8932F' stroke='none'/><path d='M4 6 L19 6'/><path d='M15.2 2.6 L19 6 L15.2 9.4'/></svg>") no-repeat left center;
  background-size: contain;
  transition: width var(--t-med) var(--ease), opacity var(--t-med) var(--ease);
}
.check li::after { content: none; }
.check li:hover {
  color: var(--text);
  padding-left: 40px;
}
.check li:hover::before {
  width: 30px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 12' fill='none' stroke='%23A8771E' stroke-width='1.1' stroke-linecap='round' stroke-linejoin='round'><circle cx='1.5' cy='6' r='1.4' fill='%23A8771E' stroke='none'/><path d='M4 6 L26.5 6'/><path d='M22.5 2.4 L26.5 6 L22.5 9.6'/></svg>");
}
.check li strong { color: var(--text); font-weight: 600; }
.check li em {
  font-family: var(--font-italic);
  font-style: italic;
  font-weight: 400;
  color: var(--accent-deep);
  font-size: 1.06em;
}

/* Light variant for dark backgrounds */
.check--light li { color: rgba(255,255,255,.78); border-bottom-color: rgba(255,255,255,.10); }
.check--light li:hover { color: #fff; }
.check--light li strong { color: #fff; }

/* ───────── Tenant tier badges (Verified Renter ranks) ───────── */
.tier-row {
  display: flex; flex-wrap: wrap; align-items: center; gap: 14px;
  margin: 18px 0 10px;
  padding: 18px 20px;
  background:
    linear-gradient(180deg, #FFFEFB 0%, #FFF9F0 100%);
  border: 1px solid rgba(200,147,47,.22);
  border-radius: var(--r-xl);
  box-shadow: 0 1px 0 rgba(255,255,255,.6) inset, 0 1px 2px rgba(58,14,20,.04);
}
.tier-row__label {
  font-family: var(--font-italic);
  font-style: italic;
  font-size: 15px; font-weight: 400;
  letter-spacing: -.005em; text-transform: none;
  color: var(--text-2);
  margin-right: 6px;
  padding-right: 14px;
  border-right: 1px solid rgba(200,147,47,.22);
}
.tier {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 600;
  letter-spacing: .8px;
  padding: 8px 14px;
  border-radius: 4px;
  border: 1px solid transparent;
  white-space: nowrap;
  text-transform: uppercase;
  color: var(--text-2);
  background: transparent;
}
.tier::before { content: none; }
.tier__num {
  font-family: var(--font-italic);
  font-style: italic;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: .5px;
  color: #C8932F;
  margin-right: 2px;
}
.tier--new {
  color: var(--text-2);
  background: transparent;
  border-color: rgba(58,14,20,.10);
}
.tier--trusted {
  color: var(--text);
  background: #fff;
  border-color: rgba(58,14,20,.18);
  box-shadow: 0 1px 2px rgba(58,14,20,.06);
}
.tier--trusted .tier__num { color: var(--accent-deep); }
.tier--super {
  color: #2A1206;
  background: linear-gradient(135deg, #E5B96A 0%, #C8932F 60%, #A8771E 100%);
  border: 1px solid rgba(168,119,30,.5);
  letter-spacing: 1.2px;
  box-shadow:
    0 1px 0 rgba(255,255,255,.4) inset,
    0 0 0 1px rgba(255,255,255,.06),
    0 6px 18px rgba(168,119,30,.32),
    0 1px 2px rgba(0,0,0,.18);
  position: relative;
}
.tier--super .tier__crown {
  margin-right: 2px;
  filter: drop-shadow(0 1px 0 rgba(255,255,255,.4));
}
.tier-arrow {
  flex: none;
  width: 22px; height: 1px;
  background: linear-gradient(90deg, rgba(200,147,47,.5), rgba(200,147,47,.15));
  position: relative;
  display: inline-block;
}
.tier-arrow::after {
  content: '';
  position: absolute;
  right: -1px; top: -2px;
  width: 5px; height: 5px;
  border-top: 1px solid rgba(200,147,47,.6);
  border-right: 1px solid rgba(200,147,47,.6);
  transform: rotate(45deg);
}
.tier-caption {
  font-size: 13px; color: var(--text-3);
  margin: 4px 0 18px;
}
.tier-caption em {
  font-style: normal;
  color: var(--accent-deep);
  font-weight: 600;
  font-size: 12px;
}

@media (max-width: 600px) {
  .tier-arrow { display: none; }
}

/* ───────── Demo (app-like) ───────── */
.demo { background: var(--bg-soft); }
.demo__stage {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 56px;
  align-items: center;
}
@media (max-width: 980px) { .demo__stage { grid-template-columns: 1fr; gap: 40px; } }

.demo__captions { display: grid; gap: 10px; }
.demo__cap {
  text-align: left;
  padding: 18px 20px;
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  background: #fff;
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 4px 16px;
  align-items: center;
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.demo__cap:hover { border-color: var(--accent-light); }
.demo__cap.is-active { border-color: var(--accent); box-shadow: 0 0 0 4px rgba(183,51,68,.10); }
.demo__cap-num {
  grid-row: 1 / span 2;
  font-size: 26px; font-weight: 700; letter-spacing: -.02em;
  color: var(--accent-light);
  align-self: start;
}
.demo__cap.is-active .demo__cap-num { color: var(--accent); }
.demo__cap strong { color: var(--text); font-weight: 600; font-size: 15px; }
.demo__cap small { color: var(--text-3); font-size: 13px; }

/* ───────── Premium services ───────── */
.prem-card { display: flex; flex-direction: column; position: relative; }
.prem-card--soon { opacity: .92; }
.prem-card--soon::after {
  content: '';
  position: absolute; inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(200,147,47,.32);
  pointer-events: none;
}
.prem-card__soon {
  position: absolute;
  top: 18px; right: 18px;
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 9.5px; font-weight: 700; letter-spacing: 1.6px; text-transform: uppercase;
  color: #2A1206;
  background: linear-gradient(135deg, #E5B96A 0%, #C8932F 100%);
  padding: 4px 10px;
  border-radius: 4px;
  box-shadow: 0 1px 0 rgba(255,255,255,.4) inset, 0 4px 10px rgba(168,119,30,.22);
}
.prem-card__icon {
  width: 56px; height: 56px;
  border-radius: var(--r-lg);
  display: grid; place-items: center;
  margin-bottom: 18px;
  border: 1px solid var(--border);
}
.prem-card__icon svg { width: 24px; height: 24px; }
.prem-card__icon--shield  { background: linear-gradient(135deg, #FEF2F4, #FBE0E4); color: var(--accent-deep); }
.prem-card__icon--money   { background: linear-gradient(135deg, #FFF4E6, #FCE7CE); color: var(--warning); border-color: #F5DCC4; }
.prem-card__icon--insure  { background: linear-gradient(135deg, #E8F5F1, #D4ECE3); color: var(--success); border-color: #C9E5DA; }
.prem-card__icon--predict { background: linear-gradient(135deg, var(--surface-tinted), var(--surface-2)); color: var(--accent); }
.prem-card__icon--bond    { background: linear-gradient(135deg, #FBE9EA, #F5D6DB); color: var(--accent-deep); }
.prem-card__icon--sos     { background: linear-gradient(135deg, #FEE2E2, #FECACA); color: var(--error); border-color: #FBC8C8; }

.prem-card p { flex: 1; }
.prem-card__more {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 600; color: var(--accent);
  margin-top: 4px;
}
.prem-card__more svg { transition: transform var(--t-fast) var(--ease); }
.prem-card__more:hover svg { transform: translateX(3px); }

/* ───────── Roadmap ───────── */
.roadmap { background: var(--bg-soft); }
.timeline {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  position: relative;
}
@media (max-width: 980px) { .timeline { grid-template-columns: 1fr; } }
.timeline__item {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
  padding: 32px 28px;
  position: relative;
  transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease);
}
.timeline__item:hover { transform: translateY(-3px); box-shadow: var(--shadow-2); }
.timeline__tag {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 10.5px; font-weight: 600; letter-spacing: 2.4px; text-transform: uppercase;
  padding: 0 0 14px 0; border-radius: 0;
  border-bottom: 1px solid rgba(200,147,47,.35);
  margin-bottom: 6px;
  color: var(--accent-deep);
  background: none;
  margin-bottom: 16px;
}
.timeline__tag::before {
  content: '';
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
  flex: none;
}
.timeline__item.is-now .timeline__tag {
  color: var(--accent-deep);
}
.timeline__item.is-now .timeline__tag::before {
  background: #2F7A5E;
  box-shadow: 0 0 0 3px rgba(47,122,94,.14);
}
.timeline__item.is-soon .timeline__tag {
  color: var(--accent-deep);
}
.timeline__item.is-soon .timeline__tag::before {
  background: #C8932F;
  box-shadow: 0 0 0 3px rgba(200,147,47,.18);
}
.timeline__item.is-future .timeline__tag {
  color: var(--text-3);
}
.timeline__item.is-future .timeline__tag::before {
  background: var(--text-3);
  opacity: .55;
}
.timeline__item.is-soon {
  border-color: rgba(200,147,47,.45);
  box-shadow: 0 0 0 1px rgba(200,147,47,.12), 0 8px 24px rgba(122,20,34,.06);
}
.timeline__item.is-future { opacity: .9; }

/* ───────── How ───────── */
.steps { list-style:none; padding:0; margin:0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 980px) { .steps { grid-template-columns: 1fr; } }
.step { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-2xl); padding: 32px; position: relative; }
.step__num {
  font-size: 56px; font-weight: 700; letter-spacing: -.04em;
  color: transparent;
  -webkit-text-stroke: 1.4px var(--accent-light);
  display: block; line-height: 1; margin-bottom: 14px;
}

/* ───────── Pricing ───────── */
.pricing__grid { align-items: stretch; gap: 18px; }
.pricing__grid .price { padding: 28px 24px; }
.pricing__grid .price h3 { font-size: 19px; margin-bottom: 4px; }
.pricing__grid .price__amount { font-size: 40px; line-height: 1; margin-top: 14px; }
.pricing__grid .price__amount .price__num { display: inline-block; transition: opacity .25s ease; }
.pricing__grid .price__amount .price__sub { display: block; margin-top: 6px; font-size: 12.5px; font-weight: 400; color: var(--text-3); letter-spacing: 0; }
.pricing__grid .check { margin-top: 16px; }
.pricing__grid .check li { font-size: 13.5px; padding: 10px 0 10px 28px; }

/* Monthly / annual toggle */
.pricing__toggle {
  display: inline-flex;
  margin: 14px auto 28px;
  padding: 5px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r-full);
  box-shadow: 0 1px 2px rgba(58,14,20,.04);
  position: relative;
}
.pricing__toggle-btn {
  position: relative;
  display: inline-flex; align-items: center; gap: 8px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .2px;
  color: var(--text-3);
  background: transparent;
  border: none;
  padding: 9px 20px;
  border-radius: var(--r-full);
  cursor: pointer;
  transition: color var(--t-med) var(--ease), background var(--t-med) var(--ease);
}
.pricing__toggle-btn.is-active {
  color: var(--text);
  background: linear-gradient(180deg, #FFFFFF 0%, #FFF6F7 100%);
  box-shadow: 0 1px 0 rgba(255,255,255,.7) inset, 0 2px 6px rgba(58,14,20,.08);
}
.pricing__save {
  display: inline-flex; align-items: center;
  font-size: 9.5px; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase;
  color: #2A1206;
  background: linear-gradient(135deg, #E5B96A 0%, #C8932F 100%);
  padding: 3px 8px;
  border-radius: 4px;
  box-shadow: 0 1px 0 rgba(255,255,255,.4) inset;
}

/* Centre the toggle in the section */
.pricing .section__head--center + .pricing__toggle {
  display: inline-flex;
}
.pricing .pricing__toggle {
  display: flex;
  width: fit-content;
  margin-left: auto; margin-right: auto;
}
.pricing__foot {
  max-width: 880px;
  margin: 28px auto 0;
  padding: 18px 24px;
  border-top: 1px solid var(--border);
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--text-2);
  text-align: center;
}
.pricing__foot strong { color: var(--text); }
.price { display:flex; flex-direction: column; }
.price__amount {
  font-size: 44px; font-weight: 700; letter-spacing: -.035em;
  margin: 8px 0 18px;
  color: var(--text);
}
.price__amount span { font-size: 14px; color: var(--text-3); margin-left: 6px; font-weight: 400; letter-spacing: 0; }
.price .check { flex: 1; }
.price--featured {
  background: var(--grad-2);
  color: var(--text-on-dark);
  border-color: transparent;
  box-shadow: var(--shadow-3);
  position: relative;
  transform: translateY(-8px);
}
.price--featured h3, .price--featured .price__amount { color: var(--text-on-dark); }
.price--featured p, .price--featured .price__amount span { color: var(--text-on-dark-2); }
.price--featured .check li { color: var(--text-on-dark-2); }
.price--featured .btn--primary { background: #fff; color: var(--primary); }
.price--featured .btn--primary:hover { color: var(--accent-deep); }
.price__fine {
  margin: 12px 0 0;
  font-size: 11.5px;
  letter-spacing: .2px;
  color: var(--text-on-dark-2);
  text-align: center;
  font-family: var(--font-italic);
  font-style: italic;
}
.price:not(.price--featured) .price__fine {
  color: var(--text-3);
}
.price__flag {
  position: absolute; top: 18px; right: 18px;
  display: inline-flex; align-items: center; gap: 6px;
  background: linear-gradient(135deg, #E5B96A 0%, #C8932F 100%);
  color: #2A1206;
  padding: 6px 12px 6px 11px;
  border-radius: var(--r-full);
  font-size: 10.5px; font-weight: 800; letter-spacing: 1.4px; text-transform: uppercase;
  box-shadow:
    0 1px 0 rgba(255,255,255,.4) inset,
    0 0 0 1px rgba(255,255,255,.08),
    0 4px 14px rgba(200,147,47,.35),
    0 1px 2px rgba(0,0,0,.2);
}
.price__flag::before {
  content: '';
  width: 5px; height: 5px; border-radius: 50%;
  background: #2A1206;
  box-shadow: 0 0 0 2px rgba(42,18,6,.18);
}

/* ───────── Quotes ───────── */
.quotes .grid--3 { gap: 28px; }
.quote {
  position: relative;
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(255,247,248,.9) 0%, rgba(255,255,255,0) 55%),
    linear-gradient(180deg, #FFFFFF 0%, #FFFBFC 100%);
  border: 1px solid var(--border);
  border-radius: var(--r-2xl);
  padding: 32px 30px 28px;
  margin: 0;
  display: flex; flex-direction: column;
  box-shadow: var(--shadow-1);
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--t-med) var(--ease), box-shadow var(--t-med) var(--ease), border-color var(--t-med) var(--ease);
}
.quote::before {
  content: '"';
  position: absolute;
  top: -22px; right: 18px;
  font-family: var(--font-italic);
  font-size: 180px; line-height: 1;
  color: var(--accent);
  opacity: .07;
  pointer-events: none;
  z-index: 0;
}
.quote::after {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, var(--accent-light) 50%, transparent 100%);
  opacity: 0;
  transition: opacity var(--t-med) var(--ease);
}
.quote:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-2);
  border-color: var(--accent-light);
}
.quote:hover::after { opacity: .55; }

/* Featured first card — subtle accent treatment */
.quote--featured {
  background:
    radial-gradient(140% 90% at 100% 0%, rgba(216,85,101,.07) 0%, rgba(255,255,255,0) 50%),
    linear-gradient(180deg, #FFFFFF 0%, #FFF6F7 100%);
  border-color: rgba(183,51,68,.22);
  box-shadow: 0 1px 2px rgba(122,20,34,.06), 0 10px 28px rgba(122,20,34,.08);
}
.quote--featured::after { opacity: .35; }

.quote__tag {
  position: relative; z-index: 1;
  display: inline-flex; align-self: flex-start; align-items: baseline;
  font-family: var(--font-italic);
  font-style: italic;
  font-size: 17px;
  font-weight: 400;
  letter-spacing: -.005em;
  color: var(--accent-deep);
  margin-bottom: 14px;
  padding: 0;
  background: none;
  border: none;
  box-shadow: none;
}
.quote__tag::before {
  content: '— ';
  margin-right: 4px;
  color: #C8932F;
  font-style: normal;
  font-family: var(--font-italic);
}
/* Legacy color modifiers reduced to a single editorial treatment */
.quote__tag--switch,
.quote__tag--ai,
.quote__tag--docs,
.quote__tag--shield,
.quote__tag--prem,
.quote__tag--tradie {
  color: var(--accent-deep);
  background: none;
  border: none;
}

.quote__stars {
  position: relative; z-index: 1;
  display: flex; gap: 3px;
  margin-bottom: 16px;
  color: #C8932F;
  font-size: 11px; letter-spacing: 2px;
}
.quote__stars::after {
  content: '';
  display: inline-block;
  width: 28px; height: 1px;
  background: linear-gradient(90deg, #C8932F 0%, transparent 100%);
  align-self: center;
  margin-left: 10px;
}

.quote blockquote {
  position: relative; z-index: 1;
  flex: 1;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
  margin: 0 0 22px;
  color: var(--text);
  letter-spacing: -.005em;
}

.quote figcaption {
  position: relative; z-index: 1;
  display: flex; align-items: center; gap: 12px;
  padding-top: 18px;
  border-top: 1px solid rgba(235,211,214,.7);
  color: var(--text-2);
  font-size: 13.5px; font-weight: 500;
  letter-spacing: -.005em;
}
.quote__avatar {
  flex: none;
  width: 36px; height: 36px;
  border-radius: 50%;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--accent-light) 0%, var(--accent-deep) 100%);
  color: #fff;
  font-size: 12.5px; font-weight: 700;
  letter-spacing: .3px;
  box-shadow: 0 2px 6px rgba(122,20,34,.22), 0 0 0 3px #fff inset;
}
.quote__who { display: flex; flex-direction: column; line-height: 1.35; }
.quote__name { color: var(--text); font-weight: 600; }
.quote__meta { color: var(--text-3); font-size: 12px; font-weight: 500; }

/* ───────── Download ───────── */
.download {
  background: var(--grad-2);
  color: var(--text-on-dark);
  position: relative; overflow: hidden;
}
.download::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(800px 400px at 80% 0%, rgba(183,51,68,.4), transparent 60%),
    radial-gradient(600px 400px at 0% 100%, rgba(122,20,34,.5), transparent 60%);
}
.download__inner { position: relative; display:grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 980px) { .download__inner { grid-template-columns: 1fr; } }
.download p { color: var(--text-on-dark-2); }
.download__buttons { display:flex; gap: 14px; flex-wrap: wrap; margin: 28px 0 18px; }
.store {
  display:inline-flex; align-items: center; gap: 12px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.18);
  padding: 12px 18px; border-radius: var(--r-lg);
  color: var(--text-on-dark);
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  backdrop-filter: blur(8px);
}
.store:hover { background: rgba(255,255,255,.14); transform: translateY(-2px); border-color: rgba(255,255,255,.4); color: var(--text-on-dark); }
.store span { display:flex; flex-direction: column; line-height: 1.1; }
.store small { font-size: 10px; opacity:.7; letter-spacing: .5px; }
.store strong { font-size: 16px; font-weight: 600; }
.download__fine { font-size: 13px; color: rgba(255,255,255,.55); margin-top: 8px; }
.download__qr { display:flex; justify-content: center; }

.qr {
  width: 240px; height: 240px;
  background: #fff;
  border-radius: var(--r-2xl);
  padding: 16px;
  position: relative;
  box-shadow: 0 30px 60px rgba(0,0,0,.45);
}
.qr-grid {
  width: 100%; height: 100%;
  display: grid;
  grid-template-columns: repeat(11, 1fr);
  grid-template-rows: repeat(11, 1fr);
  gap: 2px;
}
.qr-grid span { background: var(--primary-dark); border-radius: 1px; }
.qr-grid span.off { background: transparent; }
.qr__inner {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  background: #fff;
  padding: 8px 12px;
  border-radius: var(--r-md);
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  text-align: center;
  z-index: 2;
  box-shadow: 0 2px 8px rgba(0,0,0,.12);
}
.qr__inner img { border-radius: 6px; width: 36px; height: 36px; object-fit: contain; }
.qr__inner p { color: var(--text); font-weight: 600; font-size: 11px; margin: 0; }

/* ───────── FAQ ───────── */
.faq__list { max-width: 820px; margin: 0 auto; display: grid; gap: 12px; }
.faq details {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-xl);
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.faq details[open] { border-color: var(--accent-light); box-shadow: var(--shadow-1); }
.faq summary {
  cursor: pointer; list-style: none;
  padding: 20px 24px;
  font-weight: 500; font-size: 16px;
  color: var(--text);
  display:flex; justify-content: space-between; align-items: center; gap: 14px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq .chev {
  width: 12px; height: 12px;
  border-right: 2px solid var(--text-2); border-bottom: 2px solid var(--text-2);
  transform: rotate(45deg);
  transition: transform var(--t-fast) var(--ease);
  flex-shrink: 0;
}
.faq details[open] .chev { transform: rotate(-135deg); border-color: var(--accent); }
.faq details p { padding: 0 24px 22px; margin: 0; color: var(--text-2); }

/* ───────── Final CTA ───────── */
.finalcta { background: var(--bg-soft); }
.finalcta__inner { text-align: center; }
.finalcta h2 { font-size: clamp(32px, 4vw, 56px); }
.finalcta h2 em {
  font-family: var(--font-italic);
  font-style: italic; color: var(--accent);
  font-weight: 400; letter-spacing: -.02em;
}
.finalcta__buttons { display:inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; margin-top: 18px; }

/* ───────── Footer ───────── */
.footer { background: var(--primary-dark); color: var(--text-on-dark); padding: 64px 0 28px; }
.footer__inner { display: grid; grid-template-columns: 1.2fr 2fr; gap: 48px; }
@media (max-width: 980px) { .footer__inner { grid-template-columns: 1fr; } }
.footer__brand p { color: var(--text-on-dark-2); margin-top: 10px; }
.footer__brand .brand__chip { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.18); }
.footer__brand .brand__word { color: #fff; }
.footer__cols { display:grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.footer__cols a { display:block; color: var(--text-on-dark-2); padding: 4px 0; font-size: 14px; }
.footer__cols a:hover { color: #fff; }
.footer__cols h4 { color: rgba(255,255,255,.5); }
.footer__base {
  margin-top: 56px; padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.08);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
  color: rgba(255,255,255,.5); font-size: 12px;
}

/* ───────── Phone mock (hero & demo share) ───────── */
.phone {
  width: min(380px, 94%);
  aspect-ratio: 9 / 19.5;
  background: #0d0306;
  border-radius: 56px;
  padding: 14px;
  box-shadow: var(--shadow-3), inset 0 0 0 2px rgba(255,255,255,.04);
  position: relative;
  margin: 0 auto;
}
.phone--demo {
  transform: perspective(1500px) rotateY(-6deg) rotateX(2deg);
  transition: transform var(--t-slow) var(--ease);
}
.phone--demo:hover { transform: perspective(1500px) rotateY(-2deg) rotateX(0); }
.phone__notch {
  position: absolute; top: 18px; left: 50%; transform: translateX(-50%);
  width: 110px; height: 28px; background: #000; border-radius: 20px; z-index: 2;
}
.phone__screen {
  width: 100%; height: 100%;
  background: linear-gradient(180deg, #FFF 0%, #FBE9EA 100%);
  border-radius: 44px;
  overflow: hidden;
  padding: 56px 22px 22px;
  display: flex; flex-direction: column; gap: 14px;
}
.mock-status { display:flex; justify-content: space-between; font-size: 12px; color: var(--text-2); font-weight: 600; }
.mock-greet__hello { color: var(--text-3); margin: 0; font-size: 13px; }
.mock-greet h3 { margin: 2px 0 0; font-size: 24px; color: var(--text); font-weight: 700; letter-spacing: -.02em; }
.mock-eyebrow { font-size: 10px; letter-spacing: 1.4px; color: rgba(255,255,255,.7); font-weight: 600; text-transform: uppercase; }
.mock-card { background: var(--grad-1); color:#fff; padding: 18px; border-radius: var(--r-xl); box-shadow: var(--shadow-2); }
.mock-card__head { display:flex; justify-content: space-between; align-items: center; }
.mock-pill { background: rgba(255,255,255,.18); padding: 4px 10px; border-radius: var(--r-full); font-size: 11px; font-weight: 600; }
.mock-amount { font-size: 30px; font-weight: 700; letter-spacing: -.03em; margin: 8px 0 4px; color:#fff; }
.mock-amount span { font-size: 13px; opacity: .7; margin-left: 4px; font-weight: 400; }
.mock-sub { color: rgba(255,255,255,.7); font-size: 12px; margin: 0 0 14px; }
.mock-bars { display:flex; gap:6px; align-items:flex-end; height: 36px; }
.mock-bars span { flex:1; background: rgba(255,255,255,.6); border-radius: 3px; }
.mock-row { display:flex; gap: 10px; }
.mock-mini { flex:1; background: var(--surface); border:1px solid var(--border); border-radius: var(--r-lg); padding: 12px; }
.mock-mini__label { font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 1px; margin: 0; font-weight: 600; }
.mock-mini__value { font-size: 22px; font-weight: 700; letter-spacing: -.02em; margin: 4px 0 0; color: var(--text); }
.mock-mini__value span { font-size: 11px; color: var(--text-3); margin-left: 6px; font-weight: 400; }
.mock-list { display:flex; flex-direction: column; gap: 8px; }
.mock-item { display:flex; align-items: center; gap: 10px; background: #fff; border:1px solid var(--border); padding: 10px; border-radius: var(--r-md); }
.mock-item p { margin: 0; font-size: 13px; color: var(--text); font-weight: 500; }
.mock-item small { color: var(--text-3); font-size: 11px; }
.mock-item__icon { width: 28px; height: 28px; background: var(--surface-tinted); border-radius: 8px; display:grid; place-items: center; color: var(--accent); }
.mock-item div:nth-child(2) { flex: 1; }
.mock-tag { font-size: 10px; padding: 4px 8px; border-radius: var(--r-full); background: var(--surface-2); color: var(--text-2); font-weight: 600; }
.mock-tag--ok { background: rgba(15,138,106,.12); color: var(--success); }

/* ───────── Modal ───────── */
.modal { position: fixed; inset:0; z-index: 100; display:grid; place-items: center; padding: 24px; }
.modal[hidden] { display: none; }
.modal__backdrop { position: absolute; inset: 0; background: rgba(31,6,8,.6); backdrop-filter: blur(8px); animation: fade var(--t-med) var(--ease); }
.modal__panel {
  position: relative;
  background: #fff; border-radius: var(--r-2xl);
  padding: 32px;
  max-width: 480px; width: 100%;
  box-shadow: var(--shadow-3);
  animation: pop var(--t-med) var(--ease);
}
.modal__panel h3 { margin-top: 0; }
.modal__close {
  position: absolute; top: 14px; right: 14px;
  width: 32px; height: 32px;
  display:grid; place-items: center;
  border-radius: 50%; background: var(--surface-tinted);
  font-size: 22px; color: var(--text-2);
  transition: background var(--t-fast) var(--ease);
}
.modal__close:hover { background: var(--surface-2); color: var(--text); }
.modal__body label { display:block; font-size: 13px; color: var(--text-3); margin: 14px 0 6px; font-weight: 500; }
.modal__body input, .modal__body textarea {
  width: 100%; padding: 12px 14px;
  border: 1px solid var(--border); border-radius: var(--r-md);
  font: inherit; color: var(--text);
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.modal__body input:focus, .modal__body textarea:focus {
  outline: 0; border-color: var(--accent); box-shadow: 0 0 0 4px rgba(183,51,68,.12);
}
@keyframes fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes pop { from { opacity: 0; transform: translateY(8px) scale(.98); } to { opacity: 1; transform: none; } }

/* ───────── Toast ───────── */
.toast {
  position: fixed; left: 50%; bottom: 28px; transform: translateX(-50%);
  background: var(--primary-dark); color: #fff;
  padding: 14px 20px; border-radius: var(--r-full);
  font-size: 14px; font-weight: 500;
  box-shadow: var(--shadow-3);
  z-index: 200;
  animation: slideUp var(--t-med) var(--ease);
}
.toast[hidden] { display: none; }
.toast::before {
  content:''; display:inline-block; width:8px; height:8px; border-radius:50%;
  background: var(--accent-light); margin-right:10px; vertical-align: 1px;
}
@keyframes slideUp { from { opacity: 0; transform: translate(-50%, 16px); } to { opacity: 1; transform: translate(-50%, 0); } }

/* Reveal */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity var(--t-slow) var(--ease), transform var(--t-slow) var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }

@media (max-width: 600px) {
  section { padding: 64px 0; }
  .display { font-size: 40px; }
  .price--featured { transform: none; }
}

@media (prefers-reduced-motion: reduce) {
  .orbital__ring, .satellite, .satellite span, .orbital__pulse, .brand__dot, .dot--live, .ai-conv__typing span { animation: none !important; }
}
