.home-page {
  --home-bg: color-mix(in srgb, var(--background-color), var(--default-color) 3%);
  --home-line: color-mix(in srgb, var(--default-color), transparent 88%);
  --home-line-soft: color-mix(in srgb, var(--default-color), transparent 92%);
  --intro-panel-divider: var(--home-line);
  --intro-panel-line-soft: var(--home-line-soft);
  --home-red-soft: color-mix(in srgb, var(--accent-color), white 92%);
  --home-red-deep: color-mix(in srgb, var(--accent-color), #000000 14%);
  --home-shadow: 0 24px 60px color-mix(in srgb, var(--default-color), transparent 88%);
  --page-bg: var(--home-bg);
  --page-red-soft: var(--home-red-soft);
  --page-hero-image: url("/assets/img/cabinet/jonathan-client-home.webp");
  --page-hero-position: center 24%;
  --page-hero-copy-max: 940px;
  --page-hero-h1-max: 19ch;
  --page-hero-title-size: clamp(3rem, 5.15vw, 5.2rem);
  --page-hero-lead-size: 1.18rem;
}

@media (max-width: 991.98px) {
  .home-page {
    --page-hero-position: 64% 22%;
  }
}

@media (max-width: 575.98px) {
  .home-page {
    --page-hero-position: 68% 20%;
  }
}

.home-page .method-frame,
.home-page .territory-frame {
  position: relative;
  border-radius: 30px;
  background: linear-gradient(135deg, var(--surface-color) 0%, color-mix(in srgb, var(--surface-color), var(--accent-color) 2%) 100%);
  box-shadow: var(--home-shadow);
  overflow: hidden;
}

.home-page .method-heading,
.home-page .section-head,
.home-page .territory-copy,
.home-page .cta-copy {
  position: relative;
  z-index: 1;
}

.home-page .method-heading h2,
.home-page .section-head h2,
.home-page .territory-copy h2,
.home-page .cta-copy h2 {
  margin: 0.9rem 0 0;
  font-size: clamp(2rem, 4vw, 3.3rem);
  line-height: 1.06;
  letter-spacing: -0.03em;
}

.home-page .intro-grid,
.home-page .intro-feature-grid,
.home-page .intro-missions {
  position: relative;
  z-index: 1;
}

.home-page .intro-grid {
  display: grid;
  gap: 1.6rem;
  align-items: start;
  margin-top: 1.45rem;
}

.home-page .intro-story {
  max-width: 60rem;
}

.home-page .intro-story p {
  margin: 0;
  color: color-mix(in srgb, var(--default-color), var(--heading-color) 24%);
  line-height: 1.82;
}

.home-page .intro-story p + p {
  margin-top: 1rem;
}

.home-page .intro-founder {
  padding: 1.35rem 1.35rem 1.25rem;
  border: 1px solid var(--home-line);
  border-radius: 24px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface-color), var(--accent-color) 2%) 0%, #ffffff 100%);
}

.home-page .intro-founder h3,
.home-page .intro-video-head h3,
.home-page .intro-team-block h3,
.home-page .intro-missions-heading h3 {
  margin: 0.7rem 0 0;
  font-size: clamp(1.5rem, 2.2vw, 2.15rem);
  line-height: 1.1;
  letter-spacing: -0.03em;
}

.home-page .intro-founder p,
.home-page .intro-video-head p,
.home-page .intro-team-block > p,
.home-page .intro-missions-heading p {
  margin: 0.95rem 0 0;
  color: color-mix(in srgb, var(--default-color), var(--heading-color) 24%);
  line-height: 1.8;
}

.home-page .intro-founder-facts,
.home-page .intro-missions-list {
  margin: 1.2rem 0 0;
  padding: 0;
  list-style: none;
}

.home-page .intro-founder-facts {
  display: grid;
  gap: 0.75rem;
}

.home-page .intro-founder-facts li {
  position: relative;
  padding-left: 1.3rem;
  color: var(--heading-color);
  line-height: 1.65;
}

.home-page .intro-founder-facts li::before {
  content: "";
  position: absolute;
  top: 0.62rem;
  left: 0;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: var(--accent-color);
  box-shadow: 0 0 0 6px color-mix(in srgb, var(--accent-color), transparent 88%);
}

.home-page .intro-feature-grid {
  display: grid;
  gap: 1.5rem;
  margin-top: 1.9rem;
  padding-top: 1.8rem;
  border-top: 1px solid var(--home-line);
}

.home-page .intro-visual {
  position: relative;
  overflow: hidden;
  margin: 1.6rem 0 0;
  border-radius: 28px;
  border: 1px solid var(--home-line-soft);
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface-color), #f7f4ee 24%) 0%, color-mix(in srgb, var(--surface-color), #dbd6ce 12%) 100%);
  box-shadow: var(--home-shadow);
}

.home-page .intro-visual img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  object-position: center center;
}

.home-page .intro-visual figcaption {
  display: grid;
  gap: 0.35rem;
  padding: 1rem 1.1rem 1.05rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0.92) 100%);
}

.home-page .intro-visual-label {
  color: var(--accent-color);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-page .intro-visual-note {
  color: color-mix(in srgb, var(--default-color), var(--heading-color) 24%);
  line-height: 1.72;
}

.home-page .intro-video-block,
.home-page .intro-team-block {
  display: grid;
  align-content: start;
}

.home-page .intro-video-placeholder {
  position: relative;
  overflow: hidden;
  min-height: 360px;
  margin-top: 1.2rem;
  border-radius: 28px;
  box-shadow: var(--home-shadow);
}

.home-page .intro-video-placeholder::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(17, 17, 17, 0.06) 0%, rgba(17, 17, 17, 0.2) 36%, rgba(17, 17, 17, 0.74) 100%);
}

.home-page .intro-video-placeholder img {
  width: 100%;
  height: 100%;
  min-height: 360px;
  object-fit: cover;
}

.home-page .intro-video-overlay {
  position: absolute;
  right: 1.4rem;
  bottom: 1.35rem;
  left: 1.4rem;
  z-index: 1;
  max-width: 32ch;
  color: #ffffff;
}

.home-page .intro-video-badge {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 0.85rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(8px);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-page .intro-video-overlay strong {
  display: block;
  margin-top: 0.95rem;
  font-size: clamp(1.4rem, 2.3vw, 2rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.home-page .intro-video-overlay p {
  margin: 0.85rem 0 0;
  color: rgba(255, 255, 255, 0.86);
  line-height: 1.72;
}

.home-page .intro-team-list {
  display: grid;
  gap: 1rem;
  margin-top: 1.35rem;
}

.home-page .team-item {
  padding-top: 1rem;
  border-top: 1px solid var(--home-line);
}

.home-page .team-item strong {
  display: block;
  color: var(--heading-color);
  font-size: 1.02rem;
}

.home-page .team-item span {
  display: block;
  margin-top: 0.28rem;
  color: var(--accent-color);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-page .team-item p {
  margin: 0.75rem 0 0;
  color: color-mix(in srgb, var(--default-color), var(--heading-color) 24%);
  line-height: 1.78;
}

.home-page .intro-missions {
  margin-top: 1.95rem;
  padding-top: 1.8rem;
  border-top: 1px solid var(--home-line);
}

.home-page .intro-missions-list {
  display: grid;
  gap: 0.75rem 1.2rem;
}

.home-page .intro-missions-list li {
  position: relative;
  padding: 0.9rem 0 0.9rem 1.7rem;
  border-bottom: 1px solid var(--home-line-soft);
  color: var(--heading-color);
  line-height: 1.72;
}

.home-page .intro-missions-list li::before {
  content: "";
  position: absolute;
  top: 1.28rem;
  left: 0;
  width: 0.85rem;
  height: 2px;
  border-radius: 999px;
  background: var(--accent-color);
}

.home-page .section-head {
  max-width: 780px;
  margin-bottom: 2rem;
}

.home-page .section-head p,
.home-page .territory-copy p,
.home-page .method-step p {
  margin: 1rem 0 0;
  color: color-mix(in srgb, var(--default-color), var(--heading-color) 24%);
  line-height: 1.85;
}

.home-page .service-stripe {
  display: grid;
  gap: 2rem;
  align-items: start;
  margin-top: 2rem;
  padding: 2rem 0;
  border-top: 1px solid var(--home-line);
}

.home-page .proof-label {
  display: inline-block;
  color: var(--brand-red-ink);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-page .service-stripe:last-child {
  border-bottom: 1px solid var(--home-line);
}

.home-page .service-stripe-media {
  --service-media-position: 50% 50%;
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 28px;
  box-shadow: var(--home-shadow);
  aspect-ratio: 4 / 3;
  min-height: 300px;
  background: linear-gradient(180deg, #f4f0ea 0%, #e8e1d7 100%);
}

.home-page .service-stripe-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: var(--service-media-position);
}

.home-page .service-stripe-media img[src*="preview"] {
  object-fit: contain;
  padding: 1rem;
  background: linear-gradient(180deg, #f8f8f8 0%, #ececec 100%);
}

.home-page .service-stripe--foncier .service-stripe-media {
  --service-media-position: 50% 52%;
}

.home-page .service-stripe--topographie .service-stripe-media {
  --service-media-position: 50% 50%;
}

.home-page .service-stripe--implantation .service-stripe-media {
  --service-media-position: 50% 44%;
}

.home-page .service-stripe--copropriete .service-stripe-media {
  --service-media-position: 50% 40%;
}

.home-page .service-stripe--scanner-3d .service-stripe-media {
  --service-media-position: 50% 38%;
}

.home-page .service-stripe-body {
  max-width: 720px;
}

.home-page .service-stripe-heading {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: start;
  margin-bottom: 1rem;
}

.home-page .service-number {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  min-height: 72px;
  padding: 0;
  font-size: clamp(2.6rem, 4.6vw, 4.2rem);
  font-weight: 800;
  line-height: 0.9;
  letter-spacing: -0.05em;
  color: var(--accent-color);
  border-right: 1px solid color-mix(in srgb, var(--accent-color), transparent 78%);
}

.home-page .service-stripe-title-group {
  position: relative;
  padding-top: 0.35rem;
}

.home-page .service-subtitle {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 0.8rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent-color), white 93%);
  color: var(--accent-color);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-page .service-stripe-title-group h3 {
  margin: 0.7rem 0 0;
  font-size: clamp(1.9rem, 3vw, 2.85rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.home-page .service-stripe-body p {
  margin: 0;
  color: color-mix(in srgb, var(--default-color), var(--heading-color) 24%);
  line-height: 1.9;
}

.home-page .service-points {
  display: grid;
  gap: 0.55rem;
  margin: 1.15rem 0 1.3rem;
  padding: 0;
  list-style: none;
}

.home-page .service-points li {
  position: relative;
  padding: 0.72rem 0 0.72rem 2rem;
  border-bottom: 1px solid var(--home-line-soft);
  color: var(--heading-color);
  line-height: 1.62;
}

.home-page .service-points li:last-child {
  border-bottom: 0;
}

.home-page .service-points li::before {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.15rem;
  height: 1.15rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent-color), white 90%);
  color: var(--accent-color);
  font-size: 0.64rem;
  font-weight: 800;
  transform: translateY(-50%);
}

.home-page .service-link {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  color: var(--heading-color);
  font-weight: 700;
  text-decoration: none;
}

.home-page .service-link:hover {
  color: var(--accent-color);
}

.home-page .service-link i {
  transition: transform 0.25s ease;
}

.home-page .service-link:hover i {
  transform: translateX(4px);
}

.home-page .method-frame {
  position: relative;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.home-page .method-heading {
  max-width: 760px;
  margin-bottom: 2rem;
}

.home-page .method-grid {
  display: grid;
  gap: 1.4rem;
  margin-top: 0;
}

.home-page .method-step {
  position: relative;
  padding: 1.35rem 1.1rem 0 0;
  border: 0;
  border-top: 1px solid color-mix(in srgb, var(--accent-color), transparent 78%);
  background: transparent;
}

.home-page .method-number {
  display: block;
  margin-bottom: 0.9rem;
  color: var(--accent-color);
  font-size: clamp(2.6rem, 4vw, 3.8rem);
  font-weight: 800;
  letter-spacing: -0.05em;
  line-height: 0.88;
}

.home-page .method-step h3 {
  margin: 0;
  max-width: 14ch;
  font-size: clamp(1.25rem, 2vw, 1.55rem);
  line-height: 1.12;
  letter-spacing: -0.02em;
}

.home-page .method-step p {
  max-width: 34ch;
}

@media (min-width: 992px) {
  .home-page .method-grid {
    position: relative;
    align-items: start;
  }

  .home-page .method-grid::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: color-mix(in srgb, var(--accent-color), transparent 86%);
  }

  .home-page .method-step {
    padding-top: 1.6rem;
  }

  .home-page .method-step:not(:first-child) {
    padding-left: 1.6rem;
  }

  .home-page .method-step:not(:first-child)::before {
    content: "";
    position: absolute;
    top: 1.35rem;
    left: 0;
    bottom: 0;
    width: 1px;
    background: var(--home-line-soft);
  }
}

.home-page .territory-frame {
  display: grid;
  align-items: stretch;
  gap: 2.4rem;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}

.home-page .territory-copy {
  display: grid;
  align-content: start;
  padding: 0.5rem 0;
}

.home-page .territory-copy h2 {
  max-width: 14ch;
  margin-bottom: 1rem;
}

.home-page .territory-copy > p {
  max-width: 62ch;
  margin-bottom: 0;
  color: color-mix(in srgb, var(--default-color), var(--heading-color) 14%);
  font-size: 1.02rem;
  line-height: 1.78;
}

.home-page .territory-contact {
  display: grid;
  gap: 1rem 1.4rem;
  margin-top: 1.9rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--home-line);
}

.home-page .territory-contact-item {
  padding-left: 1.1rem;
  border-left: 2px solid color-mix(in srgb, var(--accent-color), white 74%);
}

.home-page .territory-contact span {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--accent-color);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-page .territory-contact strong {
  color: var(--heading-color);
  line-height: 1.7;
  font-size: 1rem;
}

.home-page .territory-zones-block {
  margin-top: 1.9rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--home-line);
}

.home-page .territory-zones-label {
  display: inline-block;
  margin-bottom: 1rem;
  color: color-mix(in srgb, var(--default-color), var(--heading-color) 34%);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-page .territory-zones {
  display: grid;
  gap: 0.55rem 1.2rem;
}

.home-page .zone-link {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  min-height: 46px;
  gap: 0.85rem;
  padding: 0.2rem 0;
  border-bottom: 1px solid var(--home-line-soft);
  color: var(--heading-color);
  text-decoration: none;
}

.home-page .zone-link span {
  flex: 1;
  font-weight: 600;
}

.home-page .zone-link i {
  font-size: 0.95rem;
  color: color-mix(in srgb, var(--heading-color), transparent 44%);
  transition: transform 0.25s ease, color 0.25s ease;
}

.home-page .zone-link:hover {
  color: var(--accent-color);
}

.home-page .zone-link:hover i {
  color: var(--accent-color);
  transform: translate(3px, -2px);
}

.home-page .territory-media {
  position: relative;
  overflow: hidden;
  min-height: 100%;
  border-radius: 30px;
  box-shadow: var(--home-shadow);
}

.home-page .territory-media picture {
  display: block;
  height: 100%;
}

.home-page .territory-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(17, 17, 17, 0.04) 0%, rgba(17, 17, 17, 0.16) 38%, rgba(17, 17, 17, 0.72) 100%);
  pointer-events: none;
}

.home-page .territory-media img {
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
}

.home-page .territory-overlay {
  position: absolute;
  right: 1.5rem;
  bottom: 1.45rem;
  left: 1.5rem;
  z-index: 1;
  max-width: 28ch;
  color: #ffffff;
}

.home-page .territory-overlay-kicker {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 0.85rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(8px);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-page .territory-overlay strong {
  display: block;
  margin-top: 0.95rem;
  font-size: clamp(1.5rem, 2.4vw, 2.2rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
  text-shadow: 0 10px 28px rgba(0, 0, 0, 0.28);
}

.home-page .territory-overlay p {
  max-width: 30ch;
  margin: 0.7rem 0 0;
  color: rgba(255, 255, 255, 0.84);
  line-height: 1.65;
}

@media (min-width: 992px) {
  .home-page .intro-grid {
    grid-template-columns: minmax(0, 1.45fr) minmax(300px, 0.95fr);
  }

  .home-page .intro-feature-grid {
    grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.82fr);
    align-items: start;
  }

  .home-page .intro-team-block {
    padding-left: 1.5rem;
    border-left: 1px solid var(--home-line);
  }

  .home-page .intro-missions-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-page .territory-frame,
  .home-page .service-stripe {
    grid-template-columns: minmax(0, 1fr) minmax(380px, 0.9fr);
  }

  .home-page .territory-contact,
  .home-page .territory-zones {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .home-page .service-stripe-reverse {
    grid-template-columns: minmax(380px, 0.9fr) minmax(0, 1fr);
  }

  .home-page .service-stripe-reverse .service-stripe-media {
    order: 2;
  }

  .home-page .service-stripe-reverse .service-stripe-body {
    order: 1;
  }

  .home-page .method-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

}

@media (max-width: 991.98px) {
  .home-page .territory-media img {
    min-height: 320px;
  }
}

@media (max-width: 767.98px) {
  .home-page .method-frame,
  .home-page .territory-frame {
    padding: 1.55rem;
    border-radius: 24px;
  }

  .home-page .intro-founder {
    padding: 1.15rem 1.15rem 1.1rem;
    border-radius: 20px;
  }

  .home-page .method-step {
    padding-right: 0;
  }

  .home-page .territory-copy h2,
  .home-page .territory-copy > p,
  .home-page .territory-overlay p {
    max-width: none;
  }

  .home-page .territory-contact-item {
    padding-left: 0.9rem;
  }

  .home-page .territory-overlay {
    right: 1.15rem;
    bottom: 1.15rem;
    left: 1.15rem;
  }

  .home-page .service-stripe-media img,
  .home-page .territory-media img {
    height: 100%;
  }

  .home-page .service-stripe-media {
    aspect-ratio: 16 / 10;
    min-height: 260px;
  }

  .home-page .service-stripe-heading {
    grid-template-columns: 1fr;
    gap: 0.6rem;
  }

  .home-page .service-number {
    min-width: 0;
    min-height: 0;
    padding: 0;
    border-right: 0;
  }

  .home-page .intro-feature-grid,
  .home-page .intro-missions {
    margin-top: 1.6rem;
    padding-top: 1.5rem;
  }

  .home-page .intro-video-placeholder,
  .home-page .intro-video-placeholder img {
    min-height: 280px;
  }

  .home-page .intro-video-overlay {
    right: 1.05rem;
    bottom: 1.05rem;
    left: 1.05rem;
  }
}
