/* ============================================================
   CASA DO ALTO — Folha de estilos principal
   Paleta: verde (natureza/cuidado) + âmbar (acolhimento/energia)
   Autor: revisão Opus sobre a proposta original
============================================================ */

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Verdes */
  --green-900: #123528;
  --green-800: #18402F;
  --green-700: #1F5C45;   /* primária */
  --green-600: #2A7A5B;
  --green-500: #379A72;
  --green-400: #57B68E;
  --green-300: #88CFAD;
  --green-100: #DCEFE4;
  --green-50:  #EEF7F1;

  /* Âmbar / amarelo (acento) */
  --amber-700: #B07D17;
  --amber-600: #D29A22;
  --amber-500: #EBB23A;   /* acento principal */
  --amber-400: #F4C95F;
  --amber-200: #F9E2A8;
  --amber-50:  #FCF5E2;

  /* Neutros */
  --ink:       #14241D;
  --ink-soft:  #3B4F45;
  --muted:     #6C8175;
  --muted-2:   #9CB0A4;
  --line:      #E2EDE6;
  --cream:     #FBF8F2;
  --sand:      #F3EDE1;
  --white:     #FFFFFF;

  /* Sombras */
  --shadow-sm: 0 2px 10px rgba(18,53,40,.07);
  --shadow-md: 0 10px 32px rgba(18,53,40,.10);
  --shadow-lg: 0 24px 60px rgba(18,53,40,.16);

  /* Raios */
  --r-sm: 10px;
  --r-md: 18px;
  --r-lg: 28px;
  --r-pill: 999px;

  --ease: cubic-bezier(.4,0,.2,1);
  --t: .3s var(--ease);

  --maxw: 1180px;
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Inter', system-ui, sans-serif;
  background: var(--cream);
  color: var(--ink);
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 { font-family: 'Lora', Georgia, serif; line-height: 1.22; color: var(--ink); font-weight: 600; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }
ul { list-style: none; }

/* ---------- UTILITÁRIOS ---------- */
.container { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

.section { padding: 96px 0; }
.section-sm { padding: 64px 0; }
.section-alt { background: var(--sand); }
.section-green { background: var(--green-800); color: var(--white); }
.section-green h1, .section-green h2, .section-green h3 { color: var(--white); }

.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: .74rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--amber-700);
  margin-bottom: 14px;
}
.eyebrow::before { content: ""; width: 22px; height: 2px; background: var(--amber-500); border-radius: 2px; }

.title { font-size: clamp(1.9rem, 3.6vw, 2.9rem); margin-bottom: 18px; letter-spacing: -.01em; }
.title em { color: var(--green-600); font-style: italic; }
.subtitle { font-size: 1.08rem; color: var(--ink-soft); max-width: 620px; line-height: 1.8; }
.center { text-align: center; }
.center .subtitle { margin-left: auto; margin-right: auto; }
.head { max-width: 680px; margin-bottom: 52px; }
.head.center { margin-left: auto; margin-right: auto; }

/* ---------- BOTÕES ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  padding: 14px 28px; border-radius: var(--r-pill);
  font-family: 'Inter', sans-serif; font-size: .92rem; font-weight: 600;
  cursor: pointer; transition: var(--t); border: 2px solid transparent; white-space: nowrap;
}
.btn svg { width: 18px; height: 18px; }
.btn-primary { background: var(--green-700); color: var(--white); }
.btn-primary:hover { background: var(--green-800); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn-amber { background: var(--amber-500); color: var(--green-900); }
.btn-amber:hover { background: var(--amber-400); transform: translateY(-2px); box-shadow: 0 10px 26px rgba(235,178,58,.35); }
.btn-outline { background: transparent; color: var(--green-700); border-color: var(--green-300); }
.btn-outline:hover { background: var(--green-700); color: var(--white); border-color: var(--green-700); transform: translateY(-2px); }
.btn-white { background: var(--white); color: var(--green-800); }
.btn-white:hover { background: var(--amber-50); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn-ghost-light { background: rgba(255,255,255,.12); color: var(--white); border-color: rgba(255,255,255,.3); }
.btn-ghost-light:hover { background: rgba(255,255,255,.22); transform: translateY(-2px); }
.btn-whatsapp { background: #25D366; color: #06351F; }
.btn-whatsapp:hover { background: #1FB958; transform: translateY(-2px); box-shadow: 0 10px 26px rgba(37,211,102,.35); }
.btn-block { width: 100%; }

/* ============================================================
   TOPBAR
============================================================ */
.topbar { background: var(--green-900); color: rgba(255,255,255,.72); font-size: .82rem; }
.topbar-inner { display: flex; align-items: center; justify-content: space-between; padding: 9px 0; gap: 16px; }
.topbar-left { display: flex; align-items: center; gap: 8px; }
.topbar-left .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--amber-500); box-shadow: 0 0 0 3px rgba(235,178,58,.25); }
.topbar-links { display: flex; align-items: center; gap: 20px; flex-shrink: 0; }
.topbar-links a { display: inline-flex; align-items: center; gap: 6px; transition: var(--t); white-space: nowrap; }
.topbar-links a svg { width: 14px; height: 14px; flex-shrink: 0; }
.topbar-links a:hover { color: var(--white); }
.topbar-left { min-width: 0; }
.topbar-left .welcome { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ============================================================
   NAVBAR
============================================================ */
.navbar { position: sticky; top: 0; z-index: 1000; background: var(--white); border-bottom: 1px solid var(--line); transition: var(--t); }
.navbar.scrolled { box-shadow: var(--shadow-sm); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 14px 0; }

.nav-logo { display: flex; align-items: center; gap: 12px; }
.nav-logo img { height: 48px; width: auto; display: block; }
.m-head .nav-logo img { height: 40px; }
.nav-logo .mark {
  width: 44px; height: 44px; border-radius: 13px;
  background: linear-gradient(135deg, var(--green-600), var(--green-800));
  display: grid; place-items: center; color: var(--amber-400);
  font-family: 'Lora', serif; font-weight: 700; font-size: 1.35rem; flex-shrink: 0;
  box-shadow: var(--shadow-sm);
}
.nav-logo .wordmark { line-height: 1.1; }
.nav-logo .wordmark b { font-family: 'Lora', serif; font-size: 1.18rem; color: var(--green-800); font-weight: 700; display: block; }
.nav-logo .wordmark span { font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); }

.nav-menu { display: flex; align-items: center; gap: 2px; }
.nav-item { position: relative; }
.nav-link {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 15px; border-radius: var(--r-sm);
  font-size: .92rem; font-weight: 500; color: var(--ink-soft);
  transition: var(--t); cursor: pointer;
}
.nav-link .caret { width: 11px; height: 11px; transition: transform var(--t); }
.nav-link:hover, .nav-link.active { color: var(--green-700); background: var(--green-50); }

/* Dropdown — sem gap de hover (a área hoverável encosta no item) */
.dropdown {
  position: absolute; top: 100%; left: 0;
  min-width: 268px; padding-top: 12px;   /* ponte transparente que cobre o gap */
  opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: opacity var(--t), transform var(--t), visibility var(--t);
  z-index: 100;
}
.dropdown-panel {
  background: var(--white); border: 1px solid var(--line);
  border-radius: var(--r-md); box-shadow: var(--shadow-lg); padding: 8px;
}
.nav-item:hover .dropdown,
.nav-item:focus-within .dropdown,
.nav-item.open .dropdown { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-item:hover .nav-link .caret,
.nav-item.open .nav-link .caret { transform: rotate(180deg); }

.dd-link { display: flex; align-items: center; gap: 12px; padding: 11px 14px; border-radius: var(--r-sm); transition: var(--t); }
.dd-link .ico { width: 34px; height: 34px; flex-shrink: 0; border-radius: 9px; background: var(--green-50); display: grid; place-items: center; font-size: 1.05rem; transition: var(--t); }
.dd-link .txt b { display: block; font-size: .9rem; font-weight: 600; color: var(--ink); }
.dd-link .txt small { font-size: .76rem; color: var(--muted); }
.dd-link:hover { background: var(--green-50); }
.dd-link:hover .ico { background: var(--amber-50); transform: scale(1.06); }
.dd-divider { height: 1px; background: var(--line); margin: 6px 8px; }
.dd-foot { padding: 10px 14px 6px; }
.dd-foot a { font-size: .82rem; font-weight: 600; color: var(--green-600); display: inline-flex; gap: 5px; }
.dd-foot a:hover { gap: 9px; }

.nav-actions { display: flex; align-items: center; gap: 10px; }

.hamburger { display: none; width: 46px; height: 46px; border: 1px solid var(--line); border-radius: 12px; background: var(--white); cursor: pointer; place-items: center; }
.hamburger span { display: block; width: 20px; height: 2px; background: var(--ink); position: relative; }
.hamburger span::before, .hamburger span::after { content: ""; position: absolute; left: 0; width: 20px; height: 2px; background: var(--ink); }
.hamburger span::before { top: -6px; } .hamburger span::after { top: 6px; }

/* ---------- MENU MOBILE ---------- */
.m-overlay { position: fixed; inset: 0; background: rgba(18,37,29,.5); opacity: 0; visibility: hidden; transition: var(--t); z-index: 1100; backdrop-filter: blur(2px); }
.m-overlay.open { opacity: 1; visibility: visible; }
.m-nav { position: fixed; top: 0; right: 0; width: min(360px, 88vw); height: 100%; background: var(--white); z-index: 1200; transform: translateX(100%); transition: transform var(--t); display: flex; flex-direction: column; padding: 22px; overflow-y: auto; }
.m-nav.open { transform: translateX(0); }
.m-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 22px; }
.m-close { width: 42px; height: 42px; border: 1px solid var(--line); border-radius: 11px; background: var(--white); font-size: 1.3rem; cursor: pointer; color: var(--ink); }
.m-section { font-size: .68rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--muted-2); padding: 14px 12px 6px; }
.m-link { display: flex; align-items: center; gap: 10px; padding: 12px; border-radius: var(--r-sm); font-weight: 500; color: var(--ink-soft); transition: var(--t); }
.m-link:hover, .m-link.active { background: var(--green-50); color: var(--green-700); }
.m-divider { height: 1px; background: var(--line); margin: 10px 0; }
.m-actions { margin-top: auto; padding-top: 20px; display: flex; flex-direction: column; gap: 10px; }

/* ============================================================
   HERO
============================================================ */
.hero { position: relative; overflow: hidden; background: linear-gradient(160deg, var(--green-800) 0%, var(--green-900) 100%); color: var(--white); padding: 84px 0 96px; }
.hero::before { content: ""; position: absolute; top: -120px; right: -120px; width: 460px; height: 460px; border-radius: 50%; background: radial-gradient(circle, rgba(235,178,58,.22), transparent 70%); }
.hero::after { content: ""; position: absolute; bottom: -160px; left: -120px; width: 420px; height: 420px; border-radius: 50%; background: radial-gradient(circle, rgba(55,154,114,.35), transparent 70%); }
.hero .container { position: relative; z-index: 2; }
.hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: center; }
.hero h1 { color: var(--white); font-size: clamp(2.3rem, 4.6vw, 3.5rem); margin-bottom: 20px; letter-spacing: -.015em; }
.hero h1 em { color: var(--amber-400); font-style: italic; }
.hero-tag { display: inline-flex; align-items: center; gap: 9px; padding: 7px 16px; border-radius: var(--r-pill); background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18); font-size: .8rem; font-weight: 500; margin-bottom: 22px; }
.hero-tag .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--amber-400); animation: pulse 2s infinite; }
@keyframes pulse { 0%,100%{ box-shadow:0 0 0 0 rgba(244,201,95,.6);} 50%{ box-shadow:0 0 0 7px rgba(244,201,95,0);} }
.hero-desc { font-size: 1.1rem; color: rgba(255,255,255,.82); line-height: 1.8; max-width: 520px; margin-bottom: 30px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 34px; }
.hero-trust { display: flex; align-items: center; gap: 14px; }
.hero-avatars { display: flex; }
.hero-avatars span { width: 40px; height: 40px; border-radius: 50%; border: 2px solid var(--green-800); margin-left: -10px; display: grid; place-items: center; font-weight: 700; font-size: .85rem; color: var(--green-900); background: var(--amber-300, var(--amber-400)); }
.hero-avatars span:first-child { margin-left: 0; }
.hero-trust-txt { font-size: .85rem; color: rgba(255,255,255,.78); }
.hero-trust-txt b { color: var(--white); display: block; }

/* Cartão do hero — vidro translúcido (glassmorphism) */
.hero-card {
  background: rgba(255,255,255,.10);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  color: var(--white);
  border-radius: var(--r-lg); padding: 28px;
  border: 1px solid rgba(255,255,255,.20);
  box-shadow: 0 24px 60px rgba(0,0,0,.28);
  position: relative;
}
.hero-card h3 { color: var(--white); font-size: 1.1rem; margin-bottom: 18px; }
.stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 18px; }
.stat { background: var(--green-50); border: 1px solid var(--line); border-radius: var(--r-md); padding: 18px; text-align: center; }
.stat .num { font-family: 'Lora', serif; font-size: 1.9rem; font-weight: 700; color: var(--green-700); }
.stat .lbl { font-size: .76rem; color: var(--muted); margin-top: 2px; }
/* dentro do cartão de vidro, os blocos também viram vidro com texto claro */
.hero-card .stat { background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.18); }
.hero-card .stat .num { color: var(--amber-400); }
.hero-card .stat .lbl { color: rgba(255,255,255,.78); }
.unit-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.unit-tags span { font-size: .76rem; padding: 6px 12px; background: var(--amber-50); color: var(--amber-700); border-radius: var(--r-pill); font-weight: 600; }
.hero-card .unit-tags span { background: rgba(255,255,255,.14); color: var(--white); border: 1px solid rgba(255,255,255,.12); }
.float-card {
  position: absolute;
  background: rgba(255,255,255,.14);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid rgba(255,255,255,.22);
  border-radius: var(--r-md); box-shadow: 0 12px 30px rgba(0,0,0,.22);
  padding: 12px 16px; display: flex; align-items: center; gap: 11px; font-size: .8rem; color: var(--white);
}
.float-card .fi { font-size: 1.3rem; }
.float-card b { display: block; color: var(--white); font-size: .85rem; }
.float-card small { color: rgba(255,255,255,.75); }
.float-1 { top: -22px; right: 18px; animation: floaty 4s ease-in-out infinite; }
.float-2 { bottom: -22px; left: -22px; animation: floaty 4s ease-in-out infinite 1.5s; }
@keyframes floaty { 0%,100%{ transform: translateY(0);} 50%{ transform: translateY(-9px);} }

/* ============================================================
   TRUST BAR
============================================================ */
.trustbar { background: var(--white); border-bottom: 1px solid var(--line); }
.trustbar-inner { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 14px; padding: 22px 0; }
.trust-item { display: flex; align-items: center; gap: 9px; font-size: .88rem; font-weight: 500; color: var(--ink-soft); }
.trust-item .ti { color: var(--green-600); display: inline-flex; }

/* ============================================================
   SPLIT (Sobre / blocos de imagem+texto)
============================================================ */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.split.reverse .split-media { order: 2; }
.split-media { position: relative; }
.media-frame { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-md); aspect-ratio: 4/3; }
.media-frame img { width: 100%; height: 100%; object-fit: cover; }
.media-badge { position: absolute; right: -18px; bottom: -18px; background: var(--white); border-radius: var(--r-md); padding: 18px 22px; box-shadow: var(--shadow-md); text-align: center; border: 1px solid var(--line); }
.media-badge .num { font-family: 'Lora', serif; font-size: 1.8rem; font-weight: 700; color: var(--green-700); }
.media-badge .lbl { font-size: .76rem; color: var(--muted); }

/* Placeholder elegante (sem imagem) */
.ph { background: linear-gradient(135deg, var(--green-100), var(--green-50)); position: relative; display: grid; place-items: center; color: var(--green-600); }
.ph::after { content: attr(data-ph); position: absolute; bottom: 14px; left: 0; right: 0; text-align: center; font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--green-600); opacity: .7; }
.ph .ph-ico { font-size: 2.6rem; opacity: .55; }
.ph-amber { background: linear-gradient(135deg, var(--amber-200), var(--amber-50)); color: var(--amber-700); }
.ph-amber::after { color: var(--amber-700); }

/* ---------- PILARES (Missão/Visão/Valores) ---------- */
.pillars { display: grid; gap: 14px; margin-top: 8px; }
.pillar { display: flex; gap: 16px; padding: 18px; border: 1px solid var(--line); border-radius: var(--r-md); background: var(--white); transition: var(--t); }
.pillar:hover { border-color: var(--green-300); box-shadow: var(--shadow-sm); transform: translateX(4px); }
.pillar .p-ico { width: 46px; height: 46px; flex-shrink: 0; border-radius: 13px; background: var(--green-50); display: grid; place-items: center; font-size: 1.3rem; }
.pillar h4 { font-size: 1.02rem; margin-bottom: 3px; }
.pillar p { font-size: .9rem; color: var(--ink-soft); }

/* ============================================================
   CARDS GRID (tratamentos / serviços)
============================================================ */
.cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.cards.cols-3 { grid-template-columns: repeat(3, 1fr); }
.card {
  background: var(--white); border: 1px solid var(--line); border-radius: var(--r-md);
  padding: 28px 24px; transition: var(--t); position: relative; overflow: hidden; display: flex; flex-direction: column;
}
.card::after { content: ""; position: absolute; left: 0; top: 0; height: 4px; width: 100%; background: linear-gradient(90deg, var(--green-500), var(--amber-500)); transform: scaleX(0); transform-origin: left; transition: transform var(--t); }
.card:hover { box-shadow: var(--shadow-md); transform: translateY(-5px); border-color: var(--green-300); }
.card:hover::after { transform: scaleX(1); }
.card .c-ico { width: 54px; height: 54px; border-radius: 15px; background: var(--green-50); display: grid; place-items: center; font-size: 1.5rem; margin-bottom: 16px; transition: var(--t); }
.card:hover .c-ico { background: var(--amber-50); }
.card .c-cat { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--amber-700); margin-bottom: 7px; }
.card h3 { font-size: 1.18rem; margin-bottom: 9px; }
.card p { font-size: .9rem; color: var(--ink-soft); margin-bottom: 16px; flex-grow: 1; }
.card-link { font-size: .85rem; font-weight: 600; color: var(--green-600); display: inline-flex; align-items: center; gap: 6px; transition: var(--t); margin-top: auto; }
.card-link:hover { gap: 11px; color: var(--green-800); }

/* CTA faixa */
.cta-band { margin-top: 56px; background: linear-gradient(135deg, var(--green-700), var(--green-800)); border-radius: var(--r-lg); padding: 40px; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 24px; color: var(--white); position: relative; overflow: hidden; }
.cta-band::before { content: ""; position: absolute; right: -60px; top: -60px; width: 240px; height: 240px; border-radius: 50%; background: radial-gradient(circle, rgba(235,178,58,.25), transparent 70%); }
.cta-band h3 { color: var(--white); font-size: 1.5rem; margin-bottom: 6px; position: relative; }
.cta-band p { color: rgba(255,255,255,.82); position: relative; }
.cta-band .cta-actions { display: flex; flex-wrap: wrap; gap: 12px; position: relative; }

/* ============================================================
   UNIDADES
============================================================ */
.tabs { display: inline-flex; gap: 6px; padding: 6px; background: var(--white); border: 1px solid var(--line); border-radius: var(--r-pill); margin-bottom: 40px; }
.tab-btn { padding: 9px 22px; border: none; background: transparent; border-radius: var(--r-pill); font-family: 'Inter', sans-serif; font-size: .88rem; font-weight: 600; color: var(--ink-soft); cursor: pointer; transition: var(--t); }
.tab-btn:hover { color: var(--green-700); }
.tab-btn.active { background: var(--green-700); color: var(--white); }

.units-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.unit-card { background: var(--white); border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; transition: var(--t); display: flex; flex-direction: column; }
.unit-card:hover { box-shadow: var(--shadow-md); transform: translateY(-5px); border-color: var(--green-300); }
.unit-media { aspect-ratio: 16/10; position: relative; overflow: hidden; }
.unit-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease); }
.unit-card:hover .unit-media img { transform: scale(1.05); }
.unit-gender { position: absolute; top: 14px; left: 14px; font-size: .72rem; font-weight: 700; padding: 5px 13px; border-radius: var(--r-pill); }
.g-f { background: #F6E2EF; color: #9C2F73; }
.g-m { background: #DEEAF7; color: #1F5C8C; }
.unit-body { padding: 22px; display: flex; flex-direction: column; flex-grow: 1; }
.unit-state { font-size: .74rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--amber-700); margin-bottom: 5px; }
.unit-body h3 { font-size: 1.14rem; margin-bottom: 9px; }
.unit-body p { font-size: .88rem; color: var(--ink-soft); margin-bottom: 16px; flex-grow: 1; }

/* ============================================================
   DEPOIMENTOS
============================================================ */
.testimonials { background: var(--green-800); color: var(--white); }
.testimonials .eyebrow { color: var(--amber-400); }
.testimonials .eyebrow::before { background: var(--amber-400); }
.testimonials h2 { color: var(--white); }
.tgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 44px; }
.tcard { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); border-radius: var(--r-md); padding: 28px; transition: var(--t); }
.tcard:hover { background: rgba(255,255,255,.13); transform: translateY(-4px); }
.tstars { color: var(--amber-400); letter-spacing: 2px; margin-bottom: 14px; }
.tcard p { color: rgba(255,255,255,.9); font-size: .95rem; line-height: 1.75; margin-bottom: 20px; font-style: italic; }
.tauthor { display: flex; align-items: center; gap: 12px; }
.tauthor .av { width: 44px; height: 44px; border-radius: 50%; background: var(--amber-400); color: var(--green-900); display: grid; place-items: center; font-weight: 700; }
.tauthor b { display: block; font-size: .92rem; }
.tauthor small { color: rgba(255,255,255,.6); font-size: .8rem; }

/* ============================================================
   FAQ
============================================================ */
.faq-grid { display: grid; grid-template-columns: 1.4fr .9fr; gap: 40px; align-items: start; }
.faq-item { border: 1px solid var(--line); border-radius: var(--r-md); margin-bottom: 12px; background: var(--white); overflow: hidden; transition: var(--t); }
.faq-item.open { border-color: var(--green-300); box-shadow: var(--shadow-sm); }
.faq-q { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 18px 22px; font-weight: 600; font-size: .98rem; cursor: pointer; color: var(--ink); transition: var(--t); }
.faq-q:hover { color: var(--green-700); }
.faq-toggle { width: 26px; height: 26px; flex-shrink: 0; border-radius: 50%; background: var(--green-50); color: var(--green-700); display: grid; place-items: center; font-size: 1.1rem; transition: var(--t); }
.faq-item.open .faq-toggle { background: var(--green-700); color: var(--white); transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .35s var(--ease); }
.faq-a-inner { padding: 0 22px 20px; color: var(--ink-soft); font-size: .92rem; line-height: 1.75; }

.faq-help { background: linear-gradient(135deg, var(--green-700), var(--green-800)); color: var(--white); border-radius: var(--r-lg); padding: 34px; text-align: center; position: sticky; top: 100px; }
.faq-help .fh-ico { width: 60px; height: 60px; margin: 0 auto 16px; border-radius: 50%; background: rgba(255,255,255,.14); display: grid; place-items: center; font-size: 1.6rem; }
.faq-help h3 { color: var(--white); font-size: 1.3rem; margin-bottom: 10px; }
.faq-help p { color: rgba(255,255,255,.82); font-size: .9rem; margin-bottom: 18px; }
.faq-help .phone { font-family: 'Lora', serif; font-size: 1.6rem; font-weight: 700; color: var(--amber-400); display: block; margin-bottom: 20px; }
.faq-help .help-actions { display: flex; flex-direction: column; gap: 10px; }

/* ============================================================
   CONTATO
============================================================ */
.contact-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 44px; align-items: start; }
.cinfo-item { display: flex; gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--line); }
.cinfo-item:last-of-type { border-bottom: none; }
.cinfo-ico { width: 48px; height: 48px; flex-shrink: 0; border-radius: 13px; background: var(--green-50); display: grid; place-items: center; font-size: 1.3rem; }
.cinfo-item .lbl { font-size: .76rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--muted); margin-bottom: 3px; }
.cinfo-item .val { font-weight: 500; color: var(--ink); }
.cinfo-item .val a { color: var(--green-700); font-weight: 700; }
.cinfo-item .val small { display: block; font-weight: 400; font-size: .82rem; color: var(--muted); margin-top: 3px; }

.form-card { background: var(--white); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 34px; box-shadow: var(--shadow-sm); }
.form-card h3 { font-size: 1.3rem; margin-bottom: 4px; }
.form-card .form-sub { color: var(--muted); font-size: .9rem; margin-bottom: 22px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { margin-bottom: 16px; }
.form-label { display: block; font-size: .82rem; font-weight: 600; color: var(--ink-soft); margin-bottom: 7px; }
.form-input, .form-select, .form-textarea {
  width: 100%; padding: 12px 15px; border: 1px solid var(--line); border-radius: var(--r-sm);
  font-family: 'Inter', sans-serif; font-size: .92rem; color: var(--ink); background: var(--cream); transition: var(--t);
}
.form-input:focus, .form-select:focus, .form-textarea:focus { outline: none; border-color: var(--green-500); background: var(--white); box-shadow: 0 0 0 3px var(--green-100); }
.form-textarea { min-height: 110px; resize: vertical; }
.form-note { text-align: center; margin-top: 14px; font-size: .78rem; color: var(--muted-2); }
.form-ok { display: none; padding: 14px; background: var(--green-50); border: 1px solid var(--green-300); border-radius: var(--r-sm); color: var(--green-700); font-size: .9rem; font-weight: 600; text-align: center; margin-top: 14px; }

.map-embed { border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--line); margin-top: 40px; }
.map-embed iframe { width: 100%; height: 340px; border: 0; display: block; }

/* ============================================================
   PAGE HEADER (páginas internas)
============================================================ */
.pagehead { background: linear-gradient(160deg, var(--green-800), var(--green-900)); color: var(--white); padding: 60px 0 64px; position: relative; overflow: hidden; }
.pagehead::before { content: ""; position: absolute; right: -100px; top: -100px; width: 360px; height: 360px; border-radius: 50%; background: radial-gradient(circle, rgba(235,178,58,.18), transparent 70%); }
.pagehead .container { position: relative; z-index: 2; }
.crumbs { font-size: .82rem; color: rgba(255,255,255,.62); margin-bottom: 16px; display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.crumbs a { color: rgba(255,255,255,.82); transition: var(--t); }
.crumbs a:hover { color: var(--amber-400); }
.pagehead h1 { color: var(--white); font-size: clamp(2rem, 4vw, 2.9rem); margin-bottom: 12px; }
.pagehead p { color: rgba(255,255,255,.82); max-width: 600px; font-size: 1.05rem; }

/* Cabeçalho de unidade com foto de capa */
.pagehead.unit-hero { background-size: cover; background-position: center; padding: 110px 0 110px; }
.pagehead.unit-hero::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(160deg, rgba(18,53,40,.86) 0%, rgba(18,37,29,.78) 100%); }

/* ============================================================
   PÁGINA DE UNIDADE — galeria + lightbox
============================================================ */
.unit-layout { display: grid; grid-template-columns: 1fr 340px; gap: 40px; align-items: start; }
.gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.gallery .g-thumb { aspect-ratio: 4/3; border-radius: var(--r-md); overflow: hidden; cursor: pointer; border: 1px solid var(--line); transition: var(--t); }
.gallery .g-thumb:hover { transform: scale(1.03); box-shadow: var(--shadow-md); }
.gallery .g-thumb img { width: 100%; height: 100%; object-fit: cover; }

.unit-side { position: sticky; top: 100px; background: var(--white); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px; box-shadow: var(--shadow-sm); }
.unit-side h3 { font-size: 1.2rem; margin-bottom: 12px; }
.unit-side p { font-size: .9rem; color: var(--ink-soft); margin-bottom: 18px; }
.amenities { margin-bottom: 22px; }
.amenities li { display: flex; align-items: center; gap: 10px; padding: 7px 0; font-size: .88rem; color: var(--ink-soft); }
.amenities li .ck { width: 22px; height: 22px; flex-shrink: 0; border-radius: 50%; background: var(--green-50); color: var(--green-600); display: grid; place-items: center; font-size: .8rem; font-weight: 700; }

/* Lightbox */
.lightbox { position: fixed; inset: 0; background: rgba(10,24,18,.94); z-index: 2000; display: none; align-items: center; justify-content: center; padding: 30px; }
.lightbox.open { display: flex; }
.lightbox img { max-width: 92%; max-height: 86%; border-radius: var(--r-md); box-shadow: var(--shadow-lg); }
.lb-btn { position: absolute; background: rgba(255,255,255,.14); border: none; color: var(--white); width: 52px; height: 52px; border-radius: 50%; font-size: 1.5rem; cursor: pointer; transition: var(--t); display: grid; place-items: center; }
.lb-btn:hover { background: rgba(255,255,255,.3); }
.lb-close { top: 26px; right: 26px; }
.lb-prev { left: 26px; top: 50%; transform: translateY(-50%); }
.lb-next { right: 26px; top: 50%; transform: translateY(-50%); }

/* ============================================================
   FOOTER
============================================================ */
.footer { background: var(--green-900); color: rgba(255,255,255,.7); padding: 64px 0 28px; }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 40px; padding-bottom: 44px; border-bottom: 1px solid rgba(255,255,255,.1); }
.footer-brand .mark { width: 46px; height: 46px; border-radius: 13px; background: linear-gradient(135deg, var(--green-500), var(--green-700)); display: grid; place-items: center; color: var(--amber-400); font-family: 'Lora', serif; font-weight: 700; font-size: 1.4rem; margin-bottom: 16px; }
.footer-logo { height: 52px; width: auto; margin-bottom: 18px; }
.footer-brand p { font-size: .9rem; line-height: 1.75; margin-bottom: 18px; max-width: 320px; }
.footer-socials { display: flex; gap: 10px; }
.footer-socials a { width: 40px; height: 40px; border-radius: 11px; background: rgba(255,255,255,.08); display: grid; place-items: center; transition: var(--t); }
.footer-socials a:hover { background: var(--green-600); transform: translateY(-3px); }
.footer h4 { color: var(--white); font-size: .82rem; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 18px; font-family: 'Inter', sans-serif; font-weight: 700; }
.footer-links a, .footer-links div { display: block; font-size: .88rem; padding: 6px 0; color: rgba(255,255,255,.7); transition: var(--t); }
.footer-links a:hover { color: var(--amber-400); padding-left: 5px; }
.footer-emergency { margin-top: 18px; padding: 16px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); border-radius: var(--r-md); text-align: center; }
.footer-emergency small { font-size: .72rem; color: rgba(255,255,255,.5); display: block; margin-bottom: 4px; }
.footer-emergency b { font-size: 1.2rem; color: var(--amber-400); }
.footer-bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 12px; padding-top: 24px; font-size: .82rem; color: rgba(255,255,255,.45); }
.footer-bottom-links { display: flex; gap: 20px; }
.footer-bottom-links a:hover { color: rgba(255,255,255,.75); }

/* ============================================================
   WHATSAPP FLUTUANTE
============================================================ */
.wa-float { position: fixed; bottom: 26px; right: 26px; z-index: 900; display: flex; align-items: center; }
.wa-label { background: var(--white); color: var(--ink); padding: 10px 16px; border-radius: var(--r-pill); box-shadow: var(--shadow-md); font-size: .85rem; font-weight: 600; margin-right: 12px; opacity: 0; transform: translateX(10px); transition: var(--t); white-space: nowrap; pointer-events: none; }
.wa-float:hover .wa-label { opacity: 1; transform: translateX(0); }
.wa-btn { width: 60px; height: 60px; border-radius: 50%; background: #25D366; display: grid; place-items: center; box-shadow: 0 8px 24px rgba(37,211,102,.45); transition: var(--t); }
.wa-btn:hover { transform: scale(1.08); }
.wa-btn svg { width: 30px; height: 30px; fill: #fff; }

/* ============================================================
   REVEAL ON SCROLL
============================================================ */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ============================================================
   RESPONSIVO
============================================================ */
@media (max-width: 1024px) {
  .cards { grid-template-columns: repeat(2, 1fr); }
  .units-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 920px) {
  .nav-menu, .nav-actions .btn { display: none; }
  .hamburger { display: grid; }
  .hero-grid { grid-template-columns: 1fr; gap: 44px; }
  .hero-visual { max-width: 460px; }
  .split { grid-template-columns: 1fr; gap: 40px; }
  .split.reverse .split-media { order: 0; }
  .faq-grid { grid-template-columns: 1fr; }
  .faq-help { position: static; }
  .contact-grid { grid-template-columns: 1fr; }
  .unit-layout { grid-template-columns: 1fr; }
  .unit-side { position: static; }
  .tgrid { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .section { padding: 64px 0; }
  .cards, .cards.cols-3, .units-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .stat-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 30px; }
  .topbar-links { gap: 12px; }
  .topbar-left span.welcome { display: none; }
  .gallery { grid-template-columns: repeat(2, 1fr); }
  .cta-band, .faq-help { padding: 28px; }
  .float-card { display: none; }
}
