/* ============================================================
   HOME PAGE - March 2026 Refresh
   ============================================================ */
.home-page {
  --portfolio-work-bg: #fcfbf7;
  background: #ffffff;
}

.home-page--clarity {
  --portfolio-work-bg: #fcfbf7;
}

.home-page .main {
  background: #ffffff;
  display: flex;
  flex-direction: column;
  padding: 0 0 88px;
}

.home-page .logo-band {
  order: -4;
}

.home-page .process-section {
  order: -3;
  padding-top: clamp(22px, 2.4vw, 30px);
}

.home-page .industry-routing {
  order: -1;
  padding-top: clamp(26px, 3vw, 40px);
}

.home-page .home-service-hub {
  order: -2;
  padding-bottom: clamp(36px, 4vw, 52px);
}

.hero--home,
.industry-hero,
.tour-service-hero {
  overflow: hidden;
  border-bottom-right-radius: clamp(72px, 9vw, 112px);
}

.home-page .cta-banner {
  order: 1;
}

.home-page .faq {
  order: 2;
  margin-top: 0;
}

.home-section__head {
  max-width: 760px;
  margin-bottom: 34px;
}

.home-section__head h2 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(2rem, 4vw, 3.35rem);
  line-height: 0.98;
  letter-spacing: -0.045em;
  color: var(--green-deep);
}

.home-section__head p {
  margin: 16px 0 0;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.72;
}

.home-hero {
  position: relative;
  overflow: hidden;
  padding: 132px 0 40px;
  background:
    radial-gradient(circle at 18% 14%, rgba(243, 198, 109, 0.17), transparent 20%),
    radial-gradient(circle at 84% 18%, rgba(240, 120, 90, 0.16), transparent 22%),
    linear-gradient(135deg, #09120b 0%, #0f1c11 45%, #17371b 100%);
}

.home-hero::before,
.home-hero::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  filter: blur(24px);
}

.home-hero::before {
  top: -80px;
  left: -100px;
  width: 360px;
  height: 360px;
  background: rgba(196, 141, 38, 0.12);
}

.home-hero::after {
  right: -80px;
  bottom: -120px;
  width: 420px;
  height: 420px;
  background: rgba(240, 120, 90, 0.12);
}

.home-hero__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(360px, 0.9fr);
  gap: 28px;
  align-items: center;
}

.home-hero__copy {
  color: var(--white-on-dark);
}

.home-hero__eyebrow {
  margin-bottom: 22px;
}

.home-hero h1 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(2.9rem, 5.9vw, 5.2rem);
  line-height: 0.92;
  letter-spacing: -0.055em;
}

.home-hero h1 span {
  display: block;
  margin-top: 0.14em;
  color: #f3c66d;
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.03em;
}

.home-hero__copy > p {
  width: min(100%, 58ch);
  margin: 20px 0 0;
  color: rgba(245, 241, 232, 0.82);
  font-size: 1.02rem;
  line-height: 1.72;
}

.home-hero__audience {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.home-hero__audience li {
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(245, 241, 232, 0.88);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
}

.home-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 24px;
}

.home-hero__trust {
  display: grid;
  gap: 12px;
  margin-top: 28px;
}

.home-hero__trust li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 12px;
  color: rgba(245, 241, 232, 0.78);
  font-size: 0.95rem;
  line-height: 1.55;
}

.home-hero__trust li::before {
  content: "";
  width: 14px;
  height: 14px;
  margin-top: 0.25rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #e5b451 0%, #b47a1b 100%);
  box-shadow: 0 0 0 5px rgba(196, 141, 38, 0.13);
}

.home-hero__visual {
  position: relative;
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  grid-template-rows: 300px 184px;
  gap: 16px;
  padding: 22px;
  min-height: 532px;
  border-radius: 38px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.11) 0%, rgba(255, 255, 255, 0.05) 100%);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 32px 90px rgba(4, 10, 5, 0.32);
  backdrop-filter: blur(16px);
}

.home-hero__frame {
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 22px 48px rgba(2, 7, 3, 0.22);
}

.home-hero__frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.home-hero__frame::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(10, 18, 11, 0.04) 28%, rgba(10, 18, 11, 0.72) 100%);
}

.home-hero__frame figcaption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 1;
  color: rgba(245, 241, 232, 0.9);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.home-hero__frame--primary {
  grid-row: 1 / span 2;
}

.home-hero__frame--secondary {
  grid-column: 2;
  grid-row: 1;
}

.home-hero__frame--tertiary {
  grid-column: 2;
  grid-row: 2;
}

.home-hero__note {
  position: absolute;
  left: 34px;
  bottom: 34px;
  z-index: 2;
  width: min(300px, calc(100% - 68px));
  padding: 20px 22px;
  border-radius: 24px;
  background: rgba(7, 14, 9, 0.82);
  color: var(--white-on-dark);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(14px);
}

.home-hero__note strong {
  display: block;
  color: #f3c66d;
  font-size: 0.8rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.home-hero__note span {
  display: block;
  margin-top: 10px;
  color: rgba(245, 241, 232, 0.84);
  font-size: 0.92rem;
  line-height: 1.55;
}

.home-hero__metrics {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 26px;
}

.home-hero__metric {
  padding: 22px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(14px);
}

.home-hero__metric strong {
  display: block;
  color: #fff7e9;
  font-family: var(--font-heading);
  font-size: 1.45rem;
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.home-hero__metric p {
  margin: 10px 0 0;
  color: rgba(245, 241, 232, 0.74);
  font-size: 0.9rem;
  line-height: 1.55;
}

.logo-band {
  padding-top: 26px;
}

.logo-band__inner {
  padding: 34px;
  border-radius: 34px;
  background: rgba(255, 253, 248, 0.84);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: 0 22px 60px rgba(5, 14, 6, 0.08);
  backdrop-filter: blur(14px);
}

.logo-band__copy {
  max-width: 670px;
  margin-bottom: 26px;
}

.logo-band__copy h2 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.7rem, 3vw, 2.6rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
  color: var(--green-deep);
}

.logo-band__copy p {
  margin: 14px 0 0;
  color: var(--muted);
  line-height: 1.68;
}

.logo-band__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.logo-band__item {
  min-height: 82px;
  padding: 16px 22px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 242, 232, 0.9) 100%);
  border: 1px solid rgba(16, 33, 13, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  filter: grayscale(1);
  opacity: 0.88;
  transition: transform var(--ease), opacity var(--ease), filter var(--ease), box-shadow var(--ease);
}

.logo-band__item:hover {
  transform: translateY(-2px);
  filter: grayscale(0);
  opacity: 1;
  box-shadow: var(--shadow-md);
}

.logo-band__item img {
  width: auto;
  max-width: 100%;
  max-height: 30px;
  object-fit: contain;
}

.logo-band__item--tall img {
  max-height: 40px;
}

.market-paths {
  padding-top: 88px;
}

.market-paths__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.market-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 30px;
  border-radius: 32px;
  background: rgba(255, 253, 248, 0.92);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: var(--shadow-md);
  overflow: hidden;
}

.market-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(196, 141, 38, 0.12), transparent 42%);
  pointer-events: none;
}

.market-card > * {
  position: relative;
  z-index: 1;
}

.market-card--primary {
  background: linear-gradient(155deg, #10210d 0%, #17350e 100%);
  border-color: rgba(243, 198, 109, 0.2);
  color: var(--white-on-dark);
}

.market-card--primary::before {
  background:
    radial-gradient(circle at top right, rgba(243, 198, 109, 0.18), transparent 40%),
    radial-gradient(circle at 0% 100%, rgba(240, 120, 90, 0.12), transparent 36%);
}

.market-card__eyebrow {
  display: inline-flex;
  width: fit-content;
  min-height: 34px;
  align-items: center;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(41, 98, 22, 0.08);
  color: var(--green);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.market-card--primary .market-card__eyebrow {
  background: rgba(243, 198, 109, 0.14);
  color: #f3c66d;
}

.market-card h3 {
  margin: 18px 0 10px;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.32rem;
  line-height: 1.12;
  letter-spacing: -0.03em;
  color: var(--green-deep);
}

.market-card--primary h3 {
  color: var(--white-on-dark);
}

.market-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.68;
  font-size: 0.96rem;
}

.market-card--primary p {
  color: rgba(245, 241, 232, 0.78);
}

.market-card__points {
  display: grid;
  gap: 10px;
  margin: 20px 0 26px;
}

.market-card__points li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 12px;
  color: var(--text);
  font-size: 0.92rem;
  line-height: 1.55;
}

.market-card__points li::before {
  content: "";
  width: 14px;
  height: 14px;
  margin-top: 0.22rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #d4a243 0%, #b37c1d 100%);
}

.market-card--primary .market-card__points li {
  color: rgba(245, 241, 232, 0.86);
}

.market-card__link {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--gold);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.market-card__link::after {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
}

.market-card--primary .market-card__link {
  color: #f3c66d;
}

.capture-stack {
  padding-top: 88px;
}

.capture-stack__panel {
  display: grid;
  grid-template-columns: minmax(0, 0.96fr) minmax(320px, 0.88fr);
  gap: 20px;
  margin-bottom: 20px;
}

.capture-stack__intro,
.capture-stack__summary {
  padding: 36px;
  border-radius: 34px;
  box-shadow: var(--shadow-md);
}

.capture-stack__intro {
  background: rgba(255, 253, 248, 0.94);
  border: 1px solid rgba(16, 33, 13, 0.08);
}

.capture-stack__intro h2 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.9rem, 3.5vw, 3rem);
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--green-deep);
}

.capture-stack__intro p {
  margin: 16px 0 0;
  color: var(--muted);
  line-height: 1.72;
}

.capture-stack__summary {
  background: linear-gradient(150deg, #10200d 0%, #0d180d 100%);
  border: 1px solid rgba(243, 198, 109, 0.16);
  color: var(--white-on-dark);
}

.capture-stack__lead {
  margin: 0;
  color: rgba(245, 241, 232, 0.88);
  font-size: 1.08rem;
  line-height: 1.72;
}

.capture-stack__checklist {
  display: grid;
  gap: 12px;
  margin: 24px 0 28px;
}

.capture-stack__checklist li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 12px;
  color: rgba(245, 241, 232, 0.76);
  font-size: 0.95rem;
  line-height: 1.56;
}

.capture-stack__checklist li::before {
  content: "";
  width: 14px;
  height: 14px;
  margin-top: 0.24rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #e2b050 0%, #b57e20 100%);
}

.capture-stack__gear {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.capture-stack__gear span {
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(245, 241, 232, 0.88);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
}

.capture-stack__cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.capture-card {
  padding: 26px 24px;
  border-radius: 28px;
  background: rgba(255, 253, 248, 0.94);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: var(--shadow-sm);
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
}

.capture-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(196, 141, 38, 0.22);
}

.capture-card__icon {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  margin-bottom: 18px;
  border-radius: 16px;
  background: linear-gradient(135deg, #2a6317 0%, #17350e 100%);
  color: #f5f1e8;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  box-shadow: 0 14px 26px rgba(23, 53, 14, 0.18);
}

.capture-card h3 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.12rem;
  line-height: 1.2;
  color: var(--green-deep);
}

.capture-card p {
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.66;
}

.capture-card small {
  display: block;
  margin-top: 16px;
  color: var(--green);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.selected-work {
  padding-top: 88px;
}

.selected-work__grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 18px;
}

.selected-work__story {
  grid-column: span 4;
  padding: 32px;
  border-radius: 34px;
  background: linear-gradient(180deg, rgba(255, 253, 248, 0.96) 0%, rgba(247, 242, 232, 0.92) 100%);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: var(--shadow-md);
}

.selected-work__label {
  display: inline-flex;
  min-height: 34px;
  align-items: center;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(196, 141, 38, 0.12);
  color: var(--gold);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.selected-work__story h3 {
  margin: 18px 0 12px;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.5rem, 2.6vw, 2.3rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
  color: var(--green-deep);
}

.selected-work__story p {
  margin: 0;
  color: var(--muted);
  line-height: 1.72;
}

.selected-work__story ul {
  display: grid;
  gap: 12px;
  margin-top: 24px;
}

.selected-work__story li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 12px;
  color: var(--text);
  font-size: 0.95rem;
  line-height: 1.58;
}

.selected-work__story li::before {
  content: "";
  width: 14px;
  height: 14px;
  margin-top: 0.22rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #d4a243 0%, #b37c1d 100%);
}

.selected-work__item {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  min-height: 280px;
  box-shadow: var(--shadow-md);
}

.selected-work__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s ease;
}

.selected-work__item:hover img {
  transform: scale(1.03);
}

.selected-work__item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(10, 18, 11, 0.04) 28%, rgba(10, 18, 11, 0.78) 100%);
}

.selected-work__item figcaption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 1;
  color: #f5f1e8;
}

.selected-work__item strong {
  display: block;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.05rem;
  line-height: 1.1;
}

.selected-work__item span {
  display: block;
  margin-top: 6px;
  color: rgba(245, 241, 232, 0.76);
  font-size: 0.9rem;
  line-height: 1.5;
}

.selected-work__item--wide {
  grid-column: span 8;
  min-height: 360px;
}

.selected-work__item--half {
  grid-column: span 4;
}

.selected-work__item--medium {
  grid-column: span 6;
  min-height: 260px;
}

.results-band {
  position: relative;
  margin-top: 88px;
  padding: 80px 0;
  overflow: hidden;
  background:
    radial-gradient(circle at 15% 15%, rgba(243, 198, 109, 0.14), transparent 18%),
    radial-gradient(circle at 88% 12%, rgba(240, 120, 90, 0.12), transparent 18%),
    linear-gradient(155deg, #0c150d 0%, #122212 50%, #18331a 100%);
}

.results-band__intro {
  position: relative;
  z-index: 1;
  max-width: 760px;
  margin-bottom: 30px;
}

.results-band__intro .section-label {
  color: #f3c66d;
}

.results-band__intro h2 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(2rem, 4vw, 3.3rem);
  line-height: 0.98;
  letter-spacing: -0.045em;
  color: var(--white-on-dark);
}

.results-band__intro p {
  margin: 16px 0 0;
  color: rgba(245, 241, 232, 0.74);
  line-height: 1.72;
}

.results-band__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.result-card {
  padding: 26px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(12px);
}

.result-card strong {
  display: block;
  color: #fff7eb;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 2.5rem;
  line-height: 1;
  letter-spacing: -0.05em;
}

.result-card p {
  margin: 12px 0 0;
  color: rgba(245, 241, 232, 0.78);
  font-size: 0.96rem;
  line-height: 1.58;
}

.result-card small {
  display: block;
  margin-top: 18px;
  color: #f3c66d;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.results-band__footnote {
  position: relative;
  z-index: 1;
  margin: 20px 0 0;
  color: rgba(245, 241, 232, 0.56);
  font-size: 0.84rem;
  line-height: 1.6;
}

.process-strip {
  padding-top: 88px;
}

.process-strip__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.84fr);
  gap: 24px;
}

.process-strip__steps {
  display: grid;
  gap: 18px;
}

.process-step {
  display: grid;
  grid-template-columns: 58px 1fr;
  gap: 18px;
  padding: 28px;
  border-radius: 30px;
  background: rgba(255, 253, 248, 0.94);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: var(--shadow-md);
}

.process-step__number {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  background: linear-gradient(135deg, #d7a648 0%, #b57e20 100%);
  color: #120d04;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1rem;
  display: grid;
  place-items: center;
  letter-spacing: 0.04em;
}

.process-step h3 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.18rem;
  line-height: 1.2;
  color: var(--green-deep);
}

.process-step p {
  margin: 10px 0 0;
  color: var(--muted);
  line-height: 1.68;
  font-size: 0.96rem;
}

.process-strip__aside {
  position: sticky;
  top: 98px;
  padding: 34px;
  border-radius: 34px;
  background: linear-gradient(180deg, rgba(255, 253, 248, 0.96) 0%, rgba(247, 242, 232, 0.92) 100%);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: var(--shadow-md);
  align-self: start;
}

.process-strip__aside h3 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.5rem, 2.5vw, 2.2rem);
  line-height: 1.04;
  letter-spacing: -0.04em;
  color: var(--green-deep);
}

.process-strip__aside ul {
  display: grid;
  gap: 12px;
  margin-top: 24px;
}

.process-strip__aside li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 12px;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.58;
}

.process-strip__aside li::before {
  content: "";
  width: 14px;
  height: 14px;
  margin-top: 0.22rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #d4a243 0%, #b37c1d 100%);
}

.home-page .faq {
  margin-top: 0;
}

.home-page .faq__header p {
  margin: 14px 0 0;
  max-width: 56ch;
  color: var(--muted);
  line-height: 1.7;
}

.launch-banner {
  padding-top: 68px;
}

.launch-banner__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: center;
  padding: 38px;
  border-radius: 34px;
  background:
    linear-gradient(135deg, rgba(196, 141, 38, 0.18) 0%, rgba(240, 120, 90, 0.1) 26%, rgba(15, 28, 17, 0.98) 100%);
  box-shadow: 0 28px 70px rgba(9, 18, 11, 0.18);
}

.launch-banner__inner .section-label {
  color: #f3c66d;
}

.launch-banner__inner h2 {
  margin: 0;
  max-width: 20ch;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.9rem, 3.6vw, 3rem);
  line-height: 0.98;
  letter-spacing: -0.045em;
  color: var(--white-on-dark);
}

.launch-banner__inner p {
  margin: 14px 0 0;
  max-width: 56ch;
  color: rgba(245, 241, 232, 0.78);
  line-height: 1.68;
}

.launch-banner__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: flex-end;
}

.site-footer {
  margin-top: 44px;
  padding-top: 56px;
  background:
    radial-gradient(circle at 0% 8%, rgba(196, 141, 38, 0.16), transparent 26%),
    radial-gradient(circle at 100% 82%, rgba(72, 126, 42, 0.3), transparent 34%),
    linear-gradient(90deg, #07130a 0%, #0b1a0d 50%, #153118 100%);
  color: var(--white-on-dark);
}

.site-footer__top {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.78fr);
  gap: 28px;
  align-items: start;
  padding-bottom: 34px;
}

.site-footer__form-card,
.site-footer__panel {
  border-radius: 34px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 24px 52px rgba(0, 0, 0, 0.24);
}

.site-footer__form-card {
  padding: 32px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.03) 100%);
}

.site-footer__form-card .section-label,
.site-footer__panel .section-label {
  color: #c48d26;
}

.site-footer__form-card h2 {
  margin: 0;
  max-width: 16ch;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(2rem, 3.8vw, 3.15rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
  color: var(--white-on-dark);
}

.site-footer__form-card > p {
  max-width: 44ch;
  margin: 16px 0 0;
  color: rgba(245, 241, 232, 0.72);
  font-size: 0.98rem;
  line-height: 1.7;
}

.site-footer__form {
  margin-top: 24px;
}

.site-footer__form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.site-footer__field {
  display: grid;
  gap: 8px;
}

.site-footer__field--full {
  grid-column: 1 / -1;
}

.site-footer__field label {
  color: rgba(245, 241, 232, 0.8);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.site-footer__field input,
.site-footer__field textarea {
  width: 100%;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--white-on-dark);
  font: inherit;
  line-height: 1.5;
  transition: border-color var(--ease), box-shadow var(--ease), background var(--ease);
}

.site-footer__field input {
  min-height: 54px;
  padding: 0 16px;
}

.site-footer__field textarea {
  min-height: 144px;
  padding: 16px;
  resize: vertical;
}

.site-footer__field input::placeholder,
.site-footer__field textarea::placeholder {
  color: rgba(245, 241, 232, 0.34);
}

.site-footer__field input:focus,
.site-footer__field textarea:focus {
  outline: none;
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(196, 141, 38, 0.48);
  box-shadow: 0 0 0 4px rgba(196, 141, 38, 0.12);
}

.site-footer__submit {
  width: 100%;
  margin-top: 18px;
}

.site-footer__form-note {
  margin: 12px 0 0;
  color: rgba(245, 241, 232, 0.56);
  font-size: 0.88rem;
  line-height: 1.6;
}

.site-footer__form-note a {
  color: #c48d26;
  font-weight: 700;
}

.site-footer__form-note a:hover {
  color: var(--white-on-dark);
}

.site-footer__info {
  display: grid;
  gap: 18px;
  align-content: start;
}

.site-footer__panel {
  padding: 26px 24px;
  background: rgba(255, 255, 255, 0.04);
}

.site-footer__panel h3,
.site-footer__panel h4 {
  margin: 0;
  color: var(--white-on-dark);
  font-family: var(--font-heading);
  font-weight: 800;
  letter-spacing: -0.03em;
}

.site-footer__panel h3 {
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  line-height: 1.04;
}

.site-footer__panel h4 {
  font-size: 1.12rem;
  line-height: 1.15;
}

.site-footer__panel p {
  margin: 14px 0 0;
  color: rgba(245, 241, 232, 0.7);
  font-size: 0.94rem;
  line-height: 1.65;
}

.site-footer__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.site-footer__meta span {
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: rgba(245, 241, 232, 0.82);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
}

.site-footer__detail-list {
  display: grid;
  gap: 14px;
  margin: 18px 0 0;
}

.site-footer__detail-list li {
  display: grid;
  gap: 6px;
}

.site-footer__detail-list span:first-child {
  color: #c48d26;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.site-footer__detail-list a,
.site-footer__detail-list span:last-child {
  color: var(--white-on-dark);
  font-size: 0.95rem;
  line-height: 1.55;
}

.site-footer__detail-list a:hover {
  color: #c48d26;
}

.site-footer__socials {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.site-footer__social {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 58px;
  padding: 0 16px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  transition: transform var(--ease), border-color var(--ease), box-shadow var(--ease), background var(--ease);
}

.site-footer__social > div {
  display: flex;
  align-items: center;
  min-width: 0;
}

.site-footer__social::before {
  content: "";
  width: 30px;
  height: 30px;
  flex-shrink: 0;
  background-image: var(--social-icon);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

.site-footer__social[href*="instagram.com"] {
  --social-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cdefs%3E%3ClinearGradient id='ig' x1='3' y1='21' x2='21' y2='3' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%23feda75'/%3E%3Cstop offset='0.32' stop-color='%23fa7e1e'/%3E%3Cstop offset='0.62' stop-color='%23d62976'/%3E%3Cstop offset='1' stop-color='%234f5bd5'/%3E%3C/linearGradient%3E%3C/defs%3E%3Crect x='3' y='3' width='18' height='18' rx='5.2' fill='url(%23ig)'/%3E%3Ccircle cx='12' cy='12' r='4' fill='none' stroke='white' stroke-width='1.9'/%3E%3Ccircle cx='17.2' cy='6.9' r='1.15' fill='white'/%3E%3C/svg%3E");
}

.site-footer__social[href*="tiktok.com"] {
  --social-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%2325F4EE' d='M14.55 3.4c.2 1.42 1.02 2.72 2.29 3.55.9.59 1.9.9 2.94.95v2.43a7.7 7.7 0 0 1-4.1-1.18v5.12c0 3.24-2.47 5.54-5.53 5.54A5.2 5.2 0 0 1 5 14.59c0-3.08 2.34-5.41 5.47-5.41.31 0 .61.03.9.08v2.5a3.8 3.8 0 0 0-.86-.1 2.63 2.63 0 0 0-2.7 2.75 2.56 2.56 0 0 0 2.56 2.62c1.58 0 2.43-.99 2.43-2.94V3.4h1.75Z'/%3E%3Cpath fill='%23FE2C55' d='M13.9 2.8c.2 1.43 1.03 2.73 2.3 3.56.9.58 1.9.9 2.94.94v1.57a7.7 7.7 0 0 1-4.1-1.18v5.12c0 3.24-2.47 5.53-5.53 5.53-.78 0-1.52-.15-2.19-.43a5.22 5.22 0 0 0 4.01 1.9c3.06 0 5.53-2.3 5.53-5.54V9.15a7.7 7.7 0 0 0 4.1 1.18V7.9c-1.03-.05-2.04-.36-2.94-.95-1.27-.83-2.1-2.13-2.3-3.55h-1.82Z' opacity='.95'/%3E%3Cpath fill='%23fff' d='M14.2 3.1c.19 1.34.95 2.56 2.13 3.33.83.54 1.75.83 2.79.89v1.62a7.1 7.1 0 0 1-3.76-1.08v5.02c0 3.12-2.38 5.33-5.34 5.33A4.96 4.96 0 0 1 5.1 13.2c0-2.96 2.25-5.2 5.24-5.2.3 0 .58.03.86.08v1.83a3.72 3.72 0 0 0-.82-.09 2.82 2.82 0 0 0-2.9 2.93 2.75 2.75 0 0 0 2.75 2.81c1.7 0 2.61-1.06 2.61-3.14V3.1h1.36Z'/%3E%3C/svg%3E");
}

.site-footer__social[href*="youtube.com"] {
  --social-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23FF0033' d='M21.3 8.35a2.96 2.96 0 0 0-2.08-2.1C17.4 5.75 12 5.75 12 5.75s-5.4 0-7.22.5A2.96 2.96 0 0 0 2.7 8.34c-.5 1.85-.5 3.66-.5 3.66s0 1.8.5 3.65a2.96 2.96 0 0 0 2.08 2.1c1.82.5 7.22.5 7.22.5s5.4 0 7.22-.5a2.96 2.96 0 0 0 2.08-2.1c.5-1.84.5-3.65.5-3.65s0-1.81-.5-3.65Z'/%3E%3Cpath fill='white' d='m10.15 15.27 4.77-3.27-4.77-3.27z'/%3E%3C/svg%3E");
}

.site-footer__social:hover {
  transform: translateY(-2px);
  border-color: rgba(196, 141, 38, 0.24);
  background: rgba(255, 255, 255, 0.05);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.16);
}

.site-footer__social strong {
  display: none;
}

.site-footer__social > div span {
  display: block;
  margin-top: 0;
  color: var(--white-on-dark);
  font-size: 1.12rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: none;
}

.site-footer__social-arrow {
  color: #c48d26;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  flex-shrink: 0;
}

.site-footer__bottom {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) repeat(3, minmax(0, 0.66fr));
  gap: 32px;
  padding: 32px 0 22px;
  margin-top: 4px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.site-footer__brand img {
  width: 164px;
  margin-bottom: 18px;
  filter: none;
}

.site-footer__brand p {
  max-width: 40ch;
  margin: 0;
  color: rgba(245, 241, 232, 0.68);
  font-size: 0.94rem;
  line-height: 1.65;
}

.site-footer__bottom .footer__col {
  padding-top: 8px;
}

.site-footer .footer__bar {
  margin-top: 0;
}

.site-footer .footer__bar-inner {
  color: rgba(245, 241, 232, 0.48);
}

.site-footer__form-card,
.site-footer__info .site-footer__panel {
  text-align: center;
}

.site-footer__form-card .section-label,
.site-footer__info .site-footer__panel .section-label {
  justify-content: center;
}

.site-footer__form-card h2,
.site-footer__form-card > p {
  margin-right: auto;
  margin-left: auto;
}

.site-footer__form,
.site-footer__form-note,
.site-footer__info .site-footer__social {
  text-align: left;
}

.site-footer__info .site-footer__detail-list {
  margin-top: 8px;
}

.site-footer__info .site-footer__detail-list a,
.site-footer__info .site-footer__detail-list span:last-child {
  font-size: clamp(1.16rem, 1.4vw, 1.28rem);
  font-weight: 800;
  line-height: 1.35;
}

.site-footer__info .site-footer__meta {
  justify-content: center;
}

.site-footer__info .site-footer__meta span {
  justify-content: center;
}

@media (max-width: 1180px) {
  .site-footer__top {
    grid-template-columns: 1fr;
  }

  .site-footer__bottom {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .site-footer__form-grid,
  .site-footer__bottom {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .site-footer {
    padding-top: 44px;
  }

  .site-footer__form-card,
  .site-footer__panel {
    padding: 24px;
    border-radius: 28px;
  }

  .site-footer__bottom {
    gap: 24px;
    padding: 28px 0 18px;
  }

  .site-footer__social {
    min-height: 54px;
    padding: 0 14px;
  }
}

@media (max-width: 1180px) {
  .home-hero__grid,
  .capture-stack__panel,
  .process-strip__layout,
  .launch-banner__inner,
  .site-footer__lead {
    grid-template-columns: 1fr;
  }

  .home-hero__visual {
    max-width: 760px;
  }

  .market-paths__grid {
    grid-template-columns: 1fr;
  }

  .capture-stack__cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .selected-work__story,
  .selected-work__item--wide {
    grid-column: span 12;
  }

  .selected-work__item--half,
  .selected-work__item--medium {
    grid-column: span 6;
  }

  .results-band__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .site-footer__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .process-strip__aside {
    position: static;
  }
}

@media (max-width: 900px) {
  .logo-band__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .home-hero {
    padding-top: 116px;
  }

  .home-hero__visual {
    grid-template-columns: 1fr;
    grid-template-rows: 280px 220px 170px;
    min-height: auto;
  }

  .home-hero__frame--primary,
  .home-hero__frame--secondary,
  .home-hero__frame--tertiary {
    grid-column: auto;
    grid-row: auto;
  }

  .home-hero__note {
    position: static;
    width: auto;
  }

  .home-hero__metrics,
  .logo-band__grid,
  .results-band__grid,
  .site-footer__grid {
    grid-template-columns: 1fr;
  }

  .capture-stack__cards {
    grid-template-columns: 1fr;
  }

  .selected-work__item--half,
  .selected-work__item--medium {
    grid-column: span 12;
  }

  .launch-banner__actions {
    justify-content: flex-start;
  }

  .site-footer__lead h2,
  .launch-banner__inner h2 {
    max-width: none;
  }
}

@media (max-width: 600px) {
  .home-hero h1 {
    font-size: clamp(2.5rem, 12vw, 4rem);
  }

  .home-hero__visual,
  .logo-band__inner,
  .capture-stack__intro,
  .capture-stack__summary,
  .selected-work__story,
  .launch-banner__inner,
  .process-strip__aside,
  .site-footer__contact {
    padding: 24px;
    border-radius: 28px;
  }

  .home-hero__frame,
  .selected-work__item,
  .process-step,
  .capture-card,
  .market-card {
    border-radius: 24px;
  }

  .home-hero__metrics {
    margin-top: 18px;
  }

  .logo-band__item {
    min-height: 72px;
  }

  .market-card,
  .capture-card,
  .process-step {
    padding: 24px;
  }

  .process-step {
    grid-template-columns: 1fr;
  }

  .process-step__number {
    width: 54px;
    height: 54px;
  }

  .results-band {
    padding: 64px 0;
  }

  .site-footer__lead {
    padding: 36px 0 26px;
  }
}

/* ============================================================
   HOME PAGE - Clarity Pivot
   ============================================================ */
.home-page--clarity {
  background:
    radial-gradient(circle at 12% 0%, rgba(196, 141, 38, 0.14), transparent 24%),
    radial-gradient(circle at 86% 10%, rgba(240, 120, 90, 0.1), transparent 22%),
    linear-gradient(180deg, #f6f1e7 0%, #fbf8f2 42%, #fcfbf7 100%);
}

.home-page--clarity .main {
  padding: 0 0 88px;
}

.clarity-hero {
  position: relative;
  overflow: hidden;
  padding: 132px 0 42px;
  background:
    radial-gradient(circle at 16% 12%, rgba(243, 198, 109, 0.14), transparent 20%),
    radial-gradient(circle at 84% 18%, rgba(240, 120, 90, 0.12), transparent 22%),
    linear-gradient(135deg, #09130b 0%, #0f1c11 44%, #17361b 100%);
}

.clarity-hero::before,
.clarity-hero::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  filter: blur(26px);
}

.clarity-hero::before {
  top: -100px;
  left: -120px;
  width: 360px;
  height: 360px;
  background: rgba(196, 141, 38, 0.1);
}

.clarity-hero::after {
  right: -120px;
  bottom: -160px;
  width: 440px;
  height: 440px;
  background: rgba(240, 120, 90, 0.1);
}

.clarity-hero__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 0.96fr) minmax(420px, 0.92fr);
  gap: 30px;
  align-items: center;
}

.clarity-hero__copy {
  color: var(--white-on-dark);
}

.clarity-hero__eyebrow {
  margin-bottom: 22px;
}

.clarity-hero h1 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(3rem, 6vw, 5.5rem);
  line-height: 0.92;
  letter-spacing: -0.055em;
}

.clarity-hero h1 span {
  display: block;
  margin-top: 0.15em;
  color: var(--gold);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.03em;
  text-shadow: 0 10px 28px rgba(196, 141, 38, 0.18);
}

.clarity-hero__copy > p {
  width: min(100%, 56ch);
  margin: 22px 0 0;
  color: rgba(245, 241, 232, 0.82);
  font-size: 1.04rem;
  line-height: 1.72;
}

.clarity-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 28px;
}

.clarity-hero__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}

.clarity-hero__badges li {
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.05);
  color: rgba(245, 241, 232, 0.9);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
}

.clarity-hero__visual {
  position: relative;
  min-height: 560px;
  padding: 22px;
  border-radius: 38px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.11) 0%, rgba(255, 255, 255, 0.05) 100%);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 32px 90px rgba(4, 10, 5, 0.32);
  backdrop-filter: blur(16px);
}

.clarity-hero__main,
.clarity-hero__mini {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 22px 48px rgba(2, 7, 3, 0.22);
}

.clarity-hero__main {
  height: 100%;
}

.clarity-hero__main img,
.clarity-hero__mini img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.clarity-hero__main::after,
.clarity-hero__mini::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(10, 18, 11, 0.04) 30%, rgba(10, 18, 11, 0.74) 100%);
}

.clarity-hero__main figcaption,
.clarity-hero__mini figcaption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 16px;
  z-index: 1;
  color: rgba(245, 241, 232, 0.92);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.clarity-hero__mini {
  position: absolute;
  top: 36px;
  right: 36px;
  width: 180px;
  height: 236px;
  z-index: 2;
}

.clarity-hero__offer {
  position: absolute;
  left: 38px;
  bottom: 34px;
  z-index: 2;
  width: min(360px, calc(100% - 76px));
  padding: 24px;
  border-radius: 26px;
  background: rgba(7, 14, 9, 0.88);
  color: var(--white-on-dark);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(14px);
}

.clarity-hero__offer-label {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(243, 198, 109, 0.14);
  color: #f3c66d;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.clarity-hero__offer h2 {
  margin: 16px 0 10px;
  color: var(--white-on-dark);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.6rem;
  line-height: 1.04;
  letter-spacing: -0.04em;
}

.clarity-hero__offer h2 strong {
  color: #f3c66d;
}

.clarity-hero__offer ul {
  display: grid;
  gap: 9px;
}

.clarity-hero__offer li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 12px;
  color: rgba(245, 241, 232, 0.84);
  font-size: 0.92rem;
  line-height: 1.5;
}

.clarity-hero__offer li::before {
  content: "";
  width: 14px;
  height: 14px;
  margin-top: 0.22rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #e2b050 0%, #b57e20 100%);
}

.clarity-hero__offer p {
  margin: 14px 0 0;
  color: rgba(245, 241, 232, 0.7);
  font-size: 0.9rem;
  line-height: 1.58;
}

.clarity-hero__bar {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 24px;
}

.clarity-hero__bar-item {
  padding: 22px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(14px);
}

.clarity-hero__bar-item strong {
  display: block;
  color: #fff7e9;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.34rem;
  line-height: 1.06;
  letter-spacing: -0.04em;
}

.clarity-hero__bar-item span {
  display: block;
  margin-top: 10px;
  color: rgba(245, 241, 232, 0.72);
  font-size: 0.9rem;
  line-height: 1.52;
}

.commercial-hero {
  position: relative;
  min-height: clamp(700px, 90svh, 920px);
  display: grid;
  align-content: start;
  gap: 18px;
  padding: 104px 0 24px;
  overflow: hidden;
  background: #0d1710;
}

.commercial-hero__bg,
.commercial-hero__overlay {
  position: absolute;
  inset: 0;
}

.commercial-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.commercial-hero__overlay {
  background:
    radial-gradient(circle at 20% 18%, rgba(243, 198, 109, 0.16), transparent 24%),
    linear-gradient(180deg, rgba(7, 16, 10, 0.22) 0%, rgba(7, 16, 10, 0.42) 34%, rgba(7, 16, 10, 0.84) 100%);
}

.commercial-hero__content,
.commercial-hero__metrics {
  position: relative;
  z-index: 1;
}

.commercial-hero__content {
  width: min(100%, 980px);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.commercial-hero__copy {
  width: min(100%, 920px);
  display: flex;
  flex-direction: column;
  align-items: center;
}

.commercial-hero__intro {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 18px;
  width: 100%;
}

.commercial-hero__eyebrow {
  margin: 0;
  min-height: 40px;
  padding: 0 22px;
  border-color: rgba(255, 255, 255, 0.2);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.08));
  box-shadow: 0 16px 36px rgba(5, 14, 6, 0.18);
  backdrop-filter: blur(18px);
  color: #fff4dd;
}

.commercial-hero h1 {
  max-width: 12.8ch;
  margin: 0 auto;
  color: #fff;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(2.7rem, 5.15vw, 4.8rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
}

.commercial-hero h1 span {
  display: block;
  margin-top: 0.14em;
  color: #f3c66d;
  font-style: italic;
  letter-spacing: -0.03em;
  text-shadow: 0 10px 28px rgba(196, 141, 38, 0.22);
}

.commercial-hero__copy > p {
  width: min(100%, 47ch);
  margin: 22px auto 0;
  color: rgba(245, 241, 232, 0.84);
  font-size: clamp(1rem, 1.45vw, 1.14rem);
  line-height: 1.68;
  text-align: center;
  text-wrap: balance;
}

.commercial-hero .btn--ghost {
  border-color: rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
  color: #fff7ea;
  box-shadow: 0 12px 24px rgba(5, 14, 6, 0.16);
}

.commercial-hero .btn--ghost:hover {
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.22);
}

.commercial-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  margin-top: 30px;
  width: 100%;
}

.commercial-hero__badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 24px;
}

.commercial-hero__badges li {
  min-height: 36px;
  padding: 0 15px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.08);
  color: rgba(245, 241, 232, 0.9);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  backdrop-filter: blur(12px);
}

.commercial-hero__metrics {
  display: grid;
  width: min(100%, 980px);
  margin: 0 auto;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.commercial-hero__metric {
  padding: 18px 20px;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(7, 14, 9, 0.74), rgba(7, 14, 9, 0.62));
  border-color: rgba(255, 255, 255, 0.12);
  box-shadow: 0 18px 34px rgba(5, 14, 6, 0.14);
  backdrop-filter: blur(18px);
  text-align: center;
}

.commercial-hero__metric strong {
  display: block;
  color: #fff7e8;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.14rem;
  line-height: 1.08;
  letter-spacing: -0.04em;
}

.commercial-hero__metric span {
  display: block;
  margin-top: 10px;
  color: rgba(245, 241, 232, 0.74);
  font-size: 0.92rem;
  line-height: 1.58;
}

@media (max-width: 900px) {
  .commercial-hero__metrics {
    grid-template-columns: 1fr;
    max-width: 460px;
  }
}

@media (max-width: 600px) {
  .commercial-hero__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .commercial-hero__actions .btn {
    width: 100%;
  }

  .commercial-hero__badges {
    justify-content: center;
  }
}

.fit-strip {
  padding-top: 88px;
}

.fit-strip__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) repeat(2, minmax(0, 0.9fr));
  gap: 18px;
}

.fit-card {
  padding: 30px;
  border-radius: 30px;
  background: rgba(255, 253, 248, 0.94);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: var(--shadow-md);
}

.fit-card--primary {
  background: linear-gradient(155deg, #10210d 0%, #17350e 100%);
  border-color: rgba(243, 198, 109, 0.18);
  color: var(--white-on-dark);
}

.fit-card__eyebrow {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(41, 98, 22, 0.08);
  color: var(--green);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.fit-card--primary .fit-card__eyebrow {
  background: rgba(243, 198, 109, 0.14);
  color: #f3c66d;
}

.fit-card h3 {
  margin: 18px 0 10px;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.28rem;
  line-height: 1.12;
  letter-spacing: -0.03em;
  color: var(--green-deep);
}

.fit-card--primary h3 {
  color: var(--white-on-dark);
}

.fit-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.66;
}

.fit-card--primary p {
  color: rgba(245, 241, 232, 0.78);
}

.fit-card ul {
  display: grid;
  gap: 10px;
  margin-top: 20px;
}

.fit-card li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 12px;
  color: var(--text);
  font-size: 0.92rem;
  line-height: 1.54;
}

.fit-card li::before {
  content: "";
  width: 14px;
  height: 14px;
  margin-top: 0.22rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #d4a243 0%, #b37c1d 100%);
}

.fit-card--primary li {
  color: rgba(245, 241, 232, 0.84);
}

.package-deck {
  padding-top: 88px;
}

.package-deck__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.package-card {
  position: relative;
  padding: 28px 24px 24px;
  border-radius: 30px;
  background: rgba(255, 253, 248, 0.94);
  border: 1.5px solid rgba(16, 33, 13, 0.1);
  box-shadow: var(--shadow-sm);
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease);
}

.package-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(196, 141, 38, 0.24);
}

.package-card--featured {
  border-color: rgba(41, 98, 22, 0.28);
  box-shadow: 0 0 0 1px rgba(41, 98, 22, 0.1), var(--shadow-md);
}

.package-card__badge {
  position: absolute;
  top: -13px;
  left: 24px;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, #2a6317 0%, #17350e 100%);
  color: #f5f1e8;
  display: inline-flex;
  align-items: center;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.package-card h3 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.22rem;
  line-height: 1.12;
  color: var(--green-deep);
}

.package-card__price {
  margin-top: 14px;
  color: var(--green);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 2.55rem;
  line-height: 1;
  letter-spacing: -0.05em;
}

.package-card__price--quote {
  color: var(--green-deep);
  font-size: 1.2rem;
  line-height: 1.2;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.package-card p {
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 0.93rem;
  line-height: 1.6;
}

.package-card__meta {
  color: var(--green);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.service-switcher {
  padding-top: 88px;
}

.service-switcher__header {
  max-width: 760px;
  margin-bottom: 28px;
}

.service-switcher__header h2 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.95rem, 4vw, 3.15rem);
  line-height: 0.98;
  letter-spacing: -0.045em;
  color: var(--green-deep);
}

.service-switcher__header p {
  margin: 16px 0 0;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.72;
}

.service-switcher__tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  gap: 10px;
  padding: 10px;
  margin-bottom: 22px;
  border-radius: 999px;
  background: rgba(255, 253, 248, 0.94);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: var(--shadow-sm);
  overflow: visible;
}

.service-switcher__tabs::-webkit-scrollbar {
  display: none;
}

.service-switcher__tab {
  flex: 0 1 auto;
  min-height: 46px;
  max-width: 100%;
  padding: 10px 18px;
  border-radius: 999px;
  background: transparent;
  color: var(--green-deep);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  line-height: 1.35;
  text-align: center;
  text-transform: uppercase;
  white-space: normal;
  border: 1px solid transparent;
  transition: background var(--ease), color var(--ease), box-shadow var(--ease), transform var(--ease);
}

.service-switcher__tab:hover {
  transform: translateY(-1px);
  background: rgba(41, 98, 22, 0.06);
}

.service-switcher__tab:focus-visible {
  outline: none;
  border-color: rgba(196, 141, 38, 0.44);
  box-shadow:
    0 0 0 3px rgba(196, 141, 38, 0.16);
}

.service-switcher__tab.is-active {
  background: linear-gradient(135deg, #1f4e13 0%, #0f2511 100%);
  color: var(--white-on-dark);
  box-shadow: 0 18px 30px rgba(15, 37, 17, 0.18);
}

.service-switcher__panel {
  display: none;
}

.service-switcher__panel.is-active {
  display: block;
}

.service-switcher__stage {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.88fr);
  gap: 20px;
}

.service-switcher__media {
  position: relative;
  overflow: hidden;
  min-height: 460px;
  margin: 0;
  border-radius: 34px;
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: var(--shadow-md);
  background: #17350e;
}

.service-switcher__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.service-switcher__media--gallery {
  background:
    radial-gradient(circle at 82% 14%, rgba(243, 198, 109, 0.16), transparent 24%),
    linear-gradient(145deg, #0e1b10 0%, #142617 50%, #102012 100%);
}

.service-switcher__photo-showcase {
  position: absolute;
  inset: 74px 18px 18px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-auto-rows: minmax(0, 1fr);
  gap: 14px;
}

.service-switcher__photo-showcase-card {
  position: relative;
  margin: 0;
  overflow: hidden;
  min-height: 0;
  border-radius: 24px;
  border: 1px solid rgba(255, 248, 235, 0.08);
  box-shadow: 0 18px 32px rgba(0, 0, 0, 0.2);
  background: #0a120c;
}

.service-switcher__photo-showcase-card--hero {
  grid-column: 1 / -1;
  min-height: 0;
}

.service-switcher__photo-showcase-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.service-switcher__photo-showcase-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(7, 14, 9, 0.02) 0%, rgba(7, 14, 9, 0.18) 100%);
}

.service-switcher__photo-showcase-card--hero::before {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 44%;
  background: linear-gradient(180deg, rgba(7, 14, 9, 0) 0%, rgba(7, 14, 9, 0.14) 100%);
  z-index: 1;
}

.service-switcher__hdr-layout {
  display: grid;
  gap: 22px;
}

.service-switcher__hdr-gallery-shell {
  display: grid;
  gap: 16px;
}

.service-switcher__hdr-gallery-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.service-switcher__hdr-gallery-meta {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.service-switcher__hdr-gallery-count {
  color: rgba(245, 241, 232, 0.82);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.service-switcher__hdr-slider {
  position: relative;
  display: grid;
  align-items: center;
}

.service-switcher__video-embed {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  border-radius: 34px;
  background: #0a120c;
  box-shadow: var(--shadow-md);
}

.service-switcher__video-embed iframe {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

.service-switcher__hdr-gallery-viewport {
  overflow: hidden;
  border-radius: 34px;
}

.service-switcher__hdr-gallery-track {
  display: flex;
  transition: transform 0.45s ease;
  will-change: transform;
}

.service-switcher__hdr-slide {
  position: relative;
  flex: 0 0 100%;
  min-width: 100%;
  margin: 0;
  overflow: hidden;
  border-radius: 34px;
  background: #0a120c;
  box-shadow: var(--shadow-md);
}

.service-switcher__hdr-slide img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.service-switcher__hdr-slide img.service-switcher__img--bright {
  filter: brightness(1.24) saturate(1.08) contrast(0.98);
}

.service-switcher__hdr-slide--graphic {
  background: #edeae0;
}

.service-switcher__hdr-slide--graphic img {
  object-fit: contain;
  background: #edeae0;
}

[data-service-panel="floorplan"] .service-switcher__hdr-slide {
  background: #f7f3eb;
}

[data-service-panel="floorplan"] .service-switcher__hdr-slide img {
  object-fit: contain;
  background: #f7f3eb;
}

.service-switcher__hdr-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(7, 14, 9, 0.04) 38%, rgba(7, 14, 9, 0.72) 100%),
    radial-gradient(circle at 84% 18%, rgba(243, 198, 109, 0.12), transparent 26%);
}

.service-switcher__hdr-slide--graphic::after {
  background: linear-gradient(180deg, rgba(7, 14, 9, 0.02) 44%, rgba(7, 14, 9, 0.44) 100%);
}

.service-switcher__hdr-slide figcaption {
  position: absolute;
  left: 22px;
  bottom: 22px;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(7, 14, 9, 0.78);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: #fff4dd;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}

.service-switcher__before-after {
  --before-after-position: 50%;
  position: relative;
  margin: 0;
  overflow: hidden;
  aspect-ratio: 3 / 2;
  border-radius: 34px;
  background: #0a120c;
  box-shadow: var(--shadow-md);
  isolation: isolate;
}

.service-switcher__before-after-img {
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: auto;
  object-fit: contain;
  background: #0a120c;
}

.service-switcher__before-after-before {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  clip-path: inset(0 calc(100% - var(--before-after-position)) 0 0);
  will-change: clip-path;
}

.service-switcher__before-after-before .service-switcher__before-after-img {
  height: 100%;
  aspect-ratio: auto;
}

.service-switcher__before-after::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(7, 14, 9, 0.02) 52%, rgba(7, 14, 9, 0.34) 100%);
}

.service-switcher__before-after-label {
  position: absolute;
  bottom: 22px;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(7, 14, 9, 0.78);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: #fff4dd;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}

.service-switcher__before-after-label--before {
  left: 22px;
}

.service-switcher__before-after-label--after {
  right: 22px;
}

.service-switcher__before-after-divider {
  position: absolute;
  top: 0;
  bottom: 0;
  left: var(--before-after-position);
  z-index: 5;
  width: 0;
  pointer-events: none;
}

.service-switcher__before-after-divider::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -1px;
  width: 2px;
  background: rgba(255, 253, 248, 0.88);
  box-shadow: 0 0 18px rgba(7, 14, 9, 0.3);
}

.service-switcher__before-after-handle {
  position: absolute;
  top: 50%;
  left: 0;
  width: 54px;
  height: 54px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0.09));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.3),
    0 14px 30px rgba(3, 12, 5, 0.3);
  transform: translate(-50%, -50%);
}

.service-switcher__before-after-handle::before,
.service-switcher__before-after-handle::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 9px;
  height: 9px;
  border-top: 2px solid #fff;
  border-left: 2px solid #fff;
}

.service-switcher__before-after-handle::before {
  left: 17px;
  transform: translateY(-50%) rotate(-45deg);
}

.service-switcher__before-after-handle::after {
  right: 17px;
  transform: translateY(-50%) rotate(135deg);
}

.service-switcher__before-after-range {
  position: absolute;
  inset: 0;
  z-index: 6;
  width: 100%;
  height: 100%;
  margin: 0;
  opacity: 0;
  cursor: ew-resize;
}

.service-switcher__before-after-range::-webkit-slider-runnable-track {
  width: 100%;
  height: 100%;
}

.service-switcher__before-after-range::-webkit-slider-thumb {
  width: 56px;
  height: 100%;
  -webkit-appearance: none;
  appearance: none;
}

.service-switcher__before-after-range::-moz-range-track {
  width: 100%;
  height: 100%;
}

.service-switcher__before-after-range::-moz-range-thumb {
  width: 56px;
  height: 100%;
  border: 0;
  background: transparent;
}

.service-switcher__before-after:focus-within .service-switcher__before-after-handle {
  outline: 2px solid rgba(243, 198, 109, 0.62);
  outline-offset: 4px;
}

.service-switcher__hdr-gallery-nav {
  position: absolute;
  top: 50%;
  z-index: 2;
  width: 56px;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(7, 14, 9, 0.76);
  color: #fff4dd;
  font-size: 1.2rem;
  font-weight: 700;
  transform: translateY(-50%);
  box-shadow: 0 18px 30px rgba(0, 0, 0, 0.24);
  backdrop-filter: blur(12px);
  transition: transform var(--ease), background var(--ease), border-color var(--ease);
}

.service-switcher__hdr-gallery-nav:hover,
.service-switcher__hdr-gallery-nav:focus-visible {
  background: rgba(18, 37, 20, 0.92);
  border-color: rgba(243, 198, 109, 0.38);
}

.service-switcher__hdr-gallery-nav--prev {
  left: 20px;
}

.service-switcher__hdr-gallery-nav--next {
  right: 20px;
}

.service-switcher__hdr-gallery-nav:focus-visible {
  outline: 2px solid rgba(243, 198, 109, 0.55);
  outline-offset: 3px;
}

.service-switcher__hdr-copy {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap: 24px;
  align-items: start;
  padding: 32px;
  border-radius: 30px;
  background:
    radial-gradient(circle at 88% 14%, rgba(243, 198, 109, 0.08), transparent 24%),
    radial-gradient(circle at 10% 100%, rgba(243, 198, 109, 0.05), transparent 34%),
    linear-gradient(145deg, rgba(16, 33, 13, 0.98), rgba(10, 24, 12, 0.98));
  border: 1px solid rgba(243, 198, 109, 0.14);
  box-shadow: var(--shadow-md);
}

.service-switcher__hdr-copy-intro {
  display: grid;
  align-content: start;
}

.service-switcher__hdr-copy-intro h3 {
  margin: 18px 0 12px;
  color: var(--white-on-dark);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.6rem, 3vw, 2.3rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
}

.service-switcher__hdr-copy-intro > p {
  margin: 0;
  color: rgba(245, 241, 232, 0.8);
  font-size: 0.98rem;
  line-height: 1.72;
}

.service-switcher__list--hdr {
  margin-top: 0;
  align-content: start;
}

.commercial-media-visual {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.commercial-media-visual::before,
.commercial-media-visual::after {
  content: "";
  position: absolute;
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: 0 20px 40px rgba(3, 9, 10, 0.18);
}

.commercial-media-visual__chip {
  position: absolute;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.14);
  color: rgba(255, 248, 235, 0.92);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}

.commercial-media-visual__chip--alt {
  background: rgba(243, 198, 109, 0.14);
  color: #fff3d8;
}

.commercial-media-visual--tour {
  background:
    radial-gradient(circle at 18% 16%, rgba(243, 198, 109, 0.14), transparent 23%),
    linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px),
    linear-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px),
    linear-gradient(145deg, #0f1f17 0%, #11291f 52%, #18392c 100%);
  background-size: auto, 48px 48px, 48px 48px, auto;
}

.commercial-media-visual--tour::before {
  top: 19%;
  left: 11%;
  width: 52%;
  height: 42%;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.08) 1px, transparent 1px),
    linear-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0.05) 100%);
  background-size: 34px 34px, 34px 34px, auto;
}

.commercial-media-visual--tour::after {
  top: 16%;
  right: 10%;
  width: 24%;
  height: 58%;
  background: linear-gradient(180deg, rgba(243, 198, 109, 0.22) 0%, rgba(255, 255, 255, 0.06) 100%);
}

.commercial-media-visual--tour .commercial-media-visual__chip:first-child {
  top: 9%;
  left: 6%;
}

.commercial-media-visual--tour .commercial-media-visual__chip--alt {
  right: 10%;
  bottom: 30%;
}

.commercial-media-visual--stills {
  background:
    linear-gradient(rgba(222, 207, 178, 0.95), rgba(222, 207, 178, 0.95)) 15% 58% / 24% 17% no-repeat,
    linear-gradient(rgba(212, 196, 164, 0.95), rgba(212, 196, 164, 0.95)) 45% 58% / 31% 19% no-repeat,
    radial-gradient(circle at 84% 16%, rgba(196, 141, 38, 0.18), transparent 22%),
    linear-gradient(145deg, #f2ead9 0%, #f6f1e7 45%, #e8dcc4 100%);
}

.commercial-media-visual--stills::before {
  top: 18%;
  left: 12%;
  width: 30%;
  height: 25%;
  background: linear-gradient(180deg, #decfb0 0%, #c9b48e 100%);
  box-shadow: 0 0 0 10px rgba(255, 255, 255, 0.62), 0 20px 38px rgba(61, 43, 20, 0.14);
}

.commercial-media-visual--stills::after {
  top: 13%;
  right: 12%;
  width: 36%;
  height: 35%;
  background: linear-gradient(180deg, #e7dcc7 0%, #ccb694 100%);
  box-shadow: 0 0 0 12px rgba(255, 255, 255, 0.66), 0 20px 38px rgba(61, 43, 20, 0.14);
}

.commercial-media-visual--stills .commercial-media-visual__chip:first-child {
  top: 9%;
  right: 8%;
}

.commercial-media-visual--stills .commercial-media-visual__chip--alt {
  left: 10%;
  bottom: 24%;
}

.page-commercial #service-panel-hdr .commercial-media-visual--stills {
  background:
    linear-gradient(180deg, rgba(7, 14, 9, 0.08) 10%, rgba(7, 14, 9, 0.7) 100%),
    url("../assets/images/official/home/commercial/hdr-03.jpg") center / cover no-repeat;
}

.page-commercial #service-panel-hdr .commercial-media-visual--stills::before,
.page-commercial #service-panel-hdr .commercial-media-visual--stills::after {
  display: none;
}

.commercial-media-visual--progress {
  background:
    linear-gradient(rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.08)) 18% 22% / 2px 58% no-repeat,
    radial-gradient(circle at 72% 16%, rgba(243, 198, 109, 0.16), transparent 24%),
    linear-gradient(145deg, #08151d 0%, #113041 56%, #10210d 100%);
}

.commercial-media-visual--progress::before {
  top: 16%;
  left: 24%;
  width: 56%;
  height: 14%;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0.06) 100%);
  box-shadow:
    0 116px 0 0 rgba(255, 255, 255, 0.1),
    0 232px 0 0 rgba(255, 255, 255, 0.08);
}

.commercial-media-visual--progress::after {
  top: 22%;
  left: calc(18% - 5px);
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: none;
  background: #f3c66d;
  box-shadow:
    0 116px 0 0 #f3c66d,
    0 232px 0 0 #f3c66d;
}

.commercial-media-visual--progress .commercial-media-visual__chip:first-child {
  top: 9%;
  left: 8%;
}

.commercial-media-visual--progress .commercial-media-visual__chip--alt {
  right: 10%;
  bottom: 18%;
}

.commercial-media-visual--floorplan {
  background:
    radial-gradient(circle at 82% 16%, rgba(243, 198, 109, 0.18), transparent 22%),
    linear-gradient(90deg, rgba(86, 70, 42, 0.09) 1px, transparent 1px),
    linear-gradient(rgba(86, 70, 42, 0.09) 1px, transparent 1px),
    linear-gradient(145deg, #f3ecde 0%, #faf5ea 48%, #e6dac0 100%);
  background-size: auto, 40px 40px, 40px 40px, auto;
}

.commercial-media-visual--floorplan::before {
  top: 18%;
  left: 13%;
  width: 48%;
  height: 52%;
  background:
    linear-gradient(90deg, rgba(86, 70, 42, 0.2) 1px, transparent 1px),
    linear-gradient(rgba(86, 70, 42, 0.2) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255, 255, 255, 0.94) 0%, rgba(241, 232, 214, 0.98) 100%);
  background-size: 28px 28px, 28px 28px, auto;
  box-shadow: 0 0 0 10px rgba(255, 255, 255, 0.72), 0 20px 38px rgba(61, 43, 20, 0.14);
}

.commercial-media-visual--floorplan::after {
  top: 24%;
  right: 12%;
  width: 24%;
  height: 32%;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92) 0%, rgba(236, 224, 200, 0.94) 100%);
  box-shadow: 0 0 0 10px rgba(255, 255, 255, 0.68), 0 20px 38px rgba(61, 43, 20, 0.14);
}

.commercial-media-visual--floorplan .commercial-media-visual__chip:first-child {
  top: 10%;
  left: 8%;
}

.commercial-media-visual--floorplan .commercial-media-visual__chip--alt {
  right: 10%;
  bottom: 18%;
}

.commercial-media-visual--staging {
  background:
    radial-gradient(circle at 80% 14%, rgba(243, 198, 109, 0.18), transparent 20%),
    linear-gradient(90deg, rgba(255, 255, 255, 0.06) 50%, rgba(18, 24, 14, 0) 50%),
    linear-gradient(145deg, #ede4d1 0%, #f5efe3 48%, #d8c5a0 100%);
}

.commercial-media-visual--staging::before {
  top: 16%;
  left: 10%;
  width: 34%;
  height: 56%;
  background:
    linear-gradient(180deg, rgba(221, 211, 190, 0.98) 0%, rgba(199, 183, 150, 0.98) 100%);
  box-shadow:
    inset 0 -90px 0 0 rgba(196, 180, 148, 0.75),
    inset 0 -144px 0 0 rgba(234, 224, 208, 0.82),
    0 0 0 10px rgba(255, 255, 255, 0.62),
    0 20px 38px rgba(61, 43, 20, 0.14);
}

.commercial-media-visual--staging::after {
  top: 16%;
  right: 10%;
  width: 36%;
  height: 56%;
  background:
    radial-gradient(circle at 72% 30%, rgba(255, 255, 255, 0.58), transparent 18%),
    linear-gradient(180deg, rgba(253, 249, 240, 0.98) 0%, rgba(224, 207, 173, 0.98) 100%);
  box-shadow:
    inset 0 -82px 0 0 rgba(174, 133, 69, 0.34),
    inset 0 -146px 0 0 rgba(244, 238, 226, 0.86),
    0 0 0 10px rgba(255, 255, 255, 0.68),
    0 20px 38px rgba(61, 43, 20, 0.14);
}

.commercial-media-visual--staging .commercial-media-visual__chip:first-child {
  top: 10%;
  left: 8%;
}

.commercial-media-visual--staging .commercial-media-visual__chip--alt {
  right: 10%;
  bottom: 18%;
}

.commercial-media-visual--flythrough {
  background:
    radial-gradient(circle at 78% 14%, rgba(243, 198, 109, 0.2), transparent 21%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.07) 0%, rgba(255, 255, 255, 0.02) 100%),
    linear-gradient(145deg, #0a151d 0%, #123244 55%, #0f2416 100%);
}

.commercial-media-visual--flythrough::before {
  top: 16%;
  left: 11%;
  width: 58%;
  height: 52%;
  background:
    linear-gradient(90deg, transparent 0 18%, rgba(255, 255, 255, 0.1) 18% 20%, transparent 20% 48%, rgba(255, 255, 255, 0.1) 48% 50%, transparent 50%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0.05) 100%);
}

.commercial-media-visual--flythrough::after {
  top: 28%;
  right: 13%;
  width: 18%;
  height: 22%;
  border-radius: 999px;
  border: 2px solid rgba(243, 198, 109, 0.64);
  background: rgba(243, 198, 109, 0.12);
  box-shadow:
    -74px 78px 0 -34px rgba(243, 198, 109, 0.48),
    -118px 120px 0 -30px rgba(243, 198, 109, 0.28),
    0 18px 34px rgba(0, 0, 0, 0.22);
}

.commercial-media-visual--flythrough .commercial-media-visual__chip:first-child {
  top: 10%;
  left: 8%;
}

.commercial-media-visual--flythrough .commercial-media-visual__chip--alt {
  right: 9%;
  bottom: 18%;
}

.commercial-media-visual--sales {
  background:
    radial-gradient(circle at 82% 16%, rgba(243, 198, 109, 0.22), transparent 21%),
    linear-gradient(145deg, #0f1c12 0%, #183322 54%, #0f261a 100%);
}

.commercial-media-visual--sales::before {
  top: 17%;
  left: 11%;
  width: 42%;
  height: 56%;
  background:
    linear-gradient(rgba(243, 198, 109, 0.18), rgba(243, 198, 109, 0.18)) 0 0 / 100% 18% no-repeat,
    linear-gradient(180deg, rgba(255, 255, 255, 0.92) 0%, rgba(232, 225, 210, 0.96) 100%);
  box-shadow:
    0 0 0 10px rgba(255, 255, 255, 0.16),
    0 24px 42px rgba(0, 0, 0, 0.2);
}

.commercial-media-visual--sales::after {
  top: 24%;
  right: 12%;
  width: 30%;
  height: 42%;
  background:
    linear-gradient(rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.22)) 0 0 / 100% 20% no-repeat,
    linear-gradient(180deg, rgba(252, 248, 239, 0.94) 0%, rgba(216, 198, 163, 0.94) 100%);
  box-shadow:
    0 0 0 10px rgba(255, 255, 255, 0.12),
    0 20px 38px rgba(0, 0, 0, 0.18);
}

.commercial-media-visual--sales .commercial-media-visual__chip:first-child {
  top: 10%;
  left: 8%;
}

.commercial-media-visual--sales .commercial-media-visual__chip--alt {
  right: 10%;
  bottom: 18%;
}

.commercial-media-visual--demo::before {
  top: 17%;
  left: 12%;
  width: 54%;
  height: 44%;
}

.commercial-media-visual--demo::after {
  top: 14%;
  right: 12%;
  width: 26%;
  height: 60%;
}

.tour-demo {
  padding: 80px 0;
}

.tour-demo__header {
  max-width: 680px;
  margin: 0 0 40px;
}

.tour-demo__header h2 {
  margin: 8px 0 16px;
  color: var(--text);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.75rem, 3.2vw, 2.5rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
}

.tour-demo__header p {
  margin: 0;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.65;
}

.tour-demo__embed {
  margin-bottom: 32px;
  overflow: hidden;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
}

.embed-placeholder {
  position: relative;
  height: 480px;
  cursor: pointer;
}

.embed-placeholder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.embed-placeholder .commercial-media-visual {
  position: absolute;
  inset: 0;
}

.embed-placeholder__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(16, 33, 13, 0.45);
}

.embed-container {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  background: #111;
}

.embed-container iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}

.embed-play-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 28px;
  border: none;
  border-radius: var(--radius-sm);
  background: var(--gold);
  color: var(--green-deep);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 0.9rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: background var(--ease), transform var(--ease);
}

.embed-play-btn:hover {
  background: #d4a030;
  transform: translateY(-2px);
}

.tour-demo__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.tour-demo__stat {
  padding: 28px 24px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: var(--surface);
  text-align: center;
}

.tour-demo__stat strong {
  display: block;
  margin-bottom: 8px;
  color: var(--green);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 2.5rem;
  line-height: 1;
}

.tour-demo__stat span {
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.5;
}

.service-switcher__media-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(9, 18, 11, 0.04) 14%, rgba(9, 18, 11, 0.82) 100%);
}

.service-switcher__media-top,
.service-switcher__media-card {
  position: absolute;
  z-index: 1;
}

.service-switcher__media-top {
  top: 24px;
  left: 24px;
  right: 24px;
}

.service-switcher__media-pill {
  display: inline-flex;
  min-height: 34px;
  align-items: center;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255, 253, 248, 0.18);
  color: #fff8eb;
  border: 1px solid rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(10px);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.service-switcher__media-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.service-switcher__media-tags li {
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(245, 241, 232, 0.88);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  display: inline-flex;
  align-items: center;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.service-switcher__media-card {
  left: 24px;
  right: 24px;
  bottom: 24px;
  max-width: 360px;
  padding: 22px;
  border-radius: 26px;
  background: rgba(7, 14, 9, 0.84);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(12px);
}

.service-switcher__media-card strong {
  display: block;
  color: var(--white-on-dark);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.2rem;
  line-height: 1.14;
  letter-spacing: -0.03em;
}

.service-switcher__media-card p {
  margin: 10px 0 0;
  color: rgba(245, 241, 232, 0.8);
  font-size: 0.92rem;
  line-height: 1.62;
}

.service-switcher__media-cta {
  margin-top: 16px;
  min-height: 44px;
  padding: 0 18px;
  font-size: 0.78rem;
}

.service-switcher__copy {
  padding: 34px;
  border-radius: 34px;
  background: linear-gradient(155deg, #10210d 0%, #0f1c11 100%);
  border: 1px solid rgba(243, 198, 109, 0.16);
  box-shadow: var(--shadow-md);
}

.service-switcher__eyebrow {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(243, 198, 109, 0.12);
  color: #f3c66d;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.service-switcher__copy h3 {
  margin: 18px 0 12px;
  color: var(--white-on-dark);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.55rem, 3vw, 2.3rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
}

.service-switcher__copy > p {
  margin: 0;
  color: rgba(245, 241, 232, 0.78);
  font-size: 0.98rem;
  line-height: 1.72;
}

.service-switcher__list {
  display: grid;
  gap: 12px;
  margin-top: 22px;
}

.service-switcher__list li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 12px;
  color: rgba(245, 241, 232, 0.84);
  font-size: 0.94rem;
  line-height: 1.58;
}

.service-switcher__list li::before {
  content: "";
  width: 14px;
  height: 14px;
  margin-top: 0.24rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #e2b050 0%, #b57e20 100%);
}

.service-switcher__stats {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 18px;
}

.service-switcher__tour {
  margin-top: 18px;
  padding: 28px;
  border-radius: 30px;
  background: linear-gradient(145deg, rgba(8, 17, 9, 0.98) 0%, rgba(13, 28, 16, 0.98) 100%);
  border: 1px solid rgba(243, 198, 109, 0.14);
  box-shadow: var(--shadow-md);
}

.service-switcher__tour-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: end;
  margin-bottom: 20px;
}

.service-switcher__tour-label {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(243, 198, 109, 0.12);
  color: #f3c66d;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.service-switcher__tour-head h4 {
  margin: 16px 0 10px;
  color: var(--white-on-dark);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  line-height: 1.04;
  letter-spacing: -0.035em;
}

.service-switcher__tour-head p {
  max-width: 60ch;
  margin: 0;
  color: rgba(245, 241, 232, 0.74);
  font-size: 0.96rem;
  line-height: 1.68;
}

.service-switcher__tour-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.service-switcher__tour-pills span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: rgba(245, 241, 232, 0.84);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.service-switcher__tour-stage {
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  background: #09110b;
  box-shadow: 0 20px 42px rgba(0, 0, 0, 0.2);
}

.service-switcher__tour-head--after {
  align-items: start;
  margin: 20px 0 0;
}

.service-switcher__tour-head--after .service-switcher__tour-pills {
  justify-content: flex-start;
}

.service-switcher__tour-details {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin-top: 20px;
  padding-top: 0;
  border-top: none;
}

.service-switcher__tour-copy,
.service-switcher__tour-value {
  display: grid;
  align-content: start;
}

.service-switcher__tour-intro {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(240px, 0.9fr);
  gap: 22px;
  align-items: start;
}

.service-switcher__tour-copy h5,
.service-switcher__tour-value h5 {
  margin: 18px 0 12px;
  color: var(--white-on-dark);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.45rem, 2.5vw, 2rem);
  line-height: 1.06;
  letter-spacing: -0.035em;
}

.service-switcher__tour-copy p,
.service-switcher__tour-value p {
  margin: 0;
  color: rgba(245, 241, 232, 0.8);
  font-size: 0.96rem;
  line-height: 1.68;
}

.service-switcher__tour-value {
  padding: 30px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 88% 14%, rgba(243, 198, 109, 0.08), transparent 24%),
    radial-gradient(circle at 10% 100%, rgba(243, 198, 109, 0.05), transparent 34%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.03));
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 18px 34px rgba(0, 0, 0, 0.12);
}

.service-switcher__tour-fit {
  padding: 16px 18px 18px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.service-switcher__tour-fit-label {
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(243, 198, 109, 0.12);
  color: #f3c66d;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.service-switcher__tour-fit-list {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.service-switcher__tour-fit-list li {
  color: rgba(245, 241, 232, 0.84);
  font-size: 0.9rem;
  font-weight: 600;
  line-height: 1.45;
}

.service-switcher__tour-fit-list li::before {
  content: "•";
  margin-right: 10px;
  color: #f3c66d;
}

.service-switcher__list--tour {
  margin-top: 22px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 22px;
}

.service-switcher__list--tour li {
  align-items: start;
  padding-right: 12px;
}

.service-switcher__tour-live {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  background: #09110b;
}

.service-switcher__tour-live--preview {
  display: block;
  overflow: hidden;
  border-radius: inherit;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

.service-switcher__tour-live iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
  background: #09110b;
}

.service-switcher__tour-preview {
  position: relative;
  display: block;
  width: 100%;
  margin: 0;
  padding: 0;
}

.service-switcher__tour-live--preview .service-switcher__tour-preview {
  position: absolute;
  inset: 0;
  margin: 0;
}

.service-switcher__tour-preview > img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.service-switcher__tour-live--preview .service-switcher__tour-preview > img {
  height: 100%;
  aspect-ratio: auto;
  transition: transform var(--ease), filter var(--ease);
}

.service-switcher__tour-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(9, 18, 11, 0.08) 12%, rgba(9, 18, 11, 0.78) 100%),
    radial-gradient(circle at 18% 22%, rgba(243, 198, 109, 0.18), transparent 22%);
}

.service-switcher__tour-live--preview .service-switcher__tour-overlay {
  background:
    linear-gradient(180deg, rgba(9, 18, 11, 0.12) 12%, rgba(9, 18, 11, 0.82) 100%),
    radial-gradient(circle at 50% 34%, rgba(243, 198, 109, 0.18), transparent 24%),
    linear-gradient(135deg, rgba(14, 35, 17, 0.12), rgba(14, 35, 17, 0.48));
}

.service-switcher__tour-zillow-badge {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  transform: translate(-50%, -50%);
  display: grid;
  justify-items: center;
  gap: 14px;
  width: min(100% - 48px, 280px);
  padding: 24px 20px;
  border-radius: 28px;
  background: rgba(255, 253, 248, 0.94);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: 0 22px 44px rgba(0, 0, 0, 0.22);
  transition: transform var(--ease), box-shadow var(--ease);
}

.service-switcher__tour-zillow-badge img {
  width: 112px;
  height: auto;
}

.service-switcher__tour-zillow-badge span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
  color: #ffffff;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-align: center;
}

.service-switcher__tour-card {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
  z-index: 1;
  max-width: 380px;
  padding: 22px;
  border-radius: 26px;
  background: rgba(7, 14, 9, 0.84);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(12px);
  display: grid;
  gap: 10px;
}

.service-switcher__tour-card--zillow {
  max-width: 420px;
}

.service-switcher__tour-chip {
  display: inline-flex;
  width: fit-content;
  min-height: 30px;
  align-items: center;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(243, 198, 109, 0.12);
  color: #f3c66d;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.service-switcher__tour-chip--floating {
  position: absolute;
  top: 18px;
  left: 18px;
  z-index: 1;
  background: rgba(7, 14, 9, 0.72);
  color: #fff4dd;
  border: 1px solid rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(10px);
  pointer-events: none;
}

.service-switcher__tour-card strong {
  display: block;
  color: var(--white-on-dark);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.24rem;
  line-height: 1.12;
  letter-spacing: -0.03em;
}

.service-switcher__tour-card span:last-child {
  display: block;
  color: rgba(245, 241, 232, 0.8);
  font-size: 0.92rem;
  line-height: 1.58;
}

.service-switcher__tour-live--preview:hover .service-switcher__tour-preview > img,
.service-switcher__tour-live--preview:focus-visible .service-switcher__tour-preview > img {
  transform: scale(1.04);
  filter: saturate(1.04);
}

.service-switcher__tour-live--preview:hover .service-switcher__tour-zillow-badge,
.service-switcher__tour-live--preview:focus-visible .service-switcher__tour-zillow-badge {
  transform: translate(-50%, -50%) translateY(-2px);
  box-shadow: 0 26px 50px rgba(0, 0, 0, 0.24);
}

.service-switcher__tour-card--zillow strong {
  max-width: 18ch;
}

.service-switcher__stat {
  padding: 26px 24px;
  border-radius: 26px;
  background: rgba(255, 253, 248, 0.94);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: var(--shadow-sm);
}

.service-switcher__stat--cta {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.service-switcher__stat--cta strong {
  font-size: clamp(1.45rem, 2.1vw, 1.9rem);
  line-height: 1.06;
  letter-spacing: -0.035em;
}

.service-switcher__stat-button {
  margin-top: 18px;
  min-height: 44px;
  padding: 0 18px;
  font-size: 0.78rem;
}

.service-switcher__stat strong {
  display: block;
  color: var(--green);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(2rem, 3.4vw, 2.8rem);
  line-height: 1;
  letter-spacing: -0.05em;
}

.service-switcher__stat span {
  display: block;
  margin-top: 12px;
  color: var(--green-deep);
  font-size: 0.94rem;
  font-weight: 600;
  line-height: 1.48;
}

.service-switcher__stat cite {
  display: block;
  margin-top: 10px;
  color: var(--muted);
  font-style: normal;
  font-size: 0.76rem;
  letter-spacing: 0.04em;
}

.package-card ul {
  display: grid;
  gap: 9px;
  margin-top: 18px;
}

.package-card li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 12px;
  color: var(--text);
  font-size: 0.9rem;
  line-height: 1.48;
}

.package-card li::before {
  content: "";
  width: 14px;
  height: 14px;
  margin-top: 0.2rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #d4a243 0%, #b37c1d 100%);
}

.package-card__cta {
  width: 100%;
  margin-top: 22px;
}

.package-deck__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-top: 22px;
  padding: 22px 24px;
  border-radius: 24px;
  background: rgba(255, 253, 248, 0.94);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: var(--shadow-sm);
}

.package-deck__foot p {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.62;
}

.package-deck__foot strong {
  color: var(--green-deep);
}

.page-commercial #projects {
  position: relative;
  overflow: hidden;
  padding: 88px 0 82px;
  scroll-margin-top: 112px;
  background:
    linear-gradient(90deg, rgba(196, 141, 38, 0.06) 0%, transparent 16%, transparent 84%, rgba(41, 98, 22, 0.045) 100%),
    linear-gradient(180deg, #fffdf8 0%, #f9f4ea 54%, #fffdf8 100%);
}

.page-commercial #projects .section-head {
  max-width: 780px;
  margin: 0 auto 34px;
  text-align: center;
}

.page-commercial #projects .section-head .section-label {
  justify-content: center;
  width: 100%;
}

.page-commercial #projects .section-head h2 {
  max-width: 19ch;
  margin-inline: auto;
}

.page-commercial #projects .section-head p {
  max-width: 72ch;
  margin-inline: auto;
}

.page-commercial #projects .package-deck__grid--commercial {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
  max-width: 900px;
  margin-inline: auto;
  padding-top: 18px;
}

.page-commercial #projects .package-card {
  --package-accent: var(--green);
  --package-accent-strong: var(--green-deep);
  --package-glow: rgba(41, 98, 22, 0.16);
  position: relative;
  display: flex;
  min-height: 590px;
  flex-direction: column;
  overflow: visible;
  padding: 18px 18px 20px;
  border: 1px solid rgba(16, 33, 13, 0.12);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.98) 0%, rgba(255, 255, 255, 0.96) 100%);
  box-shadow:
    0 18px 38px rgba(5, 14, 6, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.94);
  color: #111;
  transform: translateY(0) rotateX(0deg);
  transform-origin: 50% 100%;
  transition:
    transform 320ms cubic-bezier(0.2, 0.8, 0.2, 1),
    box-shadow 320ms ease,
    border-color 320ms ease,
    background 320ms ease;
}

.page-commercial #projects .package-card--silver {
  --package-accent: #296216;
  --package-accent-strong: #17350e;
  --package-glow: rgba(41, 98, 22, 0.18);
}

.page-commercial #projects .package-card--gold {
  --package-accent: #c48d26;
  --package-accent-strong: #17350e;
  --package-glow: rgba(196, 141, 38, 0.24);
}

.page-commercial #projects .package-card--platinum {
  --package-accent: #6f8f46;
  --package-accent-strong: #17350e;
  --package-glow: rgba(111, 143, 70, 0.2);
}

.page-commercial #projects .package-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  background:
    linear-gradient(115deg, transparent 0%, transparent 36%, rgba(255, 255, 255, 0.72) 48%, transparent 60%, transparent 100%);
  opacity: 0;
  pointer-events: none;
  transform: translateX(-120%);
}

.page-commercial #projects .package-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  pointer-events: none;
  box-shadow: inset 0 4px 0 var(--package-accent);
  opacity: 0.72;
}

.page-commercial #projects .package-card > * {
  position: relative;
  z-index: 1;
}

.page-commercial #projects .package-card:hover {
  border-color: color-mix(in srgb, var(--package-accent) 58%, transparent);
  box-shadow:
    0 26px 52px rgba(5, 14, 6, 0.14),
    0 0 0 1px color-mix(in srgb, var(--package-accent) 22%, transparent),
    0 0 34px var(--package-glow);
  transform: translateY(-9px) rotateX(1.2deg);
}

.page-commercial #projects .package-card:hover::before {
  animation: package-card-sweep 900ms ease forwards;
}

.page-commercial #projects .package-card--featured {
  border-color: rgba(196, 141, 38, 0.66);
  box-shadow:
    0 22px 46px rgba(5, 14, 6, 0.13),
    0 0 0 1px rgba(196, 141, 38, 0.28);
}

.page-commercial #projects .package-card__badge {
  position: absolute;
  top: -18px;
  left: 50%;
  z-index: 2;
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  gap: 7px;
  padding: 0 18px;
  border-radius: 8px 8px 5px 5px;
  background: linear-gradient(135deg, #d5a141 0%, #b47a1b 100%);
  color: #081207;
  font-family: var(--font-heading);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: 0 12px 24px rgba(180, 122, 27, 0.24);
  transform: translateX(-50%);
}

.page-commercial #projects .package-card__badge svg {
  width: 13px;
  height: 13px;
  fill: currentColor;
}

.page-commercial #projects .package-card h3 {
  margin: 0 0 14px;
  color: #121a12;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.08rem, 1.35vw, 1.24rem);
  font-weight: 700;
  line-height: 1.12;
  text-align: center;
  letter-spacing: 0.01em;
}

.page-commercial #projects .package-card__media {
  position: relative;
  overflow: hidden;
  aspect-ratio: 3 / 2;
  margin: 0 0 18px;
  border: 1px solid rgba(23, 53, 14, 0.12);
  border-radius: 8px;
  background: #f7f6f0;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.72);
}

.page-commercial #projects .package-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0) 44%),
    linear-gradient(180deg, rgba(7, 20, 7, 0) 58%, rgba(7, 20, 7, 0.08) 100%);
  pointer-events: none;
}

.page-commercial #projects .package-card__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  image-rendering: auto;
  filter: saturate(1.08) contrast(1.04) brightness(1.03);
  transform: translateZ(0) scale(1.01);
  backface-visibility: hidden;
  transition: transform 560ms cubic-bezier(0.2, 0.8, 0.2, 1), filter 320ms ease;
}

.page-commercial #projects .package-card:hover .package-card__media img {
  filter: saturate(1.12) contrast(1.06) brightness(1.04);
  transform: translateZ(0) scale(1.035);
}

.page-commercial #projects .package-card__media-chip {
  display: none;
}

.page-commercial #projects .package-card__price {
  margin: 0;
  color: #050705;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(2.35rem, 3.1vw, 2.85rem);
  font-weight: 800;
  line-height: 0.92;
  text-align: center;
  letter-spacing: -0.04em;
}

.page-commercial #projects .package-card__price--quote {
  color: #050705;
  font-size: clamp(1.45rem, 2.15vw, 1.95rem);
  letter-spacing: -0.02em;
  text-transform: none;
}

.page-commercial #projects .package-card__meta {
  margin: 9px 0 20px;
  color: #06733a;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  line-height: 1.1;
  text-align: center;
  text-transform: none;
}

.page-commercial #projects .package-card__explore {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: min(132px, 68%);
  min-height: 34px;
  margin: 0 auto 20px;
  border-radius: 8px;
  background: #f3c66d;
  color: #091207;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 0.9rem;
  font-weight: 700;
  box-shadow: 0 12px 18px rgba(196, 141, 38, 0.18);
  transition: transform var(--ease), background var(--ease), box-shadow var(--ease);
}

.page-commercial #projects .package-card__explore:hover {
  background: #d5a141;
  box-shadow: 0 16px 24px rgba(196, 141, 38, 0.26);
  transform: translateY(-2px);
}

.page-commercial #projects .package-card__includes-title {
  margin: 0 0 9px;
  color: #111;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 0.98rem;
  font-weight: 700;
  line-height: 1.2;
}

.page-commercial #projects .package-card ul {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
}

.page-commercial #projects .package-card li {
  position: relative;
  display: grid;
  min-height: 28px;
  grid-template-columns: 18px 1fr;
  align-items: start;
  gap: 8px;
  padding: 6px 0 7px;
  border-bottom: 1px dashed rgba(16, 33, 13, 0.1);
  color: #172116;
  font-size: 0.88rem;
  line-height: 1.34;
}

.page-commercial #projects .package-card li::before {
  content: "\2713";
  position: static;
  width: auto;
  height: auto;
  margin: 0;
  border-radius: 0;
  background: none;
  color: #06733a;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 0.94rem;
  font-weight: 700;
  line-height: 1.25;
}

.page-commercial #projects .package-card__fineprint {
  margin: auto 0 12px;
  padding-top: 28px;
  color: #3d493d;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 0.76rem;
  line-height: 1.45;
  text-align: center;
}

.page-commercial #projects .package-card__cta {
  display: inline-flex;
  width: min(154px, 82%);
  min-height: 36px;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  padding: 0 14px;
  border: 0;
  border-radius: 8px;
  background: linear-gradient(135deg, #1f8f50 0%, #126c38 100%);
  color: #fffdf8;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1;
  box-shadow: 0 14px 24px rgba(18, 108, 56, 0.26);
  text-transform: none;
  white-space: nowrap;
  transition: transform var(--ease), box-shadow var(--ease), background var(--ease);
}

.page-commercial #projects .package-card__cta:hover {
  background: linear-gradient(135deg, #d5a141 0%, #b47a1b 100%);
  color: #091207;
  box-shadow: 0 18px 28px rgba(196, 141, 38, 0.28);
  transform: translateY(-2px);
}

.page-commercial #projects .package-deck__foot {
  display: block;
  max-width: 780px;
  margin: 26px auto 0;
  padding: 6px 0 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  text-align: center;
}

.page-commercial #projects .package-deck__foot p {
  color: rgba(20, 32, 20, 0.72);
  font-size: 0.9rem;
}

.page-commercial #projects .package-deck__foot .btn {
  min-height: 38px;
  margin-top: 18px;
  padding: 0 18px;
  border: 1px solid rgba(16, 33, 13, 0.13);
  border-radius: 8px;
  background: rgba(255, 253, 248, 0.64);
  color: var(--green-deep);
  box-shadow: none;
}

@media (max-width: 1024px) {
  .page-commercial #projects .package-deck__grid--commercial {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: 660px;
    margin-inline: auto;
  }
}

@media (max-width: 768px) {
  .page-commercial #projects {
    padding: 70px 0;
  }

  .page-commercial #projects .package-deck__grid--commercial {
    grid-template-columns: 1fr;
    max-width: 310px;
    gap: 20px;
  }

  .page-commercial #projects .package-card {
    min-height: 610px;
  }

  .page-commercial #projects .package-card h3 {
    font-size: 1.12rem;
  }

  .page-commercial #projects .package-card__price {
    font-size: 2.55rem;
  }

  .page-commercial #projects .package-card__price--quote {
    font-size: 1.86rem;
  }
}

@keyframes package-card-sweep {
  0% {
    opacity: 0;
    transform: translateX(-120%);
  }
  18% {
    opacity: 0.74;
  }
  100% {
    opacity: 0;
    transform: translateX(120%);
  }
}

.deliverables {
  padding-top: 88px;
}

.deliverables__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.deliverable-card {
  padding: 26px 24px;
  border-radius: 28px;
  background: rgba(255, 253, 248, 0.94);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: var(--shadow-sm);
}

.deliverable-card h3 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.12rem;
  line-height: 1.16;
  color: var(--green-deep);
}

.deliverable-card p {
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.66;
}

.work-gallery {
  padding-top: 88px;
}

.work-gallery__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.work-gallery__item {
  position: relative;
  overflow: hidden;
  min-height: 260px;
  border-radius: 30px;
  box-shadow: var(--shadow-md);
}

.work-gallery__item--large {
  grid-column: span 2;
  min-height: 410px;
}

.work-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s ease;
}

.work-gallery__item:hover img {
  transform: scale(1.03);
}

.work-gallery__item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(10, 18, 11, 0.04) 28%, rgba(10, 18, 11, 0.78) 100%);
}

.work-gallery__item figcaption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 1;
  color: #f5f1e8;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1rem;
  line-height: 1.12;
  letter-spacing: -0.02em;
}

.home-page--clarity .faq {
  margin-top: 0;
}

.home-page--clarity .faq__header p {
  margin: 14px 0 0;
  color: var(--muted);
  line-height: 1.68;
}

.page-commercial.home-page--clarity .faq,
.page-hospitality.home-page--clarity .faq {
  margin-top: 0;
  margin-bottom: 0;
  padding: clamp(36px, 4vw, 50px) 0 clamp(30px, 3vw, 40px);
  border: 0;
  border-radius: 0;
  background: #fffdf8;
  box-shadow: none;
}

.page-commercial.home-page--clarity .main,
.page-hospitality.home-page--clarity .main {
  padding-bottom: 0;
}

.page-commercial.home-page--clarity .site-footer,
.page-hospitality.home-page--clarity .site-footer {
  margin-top: 0;
  padding-top: clamp(34px, 4vw, 46px);
}

.home-page--clarity .launch-banner {
  padding-top: 68px;
}

@media (max-width: 1180px) {
  .commercial-hero__grid,
  .clarity-hero__grid,
  .fit-strip__grid,
  .service-switcher__stage,
  .package-deck__grid,
  .deliverables__grid,
  .process-strip__layout,
  .launch-banner__inner,
  .site-footer__lead {
    grid-template-columns: 1fr;
  }

  .package-deck__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-switcher__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-switcher__tour-head {
    grid-template-columns: 1fr;
  }

  .service-switcher__tour-details {
    grid-template-columns: 1fr;
  }

  .service-switcher__tour-intro,
  .service-switcher__list--tour {
    grid-template-columns: 1fr;
  }

  .service-switcher__tour-pills {
    justify-content: flex-start;
  }

  .service-switcher__hdr-copy {
    grid-template-columns: 1fr;
  }

  .deliverables__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .work-gallery__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .work-gallery__item--large {
    grid-column: span 2;
  }

  .package-deck__foot {
    flex-direction: column;
    align-items: flex-start;
  }

  .commercial-hero__visual {
    width: min(100%, 720px);
    margin-left: 0;
  }
}

@media (max-width: 900px) {
  .commercial-hero__bar,
  .clarity-hero__bar,
  .logo-band__grid {
    grid-template-columns: 1fr;
  }

  .commercial-hero__visual,
  .service-switcher__stats,
  .deliverables__grid,
  .package-deck__grid,
  .work-gallery__grid {
    grid-template-columns: 1fr;
  }

  .work-gallery__item--large {
    grid-column: span 1;
    min-height: 320px;
  }

  .tour-demo__stats {
    grid-template-columns: 1fr;
  }

  .commercial-hero__bar {
    padding: 10px 0;
  }

  .commercial-hero__bar-item + .commercial-hero__bar-item {
    border-left: none;
    border-top: 1px solid rgba(16, 33, 13, 0.08);
  }
}

@media (max-width: 820px) {
  .commercial-hero {
    padding-top: 116px;
  }

  .clarity-hero {
    padding-top: 116px;
  }

  .commercial-hero__visual {
    width: 100%;
    padding: 24px 0 84px 20px;
  }

  .commercial-hero__visual::before {
    inset: 0 12px 96px 0;
  }

  .clarity-hero__visual {
    min-height: auto;
    padding: 20px;
  }

  .commercial-hero__main {
    min-height: 460px;
  }

  .clarity-hero__main {
    height: 420px;
  }

  .clarity-hero__mini {
    position: static;
    width: 100%;
    height: 220px;
    margin-top: 14px;
  }

  .clarity-hero__offer {
    position: static;
    width: auto;
    margin-top: 14px;
  }
}

@media (max-width: 600px) {
  .commercial-hero h1 {
    font-size: clamp(2.5rem, 11vw, 4.1rem);
  }

  .clarity-hero h1 {
    font-size: clamp(2.5rem, 11vw, 4.1rem);
  }

  .commercial-hero__copy > p {
    font-size: 1rem;
  }

  .clarity-hero__copy > p {
    font-size: 1rem;
  }

  .clarity-hero__visual,
  .logo-band__inner,
  .fit-card,
  .service-switcher__copy,
  .service-switcher__hdr-copy,
  .service-switcher__tour,
  .service-switcher__stat,
  .package-card,
  .package-deck__foot,
  .deliverable-card,
  .process-strip__aside,
  .site-footer__contact,
  .launch-banner__inner {
    padding: 24px;
    border-radius: 28px;
  }

  .clarity-hero__main,
  .clarity-hero__mini,
  .service-switcher__media,
  .service-switcher__tour-stage,
  .service-switcher__hdr-slide,
  .work-gallery__item,
  .process-step {
    border-radius: 24px;
  }

  .commercial-hero__main {
    min-height: 320px;
  }

  .commercial-hero__visual {
    padding: 0;
  }

  .commercial-hero__visual::before {
    inset: 14px 0 104px 0;
  }

  .commercial-hero__main-meta {
    top: 14px;
    left: 14px;
    right: 14px;
    gap: 8px;
  }

  .commercial-hero__main-meta span {
    min-height: 28px;
    padding: 0 12px;
    font-size: 0.64rem;
  }

  .commercial-hero__offer {
    position: static;
    width: 100%;
    margin-top: 18px;
    padding: 24px;
    border-radius: 28px;
  }

  .commercial-hero__offer-list {
    gap: 6px;
  }

  .embed-placeholder {
    height: 280px;
  }

  .clarity-hero__main {
    height: 340px;
  }

  .commercial-hero__bar-item {
    padding: 22px;
  }

  .clarity-hero__bar-item,
  .process-step {
    padding: 22px;
  }

  .service-switcher__header h2 {
    font-size: clamp(1.85rem, 10vw, 2.6rem);
  }

  .service-switcher__tabs {
    padding: 8px;
    border-radius: 24px;
  }

  .service-switcher__tab {
    min-height: 42px;
    padding: 0 15px;
    font-size: 0.72rem;
    letter-spacing: 0.09em;
  }

  .service-switcher__media {
    min-height: 360px;
  }

  .service-switcher__hdr-slide img {
    aspect-ratio: 16 / 10;
  }

  .service-switcher__photo-showcase {
    inset: 68px 14px 14px;
    gap: 10px;
  }

  .service-switcher__hdr-layout {
    gap: 18px;
  }

  .service-switcher__hdr-gallery-head {
    gap: 12px;
  }

  .service-switcher__hdr-gallery-meta {
    min-height: 32px;
    padding: 0 12px;
  }

  .service-switcher__hdr-gallery-count {
    font-size: 0.72rem;
  }

  .service-switcher__hdr-slide {
    border-radius: 22px;
  }

  .service-switcher__hdr-slide figcaption {
    left: 14px;
    bottom: 14px;
    min-height: 30px;
    padding: 0 12px;
    font-size: 0.68rem;
  }

  .service-switcher__hdr-gallery-nav {
    width: 46px;
    height: 46px;
    font-size: 1rem;
  }

  .service-switcher__hdr-gallery-nav--prev {
    left: 12px;
  }

  .service-switcher__hdr-gallery-nav--next {
    right: 12px;
  }

  .service-switcher__hdr-copy {
    gap: 18px;
  }

  .service-switcher__photo-showcase-card {
    border-radius: 20px;
  }

  .service-switcher__photo-showcase-card--hero {
    min-height: 172px;
  }

  .service-switcher__media-top {
    top: 18px;
    left: 18px;
    right: 18px;
  }

  .service-switcher__media-card {
    left: 18px;
    right: 18px;
    bottom: 18px;
    max-width: none;
    padding: 18px;
    border-radius: 22px;
  }

  .service-switcher__media-card strong {
    font-size: 1.05rem;
  }

  .service-switcher__media-card p,
  .service-switcher__copy > p,
  .service-switcher__hdr-copy-intro > p,
  .service-switcher__list li {
    font-size: 0.9rem;
  }

  .service-switcher__tour-card {
    left: 18px;
    right: 18px;
    bottom: 18px;
    max-width: none;
    padding: 18px;
    border-radius: 22px;
  }

  .service-switcher__tour-card strong {
    font-size: 1.08rem;
  }

  .service-switcher__tour-card--zillow {
    left: 14px;
    right: auto;
    bottom: 14px;
    max-width: min(68%, 240px);
    padding: 14px;
  }

  .service-switcher__tour-card--zillow strong {
    font-size: 0.86rem;
    line-height: 1.14;
  }

  .service-switcher__tour-card--zillow span:last-child {
    font-size: 0.74rem;
    line-height: 1.42;
  }

  .home-service-hub #home-res-panel-zillow .service-switcher__tour-live--preview {
    display: grid;
    gap: 12px;
    padding-top: 0;
    overflow: visible;
    background: transparent;
  }

  .home-service-hub #home-res-panel-zillow .service-switcher__tour-live--preview .service-switcher__tour-preview {
    position: relative;
    inset: auto;
    overflow: hidden;
    border-radius: 20px;
  }

  .home-service-hub #home-res-panel-zillow .service-switcher__tour-live--preview .service-switcher__tour-preview > img {
    height: auto;
    aspect-ratio: 16 / 10;
  }

  .home-service-hub #home-res-panel-zillow .service-switcher__tour-card--zillow {
    position: static;
    left: auto;
    right: auto;
    bottom: auto;
    width: 100%;
    max-width: none;
    padding: 16px;
  }

  .home-service-hub #home-res-panel-zillow .service-switcher__tour-card--zillow strong {
    max-width: none;
    font-size: 1.02rem;
    line-height: 1.16;
  }

  .home-service-hub #home-res-panel-zillow .service-switcher__tour-card--zillow span:last-child {
    font-size: 0.84rem;
  }

  .service-switcher__tour-zillow-badge {
    display: none;
  }

  .home-service-hub #home-res-panel-zillow .service-switcher__tour-zillow-badge {
    top: auto;
    left: 12px;
    right: 12px;
    bottom: 12px;
    transform: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: auto;
    gap: 10px;
    padding: 8px 9px;
    border-radius: 999px;
  }

  .service-switcher__tour-zillow-badge img {
    width: 76px;
  }

  .home-service-hub #home-res-panel-zillow .service-switcher__tour-zillow-badge img {
    display: block;
    flex: 0 0 auto;
    width: 54px;
    max-width: 54px;
    height: auto;
    aspect-ratio: auto;
    object-fit: contain;
  }

  .service-switcher__tour-zillow-badge span {
    min-height: 34px;
    padding: 0 12px;
    font-size: 0.64rem;
  }

  .home-service-hub #home-res-panel-zillow .service-switcher__tour-zillow-badge span {
    min-height: 30px;
    padding: 0 10px;
    font-size: 0.58rem;
    white-space: nowrap;
  }

  .service-switcher__tour-card span:last-child,
  .service-switcher__tour-head p {
    font-size: 0.9rem;
  }
}

/* ============================================================
   HOMEPAGE REDESIGN — New Sections
   ============================================================ */

/* --- Glass Card (shared glassmorphic component) --- */
.glass-card {
  padding: 28px;
  border-radius: var(--radius-lg);
  background: rgba(255, 253, 248, 0.84);
  border: 1px solid rgba(16, 33, 13, 0.08);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(14px);
}

/* --- Section Head (shared heading pattern) --- */
.section-head {
  max-width: 680px;
  margin-bottom: 42px;
}

.section-head h2 {
  margin: 0;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.8rem, 3.4vw, 2.8rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
  color: var(--green-deep);
}

.section-head p {
  margin: 14px 0 0;
  color: var(--muted);
  line-height: 1.68;
  font-size: 1.04rem;
}

.section-head--light h2 {
  color: var(--white-on-dark);
}

.section-head--light p {
  color: rgba(245, 241, 232, 0.72);
}

/* --- Hero (full-bleed homepage) --- */
.hero--home {
  position: relative;
  min-height: clamp(660px, 84svh, 820px);
  display: grid;
  align-content: start;
  gap: 18px;
  padding: clamp(82px, 10svh, 104px) 0 20px;
  overflow: hidden;
  background: #09120b url("../assets/images/official/home/residential/drone-01.jpg") center / cover no-repeat;
}

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

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    180deg,
    rgba(7, 17, 8, 0.18) 0%,
    rgba(7, 17, 8, 0.32) 34%,
    rgba(7, 17, 8, 0.82) 100%
  );
}

.hero__content {
  position: relative;
  z-index: 2;
  width: min(100%, 920px);
  margin: 0 auto;
  padding-bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.hero--home .hero__content {
  padding-top: clamp(18px, 4svh, 36px);
}

.hero__intro {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 18px;
  width: 100%;
}

.hero__eyebrow {
  margin: 0;
  min-height: 40px;
  padding: 0 22px;
  border-color: rgba(255, 255, 255, 0.2);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.08));
  box-shadow: 0 16px 36px rgba(5, 14, 6, 0.18);
  backdrop-filter: blur(18px);
  color: #fff4dd;
}

.hero__title {
  max-width: 12.6ch;
  margin: 0 auto;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(2.35rem, 4.8vw, 4.35rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
  color: #fff;
}

.hero__title-accent {
  display: block;
  margin-top: 6px;
  color: #C48D26;
  font-style: italic;
  text-shadow: 0 8px 20px rgba(95, 60, 10, 0.2);
}

.industry-hero {
  position: relative;
  min-height: clamp(660px, 84svh, 820px);
  display: grid;
  align-content: start;
  gap: 18px;
  padding: 104px 0 20px;
  overflow: hidden;
  background: #09120b;
}

.industry-hero .hero__content {
  width: min(100%, 940px);
}

.industry-hero .hero__metrics {
  width: min(100%, 900px);
}

.industry-hero .hero__actions {
  margin-top: 22px;
}

.industry-hero .hero__metric {
  min-height: 112px;
  display: grid;
  align-content: start;
}

.industry-hero--residential .hero__overlay {
  background:
    radial-gradient(circle at 50% 18%, rgba(243, 198, 109, 0.14), transparent 26%),
    linear-gradient(180deg, rgba(7, 17, 8, 0.16) 0%, rgba(7, 17, 8, 0.28) 34%, rgba(7, 17, 8, 0.84) 100%);
}

.industry-hero--commercial .hero__overlay {
  background:
    radial-gradient(circle at 52% 10%, rgba(120, 150, 190, 0.16), transparent 22%),
    linear-gradient(180deg, rgba(8, 15, 19, 0.24) 0%, rgba(8, 15, 19, 0.36) 34%, rgba(8, 15, 19, 0.88) 100%);
}

.industry-hero--hospitality .hero__overlay {
  background:
    radial-gradient(circle at 50% 14%, rgba(243, 198, 109, 0.18), transparent 24%),
    linear-gradient(180deg, rgba(14, 12, 10, 0.2) 0%, rgba(14, 12, 10, 0.34) 34%, rgba(14, 12, 10, 0.86) 100%);
}

.industry-hero--residential .hero__title {
  max-width: 10.9ch;
}

.industry-hero--residential {
  gap: 14px;
  padding-top: clamp(88px, 9.8svh, 100px);
}

.industry-hero--residential .hero__content {
  padding-top: 0;
}

.industry-hero--commercial .hero__title {
  max-width: 12.6ch;
}

.industry-hero--commercial .hero__content {
  padding-top: clamp(18px, 4svh, 36px);
}

.industry-hero--commercial .hero__metrics {
  width: min(100%, 860px);
}

.industry-hero--commercial .hero__metric {
  display: block;
  min-height: auto;
  align-content: normal;
}

.industry-hero--hospitality .hero__title {
  max-width: 13.1ch;
}

.hero__sub {
  margin: 18px auto 0;
  width: min(100%, 42ch);
  max-width: 42ch;
  font-size: clamp(1rem, 1.45vw, 1.12rem);
  line-height: 1.62;
  color: rgba(245, 241, 232, 0.85);
  text-align: center;
  text-wrap: balance;
}

.hero__rating {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin: 20px auto 0;
  padding: 10px 18px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 14px 30px rgba(5, 14, 6, 0.14);
  backdrop-filter: blur(14px);
}

.hero__rating-stars {
  color: #f3c66d;
  font-size: 0.92rem;
  letter-spacing: 0.14em;
}

.hero__rating-google {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 0;
}

.hero__rating-google svg {
  display: block;
  width: 18px;
  height: 18px;
}

.hero__actions {
  display: flex;
  gap: 14px;
  justify-content: center;
  margin-top: 24px;
  flex-wrap: wrap;
  width: 100%;
}

.hero__metrics {
  position: relative;
  z-index: 2;
  display: grid;
  width: min(100%, 860px);
  margin: 0 auto;
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 12px;
  padding-top: 0;
  padding-bottom: 0;
}

.hero__metric {
  background: linear-gradient(180deg, rgba(255, 253, 248, 0.16), rgba(255, 253, 248, 0.08));
  border-color: rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(18px);
  text-align: center;
  padding: 16px;
  border-radius: 24px;
  box-shadow: 0 18px 34px rgba(5, 14, 6, 0.14);
}

.hero__metric strong {
  display: block;
  font-family: var(--font-heading);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 8px;
}

.hero__metric span {
  font-size: 0.8rem;
  color: rgba(245, 241, 232, 0.7);
  line-height: 1.4;
}

@media (min-width: 1025px) {
  .hero--home {
    min-height: 100svh;
    align-content: center;
  }

  .hero--home .hero__metrics {
    transform: translateY(16px);
  }

  .hero--home .hero__actions {
    transform: translateY(8px);
  }

  .industry-hero:not(.flythrough-hero) {
    min-height: 100svh;
    align-content: center;
    gap: clamp(20px, 2.7svh, 26px);
    padding: clamp(70px, 8svh, 84px) 0 clamp(18px, 2.4svh, 24px);
  }

  .industry-hero:not(.flythrough-hero) .hero__content {
    padding-top: clamp(8px, 1.8svh, 16px);
  }

  .industry-hero:not(.flythrough-hero) .hero__intro {
    margin-bottom: 18px;
  }

  .industry-hero:not(.flythrough-hero) .hero__title {
    font-size: clamp(2.35rem, 4.15vw, 4.35rem);
    line-height: 1.02;
  }

  .industry-hero:not(.flythrough-hero) .hero__title-accent {
    margin-top: 8px;
  }

  .industry-hero:not(.flythrough-hero) .hero__sub {
    margin-top: 20px;
    line-height: 1.58;
  }

  .industry-hero:not(.flythrough-hero) .hero__rating {
    margin-top: 20px;
    padding: 8px 16px;
  }

  .industry-hero:not(.flythrough-hero) .hero__actions {
    gap: 18px;
    margin-top: 22px;
    transform: translateY(8px);
  }

  .industry-hero:not(.flythrough-hero) .hero__actions .btn {
    min-height: 46px;
    padding-top: 0.82rem;
    padding-bottom: 0.82rem;
  }

  .industry-hero:not(.flythrough-hero) .hero__metrics {
    width: min(100%, 980px);
    gap: 14px;
    transform: translateY(16px);
  }

  .industry-hero:not(.flythrough-hero) .hero__metric {
    min-height: 0;
    padding: 14px 16px;
    border-radius: 22px;
    align-content: center;
  }
}

@media (min-width: 1025px) and (max-height: 940px) {
  .hero--home {
    gap: clamp(20px, 2.7svh, 26px);
    padding: clamp(70px, 8svh, 84px) 0 clamp(18px, 2.4svh, 24px);
  }

  .hero--home .hero__content {
    padding-top: clamp(8px, 1.8svh, 16px);
  }

  .hero--home .hero__intro {
    margin-bottom: 18px;
  }

  .hero--home .hero__title {
    font-size: clamp(2.35rem, 4.6vw, 4.8rem);
    line-height: 1.02;
  }

  .hero--home .hero__title-accent {
    margin-top: 8px;
  }

  .hero--home .hero__rating {
    margin-top: 20px;
    padding: 8px 16px;
  }

  .hero--home .hero__actions {
    gap: 18px;
    margin-top: 22px;
  }

  .hero--home .hero__actions .btn {
    min-height: 46px;
    padding-top: 0.82rem;
    padding-bottom: 0.82rem;
  }

  .hero--home .hero__metrics {
    width: min(100%, 980px);
    gap: 14px;
  }

  .hero--home .hero__metric {
    padding: 14px 16px;
    border-radius: 22px;
  }
}

@media (min-width: 1025px) and (max-height: 800px) {
  .hero--home {
    padding-top: 66px;
    padding-bottom: 14px;
  }

  .hero--home .hero__content {
    padding-top: 6px;
  }

  .hero--home .hero__title {
    font-size: clamp(2.2rem, 4.15vw, 4.1rem);
  }

  .hero--home .hero__eyebrow {
    min-height: 36px;
  }

  .hero--home .hero__rating {
    margin-top: 12px;
  }

  .hero--home .hero__actions {
    margin-top: 14px;
  }

  .hero--home .hero__metrics {
    width: min(100%, 920px);
  }

  .hero--home .hero__metric {
    padding: 12px 14px;
  }

  .industry-hero:not(.flythrough-hero) {
    gap: clamp(16px, 2.1svh, 22px);
    padding-top: 66px;
    padding-bottom: 14px;
  }

  .industry-hero:not(.flythrough-hero) .hero__content {
    padding-top: 6px;
  }

  .industry-hero:not(.flythrough-hero) .hero__title {
    font-size: clamp(2.2rem, 3.95vw, 3.65rem);
    line-height: 1;
  }

  .industry-hero:not(.flythrough-hero) .hero__eyebrow {
    min-height: 36px;
  }

  .industry-hero:not(.flythrough-hero) .hero__sub {
    margin-top: 14px;
    font-size: 1rem;
    line-height: 1.52;
  }

  .industry-hero:not(.flythrough-hero) .hero__rating {
    margin-top: 12px;
  }

  .industry-hero:not(.flythrough-hero) .hero__actions {
    margin-top: 14px;
  }

  .industry-hero:not(.flythrough-hero) .hero__metrics {
    width: min(100%, 920px);
  }

  .industry-hero:not(.flythrough-hero) .hero__metric {
    padding: 12px 14px;
  }
}

/* --- Logo Band (simplified, centered) --- */
.logo-band--simple {
  padding: 56px 0 44px;
}

.logo-band--simple .section-label {
  display: block;
  text-align: center;
  margin-bottom: 28px;
}

.logo-band--simple .section-label::before,
.logo-band--simple .section-label::after {
  display: none;
}

.logo-band__grid--center {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  max-width: 900px;
  margin: 0 auto;
}

.logo-band--carousel {
  padding: 52px 0 46px;
  background: #ffffff;
  border-top: 1px solid rgba(16, 33, 13, 0.06);
  border-bottom: 0;
}

.logo-band--carousel .logo-band__header {
  margin-bottom: 22px;
}

.logo-band--carousel .section-label {
  display: block;
  text-align: center;
  margin-bottom: 0;
}

.logo-band--carousel .section-label::before,
.logo-band--carousel .section-label::after {
  display: none;
}

.logo-band__carousel {
  overflow: hidden;
  width: 100%;
  padding-inline: clamp(18px, 3vw, 30px);
  box-sizing: border-box;
}

.logo-band__track {
  display: flex;
  width: max-content;
  animation: logo-band-marquee 34s linear infinite;
  will-change: transform;
}

.logo-band__carousel:hover .logo-band__track {
  animation-play-state: paused;
}

.logo-band__group {
  display: flex;
  align-items: center;
  gap: clamp(30px, 3.6vw, 56px);
  min-width: max-content;
  padding-right: clamp(30px, 3.6vw, 56px);
  flex-shrink: 0;
}

.logo-band__logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  width: var(--logo-width, auto);
  flex: 0 0 var(--logo-width, auto);
}

.logo-band__logo img {
  display: block;
  width: 100%;
  max-width: 100%;
  max-height: var(--logo-height, 34px);
  height: auto;
  object-fit: contain;
  filter: grayscale(1);
  opacity: 0.72;
  transition: opacity var(--ease), filter var(--ease), transform var(--ease);
}

.logo-band__logo:hover img {
  opacity: 0.94;
  filter: grayscale(0);
  transform: translateY(-1px);
}

.logo-band__logo--compass {
  --logo-width: clamp(136px, 14vw, 188px);
}

.logo-band__logo--kw {
  --logo-width: clamp(164px, 16vw, 228px);
  --logo-height: 54px;
}

.logo-band__logo--coldwell {
  --logo-width: clamp(176px, 18vw, 248px);
  --logo-height: 36px;
}

.logo-band__logo--remax {
  --logo-width: clamp(136px, 13vw, 184px);
  --logo-height: 40px;
}

.logo-band__logo--sothebys {
  --logo-width: clamp(132px, 12vw, 176px);
}

.logo-band__logo--hilton {
  --logo-width: clamp(116px, 10vw, 150px);
  --logo-height: 40px;
}

.logo-band__logo--hyatt {
  --logo-width: clamp(108px, 10vw, 146px);
  --logo-height: 34px;
}

.logo-band__logo--ihg {
  --logo-width: clamp(142px, 13vw, 188px);
  --logo-height: 36px;
}

.logo-band__logo--livenation {
  --logo-width: clamp(132px, 12vw, 172px);
  --logo-height: 42px;
}

.logo-band__logo--aeg {
  --logo-width: clamp(104px, 10vw, 138px);
  --logo-height: 40px;
}

.logo-band__logo--kaiser {
  --logo-width: clamp(184px, 19vw, 256px);
  --logo-height: 34px;
}

.logo-band__logo--99 {
  --logo-width: clamp(112px, 11vw, 148px);
  --logo-height: 56px;
}

.logo-band__logo--cbre {
  --logo-width: clamp(108px, 11vw, 146px);
  --logo-height: 32px;
}

.logo-band__logo--newmark {
  --logo-width: clamp(142px, 14vw, 196px);
  --logo-height: 32px;
}

.logo-band__logo--colliers {
  --logo-width: clamp(152px, 15vw, 206px);
  --logo-height: 38px;
}

.logo-band__logo--jll {
  --logo-width: clamp(100px, 10vw, 138px);
  --logo-height: 42px;
}

.logo-band__logo--cushman {
  --logo-width: clamp(190px, 19vw, 256px);
  --logo-height: 30px;
}

.logo-band--home-brands .logo-band__logo--remax {
  --logo-width: clamp(142px, 12vw, 170px);
  --logo-height: 38px;
}

.logo-band--home-brands .logo-band__logo--sothebys {
  --logo-width: clamp(148px, 13vw, 184px);
  --logo-height: 36px;
}

.logo-band--home-brands .logo-band__logo--cushman {
  --logo-width: clamp(202px, 17vw, 230px);
  --logo-height: 36px;
}

.logo-band--home-brands .logo-band__logo--cbre {
  --logo-width: clamp(172px, 14.8vw, 202px);
  --logo-height: 44px;
  margin-inline: clamp(-10px, -0.6vw, -6px);
}

.logo-band--home-brands .logo-band__logo--newmark {
  --logo-width: clamp(164px, 13.4vw, 184px);
  --logo-height: 32px;
}

.logo-band--home-brands .logo-band__logo--colliers {
  --logo-width: clamp(154px, 14vw, 198px);
  --logo-height: 36px;
}

.logo-band--home-brands .logo-band__logo--jll {
  --logo-width: clamp(108px, 10.5vw, 138px);
  --logo-height: 42px;
}

.logo-band--home-brands .logo-band__header {
  text-align: center;
}

.home-page .logo-band--home-brands {
  border-top: 0;
  padding-bottom: clamp(12px, 1.8vw, 20px);
}

.logo-band--home-brands .section-label {
  display: inline-flex;
  justify-content: center;
  gap: clamp(12px, 2vw, 20px);
}

.logo-band--home-brands .section-label::before,
.logo-band--home-brands .section-label::after {
  display: block;
  width: clamp(30px, 5vw, 56px);
}

.logo-band--matterport-platforms {
  position: relative;
  left: 50%;
  width: 100vw;
  margin-top: clamp(34px, 4vw, 54px);
  margin-left: -50vw;
  padding: 8px 0 38px;
  box-sizing: border-box;
  overflow: hidden;
  border-top: 0;
  border-bottom: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.logo-band--matterport-platforms .logo-band__header {
  margin-bottom: 24px;
  padding-inline: clamp(18px, 3vw, 30px);
}

.logo-band--matterport-platforms .section-label {
  color: var(--gold);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.18em;
}

.logo-band--matterport-platforms .logo-band__carousel {
  padding-inline: clamp(18px, 3vw, 30px);
}

.logo-band--matterport-platforms .logo-band__track {
  animation-duration: 46s;
}

.logo-band--matterport-platforms .logo-band__group {
  gap: clamp(30px, 3.6vw, 56px);
  padding-right: clamp(30px, 3.6vw, 56px);
}

.logo-band--matterport-platforms .logo-band__logo--platform {
  --logo-width: clamp(176px, 15vw, 216px);
  --platform-logo-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  min-height: 56px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.logo-band--matterport-platforms .logo-band__logo--platform img {
  width: auto;
  max-width: 100%;
  height: var(--platform-logo-height);
  max-height: var(--platform-logo-height);
  object-fit: contain;
  filter: none;
  opacity: 1;
  transition: transform var(--ease);
}

.logo-band--matterport-platforms .logo-band__logo--platform:hover {
  transform: translateY(-1px);
}

.logo-band--matterport-platforms .logo-band__logo--platform:hover img {
  filter: none;
  opacity: 1;
  transform: none;
}

.logo-band--matterport-platforms .logo-band__logo--platform-zumper {
  --platform-logo-height: 46px;
}

.logo-band--matterport-platforms .logo-band__logo--platform-crexi {
  --platform-logo-height: 39px;
}

.logo-band--matterport-platforms .logo-band__logo--platform-showcase {
  --platform-logo-height: 36px;
}

.logo-band--matterport-platforms .logo-band__logo--platform-brevitas {
  --platform-logo-height: 40px;
}

.logo-band--matterport-platforms .logo-band__brevitas-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  height: var(--platform-logo-height);
  color: #535850;
  line-height: 1;
}

.logo-band--matterport-platforms .logo-band__brevitas-mark span {
  color: currentColor;
  font-family: Merriweather, Georgia, serif;
  font-size: calc(var(--platform-logo-height) * 0.58);
  font-weight: 300;
}

@keyframes logo-band-marquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .logo-band--matterport-platforms .logo-band__track {
    animation: none;
  }
}

/* --- Operator Proof --- */
.operator-proof {
  padding: 16px 0 8px;
  background:
    radial-gradient(circle at 12% 10%, rgba(224, 188, 109, 0.14) 0%, rgba(224, 188, 109, 0) 26%),
    radial-gradient(circle at 88% 20%, rgba(33, 76, 21, 0.08) 0%, rgba(33, 76, 21, 0) 24%),
    linear-gradient(180deg, #fbf7f0 0%, #f5ede2 100%);
}

.operator-proof__panel {
  position: relative;
  padding: clamp(18px, 2vw, 24px);
  border-radius: 34px;
  border: 1px solid rgba(16, 33, 13, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 252, 246, 0.96) 0%, rgba(250, 244, 234, 0.94) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.92),
    0 18px 36px rgba(10, 18, 11, 0.07);
  overflow: hidden;
}

.operator-proof__panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 18% 10%, rgba(228, 186, 97, 0.14), transparent 24%),
    radial-gradient(circle at 82% 18%, rgba(94, 142, 72, 0.1), transparent 22%);
}

.operator-proof__layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(0, 1.12fr);
  gap: 18px;
  align-items: center;
}

.operator-proof__intro h2 {
  margin: 0;
  max-width: 12ch;
  color: var(--green-deep);
  font-size: clamp(1.75rem, 2.6vw, 2.55rem);
  line-height: 0.96;
  letter-spacing: -0.05em;
}

.operator-proof__intro p {
  margin: 12px 0 0;
  max-width: 30ch;
  color: var(--muted);
  font-size: 0.94rem;
  line-height: 1.56;
}

.operator-proof__featured {
  position: relative;
  padding: 18px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 18% 18%, rgba(243, 198, 109, 0.16) 0%, rgba(243, 198, 109, 0) 26%),
    linear-gradient(160deg, #14331b 0%, #0d2414 100%);
  border-color: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 20px 38px rgba(7, 17, 9, 0.18);
}

.operator-proof__featured::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0) 34%);
}

.operator-proof__badge {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(243, 198, 109, 0.22);
  background: rgba(243, 198, 109, 0.1);
  color: #f3c66d;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.operator-proof__featured h3 {
  margin: 10px 0 7px;
  font-family: var(--font-heading);
  font-size: clamp(1.22rem, 1.75vw, 1.72rem);
  line-height: 0.98;
  letter-spacing: -0.04em;
  color: #fff7e9;
}

.operator-proof__featured p {
  margin: 0;
  color: rgba(245, 241, 232, 0.78);
  font-size: 0.9rem;
  line-height: 1.48;
  max-width: 48ch;
}

.operator-proof__signals {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 14px 0 0;
  padding: 0;
  list-style: none;
}

.operator-proof__signal {
  padding: 11px 12px 12px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.operator-proof__signal strong {
  display: block;
  color: #f3c66d;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.operator-proof__signal span {
  display: block;
  margin-top: 4px;
  color: rgba(245, 241, 232, 0.82);
  font-size: 0.8rem;
  line-height: 1.42;
}

.operator-proof__trust {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 14px;
}

.operator-proof__trust span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.54);
  border: 1px solid rgba(16, 33, 13, 0.08);
  color: var(--green-deep);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
}

/* --- Industry Routing Tiles --- */
.industry-routing {
  padding: 56px 0 72px;
}

.industry-routing .section-head {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.industry-routing__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.industry-tile {
  position: relative;
  display: grid;
  place-items: center;
  aspect-ratio: 1 / 1;
  min-height: 320px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  text-decoration: none;
  transition: transform var(--ease), box-shadow var(--ease);
  border: 1px solid rgba(255, 255, 255, 0.08);
  isolation: isolate;
}

.industry-tile:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.industry-tile--green {
  background:
    linear-gradient(180deg, rgba(12, 31, 11, 0.16) 0%, rgba(12, 31, 11, 0.82) 66%, rgba(9, 22, 8, 0.96) 100%),
    linear-gradient(160deg, #1c3e14 0%, #0d1f0a 100%);
}

.industry-tile--gold {
  background:
    linear-gradient(180deg, rgba(58, 40, 8, 0.14) 0%, rgba(58, 40, 8, 0.78) 66%, rgba(34, 25, 6, 0.94) 100%),
    linear-gradient(160deg, #6b4c10 0%, #3a2808 100%);
}

.industry-tile--dark {
  background:
    linear-gradient(180deg, rgba(17, 21, 17, 0.12) 0%, rgba(17, 21, 17, 0.78) 66%, rgba(7, 11, 8, 0.96) 100%),
    linear-gradient(160deg, #2a2a2a 0%, #111 100%);
}

.industry-tile::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background-position: var(--industry-photo-position, center);
  background-repeat: no-repeat;
  background-size: cover;
  transform: scale(1.02);
  transition: transform 320ms ease, filter 320ms ease;
  filter: saturate(0.94) contrast(1.02) brightness(0.94);
}

.industry-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg, rgba(7, 11, 8, 0.42) 0%, rgba(7, 11, 8, 0.46) 100%),
    radial-gradient(circle at 50% 24%, rgba(243, 198, 109, 0.12), transparent 24%),
    radial-gradient(circle at 50% 54%, rgba(7, 11, 8, 0.06), rgba(7, 11, 8, 0.3) 62%, rgba(7, 11, 8, 0.62) 100%);
  transition: opacity 260ms ease, background 260ms ease;
}

.industry-tile--green::before {
  background-image: url("../assets/images/official/home/residential/twilight-04.jpg");
  --industry-photo-position: center 54%;
}

.industry-tile--gold::before {
  background-image: url("../assets/images/official/home/hospitality/hdr-02.jpg");
  --industry-photo-position: center 52%;
}

.industry-tile--dark::before {
  background-image: url("../assets/images/official/home/commercial/twilight-05.jpg");
  --industry-photo-position: center 54%;
}

.industry-tile:hover::before {
  transform: scale(1.06);
  filter: saturate(1) contrast(1.04) brightness(1);
}

.industry-tile:hover::after {
  background:
    linear-gradient(180deg, rgba(7, 11, 8, 0.36) 0%, rgba(7, 11, 8, 0.42) 100%),
    radial-gradient(circle at 50% 24%, rgba(243, 198, 109, 0.16), transparent 26%),
    radial-gradient(circle at 50% 54%, rgba(7, 11, 8, 0.04), rgba(7, 11, 8, 0.24) 60%, rgba(7, 11, 8, 0.56) 100%);
}

.industry-tile__content {
  position: absolute;
  top: 50%;
  left: 50%;
  display: grid;
  grid-template-rows: auto auto;
  align-content: center;
  justify-items: center;
  width: min(calc(100% - 56px), 18rem);
  min-height: 9.5rem;
  margin: 0;
  padding: 0;
  z-index: 1;
  text-align: center;
  transform: translate(-50%, -50%);
}

.industry-tile--hospitality .industry-tile__content {
  transform: translate(-50%, -50%);
}

.industry-tile__content::before {
  content: none;
}

.industry-tile__content > * {
  position: relative;
  z-index: 1;
}

.industry-tile:hover .industry-tile__content {
  transform: translate(-50%, -50%);
}

.industry-tile__content h3 {
  margin: 0;
  display: grid;
  align-items: center;
  max-width: 13ch;
  min-height: calc(2 * 1.08em);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.5rem, 2.2vw, 2rem);
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: #fff;
  text-wrap: balance;
}

.industry-tile__content p {
  margin: 14px 0 0;
  min-height: calc(3 * 1.56em);
  max-width: 24ch;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.94rem;
  line-height: 1.56;
  text-wrap: balance;
}

.industry-tile__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 38px;
  margin-top: 26px;
  color: var(--gold);
  font-weight: 900;
  font-size: clamp(1.08rem, 1.2vw, 1.25rem);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: transform var(--ease);
}

.industry-tile__link::after {
  content: "";
  width: 1.5rem;
  height: 1rem;
  background: currentColor;
  clip-path: polygon(0 35%, 54% 35%, 54% 10%, 100% 50%, 54% 90%, 54% 65%, 0 65%);
  transition: transform var(--ease);
}

.industry-tile:hover .industry-tile__link {
  transform: translateY(-2px);
}

.industry-tile:hover .industry-tile__link::after {
  transform: translateX(4px);
}

/* --- Homepage Service Hub --- */
.home-service-hub {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  margin-top: 0;
  padding: clamp(18px, 2.6vw, 34px) 0 88px;
  background: #ffffff;
}

.home-service-hub::before {
  content: none;
}

.home-service-hub::after {
  content: none;
}

.home-service-hub > .shell {
  width: min(calc(100% - 32px), 80rem);
  position: relative;
  z-index: 1;
}

.home-service-hub__head {
  max-width: 900px;
  margin: 0 auto 32px;
  text-align: center;
  text-shadow: none;
}

.home-service-hub__head .section-label {
  justify-content: center;
  width: 100%;
  margin: 18px 0 clamp(16px, 1.8vw, 26px);
}

.home-service-hub__head p {
  max-width: 62ch;
  margin-left: auto;
  margin-right: auto;
  color: rgba(29, 49, 23, 0.72);
}

.home-service-hub__industries {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  gap: 10px;
  width: min(100%, 58rem);
  justify-content: center;
  padding: 12px;
  margin: 0 auto 16px;
  border-radius: 999px;
  background:
    linear-gradient(135deg, #607239 0%, #223d18 58%, #0c1c0b 100%);
  border: 1px solid rgba(196, 141, 38, 0.28);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 0 -18px 48px rgba(3, 12, 5, 0.16),
    0 26px 52px rgba(3, 12, 5, 0.26);
  backdrop-filter: none;
  overflow: visible;
}

.home-service-hub__industries::-webkit-scrollbar {
  display: none;
}

.home-service-hub__services-label {
  justify-content: center;
  width: 100%;
  margin: 0 0 18px;
}

.home-service-hub__industry-tab {
  flex: 0 1 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  max-width: 100%;
  padding: 10px 22px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 248, 235, 0.86);
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.35;
  text-align: center;
  text-transform: uppercase;
  white-space: normal;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 10px 22px rgba(0, 0, 0, 0.12);
  transition: background var(--ease), color var(--ease), box-shadow var(--ease), transform var(--ease), border-color var(--ease);
}

.home-service-hub__industry-tab:hover {
  transform: translateY(-1px);
  color: #fff4dd;
  border-color: rgba(196, 141, 38, 0.34);
  background: rgba(196, 141, 38, 0.16);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.09),
    0 14px 26px rgba(3, 12, 5, 0.18);
}

.home-service-hub__industry-tab:focus-visible {
  outline: none;
  border-color: rgba(196, 141, 38, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 0 0 3px rgba(196, 141, 38, 0.18);
}

.home-service-hub__industry-tab.is-active {
  color: #10210d;
  border-color: rgba(196, 141, 38, 0.54);
  background: var(--gold);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 18px 34px rgba(7, 16, 8, 0.24);
}

.home-service-hub__panel {
  display: none;
}

.home-service-hub__panel.is-active {
  display: block;
}

.home-service-hub__switcher {
  padding-top: 0;
}

.home-service-hub .service-switcher__tabs {
  flex-wrap: nowrap;
  gap: 6px;
  width: min(100%, 78rem);
  margin: 0 auto 26px;
  padding: 12px;
  border-radius: 999px;
  background:
    linear-gradient(135deg, #607239 0%, #223d18 58%, #0c1c0b 100%);
  border-color: rgba(196, 141, 38, 0.28);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 0 -18px 48px rgba(3, 12, 5, 0.16),
    0 26px 52px rgba(3, 12, 5, 0.26);
  backdrop-filter: none;
}

.home-service-hub .service-switcher__tab {
  position: relative;
  min-height: 48px;
  padding: 10px 12px 16px;
  border-color: transparent;
  background: transparent;
  color: rgba(255, 248, 235, 0.86);
  font-size: 0.8rem;
  letter-spacing: 0.09em;
  white-space: nowrap;
  box-shadow: none;
  transition: background var(--ease), color var(--ease), box-shadow var(--ease), transform var(--ease), border-color var(--ease);
}

.home-service-hub .service-switcher__tab:hover {
  transform: translateY(-1px);
  border-color: transparent;
  background: rgba(196, 141, 38, 0.08);
  color: #fff4dd;
  box-shadow: none;
}

.home-service-hub .service-switcher__tab:focus-visible {
  outline: none;
  border-color: transparent;
  box-shadow: 0 0 0 3px rgba(196, 141, 38, 0.18);
}

.home-service-hub .service-switcher__tab.is-active {
  border-color: rgba(196, 141, 38, 0.54);
  background: var(--gold);
  color: #10210d;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 18px 34px rgba(7, 16, 8, 0.24);
}

.home-service-hub .service-switcher__tab.is-active::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 6px;
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 7px solid rgba(16, 33, 13, 0.9);
  transform: translateX(-50%);
  filter: drop-shadow(0 1px 1px rgba(255, 255, 255, 0.18));
  pointer-events: none;
}

@media (max-width: 1100px) {
  .home-service-hub__industries {
    width: 100%;
    border-radius: 34px;
  }

  .home-service-hub__industry-tab {
    flex: 1 1 13rem;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .home-service-hub .service-switcher__tabs {
    flex-wrap: wrap;
    width: 100%;
  }

  .home-service-hub .service-switcher__tab {
    flex: 1 1 10.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    white-space: normal;
  }
}

@media (max-width: 680px) {
  .home-service-hub__industries,
  .home-service-hub .service-switcher__tabs {
    gap: 8px;
    border-radius: 28px;
  }

  .home-service-hub__industry-tab {
    flex-basis: 100%;
    min-height: 50px;
  }

  .home-service-hub .service-switcher__tab {
    flex-basis: calc(50% - 8px);
    min-height: 50px;
    padding: 10px 14px 16px;
  }
}

.home-service-hub .service-switcher__media {
  border-color: rgba(255, 255, 255, 0.14);
  box-shadow: 0 30px 62px rgba(3, 12, 5, 0.3);
}

.home-service-hub .service-switcher__copy,
.home-service-hub .service-switcher__tour,
.home-service-hub .service-switcher__hdr-copy {
  background:
    linear-gradient(150deg, #304e1d 0%, #142c10 52%, #081508 100%);
  border-color: rgba(196, 141, 38, 0.3);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 0 -78px 138px rgba(3, 12, 5, 0.24),
    0 32px 66px rgba(3, 12, 5, 0.32);
  backdrop-filter: none;
}

.home-service-hub .service-switcher__tour-value,
.home-service-hub .service-switcher__tour-fit,
.home-service-hub .service-switcher__media-card,
.home-service-hub .service-switcher__tour-card {
  background:
    linear-gradient(145deg, #3b5923 0%, #183412 56%, #0b190a 100%);
  border-color: rgba(255, 253, 248, 0.18);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 0 -38px 84px rgba(3, 12, 5, 0.16),
    0 20px 40px rgba(3, 12, 5, 0.22);
  backdrop-filter: none;
}

:is(
  #home-res-panel-hdr,
  #home-res-panel-drone,
  #home-res-panel-twilight,
  #home-res-panel-floorplan,
  #home-res-panel-staging,
  #home-res-panel-flythrough,
  #home-com-panel-hdr,
  #home-com-panel-drone,
  #home-com-panel-twilight,
  #home-com-panel-floorplan,
  #home-com-panel-staging,
  #home-com-panel-flythrough,
  #home-hosp-panel-hdr,
  #home-hosp-panel-drone,
  #home-hosp-panel-twilight,
  #home-hosp-panel-floorplan,
  #home-hosp-panel-staging,
  #home-hosp-panel-flythrough
) .service-switcher__tour--hdr-connected .service-switcher__hdr-copy {
  padding: 30px;
  border-radius: 28px;
  background:
    linear-gradient(145deg, #3b5923 0%, #183412 56%, #0b190a 100%);
  border: 1px solid rgba(255, 253, 248, 0.18);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 0 -38px 84px rgba(3, 12, 5, 0.16),
    0 20px 40px rgba(3, 12, 5, 0.22);
}

.home-service-hub .service-switcher__hdr-gallery-meta,
.home-service-hub .service-switcher__media-pill,
.home-service-hub .service-switcher__media-tags li,
.home-service-hub .service-switcher__tour-pills span {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.14);
}

.home-service-hub .service-switcher__tour-chip--floating {
  display: none;
}

.home-service-hub .service-switcher__hdr-gallery-head {
  display: none;
}

.home-service-hub :is(#home-res-panel-flythrough, #home-com-panel-flythrough) .service-switcher__video-shell {
  width: min(100%, 720px, calc(100vw - 82px));
  margin-inline: auto;
}

.home-service-hub :is(
  [data-service-panel="hdr"],
  [data-service-panel="drone"],
  [data-service-panel="twilight"],
  [data-service-panel="floorplan"],
  [data-service-panel="staging"],
  [data-service-panel="flythrough"]
) .service-switcher__hdr-gallery-shell {
  width: min(100%, 720px, calc(100vw - 82px));
  margin-inline: auto;
}

.home-service-hub :is(
  [data-service-panel="hdr"],
  [data-service-panel="drone"],
  [data-service-panel="twilight"],
  [data-service-panel="floorplan"],
  [data-service-panel="staging"],
  [data-service-panel="flythrough"]
) .service-switcher__hdr-slide img {
  aspect-ratio: 3 / 2;
  object-fit: contain;
  background: #0a120c;
}

body.page-real-estate :is(
  [data-service-panel="hdr"],
  [data-service-panel="drone"],
  [data-service-panel="twilight"],
  [data-service-panel="floorplan"],
  [data-service-panel="staging"],
  [data-service-panel="flythrough"]
) .service-switcher__hdr-slide img,
body.page-commercial :is(
  [data-service-panel="hdr"],
  [data-service-panel="drone"],
  [data-service-panel="twilight"],
  [data-service-panel="floorplan"],
  [data-service-panel="staging"],
  [data-service-panel="flythrough"]
) .service-switcher__hdr-slide img {
  aspect-ratio: 3 / 2;
  object-fit: contain;
  background: #0a120c;
}

body.page-real-estate [data-service-panel="floorplan"] .service-switcher__hdr-slide img,
body.page-commercial [data-service-panel="floorplan"] .service-switcher__hdr-slide img {
  background: #f7f3eb;
}

.home-service-hub #industry-panel-commercial :is(
  [data-service-panel="hdr"],
  [data-service-panel="drone"],
  [data-service-panel="twilight"],
  [data-service-panel="staging"],
  [data-service-panel="flythrough"]
) .service-switcher__hdr-slide,
body.page-commercial :is(
  [data-service-panel="hdr"],
  [data-service-panel="drone"],
  [data-service-panel="twilight"],
  [data-service-panel="staging"],
  [data-service-panel="flythrough"]
) .service-switcher__hdr-slide {
  align-self: start;
  background: transparent;
}

.home-service-hub #industry-panel-commercial :is(
  [data-service-panel="hdr"],
  [data-service-panel="drone"],
  [data-service-panel="twilight"],
  [data-service-panel="staging"],
  [data-service-panel="flythrough"]
) .service-switcher__hdr-slide img,
body.page-commercial :is(
  [data-service-panel="hdr"],
  [data-service-panel="drone"],
  [data-service-panel="twilight"],
  [data-service-panel="staging"],
  [data-service-panel="flythrough"]
) .service-switcher__hdr-slide img {
  height: auto;
  aspect-ratio: auto;
  object-fit: initial;
  background: transparent;
}

.home-service-hub :is(#home-res-panel-matterport, #home-res-panel-zillow, #home-com-panel-matterport, #home-hosp-panel-matterport) .service-switcher__tour-stage--embed {
  width: min(100%, 720px, calc(100vw - 82px));
  margin-inline: auto;
}

.home-service-hub #home-res-panel-zillow .service-switcher__tour-stage--embed {
  aspect-ratio: 16 / 9;
}

.home-service-hub #home-res-panel-zillow .service-switcher__tour-live--preview {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  padding-top: 0;
  overflow: hidden;
  background: transparent;
}

.home-service-hub #home-res-panel-zillow .service-switcher__tour-live--preview .service-switcher__tour-preview {
  position: absolute;
  inset: 0;
  margin: 0;
  overflow: hidden;
  border-radius: inherit;
}

.home-service-hub #home-res-panel-zillow .service-switcher__tour-live--preview .service-switcher__tour-preview > img {
  width: 100%;
  height: 100%;
  aspect-ratio: auto;
  object-fit: cover;
  background: transparent;
}

.home-service-hub #home-res-panel-zillow .service-switcher__tour-card--zillow {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
  width: auto;
  max-width: 420px;
}

body.page-real-estate #home-res-panel-zillow .service-switcher__tour-stage--embed {
  width: min(100%, 720px, calc(100vw - 82px));
  margin-inline: auto;
  aspect-ratio: 16 / 9;
}

body.page-real-estate #home-res-panel-zillow .service-switcher__tour-live--preview {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  padding-top: 0;
  overflow: hidden;
  background: transparent;
}

body.page-real-estate #home-res-panel-zillow .service-switcher__tour-live--preview .service-switcher__tour-preview {
  position: absolute;
  inset: 0;
  margin: 0;
  overflow: hidden;
  border-radius: inherit;
}

body.page-real-estate #home-res-panel-zillow .service-switcher__tour-live--preview .service-switcher__tour-preview > img {
  width: 100%;
  height: 100%;
  aspect-ratio: auto;
  object-fit: cover;
  background: transparent;
}

body.page-real-estate #home-res-panel-zillow .service-switcher__tour-card--zillow {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
  width: auto;
  max-width: 420px;
}

@media (max-width: 768px) {
  .home-service-hub #home-res-panel-zillow .service-switcher__tour-card--zillow,
  body.page-real-estate #home-res-panel-zillow .service-switcher__tour-card--zillow {
    display: none;
  }
}

.home-service-hub .service-switcher__eyebrow {
  justify-self: start;
  width: fit-content;
  max-width: 100%;
  white-space: nowrap;
}

.home-service-hub .service-switcher__eyebrow,
.home-service-hub .service-switcher__tour-label,
.home-service-hub .service-switcher__tour-fit-label,
.home-service-hub .service-switcher__tour-chip,
.home-service-hub .service-switcher__media-pill,
.home-service-hub .service-switcher__hdr-gallery-count {
  background: var(--gold-soft);
  color: var(--gold);
}

.home-service-hub .service-switcher__list li::before,
.home-service-hub .service-switcher__tour-fit-list li::before {
  background: var(--gold);
}

.home-service-hub .service-switcher__hdr-slide figcaption,
.home-service-hub .service-switcher__before-after-label {
  color: var(--gold);
}

.home-service-hub :is(
  [data-service-panel="hdr"],
  [data-service-panel="drone"],
  [data-service-panel="floorplan"],
  [data-service-panel="staging"],
  [data-service-panel="twilight"],
  [data-service-panel="flythrough"]
) .service-switcher__hdr-copy {
  align-items: stretch;
}

.home-service-hub :is(
  [data-service-panel="hdr"],
  [data-service-panel="drone"],
  [data-service-panel="floorplan"],
  [data-service-panel="staging"],
  [data-service-panel="twilight"],
  [data-service-panel="flythrough"]
) .service-switcher__list--hdr {
  height: 100%;
  min-height: clamp(9rem, 13vw, 12.5rem);
  padding-block: clamp(0.5rem, 1.1vw, 1rem);
  align-content: space-between;
  gap: clamp(1.15rem, 2vw, 1.9rem);
}

.home-service-hub .service-switcher__hdr-slide::after {
  background:
    linear-gradient(180deg, rgba(7, 14, 9, 0) 48%, rgba(7, 14, 9, 0.28) 100%),
    linear-gradient(145deg, rgba(196, 141, 38, 0.04), transparent 42%);
}

.home-service-hub .service-switcher__hdr-slider {
  --home-gallery-arrow-size: clamp(56px, 5vw, 68px);
  --home-gallery-arrow-gap: clamp(26px, 3vw, 44px);
  --home-gallery-arrow-offset: calc(var(--home-gallery-arrow-size) + var(--home-gallery-arrow-gap));
}

.home-service-hub .service-switcher__hdr-gallery-nav {
  width: var(--home-gallery-arrow-size);
  height: var(--home-gallery-arrow-size);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.07));
  border-color: rgba(255, 255, 255, 0.42);
  color: #ffffff;
  font-size: clamp(1.05rem, 1.5vw, 1.28rem);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.32),
    inset 0 -16px 28px rgba(255, 255, 255, 0.03),
    0 14px 30px rgba(3, 12, 5, 0.28),
    0 0 0 1px rgba(255, 255, 255, 0.08);
  text-shadow: 0 0 16px rgba(255, 255, 255, 0.42);
}

.home-service-hub .service-switcher__hdr-gallery-nav:hover,
.home-service-hub .service-switcher__hdr-gallery-nav:focus-visible {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.34), rgba(255, 255, 255, 0.13));
  border-color: rgba(255, 255, 255, 0.74);
  transform: translateY(-50%) scale(1.04);
}

.home-service-hub .service-switcher__hdr-gallery-nav--prev {
  left: calc(-1 * var(--home-gallery-arrow-offset));
}

.home-service-hub .service-switcher__hdr-gallery-nav--next {
  right: calc(-1 * var(--home-gallery-arrow-offset));
}

@media (max-width: 640px) {
  .home-service-hub .service-switcher__hdr-slider {
    --home-gallery-arrow-size: 50px;
    padding-bottom: 84px;
  }

  .home-service-hub .service-switcher__hdr-gallery-nav {
    top: auto;
    bottom: 10px;
    font-size: 1rem;
    transform: none;
  }

  .home-service-hub .service-switcher__hdr-gallery-nav:hover,
  .home-service-hub .service-switcher__hdr-gallery-nav:focus-visible {
    transform: scale(1.04);
  }

  .home-service-hub .service-switcher__hdr-gallery-nav--prev {
    left: calc(50% - var(--home-gallery-arrow-size) - 8px);
  }

  .home-service-hub .service-switcher__hdr-gallery-nav--next {
    right: auto;
    left: calc(50% + 8px);
  }
}

.home-service-hub .service-switcher__stats {
  margin-top: 20px;
  align-items: stretch;
}

.home-service-hub .service-switcher__stat {
  background:
    linear-gradient(150deg, #3e5b23 0%, #17350e 56%, #0a180a 100%);
  border-color: rgba(196, 141, 38, 0.24);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.11),
    inset 0 -32px 74px rgba(3, 12, 5, 0.16),
    0 20px 40px rgba(3, 12, 5, 0.22);
  backdrop-filter: none;
  text-align: center;
}

.home-service-hub .service-switcher__stat:not(.service-switcher__stat--cta) {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 10px;
  min-height: 100%;
}

.home-service-hub .service-switcher__stat strong {
  color: var(--gold);
}

.home-service-hub .service-switcher__stat--cta strong {
  color: #fff8eb;
}

.home-service-hub .service-switcher__stat span {
  color: rgba(245, 241, 232, 0.88);
}

.home-service-hub .service-switcher__stat cite {
  color: var(--gold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-service-hub .service-switcher__stat:not(.service-switcher__stat--cta) strong,
.home-service-hub .service-switcher__stat:not(.service-switcher__stat--cta) span,
.home-service-hub .service-switcher__stat:not(.service-switcher__stat--cta) cite {
  margin-top: 0;
  text-align: center;
}

.home-service-hub .service-switcher__stat--scope {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  gap: 8px;
  padding: 22px;
  border: 1px solid rgba(196, 141, 38, 0.24);
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.98) 0%, rgba(248, 244, 236, 0.94) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 18px 36px rgba(8, 20, 9, 0.12);
}

.home-service-hub .service-switcher__stat--scope::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 5px;
  background: linear-gradient(90deg, #c48d26 0%, #296216 100%);
}

.home-service-hub .service-switcher__stat--scope::after {
  content: "";
  position: absolute;
  right: -44px;
  bottom: -48px;
  z-index: -1;
  width: 150px;
  height: 150px;
  border-radius: 999px;
  background: rgba(41, 98, 22, 0.08);
}

.home-service-hub .service-switcher__stat--scope .service-switcher__stat-label {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(41, 98, 22, 0.08);
  color: var(--green-deep);
  border: 1px solid rgba(41, 98, 22, 0.12);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  line-height: 1;
  text-transform: uppercase;
}

.home-service-hub .service-switcher__stat--scope strong {
  max-width: 10ch;
  color: var(--green-deep);
  font-size: clamp(1.65rem, 2.4vw, 2.15rem);
  line-height: 0.95;
  letter-spacing: 0;
  text-wrap: balance;
}

.home-service-hub .service-switcher__stat--scope span:not(.service-switcher__stat-label) {
  color: #52604d;
  font-weight: 700;
}

.home-service-hub .service-switcher__stat--scope cite {
  min-height: 30px;
  margin-top: 4px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(196, 141, 38, 0.12);
  color: #906314;
  font-size: 0.68rem;
  line-height: 1.2;
}

#home-res-panel-matterport,
#home-res-panel-hdr,
#home-res-panel-drone,
#home-res-panel-zillow,
#home-res-panel-twilight,
#home-res-panel-floorplan,
#home-res-panel-staging,
#home-res-panel-flythrough {
  --service-hub-accent-gold: var(--gold);
  --service-hub-accent-gold-soft: rgba(196, 141, 38, 0.14);
}

#home-res-panel-matterport .service-switcher__eyebrow,
#home-res-panel-matterport .service-switcher__tour-fit-label,
#home-res-panel-matterport .service-switcher__tour-chip,
#home-res-panel-zillow .service-switcher__eyebrow,
#home-res-panel-zillow .service-switcher__tour-fit-label,
#home-res-panel-zillow .service-switcher__tour-chip,
#home-res-panel-twilight .service-switcher__eyebrow,
#home-res-panel-twilight .service-switcher__media-pill,
#home-res-panel-twilight .service-switcher__hdr-gallery-count,
#home-res-panel-floorplan .service-switcher__eyebrow,
#home-res-panel-floorplan .service-switcher__media-pill,
#home-res-panel-floorplan .service-switcher__hdr-gallery-count,
#home-res-panel-staging .service-switcher__eyebrow,
#home-res-panel-staging .service-switcher__media-pill,
#home-res-panel-staging .service-switcher__hdr-gallery-count,
#home-res-panel-flythrough .service-switcher__eyebrow,
#home-res-panel-flythrough .service-switcher__media-pill,
#home-res-panel-flythrough .service-switcher__hdr-gallery-count {
  background: var(--service-hub-accent-gold-soft);
  color: var(--service-hub-accent-gold);
}

#home-res-panel-matterport .service-switcher__list li::before,
#home-res-panel-zillow .service-switcher__list li::before,
#home-res-panel-twilight .service-switcher__list li::before,
#home-res-panel-floorplan .service-switcher__list li::before,
#home-res-panel-staging .service-switcher__list li::before,
#home-res-panel-flythrough .service-switcher__list li::before {
  background: var(--service-hub-accent-gold);
}

#home-res-panel-matterport .service-switcher__tour-fit-list li::before,
#home-res-panel-matterport .service-switcher__stat strong,
#home-res-panel-matterport .service-switcher__stat cite,
#home-res-panel-zillow .service-switcher__tour-fit-list li::before,
#home-res-panel-zillow .service-switcher__stat strong,
#home-res-panel-zillow .service-switcher__stat cite,
#home-res-panel-twilight .service-switcher__stat strong,
#home-res-panel-twilight .service-switcher__stat cite,
#home-res-panel-twilight .service-switcher__hdr-slide figcaption,
#home-res-panel-floorplan .service-switcher__stat strong,
#home-res-panel-floorplan .service-switcher__stat cite,
#home-res-panel-floorplan .service-switcher__hdr-slide figcaption,
#home-res-panel-staging .service-switcher__stat strong,
#home-res-panel-staging .service-switcher__stat cite,
#home-res-panel-staging .service-switcher__hdr-slide figcaption,
#home-res-panel-flythrough .service-switcher__stat strong,
#home-res-panel-flythrough .service-switcher__stat cite,
#home-res-panel-flythrough .service-switcher__hdr-slide figcaption {
  color: var(--service-hub-accent-gold);
}

#home-res-panel-matterport .service-switcher__stat:not(.service-switcher__stat--cta) strong,
#home-res-panel-zillow .service-switcher__stat:not(.service-switcher__stat--cta) strong {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 2.3rem;
  font-size: clamp(1.65rem, 2.55vw, 2.35rem);
  line-height: 0.95;
  letter-spacing: -0.045em;
}

#home-res-panel-matterport .service-switcher__stat--hosting strong,
#home-res-panel-zillow .service-switcher__stat--hosting strong {
  font-size: clamp(1.18rem, 1.6vw, 1.48rem);
  line-height: 1;
  letter-spacing: -0.03em;
  white-space: nowrap;
}

#home-com-panel-matterport .service-switcher__tour-fit-list li::before {
  background: var(--gold);
  color: var(--gold);
}

#home-res-panel-zillow .service-switcher__stat--zillow-views strong,
#home-res-panel-zillow .service-switcher__stat--zillow-engagement strong {
  font-size: clamp(1.35rem, 1.9vw, 1.85rem);
  line-height: 1;
  letter-spacing: -0.04em;
  white-space: nowrap;
}

#home-res-panel-matterport .service-switcher__stat--cta strong,
#home-res-panel-zillow .service-switcher__stat--cta strong {
  color: #fff8eb;
}

.home-service-hub .service-switcher__stat--cta-card {
  position: relative;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 10px;
  overflow: hidden;
  isolation: isolate;
  text-decoration: none;
  text-align: center;
  cursor: pointer;
  background:
    radial-gradient(circle at 84% 16%, rgba(255, 255, 255, 0.2), transparent 24%),
    linear-gradient(135deg, var(--gold) 0%, var(--gold) 100%);
  border-color: rgba(255, 248, 235, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.28),
    inset 0 -20px 46px rgba(126, 81, 14, 0.16),
    0 0 0 1px rgba(196, 141, 38, 0.18),
    0 0 26px rgba(196, 141, 38, 0.26),
    0 0 54px rgba(196, 141, 38, 0.22),
    0 24px 42px rgba(113, 73, 14, 0.24);
  transition: transform var(--ease), box-shadow var(--ease), border-color var(--ease), filter var(--ease);
}

.home-service-hub .service-switcher__stat--cta-card::before {
  content: "";
  position: absolute;
  inset: -6px auto -6px -42%;
  width: 52%;
  background: linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, 0.28) 50%, transparent 100%);
  opacity: 0.72;
  transform: translateX(0);
  transition: transform 720ms cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: none;
}

.home-service-hub .service-switcher__stat--cta-card::after {
  content: none;
}

.home-service-hub .service-switcher__stat--cta-card:hover,
.home-service-hub .service-switcher__stat--cta-card:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(255, 248, 235, 0.58);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.32),
    inset 0 -24px 56px rgba(126, 81, 14, 0.22),
    0 0 0 1px rgba(196, 141, 38, 0.24),
    0 0 34px rgba(196, 141, 38, 0.34),
    0 0 74px rgba(196, 141, 38, 0.28),
    0 30px 54px rgba(113, 73, 14, 0.3);
  filter: saturate(1.04);
}

.home-service-hub .service-switcher__stat--cta-card:hover::before,
.home-service-hub .service-switcher__stat--cta-card:focus-visible::before {
  transform: translateX(240%);
}

.home-service-hub .service-switcher__stat--cta-card:focus-visible {
  outline: none;
}

:is(
  #home-res-panel-matterport,
  #home-res-panel-zillow,
  #home-res-panel-hdr,
  #home-res-panel-drone,
  #home-res-panel-twilight,
  #home-res-panel-floorplan,
  #home-res-panel-staging,
  #home-res-panel-flythrough,
  #home-com-panel-matterport,
  #home-com-panel-hdr,
  #home-com-panel-drone,
  #home-com-panel-twilight,
  #home-com-panel-floorplan,
  #home-com-panel-staging,
  #home-com-panel-flythrough
) .service-switcher__stat--cta-card strong {
  color: #10210d;
  font-size: clamp(2.1rem, 3vw, 2.9rem);
  line-height: 0.94;
  letter-spacing: -0.05em;
  margin-inline: auto;
  max-width: 10ch;
  text-wrap: balance;
}

.home-service-hub .service-switcher__stat--cta-card .service-switcher__stat-cta-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-height: 92px;
  margin-top: 0;
  margin-inline: auto;
  color: #fff8eb;
  transition: transform 260ms ease, color 260ms ease;
}

.home-service-hub .service-switcher__stat-cta-arrow {
  position: relative;
  display: block;
  width: 10.5rem;
  height: 6px;
  border-radius: 999px;
  color: #fff8eb;
  background: #fff8eb;
  box-shadow: 0 0 18px rgba(255, 248, 235, 0.2);
  transition: width 260ms ease, transform 260ms ease, box-shadow 260ms ease;
}

.home-service-hub .service-switcher__stat-cta-arrow::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 2rem;
  height: 2rem;
  border-top: 6px solid #fff8eb;
  border-right: 6px solid #fff8eb;
  border-top-right-radius: 0.35rem;
  transform: translateY(-50%) rotate(45deg);
  transition: transform 260ms ease;
}

.home-service-hub .service-switcher__stat--cta-card .service-switcher__stat-cta-mark::before,
.home-service-hub .service-switcher__stat--cta-card .service-switcher__stat-cta-mark::after {
  content: none;
}

.home-service-hub .service-switcher__stat--cta-card .service-switcher__stat-cta-subtext {
  margin-top: 0;
  color: rgba(16, 33, 13, 0.76);
  font-size: 0.68rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: none;
}

.home-service-hub .service-switcher__stat--cta-card:hover .service-switcher__stat-cta-mark,
.home-service-hub .service-switcher__stat--cta-card:focus-visible .service-switcher__stat-cta-mark {
  color: #fff8eb;
  transform: translateX(3px);
}

.home-service-hub .service-switcher__stat--cta-card:hover .service-switcher__stat-cta-arrow,
.home-service-hub .service-switcher__stat--cta-card:focus-visible .service-switcher__stat-cta-arrow {
  width: 12rem;
  transform: translateX(0.55rem);
  box-shadow: 0 0 22px rgba(255, 248, 235, 0.24);
}

.home-service-hub .service-switcher__stat--cta-card:hover .service-switcher__stat-cta-arrow::after,
.home-service-hub .service-switcher__stat--cta-card:focus-visible .service-switcher__stat-cta-arrow::after {
  transform: translate(0.12rem, -50%) rotate(45deg);
}

#home-res-panel-matterport .service-switcher__stat--cta .service-switcher__stat-button,
#home-res-panel-zillow .service-switcher__stat--cta .service-switcher__stat-button {
  align-self: center;
  margin-inline: auto;
}

.home-service-hub .commercial-media-visual::before,
.home-service-hub .commercial-media-visual::after {
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.24);
}

.home-page .home-service-hub {
  color: #fff8eb;
}

.home-page .home-service-hub :is(h1, h2, h3, h4, h5, h6) {
  color: #fff8eb;
}

.home-page .home-service-hub .home-service-hub__head :is(h1, h2, h3, h4, h5, h6) {
  color: var(--green-deep);
}

.home-page .home-service-hub :is(p, li) {
  color: rgba(255, 248, 235, 0.86);
}

.home-page .home-service-hub .home-service-hub__head p {
  color: rgba(29, 49, 23, 0.72);
}

.home-page .home-service-hub [data-service-panel="floorplan"] .service-switcher__hdr-slide {
  background: #061209;
}

.home-page .home-service-hub [data-service-panel="floorplan"] .service-switcher__hdr-slide img {
  object-fit: contain;
  background: #061209;
  filter: grayscale(1) invert(1) brightness(0.94) contrast(1.2);
}

.home-page .home-service-hub [data-service-panel="floorplan"] .service-switcher__hdr-slide::after {
  background: linear-gradient(180deg, rgba(7, 14, 9, 0.01) 42%, rgba(7, 14, 9, 0.22) 100%);
}

.home-page .home-service-hub :is(#home-res-panel-floorplan, #home-com-panel-floorplan, #home-hosp-panel-floorplan) .service-switcher__hdr-slide {
  background: #f7f3eb;
}

.home-page .home-service-hub :is(#home-res-panel-floorplan, #home-com-panel-floorplan, #home-hosp-panel-floorplan) .service-switcher__hdr-slide img {
  object-fit: contain;
  background: #f7f3eb;
  filter: none;
}

.home-page .home-service-hub :is(#home-res-panel-floorplan, #home-com-panel-floorplan, #home-hosp-panel-floorplan) .service-switcher__hdr-slide::after {
  background: linear-gradient(180deg, rgba(7, 14, 9, 0.01) 52%, rgba(7, 14, 9, 0.3) 100%);
}

/* --- Metrics Ribbon --- */
.metrics-ribbon {
  padding: 28px 0 72px;
}

.metrics-ribbon__panel {
  position: relative;
  overflow: visible;
  padding: 0;
  border: none;
  border-radius: 0;
  background: none;
  box-shadow: none;
}

.metrics-ribbon__panel::before,
.metrics-ribbon__panel::after {
  content: none;
}

.metrics-ribbon__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.metrics-ribbon__item {
  position: relative;
  text-align: center;
  padding: clamp(18px, 2.4vw, 26px) clamp(12px, 1.8vw, 18px);
  border-radius: 26px;
  transition: transform 0.25s ease, background 0.25s ease;
}

.metrics-ribbon__item:hover {
  transform: translateY(-2px);
  background: transparent;
}

.metrics-ribbon__item:not(:first-child)::before {
  content: "";
  position: absolute;
  top: 18%;
  bottom: 18%;
  left: 0;
  width: 1px;
  background: rgba(14, 17, 20, 0.16);
}

.metrics-ribbon__value {
  position: relative;
  margin: 0;
  color: #101317;
  font-family: var(--font-heading);
  font-size: clamp(2.25rem, 5.4vw, 4rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.05em;
  font-variant-numeric: tabular-nums lining-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
  white-space: nowrap;
}

.metrics-ribbon__value::after {
  content: attr(data-exact);
  position: absolute;
  left: 50%;
  bottom: calc(100% + 12px);
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(10, 15, 11, 0.92);
  color: #fff7e8;
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transform: translate(-50%, 4px);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
  box-shadow: 0 14px 24px rgba(0, 0, 0, 0.16);
}

.metrics-ribbon__item:hover .metrics-ribbon__value::after {
  opacity: 1;
  visibility: visible;
  transform: translate(-50%, 0);
}

.metrics-ribbon__accent {
  display: block;
  width: min(66%, 148px);
  height: 3px;
  margin: 12px auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, #f7c66c 0%, #27b172 100%);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 0.7s cubic-bezier(0.2, 0.8, 0.2, 1), filter 0.35s ease;
  filter: saturate(0.92) brightness(0.98);
}

.metrics-ribbon__item:hover .metrics-ribbon__accent {
  filter: saturate(1.04) brightness(1);
}

.metrics-ribbon__label {
  max-width: 15ch;
  margin: 8px auto 0;
  color: rgba(14, 17, 20, 0.74);
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.45;
}

.metrics-ribbon.in-view .metrics-ribbon__item:nth-child(1) .metrics-ribbon__accent {
  transform: scaleX(1);
  transition-delay: 0s;
}

.metrics-ribbon.in-view .metrics-ribbon__item:nth-child(2) .metrics-ribbon__accent {
  transform: scaleX(1);
  transition-delay: 0.08s;
}

.metrics-ribbon.in-view .metrics-ribbon__item:nth-child(3) .metrics-ribbon__accent {
  transform: scaleX(1);
  transition-delay: 0.16s;
}

.metrics-ribbon.in-view .metrics-ribbon__item:nth-child(4) .metrics-ribbon__accent {
  transform: scaleX(1);
  transition-delay: 0.24s;
}

/* --- Process Section --- */
.process-section {
  position: relative;
  z-index: 2;
  overflow: visible;
  padding: 58px 0 clamp(22px, 2.5vw, 34px);
  background: transparent;
}

.process-section::before {
  content: none;
}

.process-section::after {
  content: none;
}

.process-section > .shell {
  position: relative;
  z-index: 1;
}

.process-section__layout {
  display: grid;
  gap: 22px;
}

.process-section__head {
  max-width: 560px;
  margin: 0 auto;
  text-align: center;
}

.process-section__head .section-label {
  justify-content: center;
}

.process-section__head h2 {
  margin: 8px auto 0;
  max-width: 14ch;
  color: var(--green-deep);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
}

.process-section__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-rows: auto;
  gap: 16px;
  align-items: start;
}

.process-section .process-card {
  display: none;
}

.process-point {
  --process-glow-a: rgba(243, 198, 109, 0.22);
  --process-glow-b: rgba(41, 98, 22, 0.14);
  --process-line: linear-gradient(90deg, rgba(243, 198, 109, 0.94) 0%, rgba(41, 98, 22, 0.82) 100%);
  position: relative;
  isolation: isolate;
  height: auto;
  min-height: 0;
  perspective: 1100px;
  transform-style: preserve-3d;
}

.process-point::before {
  content: "";
  position: absolute;
  inset: 16px;
  z-index: 0;
  border-radius: 34px;
  background:
    radial-gradient(circle at 16% 20%, var(--process-glow-a), transparent 38%),
    radial-gradient(circle at 82% 82%, var(--process-glow-b), transparent 42%);
  filter: blur(28px);
  opacity: 0.72;
  transition: opacity 220ms ease, transform 220ms ease;
  pointer-events: none;
}

.process-point--offset {
  margin-top: 0;
}

.process-point--pricing {
  --process-glow-a: rgba(243, 198, 109, 0.24);
  --process-glow-b: rgba(131, 170, 92, 0.14);
}

.process-point--scope {
  --process-glow-a: rgba(109, 164, 84, 0.18);
  --process-glow-b: rgba(243, 198, 109, 0.16);
}

.process-point--delivery {
  --process-glow-a: rgba(243, 198, 109, 0.22);
  --process-glow-b: rgba(67, 122, 72, 0.18);
}

.process-point--direct {
  --process-glow-a: rgba(125, 176, 106, 0.18);
  --process-glow-b: rgba(243, 198, 109, 0.18);
}

.process-point__tracker {
  position: absolute;
  z-index: 3;
  display: block;
  width: 20%;
  height: 20%;
}

.process-point__surface {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  height: auto;
  min-height: 0;
  padding: 22px 18px 18px;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(16, 33, 13, 0.08);
  background:
    radial-gradient(circle at 18% 18%, rgba(243, 198, 109, 0.12), transparent 22%),
    linear-gradient(145deg, rgba(255, 253, 248, 0.98) 0%, rgba(255, 255, 255, 0.98) 48%, rgba(250, 246, 238, 0.98) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 18px 34px rgba(17, 31, 16, 0.08);
  transition:
    transform 180ms ease,
    box-shadow 260ms ease,
    border-color 260ms ease,
    filter 260ms ease,
    background 260ms ease;
  transform-style: preserve-3d;
  will-change: transform;
}

.process-point__tracker:nth-child(5n + 1) { left: 0; }
.process-point__tracker:nth-child(5n + 2) { left: 20%; }
.process-point__tracker:nth-child(5n + 3) { left: 40%; }
.process-point__tracker:nth-child(5n + 4) { left: 60%; }
.process-point__tracker:nth-child(5n + 5) { left: 80%; }

.process-point__tracker:nth-child(n + 1):nth-child(-n + 5) { top: 0; }
.process-point__tracker:nth-child(n + 6):nth-child(-n + 10) { top: 20%; }
.process-point__tracker:nth-child(n + 11):nth-child(-n + 15) { top: 40%; }
.process-point__tracker:nth-child(n + 16):nth-child(-n + 20) { top: 60%; }
.process-point__tracker:nth-child(n + 21):nth-child(-n + 25) { top: 80%; }

.process-point__surface::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 4px;
  border-radius: 28px 28px 0 0;
  background: var(--process-line);
}

.process-point__surface::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.3) 0%, rgba(255, 255, 255, 0) 34%),
    radial-gradient(circle at 84% 18%, rgba(123, 165, 104, 0.12), transparent 24%);
  opacity: 0.96;
}

.process-point__surface > * {
  position: relative;
  z-index: 1;
}

.process-point__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 16px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 244, 213, 0.96), rgba(243, 198, 109, 0.2) 54%, rgba(41, 98, 22, 0.08) 100%);
  border: 1px solid rgba(196, 141, 38, 0.16);
  box-shadow: 0 12px 26px rgba(196, 141, 38, 0.12);
  color: var(--green-deep);
  transform: translateZ(34px);
  transition: transform 220ms ease, box-shadow 220ms ease, background 220ms ease, border-color 220ms ease, color 220ms ease;
}

.process-point__icon svg {
  width: 24px;
  height: 24px;
  display: block;
}

.process-point__icon path {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.process-point h3 {
  margin: 8px 0 8px;
  color: var(--green-deep);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.05rem, 1.3vw, 1.35rem);
  line-height: 1.02;
  letter-spacing: -0.03em;
  transform: translateZ(42px);
  transition: color 220ms ease;
}

.process-point p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.56;
  transform: translateZ(30px);
  transition: color 220ms ease;
}

.process-point__pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  margin-top: 12px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(196, 141, 38, 0.18);
  background: rgba(255, 248, 235, 0.78);
  color: rgba(41, 98, 22, 0.72);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-align: center;
  text-transform: uppercase;
  white-space: nowrap;
  transform: translateZ(34px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.66),
    0 10px 22px rgba(196, 141, 38, 0.1);
}

.process-point--pricing .process-point__surface,
.process-point--scope .process-point__surface,
.process-point--delivery .process-point__surface,
.process-point--direct .process-point__surface {
  align-items: center;
  text-align: center;
}

@media (hover: hover) and (pointer: fine) {
  .process-point:hover::before {
    opacity: 1;
    transform: scale(1.03);
  }

  .process-point:hover .process-point__surface {
    border-color: rgba(255, 255, 255, 0.08);
    background:
      radial-gradient(circle at 80% 14%, rgba(243, 198, 109, 0.12), transparent 24%),
      radial-gradient(circle at 18% 18%, rgba(110, 166, 86, 0.18), transparent 28%),
      linear-gradient(145deg, #16341b 0%, #102816 100%);
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.08),
      0 22px 42px rgba(7, 17, 9, 0.18);
    filter: brightness(1);
  }

  .process-point:hover .process-point__icon {
    background:
      radial-gradient(circle at 30% 30%, rgba(255, 244, 213, 0.3), rgba(243, 198, 109, 0.14) 54%, rgba(255, 255, 255, 0.04) 100%);
    border-color: rgba(243, 198, 109, 0.18);
    color: #fff2d0;
    transform: translateZ(52px) translateY(-2px);
    box-shadow: 0 12px 24px rgba(243, 198, 109, 0.08);
  }

  .process-point:hover h3 {
    color: #fff7e9;
  }

  .process-point:hover p {
    color: rgba(245, 241, 232, 0.78);
  }

  .process-point__tracker {
    cursor: pointer;
  }

  .process-point__tracker:hover ~ .process-point__surface {
    transition-duration: 125ms;
  }

  .process-point__tracker:nth-child(1):hover ~ .process-point__surface { transform: rotateX(14deg) rotateY(-12deg) translateY(-6px); }
  .process-point__tracker:nth-child(2):hover ~ .process-point__surface { transform: rotateX(14deg) rotateY(-6deg) translateY(-6px); }
  .process-point__tracker:nth-child(3):hover ~ .process-point__surface { transform: rotateX(14deg) rotateY(0deg) translateY(-6px); }
  .process-point__tracker:nth-child(4):hover ~ .process-point__surface { transform: rotateX(14deg) rotateY(6deg) translateY(-6px); }
  .process-point__tracker:nth-child(5):hover ~ .process-point__surface { transform: rotateX(14deg) rotateY(12deg) translateY(-6px); }
  .process-point__tracker:nth-child(6):hover ~ .process-point__surface { transform: rotateX(7deg) rotateY(-12deg) translateY(-6px); }
  .process-point__tracker:nth-child(7):hover ~ .process-point__surface { transform: rotateX(7deg) rotateY(-6deg) translateY(-6px); }
  .process-point__tracker:nth-child(8):hover ~ .process-point__surface { transform: rotateX(7deg) rotateY(0deg) translateY(-6px); }
  .process-point__tracker:nth-child(9):hover ~ .process-point__surface { transform: rotateX(7deg) rotateY(6deg) translateY(-6px); }
  .process-point__tracker:nth-child(10):hover ~ .process-point__surface { transform: rotateX(7deg) rotateY(12deg) translateY(-6px); }
  .process-point__tracker:nth-child(11):hover ~ .process-point__surface { transform: rotateX(0deg) rotateY(-12deg) translateY(-6px); }
  .process-point__tracker:nth-child(12):hover ~ .process-point__surface { transform: rotateX(0deg) rotateY(-6deg) translateY(-6px); }
  .process-point__tracker:nth-child(13):hover ~ .process-point__surface { transform: rotateX(0deg) rotateY(0deg) translateY(-6px); }
  .process-point__tracker:nth-child(14):hover ~ .process-point__surface { transform: rotateX(0deg) rotateY(6deg) translateY(-6px); }
  .process-point__tracker:nth-child(15):hover ~ .process-point__surface { transform: rotateX(0deg) rotateY(12deg) translateY(-6px); }
  .process-point__tracker:nth-child(16):hover ~ .process-point__surface { transform: rotateX(-7deg) rotateY(-12deg) translateY(-6px); }
  .process-point__tracker:nth-child(17):hover ~ .process-point__surface { transform: rotateX(-7deg) rotateY(-6deg) translateY(-6px); }
  .process-point__tracker:nth-child(18):hover ~ .process-point__surface { transform: rotateX(-7deg) rotateY(0deg) translateY(-6px); }
  .process-point__tracker:nth-child(19):hover ~ .process-point__surface { transform: rotateX(-7deg) rotateY(6deg) translateY(-6px); }
  .process-point__tracker:nth-child(20):hover ~ .process-point__surface { transform: rotateX(-7deg) rotateY(12deg) translateY(-6px); }
  .process-point__tracker:nth-child(21):hover ~ .process-point__surface { transform: rotateX(-14deg) rotateY(-12deg) translateY(-6px); }
  .process-point__tracker:nth-child(22):hover ~ .process-point__surface { transform: rotateX(-14deg) rotateY(-6deg) translateY(-6px); }
  .process-point__tracker:nth-child(23):hover ~ .process-point__surface { transform: rotateX(-14deg) rotateY(0deg) translateY(-6px); }
  .process-point__tracker:nth-child(24):hover ~ .process-point__surface { transform: rotateX(-14deg) rotateY(6deg) translateY(-6px); }
  .process-point__tracker:nth-child(25):hover ~ .process-point__surface { transform: rotateX(-14deg) rotateY(12deg) translateY(-6px); }
}

@media (hover: none), (pointer: coarse) {
  .process-point__tracker {
    display: none;
  }
}

/* --- Portfolio Marquee --- */
.portfolio-marquee {
  padding: 26px 0 0;
  background: #fff;
}

.portfolio-marquee__bleed {
  position: relative;
  left: 50%;
  width: 100vw;
  margin-left: -50vw;
  overflow: hidden;
  min-height: clamp(246px, 27vw, 344px);
  padding: clamp(26px, 3.4vw, 42px) 0 clamp(94px, 10vw, 146px);
  background:
    radial-gradient(circle at 16% 4%, rgba(243, 198, 109, 0.22), transparent 24%),
    radial-gradient(circle at 86% 18%, rgba(196, 141, 38, 0.16), transparent 20%),
    linear-gradient(150deg, #071407 0%, var(--green-deep) 42%, #0b1a0f 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    inset 0 -58px 92px rgba(5, 14, 7, 0.24);
}

.portfolio-marquee__bleed::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(243, 198, 109, 0.12) 0%, transparent 24%, transparent 76%, rgba(243, 198, 109, 0.08) 100%),
    linear-gradient(180deg, rgba(7, 14, 9, 0) 58%, rgba(7, 14, 9, 0.16) 100%);
}

.portfolio-marquee__bleed::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: clamp(-188px, -14vw, -126px);
  width: max(1800px, 124vw);
  height: clamp(214px, 28vw, 368px);
  transform: translateX(-50%);
  border-radius: 50% 50% 0 0 / 100% 100% 0 0;
  background: var(--portfolio-work-bg);
  box-shadow: 0 -1px 0 rgba(252, 251, 247, 0.72);
}

.portfolio-marquee__inner {
  position: relative;
  z-index: 1;
  width: min(1500px, calc(100vw - 28px));
  margin: 0 auto;
}

.portfolio-marquee__band {
  opacity: 0;
  transform: none;
  transition: opacity 0.62s ease;
  will-change: opacity;
}

.portfolio-marquee.visible .portfolio-marquee__band {
  opacity: 1;
  transform: none;
  will-change: auto;
}

.portfolio-marquee.reveal,
.selected-work.reveal {
  transform: none;
  transition: opacity 0.62s ease;
  will-change: opacity;
}

.portfolio-marquee.reveal.visible,
.selected-work.reveal.visible {
  transform: none;
  will-change: auto;
}

.portfolio-marquee__band {
  position: relative;
  left: 50%;
  width: 100vw;
  margin-left: -50vw;
  overflow: hidden;
  border-radius: 0;
  padding: 10px 0 12px;
  background: none;
  border: none;
  box-shadow: none;
}

.portfolio-marquee__band::before,
.portfolio-marquee__band::after {
  display: none;
}

.portfolio-marquee__band-track {
  display: flex;
  align-items: center;
  width: max-content;
  animation: portfolio-marquee-rail 40s linear infinite;
}

.portfolio-marquee__band-group {
  display: flex;
  align-items: center;
  gap: 28px;
  flex-shrink: 0;
  padding-right: 28px;
  white-space: nowrap;
  color: #fff3df;
  font-family: var(--font-heading);
  font-size: clamp(1.62rem, 2.06vw, 2.2rem);
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-shadow: 0 1px 0 rgba(7, 14, 9, 0.18);
}

.portfolio-marquee__separator {
  color: #f0c364;
  font-size: 0.9em;
}

.portfolio-marquee + .selected-work {
  position: relative;
  z-index: 1;
  margin-top: 0;
  padding-top: 0;
}

@media (prefers-reduced-motion: reduce) {
  .portfolio-marquee__band {
    transition: none;
  }

  .portfolio-marquee__band {
    opacity: 1;
    transform: none;
  }

  .portfolio-marquee__band-track {
    animation: none;
  }
}

@keyframes portfolio-marquee-rail {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

/* --- Selected Work --- */
.selected-work {
  display: flow-root;
  padding: 0 0 72px;
  background: var(--portfolio-work-bg);
}

.selected-work__head {
  position: relative;
  z-index: 2;
  max-width: 760px;
  margin: clamp(-112px, -9vw, -76px) auto 42px;
  text-align: center;
}

.selected-work__head h2 {
  font-size: clamp(2.6rem, 4.95vw, 4.5rem);
  color: #101b0f;
}

.selected-work__head p {
  max-width: 58ch;
  margin-left: auto;
  margin-right: auto;
}

.selected-work__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: auto auto;
  gap: 16px;
}

.work-card {
  position: relative;
  margin: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--ease), box-shadow var(--ease);
}

.work-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.work-card img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 4 / 3;
}

.work-card--wide {
  grid-column: span 2;
}

.work-card--wide img {
  aspect-ratio: 16 / 9;
}

.home-page .selected-work__grid,
.page-real-estate .selected-work__grid,
.page-commercial .selected-work__grid,
.page-hospitality .selected-work__grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-rows: none;
  gap: 18px;
}

.home-page .work-card,
.page-real-estate .work-card,
.page-commercial .work-card,
.page-hospitality .work-card {
  aspect-ratio: 3 / 2;
}

.home-page .work-card img,
.page-real-estate .work-card img,
.page-commercial .work-card img,
.page-hospitality .work-card img {
  aspect-ratio: auto;
}

.home-page .work-card img,
body.page-real-estate .work-card img,
body.page-commercial .work-card img,
body.page-hospitality .work-card img {
  object-fit: contain;
  background: #0a120c;
}

.home-page .work-card[data-work-industry="commercial"],
body.page-commercial .work-card,
body.page-hospitality .work-card {
  align-self: start;
  aspect-ratio: auto;
  background: transparent;
}

.home-page .work-card[data-work-industry="commercial"] img,
body.page-commercial .work-card img,
body.page-hospitality .work-card img {
  height: auto;
  aspect-ratio: auto;
  object-fit: initial;
  background: transparent;
}

.work-card figcaption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 16px 20px;
  background: linear-gradient(0deg, rgba(7, 17, 8, 0.85) 0%, transparent 100%);
  transform: translateY(100%);
  transition: transform 0.3s ease;
}

.work-card:hover figcaption {
  transform: translateY(0);
}

.work-card figcaption strong {
  display: block;
  color: #fff;
  font-size: 0.92rem;
  font-weight: 700;
}

.work-card figcaption span {
  color: rgba(245, 241, 232, 0.7);
  font-size: 0.8rem;
}

/* --- FAQ (homepage override — glassmorphic cards) --- */
.home-page .faq {
  padding: clamp(44px, 5vw, 58px) 0;
  background: none;
  border: none;
  box-shadow: none;
  border-radius: 0;
  margin-bottom: 0;
}

.home-page .faq .section-head {
  max-width: 52rem;
  margin-bottom: 28px;
  margin-right: auto;
  margin-left: auto;
  text-align: center;
}

.home-page .faq .section-head .section-label {
  justify-content: center;
  width: 100%;
}

.home-page .faq .faq__list {
  display: grid;
  gap: 10px;
}

.home-page .faq .faq-item.glass-card {
  border-bottom: none;
  padding: 0;
}

.home-page .faq .faq-item.glass-card .faq-item__question {
  padding: 18px 22px;
}

.home-page .faq .faq-item.glass-card .faq-item__answer {
  padding: 0 22px;
}

.home-page .faq .faq-item.glass-card .faq-item__answer p {
  padding-bottom: 18px;
}

/* --- CTA Banner --- */
.cta-banner {
  position: relative;
  overflow: hidden;
  padding: 84px 0;
  background:
    radial-gradient(circle at 16% 4%, rgba(243, 198, 109, 0.28), transparent 24%),
    radial-gradient(circle at 86% 18%, rgba(196, 141, 38, 0.2), transparent 20%),
    linear-gradient(150deg, #071407 0%, var(--green-deep) 42%, #0b1a0f 100%);
}

.cta-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(243, 198, 109, 0.12) 0%, transparent 24%, transparent 76%, rgba(243, 198, 109, 0.08) 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0) 42%);
}

.cta-banner__inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(340px, 0.78fr);
  align-items: center;
  gap: 34px;
  padding: 34px;
  border-radius: 34px;
  border: 1px solid rgba(243, 198, 109, 0.2);
  background:
    radial-gradient(circle at 4% 10%, rgba(243, 198, 109, 0.22), transparent 30%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.05) 0%, rgba(255, 255, 255, 0.02) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 28px 70px rgba(2, 8, 4, 0.28);
}

.cta-banner__inner h2 {
  margin: 0;
  max-width: 18ch;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.7rem, 3vw, 2.6rem);
  line-height: 1.06;
  letter-spacing: -0.04em;
  color: #fff;
}

.cta-banner__inner p {
  margin: 14px 0 0;
  max-width: 62ch;
  color: rgba(245, 241, 232, 0.72);
  line-height: 1.6;
}

.section-label--gold {
  color: var(--gold);
}

.cta-banner__actions {
  display: flex;
  gap: 14px;
  flex-shrink: 0;
  flex-wrap: wrap;
}

.cta-banner__copy {
  display: grid;
  align-content: center;
  text-align: center;
}

.cta-banner__copy .section-label {
  justify-self: center;
}

.cta-banner__copy h2 {
  margin-left: auto;
  margin-right: auto;
}

.cta-banner__intake {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 24px;
}

.cta-banner__intake span {
  display: grid;
  align-content: center;
  justify-items: center;
  min-height: 108px;
  padding: 16px;
  border-radius: 8px;
  border: 1px solid rgba(243, 198, 109, 0.22);
  text-align: center;
  background:
    radial-gradient(circle at 84% 12%, rgba(243, 198, 109, 0.18), transparent 32%),
    rgba(255, 255, 255, 0.055);
}

.cta-banner__intake strong,
.cta-banner__intake small {
  display: block;
}

.cta-banner__intake strong {
  color: var(--gold);
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.cta-banner__intake small {
  margin-top: 8px;
  color: rgba(245, 241, 232, 0.74);
  font-size: 0.86rem;
  line-height: 1.45;
}

.cta-banner__handoff {
  display: grid;
  justify-items: center;
  padding: 24px;
  border-radius: 24px;
  border: 1px solid rgba(243, 198, 109, 0.24);
  text-align: center;
  background:
    radial-gradient(circle at 100% 0%, rgba(243, 198, 109, 0.2), transparent 32%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.11), rgba(255, 255, 255, 0.055));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 22px 48px rgba(0, 0, 0, 0.22);
}

.cta-banner__handoff .cta-banner__handoff-label {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(243, 198, 109, 0.14);
  color: var(--gold);
  line-height: 1;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.cta-banner__handoff ul {
  display: grid;
  gap: 12px;
  width: 100%;
  margin-top: 18px;
}

.cta-banner__handoff li {
  display: grid;
  justify-items: center;
  gap: 4px;
  padding: 0 0 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.09);
}

.cta-banner__handoff li:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.cta-banner__handoff strong {
  color: #fff8e8;
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 800;
}

.cta-banner__handoff span {
  color: rgba(245, 241, 232, 0.72);
  font-size: 0.9rem;
  line-height: 1.45;
}

.cta-banner__handoff .cta-banner__actions {
  margin-top: 22px;
  justify-content: center;
}

/* --- Nav dropdown (new) --- */
.nav__dropdown {
  position: relative;
}

.nav__dropdown-trigger {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0;
  color: rgba(245, 241, 232, 0.88);
}

.nav.scrolled .nav__dropdown-trigger {
  color: var(--green-deep);
}

.nav__dropdown-trigger:hover,
.nav__dropdown.open .nav__dropdown-trigger {
  color: #fff;
}

.nav.scrolled .nav__dropdown-trigger:hover,
.nav.scrolled .nav__dropdown.open .nav__dropdown-trigger {
  color: var(--green);
}

.nav__caret {
  font-size: 0.7em;
  transition: transform var(--ease);
}

.nav__dropdown-menu {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  min-width: 260px;
  padding: 10px 0;
  margin-top: 12px;
  background: rgba(255, 253, 248, 0.96);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--ease), visibility var(--ease);
}

.nav__dropdown.open .nav__dropdown-menu {
  opacity: 1;
  visibility: visible;
}

.nav__dropdown.open .nav__caret {
  transform: rotate(180deg);
}

.nav__dropdown.open .nav__link::after {
  width: 100%;
}

.nav__dropdown-menu a {
  display: block;
  padding: 12px 20px;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--green-deep);
  letter-spacing: 0.01em;
  white-space: nowrap;
  transition: background var(--ease), color var(--ease);
}

.nav__dropdown-menu a:hover {
  background: var(--gold-soft);
  color: var(--gold);
}

/* Mobile nav helpers */
.nav__mobile-label {
  display: block;
  padding: 0.4rem 0 0.05rem;
  font-size: 1.14rem;
  font-weight: 850;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--white-on-dark);
  opacity: 1;
}

.nav__link--indent {
  padding-left: 0 !important;
  font-size: 1rem;
}

.nav__mobile .nav__cta {
  display: inline-flex;
  margin-top: 1rem !important;
  min-width: 214px;
  justify-content: center;
}

.section-anchor {
  display: block;
  height: 0;
  scroll-margin-top: 120px;
}

/* ============================================================
   HOMEPAGE RESPONSIVE
   ============================================================ */

@media (max-width: 1024px) {
  .nav__inner {
    padding: 11px 16px;
  }

  .hero--home {
    min-height: clamp(620px, 80svh, 760px);
    padding-top: 100px;
  }

  .operator-proof__panel {
    padding: 20px;
  }

  .operator-proof__layout {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .operator-proof__intro h2 {
    max-width: 12ch;
  }

  .operator-proof__signals {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .operator-proof__featured {
    padding: 18px;
  }

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

  .metrics-ribbon__item:not(:first-child)::before {
    display: none;
  }

  .metrics-ribbon__item:nth-child(even)::before {
    display: block;
  }

  .metrics-ribbon__item:nth-child(n+3)::after {
    content: "";
    position: absolute;
    top: 0;
    left: 14%;
    right: 14%;
    height: 1px;
    background: rgba(14, 17, 20, 0.16);
  }

  .process-section__layout {
    gap: 22px;
  }

  .process-section__head h2 {
    max-width: 14ch;
  }

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

  .cta-banner__inner {
    grid-template-columns: 1fr;
    text-align: left;
  }

  .cta-banner__actions {
    justify-content: flex-start;
  }
}

@media (max-width: 768px) {
  .nav {
    padding-top: 14px;
  }

  .nav__inner {
    padding: 11px 14px;
    border-radius: 28px;
  }

  .nav__brand {
    gap: 6px;
  }

  .nav__brand-mark {
    width: 48px;
    height: 28px;
    top: 4px;
  }

  .nav__brand-mark img {
    width: 60px;
    transform: translate(-6px, -4px) translateZ(0);
  }

  .nav__wordmark {
    width: 150px;
    top: 5px;
    left: 0;
  }

  .cta-banner {
    padding: 56px 0;
  }

  .cta-banner__inner {
    padding: 24px;
    border-radius: 28px;
  }

  .cta-banner__intake {
    grid-template-columns: 1fr;
  }

  .hero--home {
    min-height: auto;
    gap: 20px;
    padding: 104px 0 24px;
    align-content: end;
  }

  .industry-hero {
    min-height: auto;
    gap: 20px;
    padding: 104px 0 24px;
    align-content: end;
  }

  .industry-hero--residential {
    gap: 12px;
    padding-top: 82px;
    align-content: start;
  }

  .industry-hero--residential .hero__content {
    padding-top: 0;
  }

  .hero__intro {
    margin-bottom: 22px;
  }

  .hero__title {
    font-size: clamp(2.3rem, 10vw, 3.9rem);
  }

  .industry-hero--residential .hero__eyebrow {
    min-height: 32px;
    padding: 0 18px;
    font-size: 0.68rem;
  }

  .industry-hero--residential .hero__title {
    font-size: clamp(2.15rem, 5.6vw, 2.55rem);
  }

  .industry-hero--residential .hero__intro {
    margin-bottom: 10px;
  }

  .hero__sub {
    width: min(100%, 32ch);
    max-width: 32ch;
  }

  .hero__rating {
    gap: 10px;
    padding: 10px 16px;
  }

  .hero__rating-google svg {
    width: 17px;
    height: 17px;
  }

  .hero__metrics {
    grid-template-columns: 1fr;
    max-width: 380px;
    gap: 10px;
    padding-bottom: 8px;
  }

  .hero__metric {
    padding: 16px;
  }

  .industry-hero .hero__metric {
    min-height: 0;
  }

  .logo-band__grid--center {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .logo-band--matterport-platforms {
    margin-top: 32px;
    padding: 6px 0 30px;
  }

  .logo-band--matterport-platforms .logo-band__group {
    gap: 28px;
    padding-right: 28px;
  }

  .logo-band--matterport-platforms .logo-band__logo--platform {
    --logo-width: 176px;
    --platform-logo-height: 30px;
    min-height: 52px;
  }

  .logo-band--matterport-platforms .logo-band__logo--platform-zumper {
    --platform-logo-height: 39px;
  }

  .logo-band--matterport-platforms .logo-band__logo--platform-crexi {
    --platform-logo-height: 32px;
  }

  .logo-band--matterport-platforms .logo-band__logo--platform-showcase {
    --platform-logo-height: 30px;
  }

  .logo-band--matterport-platforms .logo-band__logo--platform-brevitas {
    --platform-logo-height: 34px;
  }

  .operator-proof {
    padding: 18px 0 12px;
  }

  .operator-proof__panel {
    padding: 18px;
  }

  .operator-proof__intro {
    margin-bottom: 0;
  }

  .operator-proof__layout {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .operator-proof__intro h2 {
    max-width: 12ch;
    font-size: clamp(1.8rem, 7vw, 2.4rem);
  }

  .operator-proof__intro p,
  .operator-proof__featured p {
    font-size: 0.9rem;
  }

  .operator-proof__featured {
    padding: 16px;
    border-radius: 24px;
  }

  .operator-proof__featured h3 {
    font-size: 1.2rem;
  }

  .operator-proof__signals {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .operator-proof__signal {
    padding: 11px 12px 12px;
  }

  .operator-proof__trust {
    gap: 6px;
  }

  .operator-proof__trust span {
    font-size: 0.68rem;
  }

  .operator-proof__signal span {
    font-size: 0.76rem;
  }

  .industry-routing__grid {
    grid-template-columns: 1fr;
  }

  .home-service-hub {
    margin-top: 0;
    padding: 24px 0 72px;
  }

  .home-service-hub__industries {
    border-radius: 28px;
  }

  .industry-tile {
    min-height: 200px;
  }

  .industry-tile__content {
    position: absolute;
    top: 50%;
    left: 50%;
    width: min(calc(100% - 44px), 20rem);
    min-height: auto;
    padding: 0;
    transform: translate(-50%, -50%);
  }

  .industry-tile--hospitality .industry-tile__content {
    transform: translate(-50%, -50%);
  }

  .portfolio-marquee {
    padding-top: 20px;
  }

  .portfolio-marquee__bleed {
    min-height: clamp(228px, 31vw, 304px);
    padding-bottom: clamp(82px, 12vw, 126px);
  }

  .portfolio-marquee__band {
    padding: 12px 0 14px;
  }

  .portfolio-marquee + .selected-work {
    margin-top: 0;
  }

  .selected-work__head {
    margin-top: clamp(-84px, -8vw, -52px);
    margin-bottom: 34px;
  }

  .metrics-ribbon__grid {
    grid-template-columns: 1fr 1fr;
  }

  .metrics-ribbon__panel {
    padding: 0;
    border-radius: 0;
  }

  .metrics-ribbon__item {
    padding: 18px 12px;
  }

  .metrics-ribbon__value {
    font-size: clamp(2.05rem, 8.5vw, 3rem);
  }

  .process-section__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  .process-section__head h2 {
    font-size: clamp(1.7rem, 7vw, 2.2rem);
  }

  .process-point__surface {
    padding: 18px 14px 14px;
    border-radius: 24px;
  }

  .process-point__icon {
    width: 42px;
    height: 42px;
    border-radius: 14px;
  }

  .process-point h3,
  .process-point--hero h3 {
    font-size: 1rem;
  }

  .process-point p {
    font-size: 0.82rem;
    line-height: 1.5;
  }

  .selected-work__grid {
    grid-template-columns: 1fr 1fr;
  }

  .home-page .selected-work__grid,
  .page-real-estate .selected-work__grid,
  .page-commercial .selected-work__grid,
  .page-hospitality .selected-work__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .work-card--wide {
    grid-column: span 2;
  }

  .work-card figcaption {
    transform: translateY(0);
  }
}

@media (max-width: 480px) {
  .nav__inner {
    padding: 10px 12px;
    border-radius: 24px;
  }

  .nav__brand-mark {
    width: 42px;
    height: 25px;
    top: 4px;
  }

  .nav__brand-mark img {
    width: 53px;
    transform: translate(-5px, -3px) translateZ(0);
  }

  .nav__wordmark {
    width: 140px;
    top: 5px;
    left: 0;
  }

  .cta-banner__handoff {
    padding: 20px;
    border-radius: 20px;
  }

  .cta-banner__actions .btn {
    width: auto;
    min-width: min(100%, 210px);
  }

  .hero__eyebrow {
    min-height: 38px;
    padding: 0 16px;
    font-size: 0.68rem;
    letter-spacing: 0.13em;
  }

  .hero__title {
    font-size: clamp(2.05rem, 9.5vw, 3rem);
  }

  .hero__sub {
    font-size: 0.98rem;
  }

  .hero__rating {
    flex-wrap: wrap;
    justify-content: center;
  }

  .hero__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .hero__actions .btn {
    width: 100%;
  }

  .hero__metrics {
    max-width: 100%;
    padding-bottom: 24px;
  }

  .logo-band__grid--center {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .selected-work__grid {
    grid-template-columns: 1fr;
  }

  .home-page .selected-work__grid,
  .page-real-estate .selected-work__grid,
  .page-commercial .selected-work__grid,
  .page-hospitality .selected-work__grid {
    grid-template-columns: 1fr;
  }

  .work-card--wide {
    grid-column: span 1;
  }

  .work-card--wide img {
    aspect-ratio: 4 / 3;
  }

  .portfolio-marquee {
    padding-top: 16px;
  }

  .portfolio-marquee__bleed {
    min-height: clamp(214px, 58vw, 236px);
    padding: clamp(42px, 11vw, 50px) 0 clamp(66px, 17vw, 76px);
  }

  .portfolio-marquee__bleed::after {
    bottom: -78px;
    width: 156vw;
    height: 156px;
  }

  .portfolio-marquee__band {
    padding: 14px 0 16px;
  }

  .portfolio-marquee__band-group {
    gap: 22px;
    padding-right: 22px;
    font-size: clamp(1.5rem, 6.4vw, 1.72rem);
    line-height: 1;
    letter-spacing: 0.075em;
  }

  .portfolio-marquee__separator {
    font-size: 0.82em;
  }

  .portfolio-marquee + .selected-work {
    margin-top: 0;
  }

  .selected-work__head {
    margin-top: -28px;
  }

  .selected-work__head h2 {
    font-size: clamp(2.2rem, 9.4vw, 3.1rem);
  }

  .selected-work__head p {
    font-size: 0.96rem;
  }

  .metrics-ribbon__grid {
    grid-template-columns: 1fr 1fr;
  }

  .metrics-ribbon__item:nth-child(even)::before {
    display: block;
  }

  .metrics-ribbon__item:nth-child(n+2)::after {
    content: none;
  }

  .metrics-ribbon__item:nth-child(n+3)::after {
    content: "";
    position: absolute;
    top: 0;
    left: 12%;
    right: 12%;
    height: 1px;
    background: rgba(14, 17, 20, 0.16);
  }

  .metrics-ribbon__panel {
    padding: 0;
    border-radius: 0;
  }

  .metrics-ribbon__item {
    padding: 17px 10px;
  }

  .metrics-ribbon__value {
    font-size: clamp(2rem, 11vw, 2.8rem);
  }

  .metrics-ribbon__value::after {
    display: none;
  }

  .home-service-hub__industries,
  .home-service-hub .service-switcher__tabs {
    width: 100%;
    padding: 8px;
    border-radius: 24px;
  }

  .home-service-hub__industry-tab,
  .home-service-hub .service-switcher__tab {
    min-height: 42px;
    padding: 8px 14px 14px;
    font-size: 0.74rem;
    letter-spacing: 0.09em;
  }

  .home-service-hub .service-switcher__tab {
    flex-basis: 100%;
  }

  .home-service-hub__industry-tab {
    padding: 8px 14px;
  }
}

@media (max-width: 380px) {
  .metrics-ribbon__grid {
    grid-template-columns: 1fr;
  }

  .metrics-ribbon__item:nth-child(even)::before {
    display: none;
  }

  .metrics-ribbon__item:nth-child(n+2)::after {
    content: "";
    position: absolute;
    top: 0;
    left: 12%;
    right: 12%;
    height: 1px;
    background: rgba(14, 17, 20, 0.16);
  }

  .home-service-hub__industry-tab,
  .home-service-hub .service-switcher__tab {
    font-size: 0.7rem;
    letter-spacing: 0.08em;
  }
}
