/* ============================================================
   PÁGINAS INTERNAS — page hero, serviços, sobre, contactos,
   legal, 404 e placeholders (imobiliária / admin)
   ============================================================ */

/* --- Page hero --- */
.page-hero {
  position: relative; overflow: hidden;
  background: linear-gradient(150deg, var(--color-brand-ink) 0%, var(--color-brand-deep) 55%, var(--color-brand) 100%);
  color: #fff;
}
.page-hero::before {
  content: ""; position: absolute; top: -50%; right: -10%;
  width: 55%; aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle, rgba(185,148,88,0.13), transparent 65%);
  pointer-events: none;
}
.page-hero__inner { position: relative; padding-block: clamp(3.5rem, 7vw, 6rem); max-width: 760px; }
.page-hero__title { color: #fff; font-size: var(--fs-4xl); font-weight: 700; line-height: 1.1; letter-spacing: -0.025em; margin-top: var(--space-5); }
.page-hero__title .accent-serif { color: var(--color-accent-light); font-weight: 500; }
.page-hero__sub { margin-top: var(--space-5); font-size: var(--fs-lg); color: var(--color-text-on-dark); max-width: 56ch; line-height: 1.7; }
.page-hero__actions { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-top: var(--space-8); }
@media (max-width: 560px) {
  /* evita que palavras longas alarguem o layout em ecrãs estreitos */
  .page-hero__title { hyphens: auto; overflow-wrap: anywhere; }
}

/* --- Breadcrumb --- */
.crumbs { display: flex; gap: var(--space-2); font-size: var(--fs-sm); color: rgba(255,255,255,0.55); flex-wrap: wrap; }
.crumbs a:hover { color: var(--color-accent-light); }
.crumbs li:not(:last-child)::after { content: "/"; margin-left: var(--space-2); color: rgba(255,255,255,0.25); }
.crumbs [aria-current] { color: var(--color-accent-light); }

/* --- Layout de serviço (corpo + aside fixo) --- */
.service-layout { display: grid; grid-template-columns: 1fr 340px; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.service-body > * + * { margin-top: var(--space-6); }
.service-body h2 { margin-top: var(--space-12); }
.service-body h2:first-child { margin-top: 0; }

.service-aside { position: sticky; top: calc(var(--header-h) + var(--space-6)); display: grid; gap: var(--space-6); }
.aside-card {
  position: relative; overflow: hidden;
  background: linear-gradient(160deg, var(--color-brand), var(--color-brand-deep));
  color: #fff; border-radius: var(--radius); padding: var(--space-8);
}
.aside-card::before {
  content: ""; position: absolute; top: -40%; right: -30%; width: 80%; aspect-ratio: 1;
  border-radius: 50%; background: radial-gradient(circle, rgba(185,148,88,0.18), transparent 65%);
}
.aside-card > * { position: relative; }
.aside-card h3 { color: #fff; margin-bottom: var(--space-3); }
.aside-card p { color: rgba(255,255,255,0.8); font-size: var(--fs-sm); margin-bottom: var(--space-6); }
.aside-card .btn { width: 100%; }
.aside-card .form-note { color: rgba(255,255,255,0.55); }
.aside-phone { display: flex; align-items: center; gap: var(--space-3); margin-top: var(--space-5); font-weight: 600; color: #fff; }
.aside-phone svg { width: 20px; height: 20px; color: var(--color-accent-light); }

.aside-info { background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius); padding: var(--space-6); }
.aside-info h3 { font-size: var(--fs-base); margin-bottom: var(--space-4); }
.aside-info li { display: flex; gap: var(--space-3); align-items: flex-start; font-size: var(--fs-sm); color: var(--color-text-secondary); margin-bottom: var(--space-3); }
.aside-info li svg { width: 18px; height: 18px; color: var(--color-brand); flex: none; margin-top: 2px; }

@media (max-width: 900px) { .service-layout { grid-template-columns: 1fr; } .service-aside { position: static; } }

/* --- Banda CTA --- */
.cta-band {
  position: relative; overflow: hidden;
  background: linear-gradient(150deg, var(--color-brand-ink), var(--color-brand) 120%);
  color: #fff; border-radius: var(--radius-lg);
  padding: clamp(2.5rem, 5vw, 4rem); text-align: center;
}
.cta-band::before {
  content: ""; position: absolute; top: -60%; left: 50%; transform: translateX(-50%);
  width: 70%; aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle, rgba(185,148,88,0.15), transparent 65%);
}
.cta-band > * { position: relative; }
.cta-band h2 { color: #fff; max-width: 24ch; margin-inline: auto; }
.cta-band p { margin: var(--space-4) auto 0; max-width: 52ch; color: var(--color-text-on-dark); }
.cta-band__actions { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; margin-top: var(--space-8); }

/* --- Sobre: história / retrato --- */
.story__media { position: relative; }
.story__frame { aspect-ratio: 3 / 4; overflow: hidden; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.story__frame img {
  width: 100%; height: 100%; object-fit: cover; object-position: 50% 10%;
  transform: scale(1.22); transform-origin: 50% 20%;
}
.story__badge {
  position: absolute; bottom: var(--space-6); left: calc(-1 * 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: 250px;
}
.story__badge strong { display: block; font-family: var(--font-serif); font-style: italic; font-size: var(--fs-xl); font-weight: 500; line-height: 1.25; color: #fff; }
.story__badge span { font-size: var(--fs-xs); color: rgba(255,255,255,0.75); text-transform: uppercase; letter-spacing: 0.06em; }
@media (max-width: 900px) { .story__frame { max-width: 440px; } }
@media (max-width: 560px) { .story__badge { left: var(--space-4); bottom: var(--space-4); padding: var(--space-4); } }

/* --- Percurso profissional (Sobre Nós, em secção escura) --- */
.timeline { max-width: var(--container-narrow); margin-inline: auto; }
.timeline__item { position: relative; padding: 0 0 var(--space-10) var(--space-10); border-left: 1px solid rgba(255,255,255,0.16); }
.timeline__item:last-child { padding-bottom: 0; border-left-color: transparent; }
.timeline__item::before {
  content: ""; position: absolute; left: -6.5px; top: 8px;
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--color-accent-light); box-shadow: 0 0 0 5px rgba(185, 148, 88, 0.18);
}
.timeline__period { font-family: var(--font-serif); font-style: italic; font-size: var(--fs-lg); color: var(--color-accent-light); }
.timeline__role { color: #fff; font-size: var(--fs-lg); font-weight: 600; margin: var(--space-1) 0 var(--space-2); }
.timeline__item p { color: var(--color-text-on-dark); font-size: var(--fs-sm); max-width: 62ch; }
.timeline__note { margin: var(--space-12) auto 0; max-width: 64ch; text-align: center; font-size: var(--fs-sm); color: rgba(255,255,255,0.6); }

/* valores em chips */
.values-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); }
.value-chip { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-5); background: var(--color-surface-light); border-radius: var(--radius); font-weight: 600; font-size: var(--fs-sm); }
.value-chip svg { width: 22px; height: 22px; color: var(--color-brand); flex: none; }
@media (max-width: 820px) { .values-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 460px) { .values-grid { grid-template-columns: 1fr; } }

/* --- Página de contactos --- */
.contact-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-4); }
.contact-card { display: flex; align-items: flex-start; gap: var(--space-4); padding: var(--space-6); border: 1px solid var(--color-border); border-radius: var(--radius); background: #fff; transition: transform var(--t-base), box-shadow var(--t-base); }
.contact-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-sm); }
.contact-card .icon-tile { margin: 0; flex: none; }
.contact-card h3 { font-size: var(--fs-base); margin-bottom: var(--space-1); }
.contact-card p, .contact-card a { font-size: var(--fs-sm); color: var(--color-text-secondary); }
.contact-card a { font-weight: 600; color: var(--color-brand); }
.contact-card a:hover { color: var(--color-brand-dark); }
@media (max-width: 560px) { .contact-cards { grid-template-columns: 1fr; } }

.contact-form-wrap { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(2rem, 5vw, 3.5rem); align-items: start; }
.contact-form-panel { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: clamp(1.5rem, 4vw, 2.5rem); box-shadow: var(--shadow-sm); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0 var(--space-4); }
@media (max-width: 820px) { .contact-form-wrap { grid-template-columns: 1fr; } .form-row { grid-template-columns: 1fr; } }

/* --- Páginas legais (prosa legível) --- */
.legal-body { max-width: var(--container-narrow); }
.legal-body > * + * { margin-top: var(--space-5); }
.legal-body h2 { margin-top: var(--space-12); font-size: var(--fs-2xl); }
.legal-body h3 { margin-top: var(--space-8); font-size: var(--fs-xl); }
.legal-body p, .legal-body li { color: var(--color-text-secondary); line-height: 1.75; }
.legal-body ul, .legal-body ol { padding-left: var(--space-6); display: grid; gap: var(--space-2); }
.legal-body ul { list-style: disc; }
.legal-body ol { list-style: decimal; }
.legal-body a:not(.btn) { color: var(--color-brand); text-decoration: underline; }
.legal-body a:not(.btn):hover { color: var(--color-brand-dark); }
.legal-body strong { color: var(--color-text-primary); }
.legal-note { margin-top: var(--space-10); padding: var(--space-5) var(--space-6); background: var(--color-brand-tint); border-radius: var(--radius); font-size: var(--fs-sm); }
.legal-updated { font-size: var(--fs-sm); color: var(--color-text-muted); }

/* --- 404 --- */
.error-page { min-height: 60vh; display: grid; place-items: center; text-align: center; padding-block: var(--space-24); }
.error-page__code { font-family: var(--font-serif); font-style: italic; font-size: clamp(5rem, 14vw, 9rem); line-height: 1; color: var(--color-brand); opacity: 0.14; }
.error-page h1 { margin-top: calc(-1 * var(--space-8)); }
.error-page p { margin-top: var(--space-4); max-width: 46ch; margin-inline: auto; }
.error-page__actions { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; margin-top: var(--space-8); }

/* ============================================================
   PREPARAÇÃO FUTURA — imobiliária (placeholders)
   ============================================================ */

/* Cards de imóvel em esqueleto (sem dados reais) */
.estate-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.estate-card { border: 1px solid var(--color-border); border-radius: var(--radius); overflow: hidden; background: #fff; }
.estate-card__photo { aspect-ratio: 4 / 3; border-radius: 0; display: grid; place-items: center; color: var(--color-text-muted); }
.estate-card__photo svg { width: 32px; height: 32px; opacity: 0.5; }
.estate-card__body { padding: var(--space-6); display: grid; gap: var(--space-3); }
.estate-card__line { height: 14px; }
.estate-card__line--lg { height: 20px; width: 70%; }
.estate-card__line--sm { width: 45%; }
@media (max-width: 900px) { .estate-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .estate-grid { grid-template-columns: 1fr; } }

/* Barra de filtros (visual, inativa nesta fase) */
.estate-filters {
  display: grid; grid-template-columns: repeat(4, 1fr) auto; gap: var(--space-4);
  padding: var(--space-6); background: #fff; border: 1px solid var(--color-border);
  border-radius: var(--radius); box-shadow: var(--shadow-sm);
}
.estate-filters[aria-disabled="true"] { opacity: 0.6; pointer-events: none; }
@media (max-width: 900px) { .estate-filters { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .estate-filters { grid-template-columns: 1fr; } }

/* Página de imóvel (galeria + specs placeholder) */
.property-gallery { display: grid; grid-template-columns: 2fr 1fr; gap: var(--space-4); }
.property-gallery__main { aspect-ratio: 16 / 10; }
.property-gallery__side { display: grid; gap: var(--space-4); }
.property-gallery__side .skeleton { aspect-ratio: 16 / 9.8; }
.property-specs { display: flex; flex-wrap: wrap; gap: var(--space-4); }
.property-spec { display: inline-flex; align-items: center; gap: var(--space-2); padding: var(--space-3) var(--space-5); background: var(--color-surface-light); border-radius: 999px; font-size: var(--fs-sm); font-weight: 600; color: var(--color-text-secondary); }
.property-spec svg { width: 18px; height: 18px; color: var(--color-brand); }
@media (max-width: 820px) { .property-gallery { grid-template-columns: 1fr; } .property-gallery__side { grid-template-columns: 1fr 1fr; } }

/* ============================================================
   PREPARAÇÃO FUTURA — admin (maquetas visuais, sem funcionalidade)
   ============================================================ */
.admin-login {
  min-height: 100vh; display: grid; place-items: center;
  background: linear-gradient(155deg, var(--color-brand-ink) 0%, var(--color-brand-deep) 50%, var(--color-brand) 100%);
  padding: var(--space-6);
}
.admin-login__card { width: min(440px, 100%); background: #fff; border-radius: var(--radius-lg); padding: clamp(2rem, 5vw, 3rem); box-shadow: var(--shadow-lg); }
.admin-login__brand { text-align: center; margin-bottom: var(--space-8); }
.admin-login__brand img { height: 44px; width: auto; margin-inline: auto; }
.admin-login__brand p { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.18em; color: var(--color-text-muted); margin-top: var(--space-3); }

.admin-shell { display: grid; grid-template-columns: 250px 1fr; min-height: 100vh; background: var(--color-surface-light); }
.admin-side { background: var(--color-brand-deep); color: var(--color-text-on-dark); padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-1); }
.admin-side__brand { font-family: var(--font-serif); font-style: italic; font-weight: 700; font-size: 1.5rem; color: #fff; padding: var(--space-3); margin-bottom: var(--space-6); }
.admin-side a { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4); border-radius: var(--radius-sm); font-size: var(--fs-sm); font-weight: 500; transition: background var(--t-fast), color var(--t-fast); }
.admin-side a svg { width: 18px; height: 18px; flex: none; }
.admin-side a:hover { background: rgba(255,255,255,0.06); color: #fff; }
.admin-side a.is-active { background: rgba(255,255,255,0.1); color: #fff; }
.admin-side__foot { margin-top: auto; }
.admin-main { padding: clamp(1.5rem, 4vw, 3rem); }
.admin-main__head { display: flex; justify-content: space-between; align-items: center; gap: var(--space-4); flex-wrap: wrap; margin-bottom: var(--space-8); }
.admin-main__head h1 { font-size: var(--fs-2xl); }
.admin-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); margin-bottom: var(--space-8); }
.admin-stat { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius); padding: var(--space-6); }
.admin-stat strong { display: block; font-size: var(--fs-2xl); font-weight: 700; color: var(--color-brand); }
.admin-stat span { font-size: var(--fs-sm); color: var(--color-text-muted); }
.admin-panel { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius); padding: var(--space-8); }
@media (max-width: 900px) { .admin-shell { grid-template-columns: 1fr; } .admin-side { flex-direction: row; flex-wrap: wrap; align-items: center; } .admin-side__brand { margin: 0; } .admin-side__foot { margin: 0; margin-left: auto; } .admin-stats { grid-template-columns: 1fr; } }

/* Faixa de aviso "em preparação" (imobiliária/admin) */
.wip-banner {
  display: flex; align-items: center; justify-content: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-4); text-align: center;
  background: var(--color-accent-soft); color: var(--color-accent);
  font-size: var(--fs-sm); font-weight: 600;
}
.wip-banner svg { width: 17px; height: 17px; flex: none; }
