/* ==========================================================================
   RIFAT MATARACI — Midnight Atlas
   Deep navy / RE/MAX crimson / champagne gold. Layered, editorial, premium.
   Fraunces (display serif) + Manrope (UI sans).
   ========================================================================== */

:root {
  /* Core palette — restored navy / crimson / gold */
  --navy-900: #04080f;
  --navy-850: #060d18;
  --navy-800: #0a1424;
  --navy-700: #0e1d33;
  --navy-600: #143055;
  --navy-glass: rgba(8, 16, 28, 0.72);

  --red: #d71920;
  --red-bright: #f0353c;
  --red-dark: #9c0f16;

  --gold: #c7a15d;
  --gold-bright: #e3c485;
  --gold-deep: #9c7b3f;
  --gold-soft: rgba(199, 161, 93, 0.12);

  --ice: #f4f7fb;
  --paper: #f3f1ea;
  --white: #ffffff;

  --ink: #0a1424;
  --text-dark: #364150;
  --muted-dark: #5b6878;

  --on-dark: rgba(244, 247, 251, 0.92);
  --on-dark-soft: rgba(214, 224, 238, 0.66);
  --on-dark-faint: rgba(194, 207, 224, 0.42);
  --line-dark: rgba(199, 161, 93, 0.16);
  --line-light: rgba(10, 20, 36, 0.1);

  --serif: "Playfair Display", "Georgia", serif;
  --sans: "Outfit", system-ui, -apple-system, sans-serif;

  --gutter: max(22px, calc((100vw - 1300px) / 2));
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);

  --shadow-deep: 0 40px 90px -36px rgba(0, 0, 0, 0.72);
  --shadow-card: 0 30px 70px -34px rgba(2, 8, 18, 0.7);
  --shadow-gold: 0 24px 60px -28px rgba(199, 161, 93, 0.4);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--sans);
  font-size: 16.5px;
  line-height: 1.65;
  color: var(--on-dark);
  background: var(--navy-900);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4, blockquote { font-family: var(--serif); font-weight: 500; margin: 0; color: var(--ice); }
h1 { font-size: clamp(2.5rem, 5.2vw, 4.4rem); line-height: 1.06; letter-spacing: -0.01em; }
h2 { font-size: clamp(1.9rem, 3.4vw, 2.9rem); line-height: 1.13; letter-spacing: -0.008em; }
h3 { font-size: 1.24rem; line-height: 1.3; }
p { margin: 0; }
button { font-family: inherit; cursor: pointer; }
input, select, textarea { font-family: inherit; font-size: 1rem; }
::selection { background: var(--red); color: var(--white); }
:focus-visible { outline: 2px solid var(--gold-bright); outline-offset: 3px; }

main { display: block; }
.container { padding-inline: var(--gutter); }

/* ---------- Scroll progress bar ---------- */
.scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 300;
  height: 3px;
  width: 100%;
  transform: scaleX(0);
  transform-origin: left;
  background: linear-gradient(90deg, var(--gold-bright), var(--red-bright), var(--gold-bright));
  box-shadow: 0 0 12px rgba(199, 161, 93, 0.6);
  will-change: transform;
}

/* ---------- Hero title word reveal ---------- */
.hero-title .word {
  display: inline-block;
  opacity: 0;
  transform: translateY(0.5em) rotate(2deg);
  animation: word-rise 0.85s var(--ease-out) forwards;
  animation-delay: var(--d, 0s);
}
@keyframes word-rise {
  to { opacity: 1; transform: translateY(0) rotate(0); }
}

/* ---------- Filter card pop ---------- */
@keyframes card-pop {
  from { opacity: 0; transform: translateY(26px) scale(0.96); }
  to { opacity: 1; transform: none; }
}

/* ---------- Eyebrow ---------- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold-bright);
}
.eyebrow::before {
  content: "";
  width: 30px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold));
  flex: none;
}

.section { padding-block: clamp(76px, 9vw, 132px); }
.section-title { max-width: 740px; margin-bottom: clamp(38px, 5vw, 64px); }
.section-title h2 { margin-top: 20px; }
.section-title p { margin-top: 18px; color: var(--on-dark-soft); font-size: 1.05rem; max-width: 62ch; line-height: 1.75; }

/* ---------- Buttons ---------- */
.btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 15px 32px;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border: 1px solid transparent;
  border-radius: 2px;
  overflow: hidden;
  transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease), color 0.4s var(--ease), border-color 0.4s var(--ease), background 0.4s var(--ease);
}
.btn-large { padding: 19px 40px; font-size: 0.84rem; }
.btn::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 20%, rgba(255, 255, 255, 0.22), transparent 80%);
  transform: translateX(-120%);
  transition: transform 0.7s var(--ease);
}
.btn:hover::after { transform: translateX(120%); }

.btn-primary {
  background: linear-gradient(135deg, var(--red-bright), var(--red-dark));
  color: var(--white);
  border-color: rgba(240, 53, 60, 0.5);
  box-shadow: 0 18px 40px -16px rgba(215, 25, 32, 0.6);
}
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 26px 54px -18px rgba(215, 25, 32, 0.7); }

.btn-gold,
.valuation-section .btn-dark,
.lead-form .btn-dark {
  background: linear-gradient(135deg, var(--gold-bright), var(--gold-deep));
  color: var(--navy-900);
  border-color: var(--gold);
  box-shadow: var(--shadow-gold);
}
.btn-gold:hover,
.valuation-section .btn-dark:hover,
.lead-form .btn-dark:hover { transform: translateY(-3px); }

.btn-dark {
  background: var(--ink);
  color: var(--ice);
  border-color: rgba(199, 161, 93, 0.4);
}
.btn-dark:hover { transform: translateY(-3px); border-color: var(--gold); color: var(--gold-bright); }

.btn-light {
  background: rgba(244, 247, 251, 0.06);
  color: var(--ice);
  border-color: rgba(244, 247, 251, 0.28);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}
.btn-light:hover { transform: translateY(-3px); border-color: var(--gold); color: var(--gold-bright); }

.btn-ghost { background: transparent; color: var(--ice); border: 0; text-decoration: underline; text-underline-offset: 6px; text-decoration-color: var(--gold); }
.btn-ghost:hover { color: var(--gold-bright); }

.btn-line {
  background: transparent;
  color: var(--ice);
  border-color: rgba(199, 161, 93, 0.42);
}
.btn-line:hover { background: var(--gold); border-color: var(--gold); color: var(--navy-900); transform: translateY(-3px); }

.cta-row { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }

/* ==========================================================================
   HEADER
   ========================================================================== */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 200;
  display: flex;
  align-items: center;
  gap: 28px;
  padding: 22px var(--gutter);
  transition: background 0.45s var(--ease), padding 0.45s var(--ease), box-shadow 0.45s var(--ease), border-color 0.45s var(--ease);
  border-bottom: 1px solid transparent;
}
.site-header.is-scrolled {
  padding-block: 13px;
  background: linear-gradient(180deg, rgba(4, 8, 15, 0.92), rgba(6, 13, 24, 0.82));
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  backdrop-filter: blur(18px) saturate(140%);
  border-bottom-color: var(--line-dark);
  box-shadow: 0 20px 50px -24px rgba(0, 0, 0, 0.7);
}
.brand { display: flex; align-items: center; gap: 14px; margin-right: auto; }
.brand-mark {
  position: relative;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  font-family: var(--serif);
  font-size: 1.1rem;
  font-weight: 540;
  letter-spacing: 0.02em;
  color: var(--gold-bright);
  background: linear-gradient(150deg, rgba(199, 161, 93, 0.16), rgba(10, 20, 36, 0.4));
  border: 1px solid rgba(199, 161, 93, 0.5);
  transition: all 0.4s var(--ease);
}
.brand-mark::after {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(199, 161, 93, 0.22);
}
.brand:hover .brand-mark {
  background: linear-gradient(135deg, var(--red-bright), var(--red-dark));
  border-color: var(--red);
  color: var(--white);
}
.brand strong {
  display: block;
  font-family: var(--serif);
  font-size: 1.08rem;
  font-weight: 510;
  letter-spacing: 0.01em;
  color: var(--ice);
  line-height: 1.15;
}
.brand small {
  display: block;
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: 3px;
}
.main-nav { display: flex; align-items: center; gap: 30px; }
.main-nav a {
  position: relative;
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--on-dark-soft);
  padding-block: 6px;
  transition: color 0.3s;
}
.main-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, var(--gold), var(--gold-bright));
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.45s var(--ease);
}
.main-nav a:hover { color: var(--ice); }
.main-nav a:hover::after { transform: scaleX(1); transform-origin: left; }
.header-cta {
  position: relative;
  padding: 13px 26px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ice);
  border: 1px solid rgba(199, 161, 93, 0.5);
  overflow: hidden;
  transition: all 0.4s var(--ease);
}
.header-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--gold-bright), var(--gold-deep));
  transform: translateY(101%);
  transition: transform 0.4s var(--ease);
  z-index: -1;
}
.header-cta:hover { color: var(--navy-900); border-color: var(--gold); }
.header-cta:hover::before { transform: translateY(0); }
.nav-toggle {
  display: none;
  width: 46px;
  height: 46px;
  border: 1px solid rgba(199, 161, 93, 0.4);
  background: rgba(10, 20, 36, 0.5);
  color: var(--gold-bright);
  font-size: 1.2rem;
  line-height: 1;
}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(440px, 1.02fr);
  gap: clamp(28px, 4vw, 64px);
  align-items: end;
  min-height: 100svh;
  padding: clamp(128px, 15vh, 176px) var(--gutter) 0;
  color: var(--ice);
  overflow: hidden;
  background:
    radial-gradient(1200px 620px at 84% 8%, rgba(215, 25, 32, 0.22), transparent 58%),
    radial-gradient(900px 600px at 12% 86%, rgba(199, 161, 93, 0.12), transparent 56%),
    linear-gradient(150deg, #060d18 0%, #0a1a30 46%, #0d2649 78%, #081120 100%);
}
.hero-copy { padding-bottom: clamp(60px, 9vh, 120px); }
/* Soft transition into the next section */
.hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 180px;
  background: linear-gradient(to bottom, transparent, var(--navy-850));
  pointer-events: none;
  z-index: 1;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(rgba(199, 161, 93, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(199, 161, 93, 0.05) 1px, transparent 1px);
  background-size: 92px 92px;
  mask-image: radial-gradient(ellipse 70% 60% at 55% 42%, black 30%, transparent 80%);
  pointer-events: none;
}
.hero-atmosphere { position: absolute; inset: 0; pointer-events: none; }
.hero-atmosphere span {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  opacity: 0.5;
  animation: drift 18s ease-in-out infinite;
}
.hero-atmosphere span:nth-child(1) { top: 14%; right: 22%; width: 260px; height: 260px; background: rgba(215, 25, 32, 0.3); }
.hero-atmosphere span:nth-child(2) { bottom: 8%; left: 8%; width: 320px; height: 320px; background: rgba(199, 161, 93, 0.18); animation-delay: -6s; }
.hero-atmosphere span:nth-child(3) { top: 40%; left: 44%; width: 200px; height: 200px; background: rgba(20, 48, 85, 0.5); animation-delay: -12s; }
@keyframes drift {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(24px, -28px) scale(1.12); }
}
.ankara-skyline {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  width: 100%;
  height: clamp(110px, 16vw, 220px);
  fill: none;
  stroke: rgba(199, 161, 93, 0.18);
  stroke-width: 1.3;
  pointer-events: none;
}
.ankara-skyline path:first-child { fill: rgba(199, 161, 93, 0.04); stroke: none; }

.hero-copy { position: relative; z-index: 2; max-width: 690px; }
.hero-prelude em {
  font-style: normal;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  color: var(--gold-bright);
}
.hero-prelude em::before,
.hero-prelude em::after { content: ""; width: 28px; height: 1px; background: rgba(199, 161, 93, 0.5); }
.hero-title {
  margin-top: 26px;
  font-size: clamp(2.8rem, 5.6vw, 4.9rem);
  font-weight: 400;
  line-height: 1.03;
  letter-spacing: -0.02em;
  color: var(--ice);
}
.hero-title span { display: block; }
.hero-title span:last-child {
  font-style: italic;
  font-weight: 440;
  background: linear-gradient(100deg, var(--gold-bright), var(--gold) 60%, var(--gold-deep));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero-lead {
  margin-top: 26px;
  max-width: 52ch;
  font-size: 1.08rem;
  font-weight: 450;
  line-height: 1.78;
  color: var(--on-dark-soft);
}
.hero .cta-row { margin-top: 40px; }
.hero-text-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 28px;
  font-size: 0.86rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--on-dark-soft);
  border-bottom: 1px solid rgba(199, 161, 93, 0.4);
  padding-bottom: 4px;
  transition: all 0.3s;
}
.hero-text-link:hover { color: var(--gold-bright); border-color: var(--gold-bright); gap: 12px; }

.hero-specialty-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(16px, 2.4vw, 30px);
  margin-top: clamp(46px, 6vh, 74px);
}
.hero-specialty-cards article {
  position: relative;
  padding: 20px 18px 18px;
  background: linear-gradient(160deg, rgba(244, 247, 251, 0.045), rgba(244, 247, 251, 0.01));
  border: 1px solid rgba(244, 247, 251, 0.08);
  border-top: 1px solid rgba(199, 161, 93, 0.3);
  transition: transform 0.4s var(--ease), border-color 0.4s, background 0.4s;
}
.hero-specialty-cards article:hover {
  transform: translateY(-4px);
  border-color: rgba(199, 161, 93, 0.4);
  background: linear-gradient(160deg, rgba(199, 161, 93, 0.1), rgba(244, 247, 251, 0.02));
}
.hero-specialty-cards span { font-family: var(--serif); font-style: italic; font-size: 0.98rem; color: var(--gold-bright); }
.hero-specialty-cards strong { display: block; margin-top: 10px; font-size: 0.9rem; font-weight: 700; color: var(--ice); }
.hero-specialty-cards p { margin-top: 6px; font-size: 0.78rem; line-height: 1.55; color: var(--on-dark-faint); }

/* — Hero portrait — */
.hero-visual { position: relative; z-index: 2; align-self: end; display: flex; justify-content: center; }
.hero-orbit {
  position: absolute;
  inset: 6% -8% auto;
  aspect-ratio: 1;
  border: 1px solid rgba(199, 161, 93, 0.2);
  border-radius: 50%;
  animation: orbit-spin 54s linear infinite;
}
.hero-orbit::before {
  content: "";
  position: absolute;
  inset: 12%;
  border: 1px dashed rgba(199, 161, 93, 0.14);
  border-radius: 50%;
}
.hero-orbit::after {
  content: "";
  position: absolute;
  top: 7%;
  left: 50%;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold-bright);
  box-shadow: 0 0 20px rgba(227, 196, 133, 0.9);
}
@keyframes orbit-spin { to { transform: rotate(360deg); } }
.hero-visual picture { position: relative; z-index: 2; width: min(450px, 100%); }
.hero-portrait { width: 100%; filter: drop-shadow(0 46px 70px rgba(0, 0, 0, 0.62)); }
.portrait-glow {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 84%;
  aspect-ratio: 1;
  background: radial-gradient(circle at 50% 78%, rgba(215, 25, 32, 0.32), rgba(199, 161, 93, 0.12) 45%, transparent 68%);
  pointer-events: none;
}
.hero-panel {
  position: absolute;
  z-index: 3;
  left: clamp(-34px, -3vw, -12px);
  bottom: clamp(28px, 5vh, 62px);
  max-width: 286px;
  padding: 24px 26px;
  background: linear-gradient(160deg, rgba(10, 20, 36, 0.86), rgba(6, 13, 24, 0.78));
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(199, 161, 93, 0.34);
  box-shadow: var(--shadow-deep);
}
.hero-panel::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 9px;
  right: -9px;
  bottom: -9px;
  border: 1px solid rgba(199, 161, 93, 0.16);
  pointer-events: none;
}
.hero-panel small { font-size: 0.6rem; font-weight: 700; letter-spacing: 0.3em; color: var(--gold-bright); }
.hero-panel strong { display: block; margin-top: 8px; font-family: var(--serif); font-size: 1.32rem; font-weight: 500; color: var(--ice); }
.hero-panel span { display: block; margin-top: 8px; font-size: 0.78rem; line-height: 1.6; color: var(--on-dark-soft); }
.remax-pill {
  position: absolute;
  z-index: 3;
  top: clamp(4px, 3vh, 28px);
  right: 0;
  padding: 10px 18px;
  font-size: 0.64rem;
  font-weight: 800;
  letter-spacing: 0.26em;
  color: var(--white);
  background: linear-gradient(125deg, var(--red-bright), var(--red-dark));
  box-shadow: 0 16px 34px -12px rgba(215, 25, 32, 0.6);
}
.remax-pill::after {
  content: "";
  position: absolute;
  inset: 3px;
  border: 1px solid rgba(255, 255, 255, 0.25);
}

/* ==========================================================================
   MARQUEE
   ========================================================================== */
.expertise-marquee {
  overflow: hidden;
  background: linear-gradient(90deg, var(--navy-850), var(--navy-700), var(--navy-850));
  border-top: 1px solid var(--line-dark);
  border-bottom: 1px solid var(--line-dark);
  padding-block: 19px;
}
.expertise-marquee > div { display: flex; gap: 64px; width: max-content; animation: marquee 38s linear infinite; }
.expertise-marquee span {
  position: relative;
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.04rem;
  color: var(--on-dark-soft);
  white-space: nowrap;
}
.expertise-marquee span::after {
  content: "◆";
  position: absolute;
  right: -40px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.42rem;
  color: var(--gold);
}
@keyframes marquee { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) {
  .expertise-marquee > div, .hero-orbit, .hero-atmosphere span { animation: none; }
}

/* ==========================================================================
   CODEX EXECUTIVE POLISH
   Restores the strong strategic hero language while keeping Claude's cinematic base.
   ========================================================================== */
:root {
  --executive-red: #d71920;
  --executive-red-soft: rgba(215, 25, 32, 0.18);
  --executive-blue: #071a2f;
}

body {
  background:
    radial-gradient(circle at 75% 10%, rgba(215, 25, 32, 0.07), transparent 28%),
    var(--navy-900);
}

h1,
.hero-title,
.hero-title span,
.section-title h2,
.section-kicker h2,
.region-title-block h2,
.profile-copy h2,
.final-cta h2 {
  font-family: var(--sans);
}

.site-header {
  min-height: 82px;
  border-bottom-color: rgba(255, 255, 255, 0.09);
  background: linear-gradient(180deg, rgba(4, 8, 15, 0.88), rgba(4, 8, 15, 0.68));
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
}

.brand-mark {
  border-color: rgba(215, 25, 32, 0.55);
  background: linear-gradient(145deg, var(--executive-red), var(--red-dark));
  color: var(--white);
  box-shadow: 0 18px 42px -24px rgba(215, 25, 32, 0.9);
}

.brand strong {
  font-family: var(--sans);
  font-weight: 800;
  letter-spacing: -0.03em;
}

.main-nav a::after {
  background: var(--executive-red);
}

.header-cta {
  border-color: rgba(255, 255, 255, 0.14);
  background: linear-gradient(135deg, #e11b24, #a90f17);
  color: var(--white);
  box-shadow: 0 18px 44px -24px rgba(215, 25, 32, 0.9);
}

.hero {
  grid-template-columns: minmax(590px, 1.06fr) minmax(390px, 0.88fr);
  gap: clamp(32px, 4.6vw, 82px);
  align-items: center;
  min-height: calc(100svh - 82px);
  padding: clamp(88px, 10vh, 118px) var(--gutter) 0;
  background:
    radial-gradient(720px 520px at 73% 37%, rgba(215, 25, 32, 0.18), transparent 58%),
    radial-gradient(720px 520px at 92% 14%, rgba(52, 108, 170, 0.28), transparent 62%),
    radial-gradient(740px 520px at 8% 84%, rgba(199, 161, 93, 0.07), transparent 58%),
    linear-gradient(128deg, #030812 0%, #06182c 46%, #0b2441 100%);
}

.hero::before {
  background:
    linear-gradient(rgba(255, 255, 255, 0.038) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.032) 1px, transparent 1px),
    linear-gradient(24deg, transparent 42%, rgba(215, 25, 32, 0.16) 42.18%, transparent 42.6%),
    linear-gradient(165deg, transparent 55%, rgba(255, 255, 255, 0.1) 55.18%, transparent 55.55%);
  background-size: 94px 94px, 94px 94px, auto, auto;
  mask-image: linear-gradient(90deg, black 0%, black 82%, transparent 100%);
  opacity: 0.92;
}

.hero::after {
  height: 130px;
  background: linear-gradient(to bottom, transparent, rgba(6, 13, 24, 0.96));
}

.hero-atmosphere span:nth-child(1) {
  top: 18%;
  right: 18%;
  width: 360px;
  height: 360px;
  background: rgba(215, 25, 32, 0.22);
}

.hero-atmosphere span:nth-child(2) {
  background: rgba(30, 76, 128, 0.28);
}

.hero-copy {
  max-width: 760px;
  padding-bottom: clamp(34px, 5vh, 58px);
}

.hero-prelude em {
  color: #cbd7e6;
  letter-spacing: 0.24em;
}

.hero-prelude em::before {
  width: 42px;
  background: var(--executive-red);
}

.hero-prelude em::after {
  display: none;
}

.hero-title {
  margin-top: 22px;
  max-width: 820px;
  font-size: clamp(3.1rem, 5.25vw, 5.45rem);
  font-weight: 880;
  line-height: 0.98;
  letter-spacing: -0.065em;
  text-wrap: balance;
}

.hero-title span {
  display: block;
}

.hero-title span:nth-child(1),
.hero-title span:nth-child(2) {
  color: #ffffff;
}

.hero-title span:last-child {
  position: relative;
  display: inline-block;
  padding-bottom: 12px;
  font-style: normal;
  font-weight: 900;
  background: none;
  color: #f21f2b;
  -webkit-background-clip: initial;
  background-clip: initial;
}

.hero-title span:last-child::after {
  content: "";
  position: absolute;
  left: 0.02em;
  bottom: 0;
  width: 88%;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--executive-red), rgba(215, 25, 32, 0.08));
  transform-origin: left;
  animation: strategic-line 0.75s var(--ease-out) 0.45s both;
}

@keyframes strategic-line {
  from { opacity: 0; transform: scaleX(0); }
  to { opacity: 1; transform: scaleX(1); }
}

.hero-lead {
  max-width: 680px;
  margin-top: 24px;
  padding: 16px 20px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-left: 2px solid var(--executive-red);
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.022));
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  color: rgba(226, 235, 247, 0.86);
  font-size: clamp(1rem, 1.16vw, 1.2rem);
  line-height: 1.72;
}

.hero .cta-row {
  gap: 16px;
  margin-top: 26px;
}

.hero .btn {
  position: relative;
  min-height: 58px;
  overflow: hidden;
  border-radius: 9px;
  font-weight: 850;
  letter-spacing: -0.01em;
  transition: transform 0.26s var(--ease), box-shadow 0.26s var(--ease), border-color 0.26s var(--ease);
}

.hero .btn::after {
  content: "";
  position: absolute;
  inset: 0;
  transform: translateX(-120%);
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.22), transparent);
  transition: transform 0.58s var(--ease);
}

.hero .btn:hover {
  transform: translateY(-4px);
}

.hero .btn:hover::after {
  transform: translateX(120%);
}

.hero .btn-primary {
  background: linear-gradient(135deg, #e51b25, #aa1018);
  box-shadow: 0 22px 58px -24px rgba(215, 25, 32, 0.95);
}

.hero .btn-light {
  background: rgba(255, 255, 255, 0.95);
  color: var(--ink);
  box-shadow: 0 18px 48px -30px rgba(255, 255, 255, 0.55);
}

.hero-text-link {
  gap: 10px;
  border-bottom: 0;
  color: rgba(235, 242, 251, 0.9);
}

.hero-text-link::after {
  content: "";
  width: 30px;
  height: 1px;
  background: var(--executive-red);
  transition: transform 0.25s var(--ease), width 0.25s var(--ease);
}

.hero-text-link:hover {
  color: #ffffff;
  gap: 10px;
}

.hero-text-link:hover::after {
  width: 40px;
  transform: translateX(5px);
}

.hero-specialty-cards {
  gap: 14px;
  margin-top: clamp(28px, 4vh, 42px);
}

.hero-specialty-cards article {
  min-height: 122px;
  padding: 18px 18px 17px;
  border: 1px solid rgba(255, 255, 255, 0.105);
  border-top-color: rgba(255, 255, 255, 0.105);
  border-radius: 12px;
  background:
    radial-gradient(circle at 82% 12%, rgba(215, 25, 32, 0.1), transparent 35%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.085), rgba(255, 255, 255, 0.025));
  -webkit-backdrop-filter: blur(15px);
  backdrop-filter: blur(15px);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.hero-specialty-cards article::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 2px;
  background: rgba(255, 255, 255, 0.12);
  transition: background 0.25s var(--ease);
}

.hero-specialty-cards article:hover {
  transform: translateY(-6px);
  border-color: rgba(215, 25, 32, 0.48);
  background:
    radial-gradient(circle at 82% 12%, rgba(215, 25, 32, 0.16), transparent 35%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.105), rgba(255, 255, 255, 0.032));
  box-shadow: 0 24px 58px -34px rgba(0, 0, 0, 0.9);
}

.hero-specialty-cards article:hover::before {
  background: var(--executive-red);
}

.hero-specialty-cards span {
  font-family: var(--sans);
  font-style: normal;
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  color: rgba(255, 255, 255, 0.42);
}

.hero-specialty-cards strong {
  margin-top: 12px;
  font-size: 1.02rem;
  line-height: 1.18;
  letter-spacing: -0.02em;
}

.hero-specialty-cards p {
  margin-top: 8px;
  font-size: 0.85rem;
  color: rgba(205, 218, 235, 0.68);
}

.hero-visual {
  align-self: stretch;
  align-items: flex-end;
  min-height: min(650px, calc(100svh - 86px));
}

.hero-orbit {
  inset: 8% -4% auto 2%;
  border-radius: 22px;
  transform: rotate(-8deg);
  animation: none;
  border-color: rgba(255, 255, 255, 0.1);
}

.hero-orbit::before {
  border-radius: 18px;
  border-style: solid;
  border-color: rgba(215, 25, 32, 0.14);
}

.hero-orbit::after {
  display: none;
}

.hero-visual picture {
  width: min(520px, 94%);
  filter: drop-shadow(0 48px 72px rgba(0, 0, 0, 0.48));
}

.hero-visual picture::after {
  content: "";
  position: absolute;
  left: 3%;
  right: 3%;
  bottom: 0;
  height: 27%;
  background: linear-gradient(180deg, transparent, rgba(6, 13, 24, 0.92));
  pointer-events: none;
}

.hero-portrait {
  width: 100%;
}

.portrait-glow {
  width: min(560px, 88%);
  bottom: 8%;
  background:
    radial-gradient(circle at 50% 45%, rgba(255, 255, 255, 0.13), transparent 30%),
    radial-gradient(circle at 54% 56%, rgba(215, 25, 32, 0.25), transparent 56%),
    radial-gradient(circle at 68% 42%, rgba(38, 94, 160, 0.42), transparent 66%);
  filter: blur(22px);
  animation: portrait-breath 6s ease-in-out infinite;
}

@keyframes portrait-breath {
  0%, 100% { opacity: 0.72; transform: translateX(-50%) scale(1); }
  50% { opacity: 0.88; transform: translateX(-50%) scale(1.025); }
}

.hero-panel {
  left: clamp(-8px, -1vw, 0px);
  bottom: clamp(28px, 5vh, 62px);
  max-width: 345px;
  padding: 24px 27px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-left: 3px solid var(--executive-red);
  border-radius: 12px;
  background: rgba(247, 249, 252, 0.88);
  color: var(--ink);
  box-shadow: 0 30px 70px -38px rgba(0, 0, 0, 0.92);
}

.hero-panel::before {
  display: none;
}

.hero-panel small {
  color: var(--executive-red);
  letter-spacing: 0.18em;
}

.hero-panel strong {
  font-family: var(--sans);
  font-size: 1.7rem;
  font-weight: 850;
  letter-spacing: -0.045em;
  color: var(--ink);
}

.hero-panel span {
  color: rgba(54, 65, 80, 0.74);
  font-size: 0.92rem;
}

.remax-pill {
  top: clamp(18px, 6vh, 62px);
  right: clamp(6px, 2vw, 28px);
  display: inline-flex;
  align-items: center;
  gap: 9px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.9);
  color: var(--ink);
  box-shadow: 0 20px 48px -34px rgba(0, 0, 0, 0.65);
}

.remax-pill::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--executive-red);
}

.remax-pill::after {
  display: none;
}

.expertise-marquee {
  padding-block: 11px;
  background: rgba(7, 18, 33, 0.94);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  border-top: 1px solid rgba(215, 25, 32, 0.22);
  border-bottom-color: rgba(255, 255, 255, 0.07);
}

.expertise-marquee span {
  font-family: var(--sans);
  font-style: normal;
  font-size: 0.68rem;
  font-weight: 850;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(235, 242, 251, 0.68);
}

.expertise-marquee span::after {
  content: "";
  right: -37px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--executive-red);
  opacity: 0.82;
}

@media (max-width: 1120px) {
  .hero {
    grid-template-columns: 1fr;
    min-height: auto;
    padding-top: 112px;
  }

  .hero-copy {
    max-width: 860px;
    padding-bottom: 20px;
  }

  .hero-visual {
    min-height: 560px;
  }

  .hero-specialty-cards {
    max-width: 860px;
  }
}

@media (max-width: 720px) {
  .site-header {
    min-height: 72px;
  }

  .hero {
    padding-top: 92px;
  }

  .hero-title {
    font-size: clamp(2.55rem, 12vw, 4.2rem);
    line-height: 1.01;
    letter-spacing: -0.055em;
  }

  .hero-title span:last-child {
    padding-bottom: 8px;
  }

  .hero-title span:last-child::after {
    height: 2px;
  }

  .hero-lead {
    padding: 16px;
    font-size: 0.98rem;
  }

  .hero .cta-row {
    display: grid;
    gap: 12px;
  }

  .hero .btn {
    width: 100%;
  }

  .hero-specialty-cards {
    grid-template-columns: 1fr;
  }

  .hero-visual {
    min-height: 445px;
  }

  .hero-visual picture {
    width: min(390px, 94%);
  }

  .hero-panel {
    left: 0;
    bottom: 18px;
    max-width: min(335px, 92%);
  }
}

/* Client direction: midnight, gold and silver premium identity */
:root {
  --client-midnight: #020813;
  --client-night: #071528;
  --client-blue: #102a49;
  --client-gold: #d6b46d;
  --client-gold-soft: #f1d89a;
  --client-silver: #c8d0da;
  --client-silver-muted: rgba(200, 208, 218, 0.68);
  --client-line: rgba(200, 208, 218, 0.16);
  --client-glass: rgba(9, 22, 39, 0.74);
  --red: var(--client-gold);
  --red-bright: var(--client-gold-soft);
  --red-dark: #9b7938;
  --executive-red: var(--client-gold);
}

body {
  background:
    radial-gradient(900px 520px at 78% 0%, rgba(42, 84, 132, 0.24), transparent 64%),
    radial-gradient(680px 420px at 8% 14%, rgba(214, 180, 109, 0.08), transparent 62%),
    linear-gradient(180deg, #020813 0%, #040914 48%, #020711 100%) !important;
  color: #f6f8fb;
}

.site-header,
.mobile-panel {
  background: rgba(2, 8, 19, 0.88) !important;
  border-color: rgba(200, 208, 218, 0.12) !important;
  backdrop-filter: blur(18px);
}

.brand-mark {
  background: linear-gradient(145deg, #112a4a, #040914) !important;
  border: 1px solid rgba(214, 180, 109, 0.5) !important;
  color: var(--client-gold-soft) !important;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.32), inset 0 0 0 1px rgba(255, 255, 255, 0.06) !important;
}

.nav a::after,
.mobile-panel a::after {
  background: linear-gradient(90deg, transparent, var(--client-gold), transparent) !important;
}

.header-cta,
.btn-primary,
.lead-form .btn-dark,
.lead-form .btn-primary {
  border-color: rgba(214, 180, 109, 0.48) !important;
  background:
    linear-gradient(135deg, #f3dda2 0%, #d6b46d 48%, #a9813a 100%) !important;
  color: #06101f !important;
  box-shadow: 0 18px 46px rgba(214, 180, 109, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.42) !important;
}

.btn-light {
  border-color: rgba(200, 208, 218, 0.24) !important;
  background: linear-gradient(135deg, rgba(246, 248, 251, 0.96), rgba(200, 208, 218, 0.9)) !important;
  color: #06101f !important;
}

.btn-line,
.portfolio-card .btn-line,
.profile-socials a {
  border-color: rgba(200, 208, 218, 0.22) !important;
  color: #edf2f8 !important;
  background: rgba(255, 255, 255, 0.035) !important;
}

.hero {
  min-height: calc(100svh - 82px) !important;
  background:
    radial-gradient(780px 620px at 76% 38%, rgba(59, 102, 157, 0.34), transparent 66%),
    radial-gradient(520px 420px at 61% 45%, rgba(214, 180, 109, 0.11), transparent 62%),
    radial-gradient(640px 460px at 20% 28%, rgba(12, 42, 78, 0.54), transparent 70%),
    linear-gradient(rgba(200, 208, 218, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200, 208, 218, 0.03) 1px, transparent 1px),
    #020813 !important;
  background-size: auto, auto, auto, 86px 86px, 86px 86px, auto !important;
}

.hero::before,
.hero::after {
  opacity: 0.5 !important;
  filter: saturate(0.65);
}

.hero-prelude {
  color: var(--client-silver) !important;
}

.hero-prelude::before {
  background: linear-gradient(90deg, var(--client-gold), rgba(214, 180, 109, 0)) !important;
}

.hero-title {
  max-width: 920px;
  letter-spacing: -0.045em !important;
  color: #f8fbff !important;
  text-wrap: balance;
}

.hero-title span:nth-child(1),
.hero-title span:nth-child(2) {
  color: #f8fbff !important;
  text-shadow: 0 16px 48px rgba(0, 0, 0, 0.24);
}

.hero-title span:last-child {
  color: var(--client-gold-soft) !important;
  text-shadow: 0 18px 42px rgba(214, 180, 109, 0.13) !important;
}

.hero-title span:last-child::after {
  background: linear-gradient(90deg, var(--client-gold), rgba(200, 208, 218, 0.44), transparent) !important;
  opacity: 0.75 !important;
}

.hero-lead {
  border-left-color: var(--client-gold) !important;
  background: linear-gradient(135deg, rgba(9, 22, 39, 0.7), rgba(255, 255, 255, 0.035)) !important;
  color: rgba(240, 245, 251, 0.84) !important;
  box-shadow: inset 0 0 0 1px rgba(200, 208, 218, 0.1) !important;
}

.hero-text-link,
.portfolio-card a,
.article-card a,
.featured-article a,
.audience-grid a,
.region-card em {
  color: var(--client-gold-soft) !important;
  text-decoration-color: rgba(214, 180, 109, 0.54) !important;
}

.hero-specialty-cards article,
.profile-badges article,
.audience-grid article,
.process-timeline article,
.decision-grid article,
.region-card,
.portfolio-card,
.article-card,
.testimonial-grid blockquote {
  border-color: rgba(200, 208, 218, 0.14) !important;
  background:
    linear-gradient(150deg, rgba(13, 31, 54, 0.82), rgba(4, 10, 20, 0.78)) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.055), 0 24px 70px rgba(0, 0, 0, 0.22) !important;
}

.hero-specialty-cards article::before,
.profile-badges article::before,
.portfolio-card::before,
.region-card::before {
  background: linear-gradient(90deg, var(--client-gold), rgba(200, 208, 218, 0)) !important;
}

.hero-specialty-cards article:hover,
.profile-badges article:hover,
.process-timeline article:hover,
.audience-grid article:hover,
.region-card:hover {
  border-color: rgba(214, 180, 109, 0.5) !important;
  transform: translateY(-6px);
  box-shadow: 0 30px 92px rgba(0, 0, 0, 0.34), 0 0 0 1px rgba(214, 180, 109, 0.12) !important;
}

.hero-specialty-cards span,
.profile-badges span,
.process-timeline span,
.audience-grid span {
  color: rgba(214, 180, 109, 0.88) !important;
}

.hero-specialty-cards p,
.profile-badges p,
.process-timeline p,
.audience-grid p,
.decision-grid p {
  color: var(--client-silver-muted) !important;
}

.hero-visual {
  filter: saturate(0.98);
}

.hero-visual picture::before {
  background:
    radial-gradient(circle at 50% 24%, rgba(241, 216, 154, 0.2), transparent 22%),
    radial-gradient(circle at 56% 54%, rgba(45, 92, 145, 0.3), transparent 48%) !important;
  opacity: 0.72 !important;
}

.hero-visual picture::after {
  background:
    linear-gradient(106deg, transparent 0 34%, rgba(255, 255, 255, 0.1) 43%, transparent 52%),
    radial-gradient(420px 220px at 76% 18%, rgba(241, 216, 154, 0.18), transparent 68%) !important;
  mix-blend-mode: screen !important;
  opacity: 0.34 !important;
}

.portrait-glow {
  background:
    radial-gradient(circle at 50% 36%, rgba(214, 180, 109, 0.2), transparent 34%),
    radial-gradient(circle at 56% 58%, rgba(39, 89, 148, 0.32), transparent 60%) !important;
}

.hero-panel {
  border-color: rgba(200, 208, 218, 0.2) !important;
  background:
    linear-gradient(135deg, rgba(8, 20, 36, 0.92), rgba(2, 8, 19, 0.82)) !important;
  color: #f7fbff !important;
  box-shadow: 0 24px 86px rgba(0, 0, 0, 0.34), inset 4px 0 0 rgba(214, 180, 109, 0.82) !important;
}

.hero-panel small {
  color: var(--client-gold-soft) !important;
}

.hero-panel strong {
  color: #fff !important;
}

.hero-panel span {
  color: rgba(235, 241, 248, 0.78) !important;
}

.remax-pill {
  overflow: hidden;
  width: 168px !important;
  min-height: 66px !important;
  padding: 8px 14px !important;
  border-color: rgba(200, 208, 218, 0.26) !important;
  background: rgba(255, 255, 255, 0.94) !important;
  box-shadow: 0 18px 52px rgba(0, 0, 0, 0.22), 0 0 0 1px rgba(214, 180, 109, 0.12) !important;
}

.remax-pill img {
  display: block;
  width: 100%;
  height: 100%;
  max-height: 54px;
  object-fit: contain;
}

.expertise-marquee {
  border-color: rgba(214, 180, 109, 0.18) !important;
  background: linear-gradient(90deg, rgba(4, 12, 24, 0.98), rgba(12, 28, 48, 0.98), rgba(4, 12, 24, 0.98)) !important;
}

.expertise-marquee span {
  color: rgba(235, 241, 248, 0.78) !important;
}

.profile-section {
  background:
    radial-gradient(720px 420px at 18% 42%, rgba(214, 180, 109, 0.1), transparent 62%),
    radial-gradient(900px 560px at 82% 18%, rgba(42, 84, 132, 0.22), transparent 66%),
    linear-gradient(rgba(200, 208, 218, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200, 208, 218, 0.022) 1px, transparent 1px),
    #020813 !important;
  background-size: auto, auto, 86px 86px, 86px 86px, auto !important;
  border-block: 1px solid rgba(200, 208, 218, 0.1);
}

.profile-section::before {
  background: linear-gradient(90deg, rgba(214, 180, 109, 0.25), transparent) !important;
}

.engineering-portrait {
  width: min(540px, 42vw) !important;
  min-height: 640px !important;
  border-radius: 26px !important;
  overflow: hidden !important;
  border: 1px solid rgba(214, 180, 109, 0.36) !important;
  background: linear-gradient(145deg, rgba(16, 42, 73, 0.82), rgba(3, 10, 21, 0.96)) !important;
  box-shadow: 0 36px 110px rgba(0, 0, 0, 0.42), inset 0 0 0 1px rgba(255, 255, 255, 0.055) !important;
}

.engineering-portrait::before {
  content: "";
  position: absolute;
  inset: -1px;
  z-index: 1;
  background:
    linear-gradient(180deg, transparent 58%, rgba(2, 8, 19, 0.9) 100%),
    radial-gradient(420px 260px at 72% 18%, rgba(214, 180, 109, 0.14), transparent 64%);
  pointer-events: none;
}

.engineering-portrait picture,
.engineering-portrait img {
  width: 100% !important;
  height: 100% !important;
  min-height: 640px !important;
}

.engineering-portrait img {
  object-fit: cover !important;
  object-position: center top !important;
  transform: none !important;
  filter: saturate(0.96) contrast(1.02);
}

.engineering-portrait span {
  z-index: 2;
  left: 24px !important;
  bottom: 24px !important;
  background: linear-gradient(135deg, rgba(241, 216, 154, 0.96), rgba(198, 158, 82, 0.96)) !important;
  color: #06101f !important;
  border: 1px solid rgba(255, 255, 255, 0.22) !important;
}

.profile-copy .eyebrow,
.section-title .eyebrow,
.section-kicker .eyebrow,
.region-head .eyebrow,
.decision-copy .eyebrow,
.valuation-section .eyebrow {
  color: var(--client-gold-soft) !important;
}

.profile-copy h2,
.section-title h2,
.section-kicker h2,
.decision-copy h2,
.region-title-block h2,
.valuation-section h2,
.text-hero h1 {
  color: #f7fbff !important;
  text-wrap: balance;
}

.profile-copy p,
.section-title p,
.section-kicker p,
.decision-copy p,
.region-intro p,
.valuation-section p,
.text-hero p {
  color: var(--client-silver-muted) !important;
}

.profile-name {
  border-color: rgba(214, 180, 109, 0.2) !important;
  background: rgba(255, 255, 255, 0.035) !important;
}

.profile-name strong {
  color: #fff !important;
}

.profile-name span {
  color: var(--client-silver-muted) !important;
}

.lead-form {
  background:
    radial-gradient(520px 260px at 14% 0%, rgba(42, 84, 132, 0.2), transparent 64%),
    radial-gradient(420px 240px at 100% 100%, rgba(214, 180, 109, 0.1), transparent 66%),
    linear-gradient(155deg, rgba(13, 31, 54, 0.94), rgba(5, 12, 23, 0.9)) !important;
}

.lead-form::before {
  background:
    linear-gradient(90deg, var(--client-gold), rgba(214, 180, 109, 0)) 0 0 / 120px 2px no-repeat,
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), transparent 36%) !important;
}

.form-progress span.active,
.choice-grid input:checked + span {
  border-color: rgba(214, 180, 109, 0.58) !important;
  background:
    radial-gradient(circle at 32% 24%, rgba(255, 255, 255, 0.28), transparent 32%),
    linear-gradient(135deg, #f1d89a, #a9813a) !important;
  color: #06101f !important;
  box-shadow: 0 16px 38px rgba(214, 180, 109, 0.22) !important;
}

.lead-form input:focus,
.lead-form select:focus,
.lead-form textarea:focus {
  border-color: rgba(214, 180, 109, 0.52) !important;
  box-shadow: 0 0 0 4px rgba(214, 180, 109, 0.12) !important;
}

.about-engineering-page {
  display: grid;
  grid-template-columns: minmax(280px, 420px) 1fr;
  gap: clamp(30px, 5vw, 70px);
  align-items: center;
}

.about-engineering-page img {
  width: 100%;
  max-height: 560px;
  object-fit: cover;
  object-position: center top;
  border-radius: 24px;
  border: 1px solid rgba(214, 180, 109, 0.34);
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.32);
}

.about-engineering-page h2 {
  color: #f7fbff;
  font-size: clamp(1.8rem, 3.2vw, 3.4rem);
  line-height: 1.02;
  letter-spacing: -0.035em;
}

@media (max-width: 980px) {
  .hero {
    min-height: auto !important;
  }

  .hero-title {
    font-size: clamp(2.2rem, 10vw, 4.1rem) !important;
    letter-spacing: -0.04em !important;
  }

  .hero-copy {
    padding-top: clamp(26px, 8vw, 64px) !important;
  }

  .hero-specialty-cards {
    grid-template-columns: 1fr !important;
  }

  .engineering-portrait {
    width: min(520px, 100%) !important;
    min-height: 540px !important;
  }

  .engineering-portrait picture,
  .engineering-portrait img {
    min-height: 540px !important;
  }

  .about-engineering-page {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .site-header {
    min-height: 86px !important;
  }

  .brand-text strong {
    font-size: 1.02rem !important;
  }

  .brand-text span {
    letter-spacing: 0.22em !important;
  }

  .hero {
    padding-inline: 18px !important;
  }

  .hero-title {
    max-width: 100%;
    font-size: clamp(2.05rem, 12vw, 3.45rem) !important;
  }

  .hero-title span {
    overflow-wrap: anywhere;
  }

  .hero-lead {
    padding: 20px 18px !important;
    font-size: 1rem !important;
  }

  .cta-row {
    gap: 12px !important;
  }

  .cta-row .btn {
    width: 100%;
  }

  .hero-visual {
    min-height: 620px !important;
    overflow: hidden !important;
  }

  .hero-visual picture {
    width: min(410px, 96vw) !important;
    transform: translateX(-34px) !important;
  }

  .hero-visual:hover picture {
    transform: translateX(-34px) !important;
  }

  .hero-panel {
    left: 14px !important;
    right: 14px !important;
    bottom: 18px !important;
    width: auto !important;
    max-width: none !important;
  }

  .remax-pill {
    top: 10px !important;
    right: 12px !important;
    width: 126px !important;
    min-height: 50px !important;
  }

  .profile-section {
    padding-inline: 18px !important;
  }

  .engineering-portrait {
    min-height: 420px !important;
  }

  .engineering-portrait picture,
  .engineering-portrait img {
    min-height: 420px !important;
  }

  .profile-badges {
    grid-template-columns: 1fr !important;
  }
}

/* Footer external listing links */
.site-footer .footer-listing-links {
  display: grid;
  gap: 10px;
  min-width: min(260px, 100%);
  padding: 18px 20px;
  border: 1px solid rgba(214, 180, 109, 0.22);
  border-radius: 18px;
  background:
    radial-gradient(220px 120px at 0% 0%, rgba(214, 180, 109, 0.08), transparent 66%),
    rgba(255, 255, 255, 0.035);
}

.site-footer .footer-listing-links span {
  color: var(--client-gold-soft);
  font-size: 0.68rem;
  font-weight: 850;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.site-footer .footer-listing-links a {
  color: rgba(235, 241, 248, 0.84);
  font-size: 0.9rem;
  line-height: 1.35;
  transition: color 0.25s var(--ease), transform 0.25s var(--ease);
}

.site-footer .footer-listing-links a:hover {
  color: var(--client-gold-soft);
  transform: translateX(4px);
}

@media (max-width: 760px) {
  .site-footer .footer-listing-links {
    width: 100%;
  }
}

/* ==========================================================================
   CANER DIRECTION PASS
   Less gold, more navy / white / RE/MAX red. Stronger hero, 3D portrait,
   cleaner decision, audience and trust sections.
   ========================================================================== */
:root {
  --gold: #7c8aa0;
  --gold-bright: #dbe7f7;
  --gold-deep: #53667f;
  --gold-soft: rgba(85, 115, 152, 0.12);
  --line-dark: rgba(255, 255, 255, 0.1);
}

.eyebrow {
  color: rgba(235, 242, 251, 0.78);
}

.eyebrow::before {
  background: linear-gradient(90deg, transparent, var(--executive-red));
}

.scroll-progress {
  background: linear-gradient(90deg, var(--executive-red), #ffffff, #2d6ea9);
}

/* Hero: stronger portrait stage + minimal animated headline */
.hero {
  grid-template-columns: minmax(560px, 1fr) minmax(480px, 0.96fr);
  background:
    radial-gradient(760px 560px at 76% 28%, rgba(215, 25, 32, 0.2), transparent 60%),
    radial-gradient(860px 600px at 92% 14%, rgba(48, 110, 178, 0.34), transparent 64%),
    linear-gradient(rgba(255,255,255,.036) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(128deg, #020711 0%, #06182c 48%, #0a2442 100%);
  background-size: auto, auto, 88px 88px, 88px 88px, auto;
}

.hero-title {
  font-size: clamp(3rem, 4.75vw, 5.15rem);
  line-height: 0.99;
  letter-spacing: -0.06em;
}

.hero-title .word {
  opacity: 0;
  transform: translateY(0.95em);
  clip-path: inset(0 0 100% 0);
  animation: word-mask-rise 0.9s var(--ease-out) forwards;
  animation-delay: var(--d, 0s);
}

@keyframes word-mask-rise {
  0% {
    opacity: 0;
    transform: translateY(0.95em);
    clip-path: inset(0 0 100% 0);
    filter: blur(8px);
  }
  65% {
    opacity: 1;
    clip-path: inset(0 0 0 0);
    filter: blur(0);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    clip-path: inset(0 0 0 0);
    filter: blur(0);
  }
}

.hero-title span:last-child {
  color: #ff2833;
}

.hero-title span:last-child::after {
  height: 2px;
  width: 78%;
  background: linear-gradient(90deg, #ff2833, rgba(255, 40, 51, 0));
}

.hero-visual {
  min-height: min(700px, calc(100svh - 64px));
  align-items: flex-start;
  padding-top: clamp(26px, 5vh, 54px);
}

.hero-visual picture {
  width: min(640px, 108%);
  margin-top: -42px;
  margin-right: -28px;
  filter: drop-shadow(0 54px 82px rgba(0, 0, 0, 0.58));
  transition: filter 0.35s var(--ease), scale 0.35s var(--ease);
}

.hero-visual picture::before {
  content: "";
  position: absolute;
  inset: -8% -20% 0 -18%;
  z-index: 4;
  pointer-events: none;
  background: linear-gradient(112deg, transparent 35%, rgba(255,255,255,.34) 47%, transparent 59%);
  mix-blend-mode: screen;
  opacity: 0;
  transform: translateX(-45%) skewX(-10deg);
  transition: opacity .25s var(--ease), transform .85s var(--ease);
}

.hero-visual:hover picture::before {
  opacity: 0.7;
  transform: translateX(52%) skewX(-10deg);
}

.hero-visual:hover picture {
  filter: drop-shadow(0 62px 90px rgba(0, 0, 0, 0.62)) brightness(1.06) contrast(1.03);
}

.portrait-glow {
  width: min(680px, 100%);
  bottom: 13%;
  background:
    radial-gradient(circle at 48% 35%, rgba(255,255,255,.18), transparent 25%),
    radial-gradient(circle at 51% 48%, rgba(215,25,32,.28), transparent 52%),
    radial-gradient(circle at 70% 38%, rgba(31,104,180,.48), transparent 67%);
}

.remax-pill {
  top: clamp(8px, 3vh, 24px);
  right: clamp(6px, 1.2vw, 18px);
}

.hero-panel {
  bottom: clamp(18px, 3.8vh, 44px);
  left: clamp(-24px, -2.2vw, -10px);
}

/* Decision section: remove heavy gold grid, make it cleaner and more premium */
.decision-section {
  position: relative;
  gap: clamp(48px, 7vw, 92px);
  background:
    radial-gradient(circle at 78% 18%, rgba(32, 94, 158, 0.16), transparent 30%),
    linear-gradient(135deg, #020710 0%, #06111f 100%);
}

.decision-copy h2 {
  font-family: var(--sans);
  max-width: 680px;
  font-size: clamp(2.6rem, 4.6vw, 5.2rem);
  font-weight: 780;
  line-height: 1.02;
  letter-spacing: -0.055em;
}

.decision-copy p {
  color: rgba(214, 226, 242, 0.7);
}

.decision-grid {
  gap: 14px;
  padding: 0;
  border: 0;
  background: transparent;
}

.decision-grid article {
  min-height: 205px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 16px;
  background:
    radial-gradient(circle at 86% 14%, rgba(215,25,32,.08), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.024));
  backdrop-filter: blur(14px);
}

.decision-grid article:last-child {
  grid-column: span 2;
  min-height: 170px;
}

.decision-grid article:hover {
  border-color: rgba(215, 25, 32, 0.5);
  background:
    radial-gradient(circle at 86% 14%, rgba(215,25,32,.16), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.095), rgba(255,255,255,.03));
}

.decision-grid article span {
  width: 34px;
  height: 2px;
  background: var(--executive-red);
}

.decision-grid h3 {
  font-family: var(--sans);
  font-size: 1.15rem;
  font-weight: 800;
}

.decision-grid p {
  color: rgba(199, 214, 234, 0.62);
}

/* Profile: portrait breaks out like a 3D cutout */
.profile-section {
  background:
    radial-gradient(circle at 22% 36%, rgba(215,25,32,.13), transparent 28%),
    radial-gradient(circle at 78% 12%, rgba(46,111,180,.16), transparent 30%),
    #020710;
}

.profile-visual {
  perspective: 1100px;
}

.profile-portrait {
  width: min(500px, 100%);
  min-height: 610px;
  overflow: visible;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 18px;
  background:
    linear-gradient(160deg, rgba(8,28,52,.96), rgba(3,10,20,.98));
  box-shadow: 0 42px 90px -45px rgba(0,0,0,.95);
  transform: rotateY(-7deg) rotateX(2deg);
  transform-style: preserve-3d;
}

.profile-portrait::before {
  inset: 18px -18px -18px 18px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 14px;
  transform: translateZ(-28px);
}

.profile-portrait::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  z-index: 3;
  height: 36%;
  background: linear-gradient(180deg, transparent, rgba(2,7,16,.94));
  pointer-events: none;
}

.profile-portrait img {
  width: 118%;
  max-width: none;
  margin-left: -8%;
  transform: translateY(-54px) translateZ(70px) scale(1.04);
  filter: drop-shadow(26px 34px 38px rgba(0,0,0,.42));
}

.profile-portrait span {
  left: 20px;
  bottom: 22px;
  z-index: 4;
  border-radius: 8px;
  background: linear-gradient(135deg, #e51b25, #a90f17);
}

.profile-copy h2,
.profile-name strong,
.profile-badges strong {
  font-family: var(--sans);
}

.profile-copy h2 {
  font-weight: 780;
  letter-spacing: -0.052em;
}

.profile-badges span {
  font-family: var(--sans);
  font-style: normal;
  color: rgba(255,255,255,.44);
}

/* Audience: cleaner blue/red/white cards */
.audience-section {
  background:
    radial-gradient(circle at 88% 20%, rgba(32,94,158,.14), transparent 32%),
    #020710;
}

.audience-section .section-title h2 {
  font-family: var(--sans);
  font-size: clamp(2.5rem, 4.6vw, 4.7rem);
  font-weight: 760;
  letter-spacing: -0.055em;
  max-width: 850px;
}

.audience-grid article {
  border-radius: 18px;
  border-color: rgba(255,255,255,.1);
  background:
    radial-gradient(circle at 84% 12%, rgba(215,25,32,.08), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
}

.audience-grid article::before {
  background: linear-gradient(90deg, var(--executive-red), rgba(215,25,32,0));
}

.audience-grid article:hover {
  border-color: rgba(215,25,32,.48);
}

.audience-grid span {
  font-family: var(--sans);
  font-style: normal;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: .18em;
  color: rgba(255,255,255,.42);
}

.audience-grid h3 {
  font-family: var(--sans);
  font-size: 1.35rem;
  font-weight: 820;
}

.audience-grid a {
  color: #fff;
  border-bottom-color: var(--executive-red);
}

/* Trust board: less serif/gold, more confident testimonial cards */
.trust-board blockquote,
.testimonial-grid blockquote {
  border-radius: 18px;
  border-color: rgba(255,255,255,.1);
  background:
    radial-gradient(circle at 14% 0%, rgba(215,25,32,.12), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.07), rgba(255,255,255,.024));
}

.trust-board .featured-quote {
  background:
    radial-gradient(circle at 14% 0%, rgba(215,25,32,.18), transparent 35%),
    linear-gradient(145deg, rgba(255,255,255,.085), rgba(255,255,255,.026));
}

.trust-board blockquote::before,
.testimonial-grid blockquote::before {
  color: rgba(255,255,255,.08);
}

.trust-board blockquote p,
.testimonial-grid blockquote p {
  font-family: var(--sans);
  font-style: normal;
  font-size: 1.05rem;
  font-weight: 560;
  color: rgba(242,246,252,.9);
}

.trust-board cite,
.testimonial-grid cite {
  color: #ffffff;
  letter-spacing: .08em;
}

.trust-board cite::before,
.testimonial-grid cite::before {
  content: "";
  display: inline-block;
  width: 22px;
  height: 2px;
  margin-right: 9px;
  vertical-align: middle;
  background: var(--executive-red);
}

@media (max-width: 1120px) {
  .hero-visual picture {
    margin-top: -18px;
    margin-right: 0;
  }

  .decision-grid article:last-child {
    grid-column: span 1;
  }
}

@media (max-width: 720px) {
  .hero-title {
    font-size: clamp(2.45rem, 11vw, 4rem);
  }

  .hero-visual {
    padding-top: 10px;
  }

  .hero-visual picture {
    width: min(420px, 104%);
    margin-top: -18px;
  }

  .profile-portrait {
    min-height: 480px;
    transform: none;
  }

  .profile-portrait img {
    width: 112%;
    margin-left: -6%;
    transform: translateY(-30px) scale(1.02);
  }
}

/* ==========================================================================
   NOTICE
   ========================================================================== */
.notice {
  margin-top: 34px;
  padding: 18px 26px;
  background: var(--gold-soft);
  border-left: 2px solid var(--gold);
  color: var(--ice);
  font-weight: 600;
}

/* ==========================================================================
   SECTION SURFACES — alternating depth
   ========================================================================== */
.process-section,
.region-section,
.valuation-section,
.text-hero,
.detail-hero,
.final-cta { position: relative; }

.process-section {
  padding: clamp(82px, 10vw, 144px) var(--gutter);
  background:
    radial-gradient(900px 420px at 88% 4%, rgba(199, 161, 93, 0.08), transparent 56%),
    var(--navy-850);
}
.section-kicker { max-width: 780px; }
.section-kicker h2 { margin-top: 20px; }
.section-kicker p { margin-top: 18px; color: var(--on-dark-soft); font-size: 1.06rem; max-width: 58ch; line-height: 1.78; }
.process-timeline {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin-top: clamp(46px, 6vw, 74px);
  border-top: 1px solid var(--line-dark);
}
.process-timeline article {
  position: relative;
  padding: 34px 28px 12px 0;
  border-right: 1px solid var(--line-dark);
  transition: background 0.4s;
}
.process-timeline article:last-child { border-right: 0; }
.process-timeline article::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--gold-bright), var(--red));
  transition: width 0.6s var(--ease);
}
.process-timeline article:hover::before { width: calc(100% - 28px); }
.process-timeline span { font-family: var(--serif); font-style: italic; font-size: 2.5rem; font-weight: 360; color: var(--gold); line-height: 1; }
.process-timeline h3 { margin-top: 18px; font-size: 1.26rem; color: var(--ice); }
.process-timeline p { margin-top: 10px; font-size: 0.92rem; color: var(--on-dark-faint); line-height: 1.7; }

/* DECISION */
.decision-section {
  display: grid;
  grid-template-columns: minmax(300px, 0.9fr) minmax(0, 1.4fr);
  gap: clamp(40px, 6vw, 100px);
  padding: clamp(82px, 10vw, 144px) var(--gutter);
  background:
    radial-gradient(900px 400px at 0% 0%, rgba(215, 25, 32, 0.12), transparent 56%),
    var(--navy-900);
}
.decision-copy h2 { margin-top: 20px; }
.decision-copy p { margin-top: 20px; color: var(--on-dark-soft); line-height: 1.78; }
.decision-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--line-dark); border: 1px solid var(--line-dark); }
.decision-grid article {
  position: relative;
  padding: 32px 30px;
  background: linear-gradient(160deg, var(--navy-800), var(--navy-850));
  transition: background 0.4s;
}
.decision-grid article:hover { background: linear-gradient(160deg, var(--navy-700), var(--navy-800)); }
.decision-grid article span { display: block; width: 26px; height: 2px; background: linear-gradient(90deg, var(--gold-bright), var(--red)); margin-bottom: 18px; transition: width 0.4s var(--ease); }
.decision-grid article:hover span { width: 46px; }
.decision-grid h3 { font-size: 1.14rem; color: var(--ice); }
.decision-grid p { margin-top: 10px; font-size: 0.88rem; color: var(--on-dark-faint); line-height: 1.7; }

/* ==========================================================================
   FILTERS + PORTFOLIO
   ========================================================================== */
.section.container { background: var(--navy-900); }
.filters {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: clamp(34px, 4vw, 54px);
  border-bottom: 1px solid var(--line-dark);
}
.filters button {
  position: relative;
  padding: 14px 24px;
  background: none;
  border: 0;
  font-size: 0.77rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--on-dark-faint);
  transition: color 0.3s;
}
.filters button::after {
  content: "";
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: -1px;
  height: 2px;
  background: linear-gradient(90deg, var(--gold-bright), var(--red));
  transform: scaleX(0);
  transition: transform 0.4s var(--ease);
}
.filters button:hover { color: var(--ice); }
.filters button.active { color: var(--gold-bright); }
.filters button.active::after { transform: scaleX(1); }

.portfolio-rail,
.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(330px, 1fr));
  gap: clamp(24px, 3vw, 38px);
}
.portfolio-grid.container { padding-bottom: clamp(76px, 9vw, 132px); }

/* ---------- Shared cursor-glow surface ---------- */
.portfolio-card, .audience-grid article, .service-card, .region-card,
.hero-specialty-cards article, .decision-grid article, .blog-card { --mx: 50%; --my: 50%; }
.portfolio-card::before, .audience-grid article::after, .service-card::before,
.region-card::after, .decision-grid article::after, .blog-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: radial-gradient(280px circle at var(--mx) var(--my), rgba(199, 161, 93, 0.16), transparent 60%);
  opacity: 0;
  transition: opacity 0.4s var(--ease);
  pointer-events: none;
}
.portfolio-card:hover::before, .audience-grid article:hover::after, .service-card:hover::before,
.region-card:hover::after, .decision-grid article:hover::after, .blog-card:hover::before { opacity: 1; }
.portfolio-card > *, .audience-grid article > *, .service-card > *,
.region-card > *, .decision-grid article > *, .blog-card > * { position: relative; z-index: 1; }

.portfolio-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: linear-gradient(165deg, var(--navy-800), var(--navy-850));
  border: 1px solid rgba(199, 161, 93, 0.15);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  transform-style: preserve-3d;
  will-change: transform;
  transition: transform 0.4s var(--ease), box-shadow 0.5s var(--ease), border-color 0.5s var(--ease);
}
.portfolio-card:hover {
  border-color: rgba(199, 161, 93, 0.4);
  box-shadow: 0 44px 90px -34px rgba(2, 8, 18, 0.85), var(--shadow-gold);
}
.portfolio-media { position: relative; aspect-ratio: 16 / 10.5; overflow: hidden; }
.portfolio-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.3s var(--ease); }
.portfolio-card:hover .portfolio-media img { transform: scale(1.07); }
.portfolio-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(4, 8, 15, 0.42), transparent 36%, rgba(6, 13, 24, 0.55));
  pointer-events: none;
}
.portfolio-cover-badges { position: absolute; z-index: 2; top: 16px; left: 16px; display: flex; gap: 8px; }
.status-badge, .category-badge {
  padding: 7px 13px;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.status-badge { background: linear-gradient(135deg, var(--gold-bright), var(--gold-deep)); color: var(--navy-900); }
.category-badge { background: rgba(4, 8, 15, 0.7); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); color: var(--ice); border: 1px solid rgba(199, 161, 93, 0.3); }
.featured-badge {
  position: absolute;
  z-index: 2;
  bottom: 16px;
  left: 16px;
  padding: 7px 13px;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: linear-gradient(135deg, var(--red-bright), var(--red-dark));
  color: var(--white);
}
.portfolio-content { display: flex; flex-direction: column; flex: 1; padding: 28px 28px 26px; }
.portfolio-content h3 { font-size: 1.36rem; line-height: 1.24; color: var(--ice); }
.portfolio-content > p { margin-top: 12px; font-size: 0.9rem; color: var(--on-dark-soft); line-height: 1.65; }
.portfolio-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.portfolio-tags span {
  padding: 6px 12px;
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold-bright);
  background: var(--gold-soft);
  border: 1px solid rgba(199, 161, 93, 0.22);
}
.portfolio-facts {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 22px 0 0;
  padding-top: 20px;
  border-top: 1px solid var(--line-dark);
}
.portfolio-facts dt { font-size: 0.6rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--on-dark-faint); }
.portfolio-facts dd { margin: 5px 0 0; font-size: 0.88rem; font-weight: 700; color: var(--ice); }
.portfolio-price {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-top: 20px;
  padding: 16px 18px;
  background: linear-gradient(135deg, rgba(199, 161, 93, 0.08), rgba(10, 20, 36, 0.3));
  border: 1px solid var(--line-dark);
}
.portfolio-price span { font-size: 0.62rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--on-dark-faint); }
.portfolio-price strong { font-family: var(--serif); font-size: 1.3rem; font-weight: 540; color: var(--gold-bright); }
.card-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 20px; }
.card-actions .btn { padding: 13px 12px; font-size: 0.68rem; letter-spacing: 0.1em; }
.portfolio-strategy-link { margin-top: 16px; font-size: 0.82rem; font-weight: 600; color: var(--gold-bright); transition: color 0.3s, gap 0.3s; }
.portfolio-strategy-link:hover { color: var(--red-bright); }

/* ==========================================================================
   REGION — dark atlas
   ========================================================================== */
.region-section {
  padding: clamp(82px, 10vw, 144px) var(--gutter);
  background:
    radial-gradient(1000px 500px at 0% 100%, rgba(199, 161, 93, 0.08), transparent 56%),
    radial-gradient(800px 400px at 100% 0%, rgba(215, 25, 32, 0.08), transparent 50%),
    linear-gradient(180deg, var(--navy-850), var(--navy-900));
}
.region-head {
  display: grid;
  grid-template-columns: minmax(280px, 0.8fr) minmax(0, 1.2fr);
  gap: clamp(36px, 6vw, 90px);
  align-items: end;
  margin-bottom: clamp(46px, 6vw, 74px);
}
.region-intro p { color: var(--on-dark-soft); line-height: 1.78; font-size: 0.96rem; }
.region-intro p + p { margin-top: 14px; }
.region-intro .eyebrow { margin-bottom: 18px; }
.region-title-block h2 { font-size: clamp(1.95rem, 3.6vw, 3.1rem); }
.region-metrics { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }
.region-metrics span {
  padding: 9px 16px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold-bright);
  border: 1px solid rgba(199, 161, 93, 0.36);
  background: rgba(199, 161, 93, 0.05);
}
.region-map {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1px;
  background: var(--line-dark);
  border: 1px solid var(--line-dark);
}
.region-card {
  position: relative;
  display: block;
  padding: 34px 30px 30px;
  background: linear-gradient(165deg, var(--navy-800), var(--navy-850));
  overflow: hidden;
  transition: background 0.45s;
}
.region-card:hover { background: linear-gradient(165deg, var(--navy-700), var(--navy-800)); }
.region-card i { position: absolute; top: 0; left: 0; width: 100%; height: 2px; background: linear-gradient(90deg, var(--gold-bright), var(--red)); transform: scaleX(0); transform-origin: left; transition: transform 0.5s var(--ease); }
.region-card:hover i { transform: scaleX(1); }
.region-card small { font-family: var(--serif); font-style: italic; font-size: 1rem; color: var(--gold); }
.region-card strong { display: block; margin-top: 12px; font-family: var(--serif); font-size: 1.52rem; font-weight: 500; color: var(--ice); }
.region-card > span { display: block; margin-top: 6px; font-size: 0.73rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold-bright); }
.region-card p { margin-top: 14px; font-size: 0.88rem; line-height: 1.7; color: var(--on-dark-faint); }
.region-focus { margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--line-dark); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--on-dark-faint); }
.region-card em { display: inline-flex; align-items: center; gap: 8px; margin-top: 18px; font-style: normal; font-size: 0.78rem; font-weight: 700; color: var(--gold-bright); opacity: 0; transform: translateY(6px); transition: all 0.4s var(--ease); }
.region-card:hover em { opacity: 1; transform: translateY(0); }
.region-card b { font-weight: 400; transition: transform 0.3s; }
.region-card:hover b { transform: translateX(4px); }
.region-card.featured { background: linear-gradient(150deg, rgba(199, 161, 93, 0.14), var(--navy-800) 52%); }
.region-card.featured:hover { background: linear-gradient(150deg, rgba(199, 161, 93, 0.22), var(--navy-700) 58%); }

/* ==========================================================================
   PROFILE
   ========================================================================== */
.profile-section {
  display: grid;
  grid-template-columns: minmax(300px, 0.8fr) minmax(0, 1.2fr);
  gap: clamp(40px, 6vw, 100px);
  align-items: center;
  padding: clamp(82px, 10vw, 144px) var(--gutter);
  background:
    radial-gradient(800px 500px at 16% 50%, rgba(215, 25, 32, 0.08), transparent 56%),
    var(--navy-850);
}
.profile-visual { display: flex; justify-content: center; }
.profile-portrait { position: relative; width: min(390px, 100%); background: linear-gradient(180deg, var(--navy-700), var(--navy-900)); }
.profile-portrait::before { content: ""; position: absolute; inset: 14px -14px -14px 14px; border: 1px solid var(--gold); pointer-events: none; z-index: 0; }
.profile-portrait img { position: relative; z-index: 1; width: 100%; }
.profile-portrait span { position: absolute; z-index: 2; bottom: 18px; left: 18px; padding: 8px 16px; font-size: 0.62rem; font-weight: 800; letter-spacing: 0.24em; background: linear-gradient(135deg, var(--red-bright), var(--red-dark)); color: var(--white); }
.profile-copy h2 { margin-top: 20px; }
.profile-copy > p { margin-top: 20px; color: var(--on-dark-soft); line-height: 1.82; max-width: 60ch; }
.profile-name { margin-top: 28px; padding-left: 20px; border-left: 2px solid var(--gold); }
.profile-name strong { display: block; font-family: var(--serif); font-size: 1.42rem; font-weight: 540; color: var(--ice); }
.profile-name span { font-size: 0.82rem; color: var(--on-dark-faint); letter-spacing: 0.04em; }
.profile-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 14px; margin-top: 30px; }
.profile-socials { display: flex; gap: 18px; margin-left: 6px; }
.profile-socials a { font-size: 0.76rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--on-dark-faint); border-bottom: 1px solid transparent; transition: all 0.3s; }
.profile-socials a:hover { color: var(--gold-bright); border-color: var(--gold); }
.profile-badges { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(18px, 2.5vw, 32px); margin-top: clamp(36px, 4vw, 52px); }
.profile-badges article { border-top: 1px solid var(--line-dark); padding-top: 16px; }
.profile-badges span { font-family: var(--serif); font-style: italic; color: var(--gold); }
.profile-badges strong { display: block; margin-top: 8px; font-size: 0.9rem; color: var(--ice); }
.profile-badges p { margin-top: 6px; font-size: 0.78rem; color: var(--on-dark-faint); line-height: 1.6; }

/* ==========================================================================
   AUDIENCE
   ========================================================================== */
.audience-section { padding-block: clamp(76px, 9vw, 132px); background: var(--navy-900); }
.audience-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(24px, 3vw, 38px); }
.audience-grid article {
  position: relative;
  padding: 38px 32px;
  background: linear-gradient(165deg, var(--navy-800), var(--navy-850));
  border: 1px solid rgba(199, 161, 93, 0.14);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease), border-color 0.5s;
}
.audience-grid article::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--gold-bright), var(--red));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s var(--ease);
}
.audience-grid article:hover { transform: translateY(-8px); border-color: rgba(199, 161, 93, 0.36); box-shadow: 0 40px 80px -34px rgba(2, 8, 18, 0.8); }
.audience-grid article:hover::before { transform: scaleX(1); }
.audience-grid span { font-family: var(--serif); font-style: italic; font-size: 2.3rem; font-weight: 360; color: var(--gold); line-height: 1; }
.audience-grid h3 { margin-top: 20px; font-size: 1.32rem; color: var(--ice); }
.audience-grid p { margin-top: 12px; font-size: 0.92rem; color: var(--on-dark-soft); line-height: 1.7; }
.audience-grid a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 22px;
  font-size: 0.77rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold-bright);
  border-bottom: 1px solid var(--gold);
  padding-bottom: 4px;
  transition: all 0.3s;
}
.audience-grid a:hover { color: var(--red-bright); gap: 12px; }

/* ==========================================================================
   VALUATION + LEAD FORM
   ========================================================================== */
.valuation-section {
  display: grid;
  grid-template-columns: minmax(300px, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(40px, 6vw, 100px);
  align-items: center;
  padding: clamp(82px, 10vw, 144px) var(--gutter);
  background:
    radial-gradient(900px 500px at 100% 100%, rgba(215, 25, 32, 0.16), transparent 56%),
    radial-gradient(700px 400px at 0% 0%, rgba(199, 161, 93, 0.1), transparent 50%),
    var(--navy-850);
}
.valuation-section h1, .valuation-section h2 { margin-top: 20px; }
.valuation-section > div > p { margin-top: 20px; color: var(--on-dark-soft); line-height: 1.82; }
.valuation-section.standalone { min-height: 100svh; padding-top: clamp(146px, 18vh, 206px); align-items: start; }

.lead-form {
  position: relative;
  padding: clamp(28px, 4vw, 44px);
  background: linear-gradient(165deg, var(--ice), #fff);
  color: var(--text-dark);
  box-shadow: 0 56px 110px -42px rgba(0, 0, 0, 0.7);
}
.lead-form::before { content: ""; position: absolute; inset: 12px -12px -12px 12px; border: 1px solid rgba(199, 161, 93, 0.5); pointer-events: none; }
.form-progress { display: flex; align-items: center; margin-bottom: 30px; }
.form-progress span {
  position: relative;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--muted-dark);
  border: 1px solid var(--line-light);
  border-radius: 50%;
  background: #fff;
  z-index: 1;
  transition: all 0.4s;
}
.form-progress span:not(:first-child) { margin-left: 56px; }
.form-progress span:not(:first-child)::before { content: ""; position: absolute; right: 100%; top: 50%; width: 56px; height: 1px; background: var(--line-light); }
.form-progress span.active { background: linear-gradient(135deg, var(--gold-bright), var(--gold-deep)); border-color: var(--gold); color: var(--navy-900); }
.form-progress span.active:not(:first-child)::before { background: var(--gold); }
.lead-form fieldset { display: none; border: 0; padding: 0; margin: 0; }
.lead-form fieldset.active { display: block; animation: step-in 0.5s var(--ease); }
@keyframes step-in { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
.lead-form legend { font-family: var(--serif); font-size: 1.42rem; font-weight: 520; color: var(--ink); margin-bottom: 22px; padding: 0; }
.choice-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 26px; }
.choice-grid label { position: relative; cursor: pointer; }
.choice-grid input { position: absolute; opacity: 0; }
.choice-grid span { display: grid; place-items: center; padding: 16px 10px; font-size: 0.84rem; font-weight: 700; color: var(--muted-dark); border: 1px solid var(--line-light); background: var(--paper); transition: all 0.3s var(--ease); }
.choice-grid input:checked + span { background: var(--ink); border-color: var(--ink); color: var(--gold-bright); }
.choice-grid label:hover span { border-color: var(--gold); }
.lead-form > fieldset > label, .lead-form .form-actions ~ label { }
.lead-form fieldset > label { display: block; margin-bottom: 18px; font-size: 0.7rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted-dark); }
.lead-form input:not([type="radio"]), .lead-form select, .lead-form textarea {
  display: block;
  width: 100%;
  margin-top: 8px;
  padding: 14px 16px;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: normal;
  text-transform: none;
  color: var(--ink);
  background: var(--paper);
  border: 1px solid var(--line-light);
  border-radius: 2px;
  outline: none;
  transition: border-color 0.3s, background 0.3s, box-shadow 0.3s;
}
.lead-form input:focus, .lead-form select:focus, .lead-form textarea:focus { border-color: var(--gold); background: #fff; box-shadow: 0 0 0 3px rgba(199, 161, 93, 0.16); }
.lead-form textarea { resize: vertical; }
.form-actions { display: flex; gap: 12px; margin-top: 6px; }
.form-actions .btn { flex: 1; }
.lead-form > fieldset > .btn-dark[data-next] { width: 100%; }

/* ==========================================================================
   MAGAZINE / BLOG
   ========================================================================== */
.magazine-section { padding-block: clamp(76px, 9vw, 132px); background: var(--navy-900); }
.magazine-grid { display: grid; grid-template-columns: minmax(0, 1.3fr) minmax(280px, 0.7fr); gap: clamp(28px, 4vw, 56px); align-items: start; }
.featured-article {
  background: linear-gradient(165deg, var(--navy-800), var(--navy-850));
  border: 1px solid rgba(199, 161, 93, 0.14);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease);
}
.featured-article:hover { transform: translateY(-5px); box-shadow: 0 40px 80px -34px rgba(2, 8, 18, 0.8); }
.featured-article img { width: 100%; aspect-ratio: 16 / 8.5; object-fit: cover; }
.featured-article > div { padding: clamp(26px, 3vw, 40px); }
.featured-article h3 { margin-top: 16px; font-size: clamp(1.4rem, 2.2vw, 1.95rem); line-height: 1.22; color: var(--ice); }
.featured-article p { margin-top: 14px; color: var(--on-dark-soft); line-height: 1.7; }
.featured-article small { display: block; margin-top: 16px; font-size: 0.74rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--on-dark-faint); }
.featured-article a { display: inline-flex; align-items: center; gap: 8px; margin-top: 18px; font-size: 0.78rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-bright); border-bottom: 1px solid var(--gold); padding-bottom: 4px; transition: all 0.3s; }
.featured-article a:hover { color: var(--red-bright); gap: 12px; }
.tag { display: inline-block; padding: 6px 13px; font-size: 0.62rem; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold-bright); border: 1px solid rgba(199, 161, 93, 0.4); }
.article-list { display: grid; gap: 20px; }
.blog-card {
  padding: 26px 28px;
  background: linear-gradient(165deg, var(--navy-800), var(--navy-850));
  border: 1px solid rgba(199, 161, 93, 0.14);
  box-shadow: var(--shadow-card);
  transition: transform 0.45s var(--ease), box-shadow 0.45s var(--ease), border-color 0.45s;
}
.blog-card:hover { transform: translateY(-5px); border-color: rgba(199, 161, 93, 0.34); box-shadow: 0 36px 70px -32px rgba(2, 8, 18, 0.8); }
.blog-card h3 { margin-top: 14px; font-size: 1.2rem; line-height: 1.3; color: var(--ice); }
.blog-card p { margin-top: 10px; font-size: 0.88rem; color: var(--on-dark-soft); line-height: 1.65; }
.blog-card small { display: block; margin-top: 12px; font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--on-dark-faint); }
.blog-card a { display: inline-flex; align-items: center; gap: 8px; margin-top: 14px; font-size: 0.76rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-bright); border-bottom: 1px solid var(--gold); padding-bottom: 3px; transition: all 0.3s; }
.blog-card a:hover { color: var(--red-bright); gap: 12px; }
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: clamp(22px, 3vw, 36px); padding-bottom: clamp(76px, 9vw, 132px); }

/* ==========================================================================
   TESTIMONIALS
   ========================================================================== */
.section.container + .social-band { }
.trust-board { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(22px, 3vw, 36px); }
.trust-board blockquote, .testimonial-grid blockquote {
  position: relative;
  margin: 0;
  padding: 38px 32px;
  background: linear-gradient(165deg, var(--navy-800), var(--navy-850));
  border: 1px solid rgba(199, 161, 93, 0.16);
  box-shadow: var(--shadow-card);
}
.trust-board blockquote::before, .testimonial-grid blockquote::before {
  content: "“";
  position: absolute;
  top: 6px;
  left: 22px;
  font-family: var(--serif);
  font-size: 5.6rem;
  line-height: 1;
  color: rgba(199, 161, 93, 0.28);
  pointer-events: none;
}
.trust-board blockquote p, .testimonial-grid blockquote p { position: relative; font-family: var(--serif); font-size: 1.08rem; font-style: italic; line-height: 1.66; color: var(--ice); }
.trust-board cite, .testimonial-grid cite { display: block; margin-top: 20px; font-style: normal; font-size: 0.74rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold-bright); }
.trust-board small { display: block; margin-top: 6px; font-size: 0.8rem; color: var(--on-dark-faint); }
.trust-board .featured-quote { background: linear-gradient(150deg, rgba(215, 25, 32, 0.16), var(--navy-800) 55%); border-color: rgba(215, 25, 32, 0.3); }
.testimonial-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: clamp(22px, 3vw, 36px); padding-bottom: clamp(76px, 9vw, 132px); }
.testimonial-grid blockquote > span { position: relative; color: var(--gold-bright); letter-spacing: 0.2em; font-size: 0.9rem; }
.testimonial-grid blockquote p { margin-top: 14px; }

/* ==========================================================================
   SOCIAL BAND
   ========================================================================== */
.social-band {
  display: grid;
  grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(36px, 5vw, 80px);
  align-items: center;
  padding: clamp(76px, 9vw, 124px) var(--gutter);
  background:
    radial-gradient(700px 400px at 100% 50%, rgba(199, 161, 93, 0.08), transparent 56%),
    var(--navy-850);
}
.social-band h2 { margin-top: 20px; }
.social-band p { margin-top: 18px; color: var(--on-dark-soft); line-height: 1.78; }
.video-placeholder {
  display: grid;
  place-content: center;
  gap: 10px;
  min-height: 330px;
  text-align: center;
  background:
    radial-gradient(500px 260px at 50% 45%, rgba(215, 25, 32, 0.18), transparent 70%),
    linear-gradient(165deg, var(--navy-700), var(--navy-900));
  border: 1px solid rgba(199, 161, 93, 0.28);
  position: relative;
}
.video-placeholder::before {
  content: "▶";
  display: grid;
  place-items: center;
  width: 66px;
  height: 66px;
  margin: 0 auto 8px;
  border: 1px solid rgba(199, 161, 93, 0.5);
  border-radius: 50%;
  color: var(--gold-bright);
  font-size: 1.1rem;
  padding-left: 4px;
  background: rgba(4, 8, 15, 0.4);
}
.video-placeholder strong { font-family: var(--serif); font-size: 1.32rem; font-weight: 500; color: var(--ice); }
.video-placeholder span { font-size: 0.85rem; color: var(--on-dark-soft); max-width: 36ch; }

/* ==========================================================================
   FINAL CTA + FOOTER
   ========================================================================== */
.final-cta {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) auto;
  gap: clamp(32px, 5vw, 80px);
  align-items: center;
  padding: clamp(82px, 10vw, 134px) var(--gutter);
  background:
    radial-gradient(1000px 460px at 0% 0%, rgba(215, 25, 32, 0.18), transparent 56%),
    radial-gradient(800px 400px at 100% 100%, rgba(199, 161, 93, 0.12), transparent 50%),
    linear-gradient(160deg, var(--navy-700), var(--navy-900));
  border-top: 1px solid var(--line-dark);
}
.final-cta h2 { margin-top: 20px; font-size: clamp(1.95rem, 3.6vw, 3.1rem); }
.final-cta p { margin-top: 18px; color: var(--on-dark-soft); max-width: 56ch; line-height: 1.78; }
.final-cta .cta-row { flex-direction: column; align-items: stretch; }
.final-cta .cta-row .btn { justify-content: center; }

.site-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 24px 48px;
  padding: 48px var(--gutter);
  background: var(--navy-900);
  color: var(--on-dark-faint);
  border-top: 1px solid var(--line-dark);
}
.site-footer strong { font-family: var(--serif); font-size: 1.18rem; font-weight: 520; color: var(--ice); }
.site-footer p { margin-top: 6px; font-size: 0.84rem; }
.site-footer div:nth-child(2) { display: flex; gap: 26px; margin-left: auto; }
.site-footer div:nth-child(2) a { font-size: 0.74rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--on-dark-faint); transition: color 0.3s; }
.site-footer div:nth-child(2) a:hover { color: var(--gold-bright); }
.credit { width: 100%; padding-top: 22px; border-top: 1px solid var(--line-dark); font-size: 0.76rem; }
.credit a { color: var(--on-dark-faint); transition: color 0.3s; }
.credit a:hover { color: var(--gold-bright); }

/* ==========================================================================
   FLOATERS
   ========================================================================== */
.whatsapp-float {
  position: fixed;
  z-index: 150;
  right: 26px;
  bottom: 26px;
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: #1ebe5d;
  color: var(--white);
  font-size: 0;
  box-shadow: 0 16px 36px -10px rgba(30, 190, 93, 0.55);
  transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease);
}
.whatsapp-float::after { content: ""; position: absolute; inset: 0; border-radius: 50%; border: 1px solid rgba(255, 255, 255, 0.4); animation: pulse-ring 2.6s ease-out infinite; }
@keyframes pulse-ring { 0% { transform: scale(1); opacity: 0.8; } 100% { transform: scale(1.5); opacity: 0; } }
.whatsapp-float:hover { transform: translateY(-4px) scale(1.05); box-shadow: 0 22px 44px -12px rgba(30, 190, 93, 0.65); }
.whatsapp-float::before {
  content: "";
  width: 28px;
  height: 28px;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12.04 2C6.58 2 2.13 6.45 2.13 11.91c0 1.75.46 3.45 1.32 4.95L2.05 22l5.25-1.38a9.86 9.86 0 0 0 4.74 1.21c5.46 0 9.91-4.45 9.91-9.91C21.95 6.45 17.5 2 12.04 2m0 18.03a8.1 8.1 0 0 1-4.13-1.13l-.3-.18-3.12.82.83-3.04-.2-.31a8.06 8.06 0 0 1-1.26-4.38c0-4.54 3.7-8.24 8.24-8.24 4.54 0 8.24 3.7 8.24 8.24 0 4.54-3.7 8.22-8.3 8.22m4.52-6.16c-.25-.12-1.47-.72-1.69-.81-.23-.08-.39-.12-.56.12-.17.25-.64.81-.78.97-.14.17-.29.19-.54.06-.25-.12-1.05-.39-1.99-1.23-.74-.66-1.23-1.47-1.38-1.72-.14-.25-.02-.38.11-.51.11-.11.25-.29.37-.43s.17-.25.25-.41c.08-.17.04-.31-.02-.43s-.56-1.34-.76-1.84c-.2-.48-.41-.42-.56-.43h-.48c-.17 0-.43.06-.66.31-.22.25-.86.85-.86 2.07 0 1.22.89 2.4 1.01 2.56.12.17 1.75 2.67 4.23 3.74.59.26 1.05.41 1.41.52.59.19 1.13.16 1.56.1.48-.07 1.47-.6 1.67-1.18.21-.58.21-1.07.15-1.18-.06-.1-.23-.16-.48-.27'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12.04 2C6.58 2 2.13 6.45 2.13 11.91c0 1.75.46 3.45 1.32 4.95L2.05 22l5.25-1.38a9.86 9.86 0 0 0 4.74 1.21c5.46 0 9.91-4.45 9.91-9.91C21.95 6.45 17.5 2 12.04 2m0 18.03a8.1 8.1 0 0 1-4.13-1.13l-.3-.18-3.12.82.83-3.04-.2-.31a8.06 8.06 0 0 1-1.26-4.38c0-4.54 3.7-8.24 8.24-8.24 4.54 0 8.24 3.7 8.24 8.24 0 4.54-3.7 8.22-8.3 8.22m4.52-6.16c-.25-.12-1.47-.72-1.69-.81-.23-.08-.39-.12-.56.12-.17.25-.64.81-.78.97-.14.17-.29.19-.54.06-.25-.12-1.05-.39-1.99-1.23-.74-.66-1.23-1.47-1.38-1.72-.14-.25-.02-.38.11-.51.11-.11.25-.29.37-.43s.17-.25.25-.41c.08-.17.04-.31-.02-.43s-.56-1.34-.76-1.84c-.2-.48-.41-.42-.56-.43h-.48c-.17 0-.43.06-.66.31-.22.25-.86.85-.86 2.07 0 1.22.89 2.4 1.01 2.56.12.17 1.75 2.67 4.23 3.74.59.26 1.05.41 1.41.52.59.19 1.13.16 1.56.1.48-.07 1.47-.6 1.67-1.18.21-.58.21-1.07.15-1.18-.06-.1-.23-.16-.48-.27'/%3E%3C/svg%3E") center / contain no-repeat;
}

.mobile-action-bar {
  position: fixed;
  z-index: 160;
  inset: auto 0 0 0;
  display: none;
  grid-template-columns: repeat(3, 1fr);
  background: linear-gradient(180deg, rgba(6, 13, 24, 0.92), rgba(4, 8, 15, 0.98));
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border-top: 1px solid var(--line-dark);
  padding-bottom: env(safe-area-inset-bottom);
}
.mobile-action-bar a { padding: 16px 8px; text-align: center; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ice); }
.mobile-action-bar a + a { border-left: 1px solid var(--line-dark); }
.mobile-action-bar a:nth-child(3) { color: var(--gold-bright); }

/* ==========================================================================
   INNER PAGES
   ========================================================================== */
.text-hero {
  padding: clamp(152px, 20vh, 224px) var(--gutter) clamp(60px, 8vw, 100px);
  background:
    radial-gradient(900px 400px at 82% 0%, rgba(215, 25, 32, 0.16), transparent 56%),
    radial-gradient(700px 400px at 0% 100%, rgba(199, 161, 93, 0.1), transparent 50%),
    linear-gradient(150deg, var(--navy-700), var(--navy-900));
}
.text-hero h1 { margin-top: 22px; max-width: 18ch; }
.text-hero p { margin-top: 20px; max-width: 58ch; color: var(--on-dark-soft); font-size: 1.06rem; line-height: 1.78; }
.text-hero .btn { margin-top: 30px; }

.content-page { padding-block: clamp(56px, 7vw, 96px); max-width: calc(840px + 2 * var(--gutter)); }
.content-page h1 { margin-bottom: 24px; padding-top: clamp(122px, 16vh, 162px); }
.text-hero + main .content-page h1, .text-hero + .content-page h1 { padding-top: 0; }
.content-page p { color: var(--on-dark); line-height: 1.85; font-size: 1.04rem; }
.content-page p + p { margin-top: 18px; }
.content-page .btn { margin-top: 30px; }
.wide-img { width: 100%; margin-bottom: 32px; aspect-ratio: 16 / 7; object-fit: cover; }

.article-page { max-width: calc(800px + 2 * var(--gutter)); padding-block: clamp(152px, 20vh, 214px) clamp(64px, 8vw, 110px); }
.article-page h1 { margin-top: 18px; font-size: clamp(2rem, 4vw, 3.3rem); }
.article-page img { width: 100%; margin: 34px 0; aspect-ratio: 16 / 8; object-fit: cover; }
.article-page p { line-height: 1.9; font-size: 1.06rem; color: var(--on-dark); }
.inline-cta {
  margin-top: 48px;
  padding: clamp(32px, 4vw, 52px);
  background: linear-gradient(150deg, rgba(215, 25, 32, 0.14), var(--navy-800) 55%);
  border: 1px solid var(--line-dark);
  text-align: center;
}
.inline-cta h2 { font-size: clamp(1.4rem, 2.4vw, 2rem); max-width: 26ch; margin-inline: auto; }
.inline-cta .btn { margin-top: 26px; }

/* Detail page */
.detail-hero {
  position: relative;
  display: grid;
  align-items: end;
  min-height: 80svh;
  padding: clamp(152px, 20vh, 200px) var(--gutter) clamp(48px, 6vw, 80px);
  color: var(--ice);
  isolation: isolate;
}
.detail-hero img { position: absolute; inset: 0; z-index: -2; width: 100%; height: 100%; object-fit: cover; }
.detail-hero::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(4, 8, 15, 0.6), rgba(4, 8, 15, 0.32) 38%, rgba(4, 8, 15, 0.92) 100%); }
.detail-hero h1 { margin-top: 16px; max-width: 20ch; }
.detail-hero p { margin-top: 12px; color: var(--on-dark-soft); font-size: 1.05rem; }
.detail-hero strong { display: block; margin-top: 14px; font-family: var(--serif); font-size: clamp(1.5rem, 2.6vw, 2.2rem); font-weight: 540; color: var(--gold-bright); }
.detail-hero .cta-row { margin-top: 26px; }

.detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.8fr);
  gap: clamp(36px, 5vw, 72px);
  padding-block: clamp(56px, 7vw, 96px);
  align-items: start;
  background: var(--navy-900);
}
.detail-layout article h2 { font-size: 1.72rem; margin-bottom: 18px; }
.detail-layout article h2:not(:first-child) { margin-top: 40px; }
.detail-layout article p { line-height: 1.85; color: var(--on-dark); }
.feature-list { list-style: none; margin: 0; padding: 0; display: grid; }
.feature-list li { position: relative; padding: 14px 0 14px 30px; border-bottom: 1px solid var(--line-dark); font-weight: 500; color: var(--on-dark); }
.feature-list li::before { content: ""; position: absolute; left: 4px; top: 50%; width: 12px; height: 1px; background: var(--gold); }
.map-box { margin-top: 36px; display: grid; place-items: center; min-height: 260px; background: var(--navy-850); border: 1px dashed rgba(199, 161, 93, 0.4); color: var(--on-dark-faint); font-size: 0.9rem; }
.detail-layout aside { position: sticky; top: 110px; padding: clamp(24px, 3vw, 36px); background: linear-gradient(165deg, var(--navy-800), var(--navy-850)); border: 1px solid var(--line-dark); }
.detail-layout aside h3 { font-size: 1.3rem; color: var(--ice); margin-bottom: 22px; }
.detail-layout aside .lead-form { box-shadow: none; }
.detail-layout aside .lead-form::before { display: none; }

/* Services */
.service-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); gap: clamp(22px, 3vw, 36px); padding-bottom: clamp(76px, 9vw, 132px); }
.service-card {
  padding: 38px 32px;
  background: linear-gradient(165deg, var(--navy-800), var(--navy-850));
  border: 1px solid rgba(199, 161, 93, 0.14);
  box-shadow: var(--shadow-card);
  transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease), border-color 0.5s;
}
.service-card:hover { transform: translateY(-8px); border-color: rgba(199, 161, 93, 0.36); box-shadow: 0 40px 80px -34px rgba(2, 8, 18, 0.8); }
.service-card .icon { display: grid; place-items: center; width: 56px; height: 56px; font-family: var(--serif); font-style: italic; font-size: 1.5rem; color: var(--gold-bright); border: 1px solid rgba(199, 161, 93, 0.45); background: rgba(199, 161, 93, 0.06); }
.service-card h3 { margin-top: 22px; font-size: 1.3rem; color: var(--ice); }
.service-card p { margin-top: 12px; font-size: 0.92rem; color: var(--on-dark-soft); line-height: 1.7; }
.service-card a { display: inline-flex; align-items: center; gap: 8px; margin-top: 20px; font-size: 0.78rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-bright); border-bottom: 1px solid var(--gold); padding-bottom: 4px; transition: all 0.3s; }
.service-card a:hover { color: var(--red-bright); gap: 12px; }

/* Listing pages: section-title rendered outside .container */
main > .section-title {
  padding: clamp(152px, 20vh, 214px) var(--gutter) clamp(42px, 5vw, 66px);
  margin-bottom: 0;
  max-width: none;
  background:
    radial-gradient(900px 400px at 82% 0%, rgba(215, 25, 32, 0.16), transparent 56%),
    radial-gradient(700px 400px at 0% 100%, rgba(199, 161, 93, 0.1), transparent 50%),
    linear-gradient(150deg, var(--navy-700), var(--navy-900));
}
main > .section-title h2 { font-size: clamp(2.1rem, 4vw, 3.5rem); max-width: 20ch; }
main > .section-title p { color: var(--on-dark-soft); }
main > .section-title + .portfolio-grid,
main > .section-title + .service-grid,
main > .section-title + .blog-grid,
main > .section-title + .testimonial-grid { padding-top: clamp(50px, 6vw, 82px); background: var(--navy-900); }

/* ==========================================================================
   REVEAL ANIMATIONS
   ========================================================================== */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(38px); transition: opacity 0.95s var(--ease), transform 0.95s var(--ease); }
  .reveal.is-visible { opacity: 1; transform: none; }
  .hero-copy > * { animation: hero-rise 1s var(--ease) backwards; }
  .hero-copy > *:nth-child(2) { animation-delay: 0.1s; }
  .hero-copy > *:nth-child(3) { animation-delay: 0.2s; }
  .hero-copy > *:nth-child(4) { animation-delay: 0.3s; }
  .hero-copy > *:nth-child(5) { animation-delay: 0.4s; }
  .hero-copy > *:nth-child(6) { animation-delay: 0.5s; }
  .hero-visual { animation: hero-fade 1.4s var(--ease) 0.3s backwards; }
  @keyframes hero-rise { from { opacity: 0; transform: translateY(34px); } to { opacity: 1; transform: none; } }
  @keyframes hero-fade { from { opacity: 0; transform: translateY(20px) scale(0.98); } to { opacity: 1; transform: none; } }
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1100px) {
  .hero { grid-template-columns: 1fr; min-height: 0; padding-top: 140px; }
  .hero-visual { margin-top: 24px; max-width: 520px; justify-self: center; }
  .hero-panel { left: 0; }
  .decision-section, .valuation-section, .social-band, .profile-section { grid-template-columns: 1fr; }
  .region-head { grid-template-columns: 1fr; align-items: start; }
  .magazine-grid { grid-template-columns: 1fr; }
  .trust-board { grid-template-columns: 1fr; max-width: 760px; }
  .final-cta { grid-template-columns: 1fr; }
  .final-cta .cta-row { flex-direction: row; }
  .detail-layout { grid-template-columns: 1fr; }
  .detail-layout aside { position: static; }
  .profile-visual { justify-content: flex-start; }
}

@media (max-width: 860px) {
  .main-nav {
    position: fixed;
    inset: 0;
    z-index: -1;
    flex-direction: column;
    justify-content: center;
    gap: 8px;
    padding: 100px var(--gutter) 60px;
    background: linear-gradient(180deg, rgba(6, 13, 24, 0.98), rgba(4, 8, 15, 0.99));
    -webkit-backdrop-filter: blur(20px);
    backdrop-filter: blur(20px);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.4s var(--ease), visibility 0.4s;
  }
  .main-nav.open { opacity: 1; visibility: visible; z-index: 199; }
  .main-nav a { font-size: 1.05rem; padding: 14px 0; border-bottom: 1px solid var(--line-dark); width: 100%; }
  .nav-toggle { display: grid; place-items: center; z-index: 201; }
  .header-cta { display: none; }
  .site-header { background: linear-gradient(180deg, rgba(4, 8, 15, 0.92), rgba(6, 13, 24, 0.82)); -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px); padding-block: 13px; border-bottom-color: var(--line-dark); }
  .mobile-action-bar { display: grid; }
  .whatsapp-float { bottom: 86px; right: 18px; width: 52px; height: 52px; }
  body { padding-bottom: 56px; }
  .audience-grid { grid-template-columns: 1fr; }
  .hero-specialty-cards { grid-template-columns: 1fr; gap: 10px; }
  .process-timeline { grid-template-columns: 1fr 1fr; }
  .process-timeline article { border-right: 0; border-bottom: 1px solid var(--line-dark); padding: 24px 16px 20px 0; }
  .decision-grid { grid-template-columns: 1fr; }
  .choice-grid { grid-template-columns: repeat(2, 1fr); }
  .profile-badges { grid-template-columns: 1fr; gap: 0; }
  .profile-badges article { padding-block: 14px; }
  .card-actions { grid-template-columns: 1fr; }
  .site-footer div:nth-child(2) { margin-left: 0; }
}

@media (max-width: 560px) {
  .process-timeline { grid-template-columns: 1fr; }
  .hero { padding-top: 120px; }
  .hero-panel { position: static; margin-top: -40px; max-width: none; }
  .remax-pill { top: 0; }
  .form-progress span:not(:first-child) { margin-left: 32px; }
  .form-progress span:not(:first-child)::before { width: 32px; }
  .cta-row .btn { flex: 1 1 auto; justify-content: center; }
}

/* ==========================================================================
   FINAL CANER POLISH: navy / red / white executive direction
   ========================================================================== */
:root {
  --gold: #7c8aa0;
  --gold-bright: #dbe7f7;
  --gold-deep: #53667f;
  --gold-soft: rgba(75, 106, 148, 0.12);
  --line-dark: rgba(255, 255, 255, 0.1);
}

.hero-title,
.hero-title span,
.decision-copy h2,
.profile-copy h2,
.audience-section .section-title h2,
.trust-board blockquote p,
.testimonial-grid blockquote p,
.profile-name strong,
.profile-badges strong,
.decision-grid h3,
.audience-grid h3 {
  font-family: var(--sans) !important;
}

.hero {
  overflow: hidden !important;
  background:
    radial-gradient(820px 520px at 78% 30%, rgba(32, 98, 160, 0.26), transparent 63%),
    radial-gradient(760px 520px at 68% 44%, rgba(218, 18, 31, 0.16), transparent 60%),
    linear-gradient(135deg, #020711 0%, #07172b 56%, #0e2b4b 100%) !important;
}

.hero-title {
  max-width: 10.7ch !important;
  font-size: clamp(3rem, 4.75vw, 5.18rem) !important;
  font-weight: 880 !important;
  line-height: 0.99 !important;
  letter-spacing: -0.055em !important;
  text-wrap: balance;
}

.hero-title span {
  display: block;
  color: #fff !important;
}

.hero-title span:last-child {
  position: relative;
  width: max-content;
  max-width: 100%;
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  color: #ff2631 !important;
  font-style: normal !important;
  font-weight: 900 !important;
}

.hero-title span:last-child::after {
  content: "";
  position: absolute;
  left: 0.06em;
  right: 0.08em;
  bottom: -0.09em;
  height: 0.065em;
  border-radius: 999px;
  background: linear-gradient(90deg, #ff2631, rgba(255, 38, 49, 0.08));
  transform-origin: left;
}

.hero-copy p {
  max-width: 560px !important;
  border-left: 2px solid rgba(255, 38, 49, 0.92) !important;
  border-radius: 0 14px 14px 0 !important;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.025)) !important;
  box-shadow: none !important;
}

.hero-visual {
  min-height: min(700px, calc(100svh - 64px)) !important;
  align-items: flex-start !important;
  padding-top: clamp(26px, 5vh, 54px) !important;
}

.hero-visual picture {
  position: relative;
  width: min(650px, 108%) !important;
  margin-top: -48px !important;
  margin-right: -34px !important;
  overflow: visible !important;
  transform-origin: 58% 42%;
  transition: filter 0.7s var(--ease), transform 0.7s var(--ease) !important;
  filter:
    drop-shadow(0 42px 52px rgba(0, 0, 0, 0.5))
    drop-shadow(0 0 34px rgba(48, 119, 190, 0.18)) !important;
}

.hero-visual picture::before {
  content: "";
  position: absolute;
  inset: 6% 1% 20% 14%;
  z-index: 3;
  pointer-events: none;
  opacity: 0;
  border-radius: 42% 58% 52% 48%;
  background:
    linear-gradient(110deg, transparent 22%, rgba(255, 255, 255, 0.62) 46%, transparent 68%),
    radial-gradient(circle at 52% 28%, rgba(255, 255, 255, 0.42), transparent 36%);
  mix-blend-mode: screen;
  transform: translateX(-58%) skewX(-10deg);
  transition: opacity 0.55s var(--ease), transform 0.85s var(--ease);
}

.hero-visual:hover picture {
  transform: translateY(-10px) scale(1.025) !important;
  filter:
    drop-shadow(0 50px 58px rgba(0, 0, 0, 0.55))
    drop-shadow(0 0 42px rgba(65, 137, 215, 0.25))
    brightness(1.055) !important;
}

.hero-visual:hover picture::before {
  opacity: 0.72;
  transform: translateX(54%) skewX(-10deg);
}

.hero-card,
.hero-specialty-card,
.hero-panel {
  border-color: rgba(255, 255, 255, 0.12) !important;
  background: linear-gradient(145deg, rgba(12, 27, 47, 0.78), rgba(6, 13, 25, 0.55)) !important;
  box-shadow: 0 22px 55px rgba(0, 0, 0, 0.24) !important;
}

@media (prefers-reduced-motion: no-preference) {
  .hero-copy > *,
  .hero-visual {
    opacity: 1 !important;
    transform: none !important;
    animation-fill-mode: both !important;
  }

  .hero-title .word {
    display: inline-block;
    opacity: 1;
    clip-path: inset(0 0 0 0);
    transform: translateY(0);
    animation: word-mask-rise 0.88s cubic-bezier(0.16, 1, 0.3, 1) both !important;
    animation-delay: var(--d, 0s) !important;
  }

  .hero-title span:last-child::after {
    transform: scaleX(0);
    animation: line-draw 0.72s cubic-bezier(0.16, 1, 0.3, 1) 0.9s forwards;
  }
}

@keyframes word-mask-rise {
  from {
    opacity: 0.001;
    clip-path: inset(0 0 82% 0);
    transform: translateY(0.42em);
    filter: blur(8px);
  }

  to {
    opacity: 1;
    clip-path: inset(0 0 0 0);
    transform: translateY(0);
    filter: blur(0);
  }
}

@keyframes line-draw {
  to { transform: scaleX(1); }
}

.decision-section,
.profile-section,
.audience-section,
.testimonials-section {
  background:
    radial-gradient(780px 420px at 82% 12%, rgba(215, 25, 32, 0.11), transparent 60%),
    linear-gradient(rgba(255, 255, 255, 0.024) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.024) 1px, transparent 1px),
    #020711 !important;
  background-size: auto, 84px 84px, 84px 84px, auto !important;
}

.decision-copy .eyebrow,
.audience-section .eyebrow,
.testimonials-section .eyebrow,
.profile-copy .eyebrow {
  color: #ff3944 !important;
  letter-spacing: 0.24em !important;
}

.decision-grid {
  gap: 14px !important;
  border: 0 !important;
  background: transparent !important;
}

.decision-grid article,
.audience-grid article,
.trust-board blockquote,
.testimonial-grid blockquote {
  position: relative;
  overflow: hidden;
  border-radius: 18px !important;
  border: 1px solid rgba(255, 255, 255, 0.105) !important;
  background:
    linear-gradient(160deg, rgba(16, 35, 58, 0.86), rgba(6, 13, 25, 0.76)) !important;
  box-shadow: 0 26px 70px rgba(0, 0, 0, 0.24) !important;
  transition: transform 0.38s var(--ease), border-color 0.38s var(--ease), background 0.38s var(--ease) !important;
}

.decision-grid article::after,
.audience-grid article::after,
.trust-board blockquote::after,
.testimonial-grid blockquote::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.08), transparent 34%);
  opacity: 0;
  transition: opacity 0.38s var(--ease);
}

.decision-grid article:hover,
.audience-grid article:hover,
.trust-board blockquote:hover,
.testimonial-grid blockquote:hover {
  transform: translateY(-8px) !important;
  border-color: rgba(255, 38, 49, 0.42) !important;
  background:
    radial-gradient(300px 160px at 12% 0%, rgba(215, 25, 32, 0.16), transparent 70%),
    linear-gradient(160deg, rgba(18, 42, 70, 0.92), rgba(6, 13, 25, 0.78)) !important;
}

.decision-grid article:hover::after,
.audience-grid article:hover::after,
.trust-board blockquote:hover::after,
.testimonial-grid blockquote:hover::after {
  opacity: 1;
}

.decision-grid article:last-child {
  grid-column: span 2;
}

.decision-grid h3,
.audience-grid h3 {
  font-weight: 760 !important;
  letter-spacing: -0.02em !important;
}

.decision-grid h3::before,
.audience-grid h3::before {
  background: #ff2631 !important;
}

.profile-visual {
  perspective: 1100px;
}

.profile-portrait {
  position: relative;
  width: min(500px, 100%) !important;
  min-height: 610px;
  overflow: visible !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  border-radius: 18px;
  background:
    radial-gradient(460px 420px at 54% 32%, rgba(36, 101, 170, 0.28), transparent 66%),
    linear-gradient(180deg, #0d223d, #04101f 78%) !important;
  box-shadow: 0 38px 90px rgba(0, 0, 0, 0.44) !important;
  transform: rotateY(-7deg) rotateX(2deg);
  transform-style: preserve-3d;
  transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease) !important;
}

.profile-portrait:hover {
  transform: rotateY(-3deg) rotateX(1deg) translateY(-8px);
  box-shadow: 0 46px 110px rgba(0, 0, 0, 0.54) !important;
}

.profile-portrait::before {
  content: "";
  position: absolute;
  inset: 18px -18px -18px 18px !important;
  z-index: 0;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  border-radius: 14px;
  transform: translateZ(-28px);
  pointer-events: none;
}

.profile-portrait::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  z-index: 3;
  height: 36%;
  border-radius: 0 0 18px 18px;
  background: linear-gradient(180deg, transparent, rgba(2, 7, 16, 0.94));
  pointer-events: none;
}

.profile-portrait img {
  position: relative;
  z-index: 2;
  width: 118% !important;
  max-width: none !important;
  margin-left: -8%;
  transform: translateY(-54px) translateZ(70px) scale(1.04);
  filter: drop-shadow(0 34px 42px rgba(0, 0, 0, 0.58));
}

.profile-portrait span {
  z-index: 4 !important;
  bottom: 22px !important;
  left: 22px !important;
  border-radius: 8px;
  background: linear-gradient(135deg, #e51b25, #a90f17) !important;
  box-shadow: 0 18px 38px rgba(215, 25, 32, 0.26);
}

.profile-badges,
.audience-grid,
.trust-board {
  gap: clamp(18px, 2.5vw, 30px) !important;
}

.profile-badges article {
  border-radius: 16px !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
  background: linear-gradient(145deg, rgba(16, 35, 58, 0.78), rgba(5, 12, 23, 0.72)) !important;
}

.audience-grid span,
.profile-badges span {
  font-family: var(--sans) !important;
  font-style: normal !important;
  color: rgba(255, 255, 255, 0.44) !important;
}

.audience-grid a,
.service-card a,
.trust-board cite,
.testimonial-grid cite {
  color: #dbe7f7 !important;
  border-bottom-color: #ff2631 !important;
}

.trust-board blockquote::before,
.testimonial-grid blockquote::before {
  color: rgba(255, 38, 49, 0.2) !important;
}

.trust-board blockquote p,
.testimonial-grid blockquote p {
  font-style: normal !important;
  font-size: clamp(1rem, 1.25vw, 1.16rem) !important;
  font-weight: 560 !important;
  line-height: 1.72 !important;
  color: rgba(242, 246, 252, 0.9) !important;
}

.trust-board .featured-quote {
  background:
    radial-gradient(320px 200px at 0% 0%, rgba(215, 25, 32, 0.19), transparent 68%),
    linear-gradient(160deg, rgba(18, 42, 70, 0.94), rgba(6, 13, 25, 0.78)) !important;
  border-color: rgba(255, 38, 49, 0.32) !important;
}

@media (max-width: 1120px) {
  .hero-title {
    max-width: 11.5ch !important;
  }

  .hero-visual {
    min-height: 580px !important;
    padding-top: 0 !important;
  }

  .hero-visual picture {
    width: min(560px, 96%) !important;
    margin: -20px auto 0 !important;
  }

  .decision-grid article:last-child {
    grid-column: span 1;
  }

  .profile-portrait {
    transform: none;
  }
}

@media (max-width: 720px) {
  .hero-title {
    font-size: clamp(2.55rem, 14vw, 4.1rem) !important;
    letter-spacing: -0.045em !important;
  }

  .hero-copy p {
    font-size: 1.02rem !important;
  }

  .hero-visual {
    min-height: 500px !important;
  }

  .hero-visual picture {
    width: min(440px, 112%) !important;
    margin-top: -18px !important;
  }

  .profile-portrait {
    min-height: 500px;
    width: min(390px, 100%) !important;
  }

  .profile-portrait img {
    width: 112% !important;
    margin-left: -6%;
    transform: translateY(-30px) scale(1.02);
  }
}

/* Stable hero title: visible by default, animated through premium light details */
.hero-title,
.hero-title span,
.hero-title .word {
  opacity: 1 !important;
  transform: none !important;
  clip-path: none !important;
  filter: none !important;
}

.hero-title .word {
  animation: none !important;
}

.hero-title {
  position: relative;
  isolation: isolate;
}

.hero-title::before {
  content: "";
  position: absolute;
  inset: -0.08em -0.12em;
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  background: linear-gradient(105deg, transparent 18%, rgba(255, 255, 255, 0.34) 42%, transparent 64%);
  mix-blend-mode: screen;
  transform: translateX(-120%);
}

@media (prefers-reduced-motion: no-preference) {
  .hero-title::before {
    animation: title-sheen 1.15s cubic-bezier(0.16, 1, 0.3, 1) 0.28s both;
  }

  .hero-copy p,
  .hero-actions,
  .hero-proof-link,
  .hero-specialty-card {
    animation: calm-rise 0.72s cubic-bezier(0.16, 1, 0.3, 1) both;
  }

  .hero-copy p { animation-delay: 0.12s; }
  .hero-actions { animation-delay: 0.2s; }
  .hero-proof-link { animation-delay: 0.26s; }
  .hero-specialty-card:nth-child(1) { animation-delay: 0.32s; }
  .hero-specialty-card:nth-child(2) { animation-delay: 0.4s; }
  .hero-specialty-card:nth-child(3) { animation-delay: 0.48s; }
}

@keyframes title-sheen {
  0% { opacity: 0; transform: translateX(-120%); }
  18% { opacity: 0.34; }
  100% { opacity: 0; transform: translateX(120%); }
}

@keyframes calm-rise {
  from { opacity: 0; transform: translateY(14px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Hero personal brand card readability */
.hero-panel {
  background:
    linear-gradient(145deg, rgba(8, 21, 38, 0.94), rgba(5, 13, 25, 0.9)) !important;
  border-color: rgba(219, 231, 247, 0.2) !important;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.36) !important;
}

.hero-panel small {
  color: #ff3340 !important;
  text-shadow: 0 0 18px rgba(255, 38, 49, 0.22);
}

.hero-panel strong {
  color: #ffffff !important;
  text-shadow: 0 10px 34px rgba(0, 0, 0, 0.38);
}

.hero-panel span {
  color: rgba(232, 240, 251, 0.82) !important;
}

/* Refined portrait shine: elegant edge glint, no large white flare */
.hero-visual picture::before {
  content: "" !important;
  position: absolute !important;
  inset: 10% 6% 20% 58% !important;
  z-index: 3 !important;
  pointer-events: none !important;
  opacity: 0 !important;
  border-radius: 999px !important;
  background:
    linear-gradient(
      112deg,
      transparent 0%,
      transparent 34%,
      rgba(255, 255, 255, 0.05) 43%,
      rgba(255, 255, 255, 0.34) 50%,
      rgba(130, 186, 245, 0.12) 56%,
      transparent 70%,
      transparent 100%
    ) !important;
  filter: blur(9px) !important;
  mix-blend-mode: screen !important;
  transform: translateX(-26%) rotate(-7deg) skewX(-8deg) !important;
  transition: opacity 0.38s var(--ease), transform 0.86s var(--ease), filter 0.86s var(--ease) !important;
}

.hero-visual:hover picture::before {
  opacity: 0.46 !important;
  transform: translateX(18%) rotate(-7deg) skewX(-8deg) !important;
  filter: blur(7px) !important;
}

.hero-visual picture::after {
  content: "";
  position: absolute;
  inset: 6% 12% 16% 46%;
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  border-radius: 48% 52% 42% 58%;
  background: radial-gradient(circle at 56% 34%, rgba(145, 199, 255, 0.2), transparent 44%);
  mix-blend-mode: screen;
  transition: opacity 0.45s var(--ease);
}

.hero-visual:hover picture::after {
  opacity: 0.24;
}

/* Premium process timeline */
.process-section {
  background:
    radial-gradient(760px 380px at 82% 12%, rgba(32, 98, 160, 0.13), transparent 62%),
    radial-gradient(620px 340px at 12% 0%, rgba(215, 25, 32, 0.075), transparent 60%),
    linear-gradient(rgba(255, 255, 255, 0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.018) 1px, transparent 1px),
    #020711 !important;
  background-size: auto, auto, 86px 86px, 86px 86px, auto !important;
}

.process-timeline {
  gap: 14px !important;
  padding: 1px !important;
  border-top: 0 !important;
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.02)),
    linear-gradient(90deg, rgba(255, 38, 49, 0.16), rgba(47, 124, 204, 0.12));
  box-shadow: 0 32px 90px rgba(0, 0, 0, 0.22);
}

.process-timeline article {
  min-height: 210px;
  padding: 30px 28px 28px !important;
  border-right: 0 !important;
  border-radius: 20px;
  background:
    linear-gradient(155deg, rgba(14, 32, 55, 0.88), rgba(5, 12, 23, 0.86)) !important;
  overflow: hidden;
  transition:
    transform 0.36s var(--ease),
    border-color 0.36s var(--ease),
    background 0.36s var(--ease),
    box-shadow 0.36s var(--ease) !important;
}

.process-timeline article::before {
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  opacity: 0.68;
  background: linear-gradient(90deg, #ff2631, rgba(255, 38, 49, 0.04)) !important;
  transform: scaleX(0.18);
  transform-origin: left;
  transition: transform 0.42s var(--ease), opacity 0.42s var(--ease) !important;
}

.process-timeline article::after {
  content: "";
  position: absolute;
  inset: -40% -25% auto auto;
  width: 180px;
  height: 180px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(67, 142, 224, 0.14), transparent 66%);
  opacity: 0;
  transition: opacity 0.36s var(--ease), transform 0.36s var(--ease);
  pointer-events: none;
}

.process-timeline article:hover {
  transform: translateY(-8px) !important;
  background:
    radial-gradient(280px 170px at 12% 0%, rgba(215, 25, 32, 0.14), transparent 68%),
    linear-gradient(155deg, rgba(17, 42, 72, 0.95), rgba(5, 12, 23, 0.88)) !important;
  box-shadow: 0 26px 64px rgba(0, 0, 0, 0.3);
}

.process-timeline article:hover::before {
  transform: scaleX(1);
  opacity: 1;
}

.process-timeline article:hover::after {
  opacity: 1;
  transform: translate(-10px, 10px);
}

.process-timeline span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 38px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.045);
  font-family: var(--sans) !important;
  font-style: normal !important;
  font-size: 0.82rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.18em;
  color: rgba(219, 231, 247, 0.72) !important;
}

.process-timeline h3 {
  margin-top: 28px !important;
  font-family: var(--sans) !important;
  font-size: clamp(1.2rem, 1.35vw, 1.48rem) !important;
  font-weight: 760 !important;
  letter-spacing: -0.025em;
  color: #fff !important;
}

.process-timeline p {
  max-width: 31ch;
  margin-top: 12px !important;
  font-size: 0.98rem !important;
  font-weight: 500;
  line-height: 1.72 !important;
  color: rgba(220, 230, 244, 0.68) !important;
}

@media (max-width: 860px) {
  .process-timeline {
    gap: 12px !important;
  }

  .process-timeline article {
    min-height: 0;
    border-bottom: 0 !important;
  }
}

/* Premium profile expertise badges */
.profile-badges {
  align-items: stretch;
  gap: clamp(16px, 2vw, 24px) !important;
}

.profile-badges article {
  position: relative;
  min-height: 164px;
  padding: 24px 24px 22px !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  border-radius: 20px !important;
  background:
    radial-gradient(260px 160px at 12% 0%, rgba(61, 130, 210, 0.13), transparent 70%),
    linear-gradient(150deg, rgba(16, 36, 61, 0.9), rgba(5, 12, 23, 0.82)) !important;
  box-shadow: 0 20px 58px rgba(0, 0, 0, 0.22);
  overflow: hidden;
  transition: transform 0.34s var(--ease), border-color 0.34s var(--ease), box-shadow 0.34s var(--ease), background 0.34s var(--ease);
}

.profile-badges article::before {
  content: "";
  position: absolute;
  top: 0;
  left: 24px;
  width: 42px;
  height: 2px;
  background: linear-gradient(90deg, #ff2631, rgba(255, 38, 49, 0));
  transition: width 0.34s var(--ease);
}

.profile-badges article::after {
  content: "";
  position: absolute;
  right: 20px;
  top: 22px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ff2631;
  box-shadow: 0 0 0 8px rgba(255, 38, 49, 0.08), 0 0 22px rgba(255, 38, 49, 0.26);
  opacity: 0.78;
}

.profile-badges article:hover {
  transform: translateY(-7px);
  border-color: rgba(255, 38, 49, 0.34) !important;
  background:
    radial-gradient(280px 170px at 15% 0%, rgba(215, 25, 32, 0.14), transparent 68%),
    linear-gradient(150deg, rgba(19, 45, 75, 0.96), rgba(5, 12, 23, 0.86)) !important;
  box-shadow: 0 28px 72px rgba(0, 0, 0, 0.32);
}

.profile-badges article:hover::before {
  width: 92px;
}

.profile-badges span {
  display: inline-flex;
  margin-bottom: 24px;
  font-size: 0.78rem !important;
  font-weight: 800;
  letter-spacing: 0.2em;
  color: rgba(219, 231, 247, 0.58) !important;
}

.profile-badges strong {
  display: block;
  margin-top: 0 !important;
  max-width: 13ch;
  font-size: clamp(1.03rem, 1.15vw, 1.24rem) !important;
  font-weight: 780 !important;
  letter-spacing: -0.025em;
  line-height: 1.15;
  color: #fff !important;
}

.profile-badges p {
  margin-top: 12px !important;
  max-width: 25ch;
  font-size: 0.92rem !important;
  font-weight: 500;
  line-height: 1.62 !important;
  color: rgba(221, 231, 244, 0.68) !important;
}

@media (max-width: 860px) {
  .profile-badges {
    gap: 12px !important;
  }

  .profile-badges article {
    min-height: 0;
  }
}

/* Premium services listing */
.service-grid {
  align-items: stretch;
  gap: clamp(18px, 2.4vw, 30px) !important;
}

.service-card {
  position: relative;
  min-height: 300px;
  display: flex;
  flex-direction: column;
  padding: 34px 32px 30px !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  border-radius: 22px;
  background:
    radial-gradient(320px 190px at 15% 0%, rgba(55, 127, 210, 0.14), transparent 68%),
    linear-gradient(155deg, rgba(14, 32, 55, 0.92), rgba(5, 12, 23, 0.88)) !important;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.26) !important;
  overflow: hidden;
  isolation: isolate;
}

.service-card::before {
  background:
    radial-gradient(360px circle at var(--mx) var(--my), rgba(255, 38, 49, 0.13), transparent 62%) !important;
}

.service-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(90deg, #ff2631, rgba(255, 38, 49, 0)) 0 0 / 72px 2px no-repeat,
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), transparent 34%);
  opacity: 0.9;
}

.service-card:hover {
  transform: translateY(-9px) !important;
  border-color: rgba(255, 38, 49, 0.34) !important;
  box-shadow: 0 34px 86px rgba(0, 0, 0, 0.36) !important;
}

.service-card .icon {
  width: 58px !important;
  height: 58px !important;
  border-radius: 16px;
  border: 1px solid rgba(219, 231, 247, 0.18) !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.025)) !important;
  color: #fff !important;
  font-family: var(--sans) !important;
  font-style: normal !important;
  font-size: 1.2rem !important;
  font-weight: 850;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 16px 34px rgba(0, 0, 0, 0.22);
}

.service-card h3 {
  margin-top: 28px !important;
  max-width: 18ch;
  font-family: var(--sans) !important;
  font-size: clamp(1.24rem, 1.5vw, 1.55rem) !important;
  font-weight: 780;
  letter-spacing: -0.03em;
  line-height: 1.16;
  color: #fff !important;
}

.service-card p {
  margin-top: 14px !important;
  max-width: 34ch;
  min-height: 4.9em;
  font-size: 0.98rem !important;
  font-weight: 500;
  line-height: 1.7 !important;
  color: rgba(221, 231, 244, 0.72) !important;
}

.service-card a {
  width: max-content;
  margin-top: auto !important;
  padding-top: 18px;
  color: #f4f7fb !important;
  border-bottom-color: #ff2631 !important;
  letter-spacing: 0.14em !important;
}

.service-card a::after {
  content: "→";
  margin-left: 2px;
  transition: transform 0.3s var(--ease);
}

.service-card a:hover::after {
  transform: translateX(5px);
}

/* Restore soft portrait grounding: no hard-cut bottom edge */
.hero-visual picture {
  padding-bottom: 42px;
}

.hero-portrait {
  -webkit-mask-image: linear-gradient(
    180deg,
    #000 0%,
    #000 72%,
    rgba(0, 0, 0, 0.92) 82%,
    rgba(0, 0, 0, 0.34) 94%,
    transparent 100%
  );
  mask-image: linear-gradient(
    180deg,
    #000 0%,
    #000 72%,
    rgba(0, 0, 0, 0.92) 82%,
    rgba(0, 0, 0, 0.34) 94%,
    transparent 100%
  );
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}

.hero-visual picture::after {
  content: "" !important;
  position: absolute !important;
  left: 5% !important;
  right: 8% !important;
  bottom: 22px !important;
  top: auto !important;
  z-index: 1 !important;
  height: 190px !important;
  pointer-events: none !important;
  opacity: 0.88 !important;
  border-radius: 50% !important;
  background:
    radial-gradient(ellipse at 52% 70%, rgba(0, 0, 0, 0.48), transparent 58%),
    radial-gradient(ellipse at 66% 60%, rgba(33, 102, 174, 0.18), transparent 62%) !important;
  filter: blur(18px) !important;
  mix-blend-mode: multiply !important;
  transform: translateY(26px) scaleX(0.92) !important;
  transition: opacity 0.45s var(--ease), transform 0.45s var(--ease) !important;
}

.hero-visual:hover picture::after {
  opacity: 0.96 !important;
  transform: translateY(22px) scaleX(0.96) !important;
}

/* Floating quick contact */
.whatsapp-float {
  right: 24px !important;
  bottom: 24px !important;
  width: auto !important;
  height: auto !important;
  min-width: 206px;
  display: inline-flex !important;
  align-items: center;
  gap: 12px;
  padding: 12px 16px 12px 12px;
  border-radius: 999px !important;
  color: #fff !important;
  background:
    linear-gradient(135deg, rgba(13, 34, 61, 0.92), rgba(5, 14, 27, 0.94)) !important;
  border: 1px solid rgba(255, 255, 255, 0.13);
  box-shadow: 0 22px 70px rgba(0, 0, 0, 0.36), 0 0 0 1px rgba(28, 205, 102, 0.12) inset !important;
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  text-align: left;
  overflow: visible;
}

.whatsapp-float::before {
  display: none !important;
}

.whatsapp-float::after {
  inset: -8px !important;
  border-radius: 999px !important;
  border-color: rgba(28, 205, 102, 0.26) !important;
}

.whatsapp-float .wa-icon {
  display: grid;
  place-items: center;
  flex: 0 0 46px;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  color: #fff;
  background: linear-gradient(135deg, #27d86c, #0faa53);
  box-shadow: 0 14px 34px rgba(24, 196, 93, 0.34);
}

.whatsapp-float .wa-icon::before {
  content: "";
  width: 25px;
  height: 25px;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12.04 2C6.58 2 2.13 6.45 2.13 11.91c0 1.75.46 3.45 1.32 4.95L2.05 22l5.25-1.38a9.86 9.86 0 0 0 4.74 1.21c5.46 0 9.91-4.45 9.91-9.91C21.95 6.45 17.5 2 12.04 2m0 18.03a8.1 8.1 0 0 1-4.13-1.13l-.3-.18-3.12.82.83-3.04-.2-.31a8.06 8.06 0 0 1-1.26-4.38c0-4.54 3.7-8.24 8.24-8.24 4.54 0 8.24 3.7 8.24 8.24 0 4.54-3.7 8.22-8.3 8.22m4.52-6.16c-.25-.12-1.47-.72-1.69-.81-.23-.08-.39-.12-.56.12-.17.25-.64.81-.78.97-.14.17-.29.19-.54.06-.25-.12-1.05-.39-1.99-1.23-.74-.66-1.23-1.47-1.38-1.72-.14-.25-.02-.38.11-.51.11-.11.25-.29.37-.43s.17-.25.25-.41c.08-.17.04-.31-.02-.43s-.56-1.34-.76-1.84c-.2-.48-.41-.42-.56-.43h-.48c-.17 0-.43.06-.66.31-.22.25-.86.85-.86 2.07 0 1.22.89 2.4 1.01 2.56.12.17 1.75 2.67 4.23 3.74.59.26 1.05.41 1.41.52.59.19 1.13.16 1.56.1.48-.07 1.47-.6 1.67-1.18.21-.58.21-1.07.15-1.18-.06-.1-.23-.16-.48-.27'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12.04 2C6.58 2 2.13 6.45 2.13 11.91c0 1.75.46 3.45 1.32 4.95L2.05 22l5.25-1.38a9.86 9.86 0 0 0 4.74 1.21c5.46 0 9.91-4.45 9.91-9.91C21.95 6.45 17.5 2 12.04 2m0 18.03a8.1 8.1 0 0 1-4.13-1.13l-.3-.18-3.12.82.83-3.04-.2-.31a8.06 8.06 0 0 1-1.26-4.38c0-4.54 3.7-8.24 8.24-8.24 4.54 0 8.24 3.7 8.24 8.24 0 4.54-3.7 8.22-8.3 8.22m4.52-6.16c-.25-.12-1.47-.72-1.69-.81-.23-.08-.39-.12-.56.12-.17.25-.64.81-.78.97-.14.17-.29.19-.54.06-.25-.12-1.05-.39-1.99-1.23-.74-.66-1.23-1.47-1.38-1.72-.14-.25-.02-.38.11-.51.11-.11.25-.29.37-.43s.17-.25.25-.41c.08-.17.04-.31-.02-.43s-.56-1.34-.76-1.84c-.2-.48-.41-.42-.56-.43h-.48c-.17 0-.43.06-.66.31-.22.25-.86.85-.86 2.07 0 1.22.89 2.4 1.01 2.56.12.17 1.75 2.67 4.23 3.74.59.26 1.05.41 1.41.52.59.19 1.13.16 1.56.1.48-.07 1.47-.6 1.67-1.18.21-.58.21-1.07.15-1.18-.06-.1-.23-.16-.48-.27'/%3E%3C/svg%3E") center / contain no-repeat;
}

.whatsapp-float .wa-copy {
  display: grid;
  gap: 2px;
  line-height: 1.1;
}

.whatsapp-float .wa-copy strong {
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  color: #fff;
}

.whatsapp-float .wa-copy small {
  font-size: 0.72rem;
  font-weight: 600;
  color: rgba(221, 231, 244, 0.72);
}

.whatsapp-float:hover {
  transform: translateY(-5px) !important;
  border-color: rgba(28, 205, 102, 0.34);
  box-shadow: 0 28px 84px rgba(0, 0, 0, 0.42), 0 0 34px rgba(28, 205, 102, 0.14) !important;
}

@media (max-width: 860px) {
  .whatsapp-float {
    right: 14px !important;
    bottom: 74px !important;
    min-width: 0;
    padding: 10px !important;
  }

  .whatsapp-float .wa-copy {
    display: none;
  }

  .whatsapp-float .wa-icon {
    width: 46px;
    height: 46px;
    flex-basis: 46px;
  }
}

/* Mobile hero repair */
@media (max-width: 720px) {
  html,
  body {
    max-width: 100%;
    overflow-x: hidden;
  }

  .site-header {
    left: 0;
    right: 0;
    width: 100%;
    padding: 10px 20px !important;
  }

  .brand {
    min-width: 0;
  }

  .brand-mark {
    width: 54px;
    height: 54px;
    flex: 0 0 54px;
  }

  .brand span:not(.brand-mark) {
    min-width: 0;
  }

  .brand strong {
    font-size: 1rem;
    white-space: nowrap;
  }

  .brand small {
    font-size: 0.65rem;
    letter-spacing: 0.22em;
  }

  .nav-toggle {
    width: 54px;
    height: 54px;
    flex: 0 0 54px;
  }

  .hero {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 22px !important;
    width: 100% !important;
    min-height: auto !important;
    padding: 102px 20px 44px !important;
    overflow: hidden !important;
  }

  .hero *,
  .hero *::before,
  .hero *::after {
    box-sizing: border-box;
  }

  .hero-copy {
    min-width: 0 !important;
    width: 100%;
    max-width: 100% !important;
    padding-bottom: 0 !important;
  }

  .hero-prelude {
    font-size: 0.68rem !important;
    letter-spacing: 0.22em !important;
  }

  .hero-title {
    max-width: 100% !important;
    width: 100% !important;
    margin-top: 16px !important;
    font-size: clamp(2.45rem, 10.5vw, 3.35rem) !important;
    line-height: 1.03 !important;
    letter-spacing: -0.055em !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    text-wrap: balance;
  }

  .hero-title,
  .hero-copy p,
  .hero .cta-row,
  .hero-specialty-cards {
    min-width: 0 !important;
  }

  .hero-title span {
    width: 100% !important;
    max-width: 100% !important;
  }

  .hero-title span:last-child {
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
  }

  .hero-title span:last-child::after {
    right: 22% !important;
  }

  .hero-copy p {
    width: 100% !important;
    max-width: 100% !important;
    margin-top: 20px !important;
    padding: 18px 18px !important;
    font-size: 1rem !important;
    line-height: 1.62 !important;
    border-radius: 0 14px 14px 0 !important;
  }

  .hero .cta-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    width: 100% !important;
    margin-top: 24px !important;
  }

  .hero .cta-row .btn {
    width: 100% !important;
    min-width: 0 !important;
    justify-content: center !important;
    padding-inline: 18px !important;
    text-align: center !important;
    white-space: normal !important;
    overflow-wrap: anywhere;
  }

  .hero-text-link {
    max-width: 100%;
    font-size: 0.9rem !important;
    line-height: 1.45;
  }

  .hero-specialty-cards {
    width: 100% !important;
    max-width: 100% !important;
  }

  .hero-specialty-cards article {
    min-width: 0 !important;
  }

  .hero-visual {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 560px !important;
    margin-top: 10px !important;
    padding-top: 0 !important;
    justify-self: stretch !important;
    align-items: start !important;
    justify-content: center !important;
    overflow: visible !important;
  }

  .hero-visual picture {
    width: min(330px, 78vw) !important;
    margin: 12px auto 0 !important;
    padding-bottom: 34px !important;
    transform: translateX(-42px) !important;
  }

  .hero-visual:hover picture {
    transform: translateX(-42px) !important;
  }

  .remax-pill {
    top: 8px !important;
    right: 10px !important;
    padding: 12px 16px !important;
    font-size: 0.7rem !important;
  }

  .hero-panel {
    position: absolute !important;
    left: auto !important;
    right: 10px !important;
    bottom: 34px !important;
    width: min(245px, 60vw) !important;
    max-width: 60vw !important;
    padding: 22px 22px !important;
    margin: 0 !important;
    border-radius: 14px !important;
  }

  .hero-panel small {
    font-size: 0.58rem !important;
    letter-spacing: 0.2em !important;
  }

  .hero-panel strong {
    margin-top: 8px !important;
    font-size: clamp(1.28rem, 6vw, 1.62rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.04em !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
  }

  .hero-panel span {
    margin-top: 10px !important;
    font-size: 0.84rem !important;
    line-height: 1.55 !important;
    overflow-wrap: anywhere;
  }
}

@media (max-width: 430px) {
  .hero {
    padding-inline: 16px !important;
  }

  .hero-title {
    font-size: clamp(2.25rem, 10vw, 2.85rem) !important;
    letter-spacing: -0.05em !important;
  }

  .hero-visual {
    min-height: 520px !important;
  }

  .hero-visual picture {
    width: min(300px, 76vw) !important;
    transform: translateX(-38px) !important;
  }

  .hero-visual:hover picture {
    transform: translateX(-38px) !important;
  }

  .hero-panel {
    right: 8px !important;
    bottom: 28px !important;
    width: min(226px, 62vw) !important;
    max-width: 62vw !important;
    padding: 18px 18px !important;
  }

  .remax-pill {
    right: 8px !important;
    padding: 10px 13px !important;
    letter-spacing: 0.14em !important;
  }

  .hero-panel strong {
    font-size: clamp(1.16rem, 5.4vw, 1.42rem) !important;
  }

  .hero-panel span {
    font-size: 0.78rem !important;
  }
}

/* Premium valuation / lead form */
.valuation-section {
  background:
    radial-gradient(860px 470px at 86% 78%, rgba(215, 25, 32, 0.14), transparent 62%),
    radial-gradient(760px 430px at 10% 8%, rgba(45, 114, 190, 0.13), transparent 58%),
    linear-gradient(rgba(255, 255, 255, 0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.018) 1px, transparent 1px),
    #020711 !important;
  background-size: auto, auto, 86px 86px, 86px 86px, auto !important;
}

.lead-form {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  padding: clamp(28px, 4vw, 46px) !important;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 24px;
  background:
    radial-gradient(520px 260px at 14% 0%, rgba(62, 136, 220, 0.13), transparent 64%),
    radial-gradient(420px 240px at 100% 100%, rgba(215, 25, 32, 0.12), transparent 66%),
    linear-gradient(155deg, rgba(13, 31, 54, 0.94), rgba(5, 12, 23, 0.9)) !important;
  color: #f4f7fb !important;
  box-shadow: 0 34px 96px rgba(0, 0, 0, 0.36) !important;
}

.lead-form::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: -1;
  border: 0 !important;
  pointer-events: none;
  background:
    linear-gradient(90deg, #ff2631, rgba(255, 38, 49, 0)) 0 0 / 120px 2px no-repeat,
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), transparent 36%);
}

.lead-form::after {
  content: "";
  position: absolute;
  right: -120px;
  bottom: -120px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(43, 129, 220, 0.14), transparent 68%);
  pointer-events: none;
}

.form-progress {
  position: relative;
  width: max-content;
  max-width: 100%;
  gap: 0;
  margin-bottom: clamp(30px, 4vw, 42px) !important;
}

.form-progress span {
  width: 44px !important;
  height: 44px !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.045) !important;
  color: rgba(219, 231, 247, 0.66) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.form-progress span:not(:first-child) {
  margin-left: 62px !important;
}

.form-progress span:not(:first-child)::before {
  width: 62px !important;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.06)) !important;
}

.form-progress span.active {
  border-color: rgba(255, 38, 49, 0.5) !important;
  background:
    radial-gradient(circle at 32% 24%, rgba(255, 255, 255, 0.28), transparent 32%),
    linear-gradient(135deg, #ff2631, #b40f19) !important;
  color: #fff !important;
  box-shadow: 0 16px 38px rgba(215, 25, 32, 0.28) !important;
}

.form-progress span.active:not(:first-child)::before {
  background: linear-gradient(90deg, rgba(255, 38, 49, 0.72), rgba(255, 255, 255, 0.08)) !important;
}

.lead-form legend {
  font-family: var(--sans) !important;
  font-size: clamp(1.55rem, 2vw, 2rem) !important;
  font-weight: 760 !important;
  letter-spacing: -0.035em;
  line-height: 1.12;
  color: #fff !important;
  margin-bottom: 26px !important;
}

.choice-grid {
  gap: 12px !important;
  margin-bottom: 28px !important;
}

.choice-grid label {
  min-width: 0;
}

.choice-grid span {
  position: relative;
  min-height: 68px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.11) !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.025)) !important;
  color: rgba(221, 231, 244, 0.74) !important;
  overflow: hidden;
}

.choice-grid span::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(160px circle at 50% 0%, rgba(67, 142, 224, 0.13), transparent 64%);
  opacity: 0;
  transition: opacity 0.32s var(--ease);
}

.choice-grid label:hover span {
  border-color: rgba(255, 255, 255, 0.22) !important;
  color: #fff !important;
  transform: translateY(-2px);
}

.choice-grid label:hover span::before {
  opacity: 1;
}

.choice-grid input:checked + span {
  border-color: rgba(255, 38, 49, 0.52) !important;
  background:
    radial-gradient(220px 120px at 50% 0%, rgba(255, 38, 49, 0.22), transparent 66%),
    linear-gradient(145deg, rgba(17, 40, 68, 0.94), rgba(7, 16, 30, 0.92)) !important;
  color: #fff !important;
  box-shadow: inset 0 0 0 1px rgba(255, 38, 49, 0.12), 0 16px 34px rgba(0, 0, 0, 0.24);
}

.lead-form fieldset > label {
  color: rgba(219, 231, 247, 0.72) !important;
}

.lead-form input:not([type="radio"]),
.lead-form select,
.lead-form textarea {
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.055) !important;
  color: #fff !important;
}

.lead-form input::placeholder,
.lead-form textarea::placeholder {
  color: rgba(221, 231, 244, 0.42);
}

.lead-form input:focus,
.lead-form select:focus,
.lead-form textarea:focus {
  border-color: rgba(255, 38, 49, 0.52) !important;
  background: rgba(255, 255, 255, 0.075) !important;
  box-shadow: 0 0 0 4px rgba(255, 38, 49, 0.12) !important;
}

.lead-form .btn-dark {
  min-height: 58px;
  border-radius: 14px !important;
  border-color: rgba(255, 38, 49, 0.55) !important;
  background: linear-gradient(135deg, #e51b25, #a90f17) !important;
  color: #fff !important;
  box-shadow: 0 20px 52px rgba(215, 25, 32, 0.24) !important;
}

.lead-form .btn-line {
  min-height: 58px;
  border-radius: 14px !important;
  color: #f4f7fb !important;
  border-color: rgba(255, 255, 255, 0.16) !important;
}

.lead-form .btn-primary {
  min-height: 58px;
  border-radius: 14px !important;
}

@media (max-width: 720px) {
  .valuation-section {
    padding-inline: 16px !important;
  }

  .lead-form {
    border-radius: 20px;
  }

  .choice-grid {
    grid-template-columns: 1fr 1fr !important;
  }

  .form-progress span:not(:first-child) {
    margin-left: 42px !important;
  }

  .form-progress span:not(:first-child)::before {
    width: 42px !important;
  }
}

/* Final brand lock: keep RE/MAX logo, move UI language to midnight/gold/silver */
:root {
  --client-midnight: #020813;
  --client-night: #071528;
  --client-gold: #d6b46d;
  --client-gold-soft: #f1d89a;
  --client-silver: #c8d0da;
  --client-silver-muted: rgba(200, 208, 218, 0.72);
  --red: #d6b46d;
  --red-bright: #f1d89a;
  --red-dark: #9b7938;
  --executive-red: #d6b46d;
}

body {
  background: #020813 !important;
}

.site-header {
  background: rgba(2, 8, 19, 0.9) !important;
  border-bottom-color: rgba(200, 208, 218, 0.12) !important;
}

.brand-mark {
  background: linear-gradient(145deg, #10233d, #050b15) !important;
  border-color: rgba(214, 180, 109, 0.55) !important;
  color: var(--client-gold-soft) !important;
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.34), inset 0 0 0 1px rgba(255,255,255,0.06) !important;
}

.header-cta,
.btn-primary,
.lead-form .btn-dark,
.lead-form .btn-primary {
  background: linear-gradient(135deg, #f2d995 0%, #d3ad5d 52%, #a67f39 100%) !important;
  border-color: rgba(214, 180, 109, 0.55) !important;
  color: #06101f !important;
  box-shadow: 0 18px 48px rgba(214, 180, 109, 0.2), inset 0 1px 0 rgba(255,255,255,0.42) !important;
}

.btn-light {
  background: linear-gradient(135deg, #f6f8fb, #c8d0da) !important;
  border-color: rgba(200, 208, 218, 0.28) !important;
  color: #06101f !important;
}

.hero {
  background:
    radial-gradient(780px 620px at 77% 34%, rgba(56, 104, 158, 0.34), transparent 66%),
    radial-gradient(520px 420px at 57% 42%, rgba(214, 180, 109, 0.11), transparent 62%),
    radial-gradient(640px 460px at 18% 30%, rgba(12, 42, 78, 0.52), transparent 70%),
    linear-gradient(rgba(200, 208, 218, 0.033) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200, 208, 218, 0.03) 1px, transparent 1px),
    #020813 !important;
  background-size: auto, auto, auto, 86px 86px, 86px 86px, auto !important;
}

.hero-prelude,
.hero-prelude em {
  color: var(--client-silver) !important;
}

.hero-prelude::before,
.hero-title::before,
.hero-title span:last-child::after,
.hero-title .word::after,
.hero-lead::before,
.decision-grid article span,
.region-card i,
.lead-form::before {
  background: linear-gradient(90deg, var(--client-gold-soft), rgba(214, 180, 109, 0.08), transparent) !important;
  box-shadow: none !important;
}

.hero-title,
.hero-title span,
.hero-title .word,
.hero-title span:nth-child(1),
.hero-title span:nth-child(2) {
  color: #f8fbff !important;
  text-shadow: 0 16px 46px rgba(0, 0, 0, 0.28) !important;
}

.hero-title span:last-child,
.hero-title span:last-child .word {
  color: var(--client-gold-soft) !important;
  text-shadow: 0 18px 46px rgba(214, 180, 109, 0.14) !important;
}

.hero-title .word:nth-child(2n),
.hero-title .word:nth-child(3n),
.hero-title .word:nth-child(4n) {
  color: inherit !important;
  -webkit-text-stroke: 0 !important;
}

.hero-lead {
  border-left-color: var(--client-gold) !important;
  background: linear-gradient(135deg, rgba(9, 22, 39, 0.72), rgba(255,255,255,0.032)) !important;
  color: rgba(240, 245, 251, 0.86) !important;
  box-shadow: inset 0 0 0 1px rgba(200, 208, 218, 0.11) !important;
}

.hero-specialty-cards article,
.profile-badges article,
.process-timeline article,
.decision-grid article,
.audience-grid article,
.region-card,
.portfolio-card,
.article-card,
.service-card,
.testimonial-grid blockquote {
  border-color: rgba(200, 208, 218, 0.15) !important;
  background: linear-gradient(150deg, rgba(13, 31, 54, 0.84), rgba(4, 10, 20, 0.8)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.055), 0 24px 70px rgba(0,0,0,0.22) !important;
}

.hero-specialty-cards article:hover,
.profile-badges article:hover,
.process-timeline article:hover,
.decision-grid article:hover,
.audience-grid article:hover,
.region-card:hover,
.portfolio-card:hover,
.service-card:hover {
  border-color: rgba(214, 180, 109, 0.52) !important;
  box-shadow: 0 30px 92px rgba(0,0,0,0.34), 0 0 0 1px rgba(214, 180, 109, 0.12) !important;
}

.hero-specialty-cards span,
.profile-badges span,
.process-timeline span,
.audience-grid span,
.region-card small {
  color: rgba(214, 180, 109, 0.88) !important;
}

.hero-specialty-cards p,
.profile-badges p,
.process-timeline p,
.decision-grid p,
.audience-grid p,
.region-card p,
.region-card span,
.portfolio-card p,
.article-card p,
.service-card p {
  color: var(--client-silver-muted) !important;
}

.hero-text-link,
.portfolio-card a,
.article-card a,
.featured-article a,
.audience-grid a,
.region-card em,
.blog-card a,
.service-card a {
  color: var(--client-gold-soft) !important;
  text-decoration-color: rgba(214, 180, 109, 0.54) !important;
}

.hero-panel {
  background: linear-gradient(135deg, rgba(8, 20, 36, 0.94), rgba(2, 8, 19, 0.84)) !important;
  border-color: rgba(200, 208, 218, 0.22) !important;
  box-shadow: 0 24px 86px rgba(0,0,0,0.34), inset 4px 0 0 rgba(214, 180, 109, 0.82) !important;
}

.hero-panel small,
.profile-copy .eyebrow,
.section-title .eyebrow,
.section-kicker .eyebrow,
.region-head .eyebrow,
.decision-copy .eyebrow,
.valuation-section .eyebrow,
.text-hero .eyebrow {
  color: var(--client-gold-soft) !important;
}

.hero-panel strong,
.profile-copy h2,
.section-title h2,
.section-kicker h2,
.decision-copy h2,
.region-title-block h2,
.valuation-section h2,
.text-hero h1 {
  color: #f8fbff !important;
}

.hero-panel span,
.profile-copy p,
.section-title p,
.section-kicker p,
.decision-copy p,
.region-intro p,
.valuation-section p,
.text-hero p {
  color: var(--client-silver-muted) !important;
}

.remax-pill {
  width: 168px !important;
  min-height: 66px !important;
  padding: 8px 14px !important;
  background: rgba(255, 255, 255, 0.94) !important;
  border-color: rgba(200, 208, 218, 0.28) !important;
}

.remax-pill img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-height: 54px !important;
  object-fit: contain !important;
}

.expertise-marquee {
  background: linear-gradient(90deg, rgba(4,12,24,0.98), rgba(13,31,54,0.98), rgba(4,12,24,0.98)) !important;
  border-color: rgba(214, 180, 109, 0.18) !important;
}

.expertise-marquee span {
  color: rgba(235,241,248,0.78) !important;
}

.profile-section {
  background:
    radial-gradient(720px 420px at 18% 42%, rgba(214, 180, 109, 0.1), transparent 62%),
    radial-gradient(900px 560px at 82% 18%, rgba(42, 84, 132, 0.22), transparent 66%),
    linear-gradient(rgba(200, 208, 218, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200, 208, 218, 0.022) 1px, transparent 1px),
    #020813 !important;
  background-size: auto, auto, 86px 86px, 86px 86px, auto !important;
  border-block: 1px solid rgba(200, 208, 218, 0.1) !important;
}

.engineering-portrait {
  width: min(540px, 42vw) !important;
  min-height: 640px !important;
  overflow: hidden !important;
  border-radius: 26px !important;
  border: 1px solid rgba(214, 180, 109, 0.36) !important;
  background: linear-gradient(145deg, rgba(16,42,73,0.82), rgba(3,10,21,0.96)) !important;
  box-shadow: 0 36px 110px rgba(0,0,0,0.42), inset 0 0 0 1px rgba(255,255,255,0.055) !important;
}

.engineering-portrait::before {
  content: "" !important;
  position: absolute !important;
  inset: -1px !important;
  z-index: 1 !important;
  pointer-events: none !important;
  background:
    linear-gradient(180deg, transparent 58%, rgba(2, 8, 19, 0.9) 100%),
    radial-gradient(420px 260px at 72% 18%, rgba(214, 180, 109, 0.14), transparent 64%) !important;
}

.engineering-portrait picture,
.engineering-portrait img {
  width: 100% !important;
  height: 100% !important;
  min-height: 640px !important;
}

.engineering-portrait img {
  object-fit: cover !important;
  object-position: center top !important;
  transform: none !important;
  filter: saturate(0.96) contrast(1.02) !important;
}

.engineering-portrait span,
.profile-portrait span {
  background: linear-gradient(135deg, #f1d89a, #b98d40) !important;
  color: #06101f !important;
  border: 1px solid rgba(255,255,255,0.22) !important;
}

.profile-name {
  background: rgba(255,255,255,0.035) !important;
  border-color: rgba(214,180,109,0.2) !important;
}

.profile-name strong {
  color: #fff !important;
}

.profile-name span {
  color: var(--client-silver-muted) !important;
}

.lead-form {
  background:
    radial-gradient(520px 260px at 14% 0%, rgba(42,84,132,0.2), transparent 64%),
    radial-gradient(420px 240px at 100% 100%, rgba(214,180,109,0.1), transparent 66%),
    linear-gradient(155deg, rgba(13,31,54,0.94), rgba(5,12,23,0.9)) !important;
}

.form-progress span.active,
.choice-grid input:checked + span {
  border-color: rgba(214,180,109,0.58) !important;
  background:
    radial-gradient(circle at 32% 24%, rgba(255,255,255,0.28), transparent 32%),
    linear-gradient(135deg, #f1d89a, #a9813a) !important;
  color: #06101f !important;
  box-shadow: 0 16px 38px rgba(214,180,109,0.22) !important;
}

.lead-form input:focus,
.lead-form select:focus,
.lead-form textarea:focus {
  border-color: rgba(214,180,109,0.52) !important;
  box-shadow: 0 0 0 4px rgba(214,180,109,0.12) !important;
}

.about-engineering-page {
  display: grid !important;
  grid-template-columns: minmax(280px, 420px) 1fr !important;
  gap: clamp(30px, 5vw, 70px) !important;
  align-items: center !important;
}

.about-engineering-page img {
  width: 100% !important;
  max-height: 560px !important;
  object-fit: cover !important;
  object-position: center top !important;
  border-radius: 24px !important;
  border: 1px solid rgba(214,180,109,0.34) !important;
  box-shadow: 0 30px 90px rgba(0,0,0,0.32) !important;
}

.about-engineering-page h2 {
  color: #f7fbff !important;
  font-size: clamp(1.8rem, 3.2vw, 3.4rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -0.035em !important;
}

@media (max-width: 980px) {
  .hero-title {
    font-size: clamp(2.2rem, 10vw, 4.1rem) !important;
    letter-spacing: -0.04em !important;
  }

  .hero-copy {
    padding-top: clamp(26px, 8vw, 64px) !important;
  }

  .engineering-portrait {
    width: min(520px, 100%) !important;
    min-height: 540px !important;
  }

  .engineering-portrait picture,
  .engineering-portrait img {
    min-height: 540px !important;
  }

  .about-engineering-page {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  .hero {
    padding-inline: 18px !important;
  }

  .hero-title {
    max-width: 100% !important;
    font-size: clamp(1.95rem, 10.4vw, 2.9rem) !important;
    letter-spacing: -0.035em !important;
    line-height: 1.08 !important;
  }

  .hero-title span {
    overflow-wrap: anywhere !important;
  }

  .hero-lead {
    width: calc(100vw - 36px) !important;
    max-width: calc(100vw - 36px) !important;
    box-sizing: border-box !important;
    overflow-wrap: break-word !important;
    padding: 20px 18px !important;
    font-size: 0.95rem !important;
    line-height: 1.72 !important;
  }

  .cta-row .btn {
    width: 100% !important;
  }

  .hero-visual {
    min-height: 620px !important;
    overflow: hidden !important;
  }

  .hero-visual picture {
    width: min(410px, 96vw) !important;
    transform: translateX(-34px) !important;
  }

  .hero-visual:hover picture {
    transform: translateX(-34px) !important;
  }

  .hero-panel {
    left: 14px !important;
    right: 14px !important;
    bottom: 18px !important;
    width: auto !important;
    max-width: none !important;
  }

  .remax-pill {
    top: 10px !important;
    right: 12px !important;
    width: 126px !important;
    min-height: 50px !important;
  }

  .engineering-portrait {
    min-height: 420px !important;
  }

  .engineering-portrait picture,
  .engineering-portrait img {
    min-height: 420px !important;
  }
}

/* Final small QA fixes */
.hero .hero-lead {
  border-left: 0 !important;
  box-shadow:
    inset 3px 0 0 rgba(214, 180, 109, 0.92),
    inset 0 0 0 1px rgba(200, 208, 218, 0.11) !important;
}

.hero .hero-lead::before,
.hero .hero-lead::after {
  background: linear-gradient(180deg, rgba(214, 180, 109, 0.92), rgba(214, 180, 109, 0)) !important;
}

@media (max-width: 640px) {
  .site-header .container,
  .header-inner {
    padding-inline: 18px !important;
  }

  .site-header {
    overflow: hidden !important;
  }

  .brand {
    min-width: 0 !important;
    max-width: calc(100vw - 118px) !important;
  }

  .nav-toggle {
    flex: 0 0 54px !important;
    width: 54px !important;
    height: 54px !important;
    margin-left: auto !important;
  }

  .hero {
    display: block !important;
    min-height: auto !important;
    padding-top: 112px !important;
    padding-bottom: 132px !important;
  }

  .hero-copy {
    max-width: 100% !important;
    padding-bottom: 0 !important;
  }

  .hero .cta-row {
    margin-bottom: 18px !important;
  }

  .hero-visual {
    position: relative !important;
    z-index: 1 !important;
    display: block !important;
    min-height: 540px !important;
    margin-top: 42px !important;
    overflow: hidden !important;
  }

  .hero-visual picture {
    display: block !important;
    width: min(390px, 92vw) !important;
    margin: 0 auto !important;
    transform: none !important;
  }

  .hero-visual:hover picture {
    transform: none !important;
  }

  .hero-panel {
    z-index: 4 !important;
  }
}

/* Listings, contact and transparent RE/MAX ATA logo refinements */
.remax-pill {
  width: 112px !important;
  min-height: 86px !important;
  padding: 0 !important;
  right: clamp(-10px, -1vw, 10px) !important;
  top: clamp(10px, 4vh, 42px) !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.remax-pill::before,
.remax-pill::after {
  display: none !important;
}

.remax-pill img {
  width: 100% !important;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  filter: drop-shadow(0 14px 28px rgba(0, 0, 0, 0.34)) !important;
}

.external-listing-panel {
  margin-top: clamp(36px, 5vw, 70px);
  margin-bottom: clamp(28px, 4vw, 52px);
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(320px, 1.05fr);
  gap: clamp(24px, 4vw, 56px);
  align-items: stretch;
  padding: clamp(28px, 4vw, 48px);
  border: 1px solid rgba(214, 180, 109, 0.24);
  border-radius: 28px;
  background:
    radial-gradient(560px 280px at 14% 0%, rgba(214, 180, 109, 0.11), transparent 64%),
    linear-gradient(145deg, rgba(13, 31, 54, 0.86), rgba(3, 9, 18, 0.92));
  box-shadow: 0 28px 90px rgba(0, 0, 0, 0.26);
}

.portfolio-source-hero {
  position: relative;
  overflow: hidden;
  padding: clamp(126px, 12vw, 168px) 0 clamp(22px, 4vw, 44px);
  background:
    radial-gradient(760px 420px at 80% 10%, rgba(214, 180, 109, 0.12), transparent 64%),
    radial-gradient(720px 420px at 12% 28%, rgba(42, 84, 132, 0.22), transparent 66%),
    linear-gradient(rgba(200, 208, 218, 0.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200, 208, 218, 0.024) 1px, transparent 1px),
    #020813;
  background-size: auto, auto, 88px 88px, 88px 88px, auto;
}

.portfolio-source-hero h1 {
  max-width: 900px;
  margin-top: 16px;
  color: #f8fbff;
  font-size: clamp(2.8rem, 5.4vw, 6.2rem);
  line-height: 0.96;
  letter-spacing: -0.055em;
}

.portfolio-source-hero p {
  max-width: 760px;
  margin-top: 24px;
  color: rgba(220, 228, 238, 0.82);
  font-size: clamp(1.04rem, 1.3vw, 1.25rem);
  line-height: 1.78;
}

.portfolio-source-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 32px;
}

.listing-source-section {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(18px, 3vw, 34px);
  padding-top: clamp(10px, 2vw, 26px);
  padding-bottom: clamp(42px, 6vw, 84px);
}

.listing-source-card.large {
  min-height: 250px;
  border-color: rgba(214, 180, 109, 0.24);
}

.listing-source-card.large strong {
  font-size: clamp(1.9rem, 3.4vw, 3.7rem);
  letter-spacing: -0.045em;
}

.external-listing-panel h2 {
  color: #f8fbff;
  font-size: clamp(2rem, 3.6vw, 4rem);
  line-height: 1.02;
  letter-spacing: -0.035em;
  margin: 10px 0 18px;
}

.external-listing-panel p {
  color: rgba(200, 208, 218, 0.78);
  max-width: 58ch;
  line-height: 1.75;
}

.listing-source-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.listing-source-card {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 240px;
  padding: 24px;
  border-radius: 20px;
  border: 1px solid rgba(200, 208, 218, 0.16);
  background:
    linear-gradient(160deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)),
    #071528;
  color: #f8fbff;
  transition: transform 0.32s var(--ease), border-color 0.32s var(--ease), box-shadow 0.32s var(--ease);
}

.listing-source-card:hover {
  transform: translateY(-6px);
  border-color: rgba(214, 180, 109, 0.52);
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.28);
}

.listing-source-card small {
  color: var(--client-gold-soft);
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.listing-source-card strong {
  margin-top: 12px;
  color: #fff;
  font-size: clamp(1.45rem, 2.2vw, 2.2rem);
}

.listing-source-card span {
  margin-top: 12px;
  color: rgba(200, 208, 218, 0.72);
  line-height: 1.55;
}

.portfolio-empty-source {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(360px, 1.1fr);
  gap: clamp(20px, 4vw, 46px);
  align-items: center;
  margin-top: clamp(26px, 4vw, 46px);
  padding: clamp(26px, 4vw, 42px);
  overflow: hidden;
  border: 1px solid rgba(200, 208, 218, 0.14);
  border-radius: 28px;
  background:
    radial-gradient(620px 300px at 100% 0%, rgba(42, 84, 132, 0.2), transparent 68%),
    radial-gradient(520px 260px at 0% 100%, rgba(210, 20, 34, 0.08), transparent 66%),
    linear-gradient(145deg, rgba(12, 28, 48, 0.84), rgba(3, 8, 16, 0.94));
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.28);
}

.portfolio-empty-source::before {
  content: "";
  position: absolute;
  inset: 16px;
  pointer-events: none;
  border: 1px solid rgba(200, 208, 218, 0.08);
  border-radius: 22px;
}

.portfolio-empty-source h3 {
  position: relative;
  max-width: 620px;
  margin: 12px 0 16px;
  color: #fff;
  font-size: clamp(1.8rem, 3.1vw, 3.6rem);
  line-height: 1;
  letter-spacing: -0.04em;
}

.portfolio-empty-source p {
  position: relative;
  max-width: 58ch;
  color: rgba(220, 228, 238, 0.76);
  line-height: 1.75;
}

.portfolio-empty-source--compact {
  margin-top: clamp(10px, 2vw, 24px);
  margin-bottom: clamp(34px, 5vw, 76px);
}

.portfolio-empty-source--compact .listing-source-card {
  min-height: 180px;
}

.portfolio-request {
  margin-top: clamp(42px, 6vw, 82px) !important;
}

.contact-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(320px, 1.05fr);
  gap: clamp(28px, 5vw, 70px);
  align-items: stretch;
  padding-top: clamp(130px, 14vw, 190px);
  padding-bottom: clamp(56px, 8vw, 110px);
}

.contact-hero h1 {
  color: #f8fbff;
  font-size: clamp(2.6rem, 5vw, 5.6rem);
  line-height: 0.98;
  letter-spacing: -0.045em;
  margin: 14px 0 22px;
}

.contact-hero p {
  color: rgba(200, 208, 218, 0.78);
  max-width: 62ch;
  line-height: 1.75;
}

.contact-info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: clamp(28px, 4vw, 46px);
}

.contact-info-grid a,
.contact-info-grid span {
  min-width: 0;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid rgba(200, 208, 218, 0.15);
  background: rgba(255, 255, 255, 0.045);
  color: #f8fbff;
}

.contact-info-grid small {
  display: block;
  color: var(--client-gold-soft);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 10px;
}

.contact-info-grid strong {
  display: block;
  color: #fff;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.map-panel {
  position: relative;
  min-height: 440px;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(214, 180, 109, 0.28);
  background:
    linear-gradient(rgba(200, 208, 218, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200, 208, 218, 0.03) 1px, transparent 1px),
    linear-gradient(145deg, rgba(13, 31, 54, 0.86), rgba(3, 9, 18, 0.92));
  background-size: 56px 56px, 56px 56px, auto;
  box-shadow: 0 30px 100px rgba(0, 0, 0, 0.32);
}

.map-panel iframe {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 440px;
  border: 0;
  filter: grayscale(0.15) contrast(0.96) saturate(0.9);
}

.map-open-link {
  position: absolute;
  left: 22px;
  bottom: 22px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(214, 180, 109, 0.44);
  background: rgba(2, 8, 19, 0.82);
  color: var(--client-gold-soft);
  font-weight: 800;
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  backdrop-filter: blur(12px);
}

.article-content {
  color: rgba(235, 241, 248, 0.86);
  font-size: clamp(1.05rem, 1.2vw, 1.22rem);
  line-height: 1.9;
  overflow-wrap: break-word;
  padding: clamp(26px, 4vw, 46px);
  border: 1px solid rgba(200, 208, 218, 0.14);
  border-radius: 22px;
  background:
    radial-gradient(420px 220px at 0% 0%, rgba(214, 180, 109, 0.08), transparent 64%),
    linear-gradient(150deg, rgba(13, 31, 54, 0.72), rgba(4, 10, 20, 0.84));
}

.article-content p,
.article-content li {
  color: rgba(235, 241, 248, 0.9) !important;
}

.article-content h2,
.article-content h3,
.article-content h4 {
  color: #fff;
  margin-top: 1.4em;
  margin-bottom: 0.6em;
}

.article-content p + p,
.article-content ul + p,
.article-content ol + p {
  margin-top: 18px;
}

.article-page img {
  background: rgba(255, 255, 255, 0.04);
}

@media (max-width: 980px) {
  .external-listing-panel,
  .portfolio-empty-source,
  .contact-hero {
    grid-template-columns: 1fr;
  }

  .listing-source-section {
    grid-template-columns: 1fr;
  }

  .contact-info-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .remax-pill {
    width: 86px !important;
    min-height: 68px !important;
    top: 18px !important;
    right: 10px !important;
  }

  .external-listing-panel {
    padding: 22px;
    border-radius: 22px;
  }

  .portfolio-empty-source {
    padding: 22px;
    border-radius: 22px;
  }

  .listing-source-grid {
    grid-template-columns: 1fr;
  }

  .listing-source-card {
    min-height: 168px;
  }

  .contact-hero {
    padding-top: 118px;
    padding-inline: 18px;
  }

  .map-panel,
  .map-panel iframe {
    min-height: 320px;
  }
}

/* Professional about page */
.about-signature {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(360px, 0.9fr);
  gap: clamp(34px, 6vw, 92px);
  align-items: center;
  min-height: 100svh;
  padding: clamp(132px, 15vw, 190px) var(--gutter) clamp(72px, 9vw, 124px);
  background:
    radial-gradient(760px 460px at 82% 30%, rgba(214, 180, 109, 0.12), transparent 64%),
    radial-gradient(820px 560px at 18% 18%, rgba(42, 84, 132, 0.25), transparent 64%),
    linear-gradient(rgba(200, 208, 218, 0.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200, 208, 218, 0.024) 1px, transparent 1px),
    #020813;
  background-size: auto, auto, 88px 88px, 88px 88px, auto;
}

.about-signature::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 180px;
  background: linear-gradient(180deg, transparent, #020813);
  pointer-events: none;
}

.about-signature-copy {
  position: relative;
  z-index: 2;
  max-width: 760px;
}

.about-signature h1 {
  margin-top: 18px;
  color: #f8fbff;
  font-size: clamp(3.2rem, 6.1vw, 7.5rem);
  line-height: 0.94;
  letter-spacing: -0.06em;
  text-wrap: balance;
}

.about-signature p {
  margin-top: 28px;
  max-width: 64ch;
  color: rgba(220, 228, 238, 0.8);
  font-size: clamp(1.04rem, 1.25vw, 1.24rem);
  line-height: 1.78;
}

.about-signature-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 34px;
}

.about-signature-media {
  position: relative;
  z-index: 2;
  min-height: 640px;
  border-radius: 32px;
  border: 1px solid rgba(214, 180, 109, 0.3);
  background:
    radial-gradient(420px 260px at 70% 12%, rgba(214, 180, 109, 0.16), transparent 64%),
    linear-gradient(145deg, rgba(13, 31, 54, 0.78), rgba(3, 9, 18, 0.94));
  box-shadow: 0 36px 120px rgba(0, 0, 0, 0.42);
  overflow: hidden;
}

.about-signature-media::before {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(214, 180, 109, 0.16);
  border-radius: 24px;
  pointer-events: none;
  z-index: 2;
  box-shadow: inset 0 0 80px rgba(2, 8, 19, 0.08);
}

.about-signature-media::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(2, 8, 19, 0.08), transparent 28%, rgba(2, 8, 19, 0.94) 100%),
    radial-gradient(520px 340px at 78% 18%, rgba(214, 180, 109, 0.08), transparent 64%),
    linear-gradient(90deg, rgba(2, 8, 19, 0.16), transparent 28%, rgba(2, 8, 19, 0.12));
  pointer-events: none;
}

.about-signature-media img {
  width: 100%;
  height: 100%;
  min-height: 640px;
  object-fit: cover;
  object-position: center top;
  filter: saturate(0.96) contrast(1.02);
}

.about-media-card {
  position: absolute;
  left: 26px;
  right: 26px;
  bottom: 26px;
  z-index: 3;
  padding: 22px 24px;
  border-radius: 20px;
  border: 1px solid rgba(200, 208, 218, 0.18);
  background: rgba(3, 10, 21, 0.78);
  backdrop-filter: blur(16px);
  box-shadow: inset 4px 0 0 rgba(214, 180, 109, 0.88);
}

.about-media-card small {
  color: var(--client-gold-soft);
  font-size: 0.66rem;
  font-weight: 850;
  letter-spacing: 0.2em;
}

.about-media-card strong {
  display: block;
  margin-top: 9px;
  color: #fff;
  font-size: clamp(1.45rem, 2vw, 2rem);
}

.about-media-card span {
  display: block;
  margin-top: 5px;
  color: rgba(200, 208, 218, 0.78);
}

.about-proof {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  padding-top: clamp(44px, 7vw, 90px);
  padding-bottom: clamp(52px, 8vw, 110px);
}

.about-proof article {
  min-height: 300px;
  padding: clamp(24px, 3vw, 36px);
  border: 1px solid rgba(200, 208, 218, 0.13);
  background:
    linear-gradient(150deg, rgba(13, 31, 54, 0.72), rgba(4, 10, 20, 0.82));
  transition: transform 0.32s var(--ease), border-color 0.32s var(--ease), box-shadow 0.32s var(--ease);
}

.about-proof article:hover {
  transform: translateY(-8px);
  border-color: rgba(214, 180, 109, 0.48);
  box-shadow: 0 26px 80px rgba(0, 0, 0, 0.28);
}

.about-proof span {
  color: rgba(214, 180, 109, 0.9);
  font-family: var(--serif);
  font-size: 2.4rem;
  font-style: italic;
}

.about-proof h2 {
  margin-top: 48px;
  color: #f8fbff;
  font-size: clamp(1.2rem, 1.8vw, 1.72rem);
  line-height: 1.15;
}

.about-proof p {
  margin-top: 14px;
  color: rgba(200, 208, 218, 0.74);
  line-height: 1.72;
}

.about-method {
  display: grid;
  grid-template-columns: minmax(260px, 0.78fr) minmax(0, 1.22fr);
  gap: clamp(32px, 5vw, 78px);
  align-items: start;
  padding-top: clamp(48px, 7vw, 96px);
  padding-bottom: clamp(54px, 8vw, 112px);
  border-top: 1px solid rgba(200, 208, 218, 0.1);
}

.about-method h2 {
  margin-top: 14px;
  color: #f8fbff;
  font-size: clamp(2.2rem, 4.5vw, 5rem);
  line-height: 1;
  letter-spacing: -0.045em;
  text-wrap: balance;
}

.about-method-steps {
  display: grid;
  gap: 14px;
}

.about-method-steps article {
  padding: clamp(22px, 3vw, 34px);
  border-radius: 22px;
  border: 1px solid rgba(200, 208, 218, 0.14);
  background:
    radial-gradient(280px 140px at 0% 0%, rgba(214, 180, 109, 0.09), transparent 62%),
    rgba(255, 255, 255, 0.035);
}

.about-method-steps small {
  color: var(--client-gold-soft);
  font-weight: 850;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.about-method-steps p {
  margin-top: 12px;
  color: rgba(220, 228, 238, 0.8);
  font-size: 1.03rem;
  line-height: 1.75;
}

.about-statement {
  padding: clamp(64px, 9vw, 130px) 0;
  background:
    radial-gradient(860px 420px at 50% 0%, rgba(214, 180, 109, 0.12), transparent 64%),
    #040a13;
  border-block: 1px solid rgba(214, 180, 109, 0.14);
}

.about-statement blockquote {
  max-width: 980px;
  margin-top: 18px;
  color: #f8fbff;
  font-family: var(--serif);
  font-size: clamp(2.1rem, 4.2vw, 5.2rem);
  line-height: 1.06;
  letter-spacing: -0.03em;
}

.about-statement p {
  max-width: 760px;
  margin-top: 26px;
  color: rgba(200, 208, 218, 0.78);
  line-height: 1.8;
  font-size: 1.08rem;
}

@media (max-width: 1080px) {
  .about-signature,
  .about-method {
    grid-template-columns: 1fr;
  }

  .about-signature-media {
    min-height: 560px;
  }

  .about-signature-media img {
    min-height: 560px;
  }

  .about-proof {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .about-signature {
    padding-top: 118px;
    padding-inline: 18px;
  }

  .about-signature h1 {
    font-size: clamp(2.45rem, 13vw, 3.55rem);
    line-height: 1;
  }

  .about-signature-actions .btn {
    width: 100%;
  }

  .about-signature-media {
    min-height: 430px;
    border-radius: 24px;
    margin-top: 34px;
  }

  .about-signature-media img {
    min-height: 430px;
  }

  .about-media-card {
    left: 16px;
    right: 16px;
    bottom: 16px;
  }

  .about-proof {
    grid-template-columns: 1fr;
    padding-inline: 18px;
  }

  .about-proof article {
    min-height: 230px;
  }

  .about-method {
    padding-inline: 18px;
  }

  body:has(.about-signature) .whatsapp-float {
    bottom: 92px !important;
    right: 12px !important;
    transform: scale(0.88) !important;
  }
}
