/* ============================================================
   HOMEPAGE — hero, credenciais, secções de serviço
   ============================================================ */

/* --- Hero --- */
.hero {
  position: relative; overflow: hidden;
  background: linear-gradient(155deg, var(--color-brand-ink) 0%, var(--color-brand-deep) 45%, var(--color-brand) 100%);
  color: #fff;
}
/* brilho dourado subtil no canto superior */
.hero::before {
  content: ""; position: absolute; top: -30%; right: -10%;
  width: 60%; aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle, rgba(185,148,88,0.14), transparent 65%);
  pointer-events: none;
}
/* grelha fina, quase impercetível */
.hero::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.028) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,0.9), transparent 85%);
  -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,0.9), transparent 85%);
}
.hero__inner {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1.15fr 0.85fr;
  gap: clamp(2.5rem, 6vw, 5rem); align-items: center;
  padding-block: clamp(4rem, 8vw, 7rem) clamp(6rem, 10vw, 8.5rem);
}

.hero__eyebrow {
  display: inline-flex; align-items: center; gap: var(--space-3);
  padding: var(--space-2) var(--space-5); border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.16);
  font-size: var(--fs-xs); font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(255,255,255,0.8);
  margin-bottom: var(--space-8);
}
.hero__eyebrow::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--color-accent-light); }

.hero__title { color: #fff; font-size: var(--fs-5xl); font-weight: 700; line-height: 1.08; letter-spacing: -0.03em; max-width: 15ch; }
.hero__title .accent-serif { color: var(--color-accent-light); font-weight: 500; }
.hero__sub { margin-top: var(--space-6); font-size: var(--fs-lg); color: var(--color-text-on-dark); max-width: 48ch; line-height: 1.7; }
.hero__actions { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-top: var(--space-10); }

/* fila de confiança: registos oficiais */
.hero__trust { display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-6); margin-top: var(--space-10); padding-top: var(--space-8); border-top: 1px solid rgba(255,255,255,0.12); }
.hero__trust li { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--fs-xs); color: rgba(255,255,255,0.6); letter-spacing: 0.02em; }
.hero__trust svg { width: 15px; height: 15px; color: var(--color-accent-light); flex: none; }

/* retrato — a fotografia original é de corpo inteiro com muito fundo vazio;
   a moldura (overflow hidden) + scale recorta um plano americano sem deformar */
.hero__media { position: relative; justify-self: end; width: min(400px, 100%); }
.hero__frame {
  aspect-ratio: 4 / 5; overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 30px 80px rgba(5, 15, 24, 0.5);
}
.hero__photo {
  width: 100%; height: 100%; object-fit: cover; object-position: 50% 12%;
  transform: scale(1.32); transform-origin: 50% 18%;
}
.hero__card {
  position: absolute; left: calc(-1 * var(--space-8)); bottom: var(--space-8);
  display: flex; align-items: center; gap: var(--space-4);
  background: #fff; color: var(--color-text-primary);
  border-radius: var(--radius); padding: var(--space-4) var(--space-5);
  box-shadow: var(--shadow-lg); max-width: 300px;
}
.hero__card-icon {
  flex: none; width: 44px; height: 44px; border-radius: var(--radius-sm);
  background: var(--color-brand-soft); color: var(--color-brand);
  display: grid; place-items: center;
}
.hero__card-icon svg { width: 22px; height: 22px; }
.hero__card strong { display: block; font-size: var(--fs-sm); font-weight: 600; line-height: 1.3; }
.hero__card span { font-size: var(--fs-xs); color: var(--color-text-muted); }

@media (max-width: 900px) {
  .hero__inner { grid-template-columns: 1fr; padding-block: clamp(3.5rem, 8vw, 5rem) clamp(6rem, 12vw, 7.5rem); }
  .hero__media { justify-self: start; width: min(340px, 86%); margin-top: var(--space-4); }
  .hero__card { left: auto; right: calc(-1 * var(--space-4)); }
}
@media (max-width: 560px) {
  /* palavras longas ("acompanhamento") não podem alargar a coluna do grid */
  .hero__title { hyphens: auto; overflow-wrap: anywhere; }
  .hero__actions .btn { width: 100%; }
  .hero__card { right: var(--space-2); bottom: var(--space-4); max-width: 260px; }
}

/* --- Banda de credenciais (sobrepõe o hero) --- */
.creds { position: relative; z-index: 2; margin-top: calc(-1 * clamp(3rem, 6vw, 4.5rem)); }
.creds__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.cred-card {
  display: flex; gap: var(--space-4); align-items: flex-start;
  background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius);
  padding: var(--space-6); box-shadow: var(--shadow);
}
.cred-card__icon {
  flex: none; width: 48px; height: 48px; border-radius: var(--radius-sm);
  background: var(--color-brand-soft); color: var(--color-brand);
  display: grid; place-items: center;
}
.cred-card__icon svg { width: 24px; height: 24px; }
.cred-card strong { display: block; font-size: var(--fs-base); font-weight: 600; margin-bottom: 2px; }
.cred-card span { display: block; font-size: var(--fs-sm); color: var(--color-text-secondary); }
.cred-card small { display: block; margin-top: var(--space-1); font-size: var(--fs-xs); color: var(--color-text-muted); letter-spacing: 0.04em; }
@media (max-width: 900px) { .creds__grid { grid-template-columns: 1fr; } }

/* --- Split de serviço (Créditos / Seguros) --- */
.home-split__media { position: relative; }
.home-split__panel {
  position: relative; overflow: hidden;
  background: linear-gradient(160deg, var(--color-brand) 0%, var(--color-brand-deep) 100%);
  border-radius: var(--radius-lg); padding: clamp(2rem, 5vw, 3.5rem);
  color: #fff; box-shadow: var(--shadow-lg);
}
.home-split__panel::before {
  content: ""; position: absolute; top: -40%; right: -20%; width: 70%; aspect-ratio: 1;
  border-radius: 50%; background: radial-gradient(circle, rgba(185,148,88,0.18), transparent 65%);
}
.home-split__panel h3 { color: #fff; font-size: var(--fs-xl); margin-bottom: var(--space-4); position: relative; }
.home-split__panel .check-list { position: relative; }
.home-split__panel .btn { margin-top: var(--space-8); position: relative; }

/* selo numérico decorativo */
.home-split__figure { font-family: var(--font-serif); font-style: italic; font-size: clamp(3rem, 6vw, 4.5rem); line-height: 1; color: var(--color-accent-light); }
.home-split__figure small { display: block; font-family: var(--font-base); font-style: normal; font-size: var(--fs-sm); color: rgba(255,255,255,0.65); margin-top: var(--space-2); letter-spacing: 0.04em; }

/* --- Cards de parceiros na homepage --- */
.partners-note { text-align: center; font-size: var(--fs-sm); color: var(--color-text-muted); margin-top: var(--space-8); }

/* --- Secção owner --- */
.owner__media { position: relative; }
.owner__frame {
  width: 100%; max-width: 440px; aspect-ratio: 4 / 5; overflow: hidden;
  border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
}
.owner__photo {
  width: 100%; height: 100%; object-fit: cover; object-position: 50% 10%;
  transform: scale(1.26); transform-origin: 50% 20%;
}
.owner__badge {
  position: absolute; bottom: var(--space-6); right: var(--space-6);
  background: var(--color-brand); color: #fff;
  border-radius: var(--radius); padding: var(--space-5) var(--space-6);
  box-shadow: var(--shadow-lg); max-width: 240px;
}
.owner__badge strong { display: block; font-family: var(--font-serif); font-style: italic; font-size: var(--fs-xl); font-weight: 500; color: #fff; line-height: 1.2; }
.owner__badge span { font-size: var(--fs-xs); color: rgba(255,255,255,0.75); letter-spacing: 0.06em; text-transform: uppercase; }
.owner__regs { margin-top: var(--space-8); display: grid; gap: var(--space-3); }
.owner__regs li { display: flex; gap: var(--space-3); align-items: center; font-size: var(--fs-sm); color: var(--color-text-secondary); }
.owner__regs svg { width: 18px; height: 18px; color: var(--color-accent); flex: none; }

/* --- Teaser imobiliária --- */
.estate-teaser {
  position: relative; overflow: hidden;
  background: linear-gradient(150deg, var(--color-brand-ink), var(--color-brand-deep) 70%);
  border-radius: var(--radius-lg);
  padding: clamp(2.5rem, 6vw, 4.5rem);
  color: #fff;
}
.estate-teaser::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 56px 56px;
}
.estate-teaser__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.2fr 0.8fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.estate-teaser h2 { color: #fff; margin-top: var(--space-5); }
.estate-teaser p { margin-top: var(--space-4); color: var(--color-text-on-dark); max-width: 52ch; }
.estate-teaser .btn { margin-top: var(--space-8); }
.estate-teaser__license { display: inline-flex; align-items: center; gap: var(--space-2); margin-top: var(--space-6); font-size: var(--fs-xs); color: rgba(255,255,255,0.55); }
.estate-teaser__license svg { width: 15px; height: 15px; color: var(--color-accent-light); }

/* mini-mosaico ilustrativo de "brevemente" */
.estate-teaser__preview { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.estate-teaser__tile {
  aspect-ratio: 4 / 3; border-radius: var(--radius);
  background: rgba(255,255,255,0.05); border: 1px dashed rgba(255,255,255,0.18);
  display: grid; place-items: center; color: rgba(255,255,255,0.35);
}
.estate-teaser__tile svg { width: 28px; height: 28px; }
@media (max-width: 900px) {
  .estate-teaser__inner { grid-template-columns: 1fr; }
  .estate-teaser__preview { max-width: 380px; }
}

/* --- Contacto rápido (homepage) --- */
.quick-contact { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.quick-contact__card {
  display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-2);
  background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius);
  padding: var(--space-8);
  transition: transform var(--t-base), box-shadow var(--t-base);
}
.quick-contact__card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.quick-contact__card .icon-tile { margin-bottom: var(--space-3); }
.quick-contact__card h3 { font-size: var(--fs-base); }
.quick-contact__card a { font-weight: 600; color: var(--color-brand); }
.quick-contact__card a:hover { color: var(--color-brand-dark); }
.quick-contact__card p { font-size: var(--fs-sm); }
@media (max-width: 900px) { .quick-contact { grid-template-columns: 1fr; } }
