/* ============================================================
   VIVA PEDIATRIA — DESIGN SYSTEM
   Identidade visual: Thaís Guimarães Design
   Brandbook: Vogel Digital × Brand Squad
   ============================================================ */

/* ============ DESIGN TOKENS ============ */
:root {
  /* Cores principais */
  --coral: #F2AA94;
  --coral-light: #F7C9BF;
  --coral-pale: #FBE4DD;
  --amarelo: #F2C000;
  --amarelo-light: #F9D969;
  --amarelo-pale: #FCE59D;
  --azul: #B2C9D6;
  --azul-light: #D4E1E8;
  --nude: #E4DAD0;
  --nude-light: #F6F3EF;
  --nude-cream: #FAF7F3;
  --verde: #596E65;
  --verde-light: #8C9F96;
  --verde-claro: #CBD0B2;
  --verde-pale: #E5E8D1;
  --cinza: #808D96;
  --cinza-light: #B2BBC0;
  --branco: #FFFFFF;
  --erro: #A12B0E;
  --erro-bg: #FBE4DD;

  /* Tipografia */
  --font-display: 'Bricolage Grotesque', system-ui, -apple-system, sans-serif;
  --font-script: 'Borel', cursive;
  --font-body: 'Poppins', system-ui, -apple-system, sans-serif;

  /* Sombras */
  --shadow-sm: 0 1px 2px rgba(89,110,101,.05), 0 1px 3px rgba(89,110,101,.05);
  --shadow: 0 4px 6px -1px rgba(89,110,101,.08), 0 2px 4px -1px rgba(89,110,101,.04);
  --shadow-md: 0 10px 15px -3px rgba(89,110,101,.08), 0 4px 6px -2px rgba(89,110,101,.04);
  --shadow-lg: 0 20px 25px -5px rgba(89,110,101,.10), 0 10px 10px -5px rgba(89,110,101,.04);

  /* Container */
  --container: 1200px;
  --container-sm: 900px;
}

/* ============ RESET ============ */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  background: var(--nude-cream);
  color: var(--verde);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, svg { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .2s; }
button { font-family: inherit; cursor: pointer; }
ul, ol { list-style: none; }

/* ============ TIPOGRAFIA ============ */
.font-display { font-family: var(--font-display); letter-spacing: -.02em; }
.font-script { font-family: var(--font-script); }
.font-body { font-family: var(--font-body); }

h1, h2, h3, h4, h5 {
  font-family: var(--font-display);
  letter-spacing: -.025em;
  color: var(--verde);
  line-height: 1.1;
  font-weight: 700;
}
h1 { font-size: clamp(40px, 6vw, 72px); letter-spacing: -.04em; }
h2 { font-size: clamp(28px, 4vw, 44px); }
h3 { font-size: clamp(22px, 3vw, 32px); font-weight: 600; }
h4 { font-size: clamp(17px, 2vw, 22px); font-weight: 600; }
h5 { font-size: 16px; font-weight: 600; }
p { line-height: 1.7; }

.eyebrow {
  display: inline-block;
  font-size: 12px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--coral);
  font-weight: 600;
  margin-bottom: 8px;
}
.script-accent {
  font-family: var(--font-script);
  color: var(--coral);
  display: inline-block;
}

/* ============ LAYOUT ============ */
.container { max-width: var(--container); margin: 0 auto; padding: 0 24px; }
.container-sm { max-width: var(--container-sm); margin: 0 auto; padding: 0 24px; }

.section { padding: 96px 0; position: relative; overflow: hidden; }
.section-sm { padding: 64px 0; position: relative; overflow: hidden; }

@media (max-width: 768px) {
  .section { padding: 64px 0; }
  .section-sm { padding: 48px 0; }
}

.section-header { text-align: center; margin-bottom: 56px; max-width: 720px; margin-left: auto; margin-right: auto; }
.section-header .eyebrow { margin-bottom: 12px; }
.section-header p { color: var(--cinza); margin-top: 16px; }

/* ============ GRIDS ============ */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.grid-6 { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }

@media (max-width: 1024px) {
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-6 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; gap: 16px; }
  .grid-6 { grid-template-columns: repeat(2, 1fr); }
}

/* ============ BOTÕES ============ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: 999px;
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 15px;
  border: none;
  transition: all .2s;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  line-height: 1;
}
.btn-primary { background: var(--verde); color: var(--branco); }
.btn-primary:hover { background: #48594F; transform: translateY(-1px); box-shadow: var(--shadow); }
.btn-coral { background: var(--coral); color: var(--branco); }
.btn-coral:hover { background: #E89478; transform: translateY(-1px); box-shadow: var(--shadow); }
.btn-outline { background: transparent; color: var(--verde); border: 1.5px solid var(--verde); }
.btn-outline:hover { background: var(--verde); color: var(--branco); }
.btn-glass { background: rgba(255,255,255,.7); backdrop-filter: blur(6px); color: var(--verde); border: 1.5px solid var(--verde); }
.btn-glass:hover { background: var(--verde); color: var(--branco); }
.btn-light { background: var(--branco); color: var(--coral); font-weight: 600; }
.btn-light:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.btn-lg { padding: 18px 36px; font-size: 16px; }

/* ============ CARDS ============ */
.card { background: var(--branco); border-radius: 20px; padding: 32px; box-shadow: var(--shadow-sm); border: 1px solid var(--nude-light); position: relative; overflow: hidden; }
.card-coral { background: linear-gradient(135deg, var(--coral-pale) 0%, var(--branco) 100%); border: 1px solid var(--coral-light); border-radius: 20px; padding: 32px; position: relative; overflow: hidden; }
.card-azul { background: linear-gradient(135deg, var(--azul-light) 0%, var(--branco) 100%); border: 1px solid var(--azul); border-radius: 20px; padding: 32px; position: relative; overflow: hidden; }
.card-amarelo { background: linear-gradient(135deg, var(--amarelo-pale) 0%, var(--branco) 100%); border: 1px solid var(--amarelo-light); border-radius: 20px; padding: 32px; position: relative; overflow: hidden; }
.card-verde { background: linear-gradient(135deg, var(--verde-pale) 0%, var(--branco) 100%); border: 1px solid var(--verde-claro); border-radius: 20px; padding: 32px; position: relative; overflow: hidden; }
.card-soft { background: var(--nude-cream); border: 1px solid var(--nude-light); border-radius: 20px; padding: 32px; position: relative; overflow: hidden; }
.card-dark { background: var(--verde); color: var(--branco); border-radius: 20px; padding: 32px; position: relative; overflow: hidden; }

/* ============ HEADER / NAV ============ */
.site-header {
  position: relative;
  z-index: 100;
  background: linear-gradient(180deg, var(--nude-cream) 0%, rgba(250,247,243,.85) 100%);
  border-bottom: 1px solid rgba(228,218,208,.5);
}
.nav {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  padding: 10px 32px;
  max-width: 1380px;
  margin: 0 auto;
  gap: 20px;
}
.nav-logo {
  display: flex;
  align-items: center;
  justify-self: start;
}
.nav-logo img { width: 240px; height: auto; transition: transform .2s; }
.nav-logo:hover img { transform: scale(1.04); }
.nav-menu {
  display: flex;
  gap: 6px;
  align-items: center;
  justify-self: center;
}
.nav-menu a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  border-radius: 14px;
  font-size: 14px;
  font-weight: 500;
  color: var(--verde);
  background: var(--branco);
  border: 1px solid var(--nude-light);
  transition: all .2s;
  white-space: nowrap;
}
.nav-menu a:hover { background: var(--coral-pale); border-color: var(--coral-light); transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.nav-menu a.active { background: var(--coral); color: var(--branco); border-color: var(--coral); }
.nav-menu a.active .nav-icon { color: var(--branco); }
.nav-icon { font-size: 15px; color: var(--coral); }
.nav-cta {
  justify-self: end;
  padding: 12px 24px !important;
  font-size: 14px !important;
  background: var(--verde) !important;
  color: var(--branco) !important;
  font-weight: 600;
}
.nav-cta:hover {
  background: #48594F !important;
  transform: translateY(-1px);
  box-shadow: var(--shadow);
}
.mobile-only-cta { display: none; }

.menu-toggle {
  display: none;
  align-items: center;
  gap: 6px;
  background: var(--coral);
  border: 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--branco);
  padding: 9px 16px;
  border-radius: 999px;
  box-shadow: var(--shadow);
  letter-spacing: .06em;
  text-transform: uppercase;
  transition: all .2s;
}
.menu-toggle:hover, .menu-toggle:focus { background: #E89478; transform: translateY(-1px); }
.menu-toggle .menu-icon {
  display: inline-flex;
  flex-direction: column;
  gap: 3px;
  width: 14px;
}
.menu-toggle .menu-icon span {
  display: block;
  height: 2px;
  background: var(--branco);
  border-radius: 2px;
  transition: transform .25s;
}
.menu-toggle[aria-expanded="true"] .menu-icon span:nth-child(1) { transform: translateY(5px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] .menu-icon span:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] .menu-icon span:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }

@media (max-width: 1024px) {
  .nav { padding: 10px 20px; }
  .nav-logo img { width: 190px; }
  .nav-menu, .nav-cta { display: none; }
  .nav-menu.open {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: linear-gradient(180deg, var(--nude-cream) 0%, var(--nude-light) 100%);
    padding: 20px 16px;
    gap: 8px;
    box-shadow: 0 12px 32px -8px rgba(89,110,101,.18);
    border-bottom: 1px solid var(--nude);
    z-index: 99;
    animation: menuSlide .35s cubic-bezier(.2,.8,.2,1);
  }
  @keyframes menuSlide {
    from { opacity: 0; transform: translateY(-12px); }
    to { opacity: 1; transform: translateY(0); }
  }
  .nav-menu.open a {
    padding: 14px 16px;
    border-radius: 14px;
    font-size: 16px;
    background: var(--branco);
    border: 1px solid var(--nude);
    box-shadow: var(--shadow-sm);
  }
  .nav-menu.open .nav-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 999px;
    background: var(--coral-pale);
    color: var(--coral);
    font-size: 17px;
    margin-right: 10px;
    flex-shrink: 0;
    transition: all .2s;
  }
  .nav-menu.open a:hover .nav-icon {
    background: var(--coral);
    color: var(--branco);
    transform: scale(1.05);
  }
  .nav-menu.open .mobile-only-cta { display: block; margin-top: 12px; }
  .nav-menu.open .mobile-only-cta a {
    display: flex;
    justify-content: center;
    background: var(--verde) !important;
    color: var(--branco) !important;
    border: 0 !important;
    padding: 16px 20px;
    font-size: 15px;
    font-weight: 600;
    border-radius: 999px;
  }
  .nav-menu.open .mobile-only-cta a:hover {
    background: #48594F !important;
  }
  .menu-toggle { display: inline-flex; }
}

/* Em desktop reduzir um pouco mais quando viewport é menor */
@media (max-width: 1280px) and (min-width: 1025px) {
  .nav-menu a { padding: 10px 14px; font-size: 13px; }
  .nav-logo img { width: 200px; }
}

/* ============ FOOTER ============ */
.site-footer {
  background: var(--verde);
  color: var(--branco);
  padding: 64px 0 32px;
  position: relative;
  overflow: hidden;
}
.footer-graphic {
  position: absolute;
  width: 120px;
  opacity: .12;
  pointer-events: none;
}
.footer-graphic.tr { top: 40px; right: 80px; }
.footer-graphic.bl { bottom: 40px; left: 80px; }
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 32px;
  margin-bottom: 40px;
  position: relative;
}
.footer-grid h5 { font-family: var(--font-display); font-size: 15px; margin-bottom: 14px; color: var(--branco); }
.footer-grid p, .footer-grid a { opacity: .85; line-height: 1.7; font-size: 14px; }
.footer-grid a:hover { opacity: 1; color: var(--coral); }
.footer-logo { width: 240px; margin-bottom: 16px; }
.footer-tagline { font-family: var(--font-script); color: var(--coral); font-size: 24px; margin-bottom: 16px; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: 24px;
  text-align: center;
  opacity: .6;
  font-size: 13px;
  position: relative;
}
@media (max-width: 768px) {
  .footer-grid { grid-template-columns: 1fr; gap: 24px; }
  .footer-logo { width: 200px; }
}

/* ============ HERO ============ */
.hero {
  padding: 140px 24px 120px;
  text-align: center;
  position: relative;
  overflow: hidden;
  background: url('../img/ambientes/fachada-viva.JPG') center 30%/cover no-repeat;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at center, rgba(255,255,255,.55) 0%, rgba(255,255,255,0) 65%),
    linear-gradient(135deg, rgba(247,201,191,.92) 0%, rgba(250,247,243,.85) 33%, rgba(212,225,232,.92) 66%, rgba(247,201,191,.85) 100%);
  background-size: 100% 100%, 300% 300%;
  background-position: center, 0% 50%;
  animation: heroGradient 18s ease-in-out infinite;
  z-index: 1;
  pointer-events: none;
}
@keyframes heroGradient {
  0%, 100% { background-position: center, 0% 50%; }
  50% { background-position: center, 100% 50%; }
}
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 20% 30%, rgba(247,201,191,.3) 0%, transparent 35%),
              radial-gradient(circle at 80% 70%, rgba(178,201,214,.3) 0%, transparent 35%),
              radial-gradient(circle at 50% 50%, rgba(242,192,0,.12) 0%, transparent 40%);
  z-index: 1;
  pointer-events: none;
  animation: heroBlobs 20s ease-in-out infinite;
}
@keyframes heroBlobs {
  0%, 100% { transform: scale(1) rotate(0deg); opacity: .9; }
  50% { transform: scale(1.1) rotate(5deg); opacity: 1; }
}
.hero-content {
  position: relative;
  z-index: 2;
  max-width: 760px;
  margin: 0 auto;
}
.hero h1 {
  font-size: clamp(44px, 7vw, 84px);
  margin-bottom: 16px;
  color: var(--verde);
  text-shadow: 0 2px 12px rgba(255,255,255,.6), 0 4px 32px rgba(255,255,255,.3);
}
.hero-script {
  font-family: var(--font-script);
  font-size: clamp(28px, 4.5vw, 48px);
  color: var(--coral);
  margin: 8px 0 24px;
  line-height: 1.2;
  text-shadow: 0 2px 16px rgba(255,255,255,.7);
  min-height: 1.5em;
  display: block;
}
.hero-script .typed-text {
  display: inline;
}
.hero-script .typed-cursor {
  display: inline-block;
  width: 2px;
  height: .9em;
  background: var(--coral);
  margin-left: 4px;
  vertical-align: text-bottom;
  animation: cursorBlink 1s step-end infinite;
  border-radius: 2px;
}
@keyframes cursorBlink {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0; }
}
.hero-sub {
  display: block;
  max-width: 640px;
  margin: 0 auto 32px;
  font-size: clamp(16px, 2vw, 19px);
  color: var(--verde);
  font-weight: 600;
  text-shadow: 0 2px 12px rgba(255,255,255,.9), 0 0 28px rgba(255,255,255,.55);
  padding: 4px 0;
  position: relative;
}
.hero-sub::before, .hero-sub::after {
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 32px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--coral) 50%, transparent);
  margin: 0 12px;
  opacity: .8;
}
@media (max-width: 768px) {
  .hero-sub::before, .hero-sub::after { width: 18px; margin: 0 6px; }
}
.hero-buttons { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.hero-graphic { position: absolute; pointer-events: none; z-index: 0; }
.hero-graphic.tr { top: 40px; right: 60px; width: 140px; opacity: .85; }
.hero-graphic.bl { bottom: 40px; left: 50px; width: 120px; opacity: .75; }
.hero-graphic.tl { top: 80px; left: 70px; width: 90px; opacity: .65; }
.hero-graphic.mr { top: 50%; right: 4%; width: 80px; opacity: .55; transform: translateY(-50%); }
.hero-illustration { position: absolute; pointer-events: none; z-index: 0; }
.hero-illustration.left { bottom: 12%; left: 3%; width: 110px; opacity: .85; animation: floatY 6s ease-in-out infinite; }
.hero-illustration.right { top: 18%; right: 8%; width: 95px; opacity: .8; animation: floatY 7s ease-in-out infinite reverse; }
.hero-eyebrow { color: #A85F49 !important; }

@keyframes floatY {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}

@media (max-width: 768px) {
  .hero { padding: 80px 24px; }
  .hero-graphic.tr, .hero-graphic.bl, .hero-graphic.tl { width: 70px; opacity: .5; }
  .hero-graphic.mr { display: none; }
  .hero-illustration.left { width: 64px; bottom: 6%; opacity: .65; }
  .hero-illustration.right { width: 60px; top: 8%; opacity: .65; }
}

/* ============ STAKES (espelhar a dor) ============ */
.stakes-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  max-width: 920px;
  margin: 0 auto 40px;
  text-align: left;
}
.stakes-card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  background: var(--branco);
  border: 1px solid var(--nude);
  padding: 24px 26px;
  border-radius: 20px;
  transition: all .3s cubic-bezier(.2,.8,.2,1);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}
.stakes-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 40px -12px rgba(89,110,101,.18);
}
.stakes-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 0%, rgba(247,201,191,.06) 100%);
  opacity: 0;
  transition: opacity .3s;
  pointer-events: none;
}
.stakes-card:hover::after { opacity: 1; }
.stakes-icon {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  flex-shrink: 0;
  font-weight: 700;
  transition: transform .3s;
}
.stakes-card:hover .stakes-icon { transform: scale(1.08) rotate(-4deg); }
.stakes-card.coral .stakes-icon { background: var(--coral-pale); color: var(--coral); }
.stakes-card.coral { border-color: var(--coral-light); }
.stakes-card.azul .stakes-icon { background: var(--azul-light); color: #3D5A6A; }
.stakes-card.azul { border-color: var(--azul); }
.stakes-card.amarelo .stakes-icon { background: var(--amarelo-pale); color: #7A5C00; }
.stakes-card.amarelo { border-color: var(--amarelo-light); }
.stakes-card.verde .stakes-icon { background: var(--verde-pale); color: var(--verde); }
.stakes-card.verde { border-color: var(--verde-claro); }
.stakes-card p {
  font-size: 15px;
  color: var(--verde);
  line-height: 1.5;
  margin: 0;
  font-weight: 500;
}
.stakes-card p strong {
  color: var(--coral);
  font-weight: 700;
}
.stakes-final {
  font-family: var(--font-display);
  font-size: clamp(24px, 3.2vw, 34px);
  font-weight: 700;
  color: var(--coral);
  text-align: center;
  margin-top: 40px;
  letter-spacing: -.02em;
}
@media (max-width: 640px) {
  .stakes-grid { grid-template-columns: 1fr; gap: 14px; }
  .stakes-card { padding: 20px; gap: 14px; }
  .stakes-icon { width: 48px; height: 48px; font-size: 20px; }
}

/* ============ VALUE GRID (6 benefícios) ============ */
.value-card {
  background: var(--branco);
  border: 1px solid var(--nude-light);
  border-radius: 18px;
  padding: 28px 24px;
  text-align: center;
  transition: all .25s;
  box-shadow: var(--shadow-sm);
}
.value-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--coral-light); }
.value-card img { width: 64px; height: 64px; margin: 0 auto 14px; object-fit: contain; }
.value-card h4 { margin-bottom: 8px; }
.value-card p { font-size: 14px; color: var(--cinza); }

/* ============ SOBRE (split) ============ */
.split-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  max-width: 1100px;
  margin: 0 auto;
}
.split-section img { border-radius: 24px; box-shadow: var(--shadow-md); aspect-ratio: 4/5; object-fit: cover; }
.split-section .split-content h2 { margin-bottom: 24px; }
.split-section .split-content p { color: var(--cinza); line-height: 1.7; margin-bottom: 16px; }
.split-section .split-content .signature { font-family: var(--font-script); color: var(--coral); font-size: 26px; margin-top: 24px; }
.split-section .split-content .role { font-size: 13px; color: var(--cinza); }
@media (max-width: 900px) {
  .split-section { grid-template-columns: 1fr; gap: 32px; }
  .split-section img { aspect-ratio: 4/3; max-height: 400px; }
}

/* ============ PLANO (3 passos) ============ */
.plano {
  background: var(--verde);
  color: var(--branco);
  padding: 96px 24px;
  position: relative;
  overflow: hidden;
}
.plano-graphic { position: absolute; opacity: .15; pointer-events: none; width: 120px; }
.plano-graphic.tr { top: 40px; right: 60px; }
.plano-graphic.bl { bottom: 40px; left: 60px; }
.plano-header { text-align: center; margin-bottom: 56px; position: relative; }
.plano-header .eyebrow { color: var(--coral); }
.plano-header h2 { color: var(--branco); }
.plano-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; max-width: 900px; margin: 0 auto; position: relative; }
.plano-step { text-align: center; padding: 24px; }
.plano-step-num {
  width: 64px;
  height: 64px;
  border-radius: 20px;
  background: var(--coral);
  color: var(--branco);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 700;
  font-family: var(--font-display);
  margin-bottom: 16px;
}
.plano-step h4 { color: var(--branco); margin-bottom: 8px; }
.plano-step p { font-size: 14px; opacity: .85; }
.plano-cta { text-align: center; margin-top: 40px; position: relative; }
@media (max-width: 768px) { .plano-grid { grid-template-columns: 1fr; gap: 16px; } }

/* ============ TOUR DA CLÍNICA (grid 3x2) ============ */
.tour-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  max-width: 1100px;
  margin: 0 auto;
}
.tour-grid > div {
  aspect-ratio: 1;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  background: var(--nude-cream);
}
.tour-grid img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 768px) { .tour-grid { grid-template-columns: repeat(2, 1fr); } }

/* ============ EQUIPE PREVIEW ============ */
.equipe-preview {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  max-width: 1000px;
  margin: 0 auto;
}
.doctor-mini {
  background: var(--branco);
  border: 1px solid var(--nude-light);
  border-radius: 16px;
  padding: 18px;
  text-align: center;
  transition: all .25s;
  box-shadow: var(--shadow-sm);
}
.doctor-mini:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--coral-light); }
.doctor-mini img {
  width: 96px;
  height: 96px;
  border-radius: 24px;
  object-fit: cover;
  object-position: center top;
  margin: 0 auto 12px;
}
.doctor-mini-name { font-family: var(--font-display); font-weight: 700; font-size: 14px; color: var(--verde); margin-bottom: 4px; }
.doctor-mini-spec { font-size: 11px; color: var(--coral); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }
.doctor-mini-more {
  background: linear-gradient(135deg, var(--coral-pale), var(--nude-cream));
  cursor: pointer;
}
.doctor-mini-more .num {
  width: 96px;
  height: 96px;
  border-radius: 24px;
  background: linear-gradient(135deg, var(--coral), var(--amarelo));
  color: var(--branco);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 28px;
  margin: 0 auto 12px;
}
@media (max-width: 768px) { .equipe-preview { grid-template-columns: repeat(2, 1fr); } }

/* ============ EQUIPE COMPLETA (página /equipe) ============ */
.doctor-card {
  background: var(--branco);
  border-radius: 20px;
  padding: 24px;
  border: 1px solid var(--nude-light);
  box-shadow: var(--shadow-sm);
  transition: all .25s;
  display: flex;
  flex-direction: column;
  gap: 14px;
  height: 100%;
}
.doctor-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--coral-light); }
.doctor-card-header { display: flex; align-items: center; gap: 16px; }
.doctor-card img {
  width: 96px;
  height: 96px;
  border-radius: 24px;
  flex-shrink: 0;
  object-fit: cover;
  object-position: center top;
}
.doctor-card-name { font-family: var(--font-display); font-weight: 700; font-size: 17px; color: var(--verde); line-height: 1.2; }
.doctor-card-spec { font-size: 12px; color: var(--coral); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; margin-top: 4px; }
.doctor-card-bio { font-size: 13.5px; color: var(--cinza); line-height: 1.6; flex: 1; }
.doctor-card-crm { font-size: 11px; color: var(--cinza-light); border-top: 1px solid var(--nude-light); padding-top: 10px; margin-top: auto; letter-spacing: .04em; }
.doctor-card.featured { border: 2px solid var(--coral); background: linear-gradient(180deg, var(--coral-pale) 0%, var(--branco) 60%); }

/* ============ LOCALIZAÇÃO (mapa + info) ============ */
.localizacao-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 32px;
  max-width: 1100px;
  margin: 0 auto;
  align-items: stretch;
}
.localizacao-info { display: flex; flex-direction: column; gap: 14px; }
.localizacao-info .card-coral, .localizacao-info .card-soft, .localizacao-info .card { padding: 24px; }
.contact-pill {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--branco);
  padding: 18px 20px;
  border-radius: 16px;
  border: 1px solid var(--nude-light);
}
.contact-pill .icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--branco);
  flex-shrink: 0;
}
.contact-pill .icon svg { width: 26px; height: 26px; fill: currentColor; }
.contact-pill .icon.whatsapp { background: #25D366; }
.contact-pill .icon.instagram { background: linear-gradient(135deg, #F58529, #DD2A7B, #8134AF); }
.contact-pill .icon.phone { background: var(--verde); }
.contact-pill .label { font-size: 11px; color: var(--cinza); letter-spacing: .1em; text-transform: uppercase; }
.contact-pill .value { font-family: var(--font-display); font-weight: 600; font-size: 15px; color: var(--verde); }
.localizacao-map {
  border-radius: 20px;
  overflow: hidden;
  box-shadow: var(--shadow-md);
  min-height: 400px;
  background: var(--nude-cream);
}
.localizacao-map iframe { width: 100%; height: 100%; min-height: 400px; border: 0; display: block; }
@media (max-width: 900px) {
  .localizacao-grid { grid-template-columns: 1fr; }
  .localizacao-map { min-height: 320px; }
}

/* ============ CTA FINAL ============ */
.cta-final {
  background: linear-gradient(135deg, var(--coral-pale), var(--azul-light));
  padding: 96px 24px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-final-graphic { position: absolute; opacity: .5; pointer-events: none; width: 100px; }
.cta-final-graphic.tl { top: 40px; left: 60px; }
.cta-final-graphic.br { bottom: 40px; right: 60px; }
.cta-final h2 {
  font-size: clamp(32px, 5vw, 56px);
  margin-bottom: 16px;
  position: relative;
}
.cta-final p { color: var(--cinza); max-width: 480px; margin: 0 auto 32px; position: relative; }
.cta-final .hero-buttons { position: relative; }
.cta-final.coral {
  background: linear-gradient(135deg, var(--coral), #E89478);
  color: var(--branco);
}
.cta-final.coral h2 { color: var(--branco); }
.cta-final.coral p { color: rgba(255,255,255,.9); }

/* ============ FAQ ACCORDION ============ */
.faq-list { max-width: 740px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.faq-item { background: var(--branco); border: 1px solid var(--nude-light); border-radius: 16px; padding: 20px 24px; box-shadow: var(--shadow-sm); }
.faq-item summary { font-family: var(--font-display); font-weight: 600; color: var(--verde); cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; font-size: 15px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; color: var(--coral); font-size: 24px; font-weight: 400; transition: transform .2s; }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item p { margin-top: 12px; color: var(--cinza); font-size: 14px; line-height: 1.7; }

/* ============ WHATSAPP FLOAT ============ */
.whatsapp-float {
  position: fixed;
  bottom: 24px;
  right: 24px;
  background: #25D366;
  color: white;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  box-shadow: var(--shadow-lg);
  z-index: 90;
  transition: transform .2s;
}
.whatsapp-float:hover { transform: scale(1.1); }
.whatsapp-float svg { width: 32px; height: 32px; fill: currentColor; }

/* ============ GRAFISMOS DECORATIVOS ============ */
.graphic-bg {
  position: absolute;
  pointer-events: none;
  z-index: 0;
}

/* ============ UTILITÁRIOS ============ */
.text-center { text-align: center; }
.text-coral { color: var(--coral); }
.text-verde { color: var(--verde); }
.text-cinza { color: var(--cinza); }
.relative { position: relative; }
.z-2 { z-index: 2; }
.mb-1 { margin-bottom: 4px; }
.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 12px; }
.mb-4 { margin-bottom: 16px; }
.mb-6 { margin-bottom: 24px; }
.mb-8 { margin-bottom: 32px; }
.mt-3 { margin-top: 12px; }
.mt-4 { margin-top: 16px; }
.mt-6 { margin-top: 24px; }

/* ============ ANIMAÇÕES ON-SCROLL ============ */
@media (prefers-reduced-motion: no-preference) {
  [data-animate] {
    opacity: 0;
    transform: translateY(36px);
    transition: opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1);
    will-change: opacity, transform;
  }
  [data-animate="fade-left"]  { transform: translateX(-36px) translateY(0); }
  [data-animate="fade-right"] { transform: translateX(36px) translateY(0); }
  [data-animate="scale"]      { transform: scale(.92); }
  [data-animate="zoom"]       { transform: scale(.85); }

  [data-animate].is-visible {
    opacity: 1;
    transform: translate(0, 0) scale(1);
  }
}
@media (prefers-reduced-motion: reduce) {
  [data-animate] { opacity: 1 !important; transform: none !important; }
}

/* ============ SESSÃO INSTAGRAM ============ */
.instagram-section { background: var(--branco); position: relative; }
.instagram-handle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(135deg, #F58529, #DD2A7B, #8134AF);
  color: var(--branco);
  padding: 10px 22px;
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 12px;
  text-decoration: none;
  box-shadow: 0 4px 14px rgba(221,42,123,.25);
  transition: transform .2s;
}
.instagram-handle:hover { transform: translateY(-1px); }
.instagram-handle svg { width: 20px; height: 20px; fill: currentColor; }
.instagram-cta svg { width: 22px; height: 22px; fill: currentColor; }
.instagram-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  max-width: 1100px;
  margin: 0 auto;
}
.instagram-post {
  position: relative;
  aspect-ratio: 1;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  transition: all .3s;
  background: var(--nude-cream);
}
.instagram-post:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.instagram-post img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s;
}
.instagram-post:hover img { transform: scale(1.06); }
.instagram-post-text {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  text-align: center;
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -.02em;
  line-height: 1.2;
  position: relative;
  overflow: hidden;
}
.instagram-post-text.coral { background: linear-gradient(135deg, var(--coral), #E89478); color: var(--branco); }
.instagram-post-text.verde { background: linear-gradient(135deg, var(--verde), #6E837A); color: var(--branco); }
.instagram-post-text.amarelo { background: linear-gradient(135deg, var(--amarelo-light), var(--amarelo)); color: var(--verde); }
.instagram-post-text .post-graphic {
  position: absolute;
  width: 80px;
  opacity: .25;
  top: 16px;
  right: 16px;
  pointer-events: none;
}
.instagram-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,.7) 100%);
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  padding: 16px;
  color: var(--branco);
  font-size: 13px;
  font-weight: 600;
  opacity: 0;
  transition: opacity .25s;
}
.instagram-post:hover .instagram-overlay { opacity: 1; }
.instagram-overlay .stat {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.instagram-cta-wrap { text-align: center; margin-top: 40px; }
.instagram-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 32px;
  background: linear-gradient(135deg, #F58529, #DD2A7B, #8134AF);
  color: var(--branco);
  border-radius: 999px;
  font-weight: 600;
  font-size: 15px;
  box-shadow: 0 8px 24px rgba(221,42,123,.3);
  transition: all .25s;
  text-decoration: none;
}
.instagram-cta:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(221,42,123,.4); }
@media (max-width: 768px) {
  .instagram-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .instagram-post-text { font-size: 16px; }
}

/* ============ CARROSSEL DA EQUIPE ============ */
.carousel-wrap {
  position: relative;
  max-width: 1280px;
  margin: 0 auto;
}
.carousel {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scroll-padding-left: 24px;
  padding: 8px 24px 24px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.carousel::-webkit-scrollbar { display: none; }
.carousel-card {
  flex: 0 0 400px;
  scroll-snap-align: start;
  background: var(--branco);
  border-radius: 24px;
  padding: 36px 32px;
  border: 1px solid var(--nude-light);
  border-top: 5px solid var(--coral-light);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 18px;
  transition: all .3s cubic-bezier(.2,.8,.2,1);
  position: relative;
  overflow: hidden;
}
.carousel-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(89,110,101,.02));
  pointer-events: none;
  border-radius: inherit;
}
.carousel-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 40px -12px rgba(89,110,101,.18);
}
/* Bordas coloridas rotativas (4 cores por ciclo, pulando os featured) */
.carousel-card:not(.featured):nth-of-type(4n+3) { border-top-color: var(--coral); background: linear-gradient(180deg, var(--coral-pale) 0%, var(--branco) 35%); }
.carousel-card:not(.featured):nth-of-type(4n)   { border-top-color: var(--azul);  background: linear-gradient(180deg, var(--azul-light) 0%, var(--branco) 35%); }
.carousel-card:not(.featured):nth-of-type(4n+1) { border-top-color: var(--amarelo); background: linear-gradient(180deg, var(--amarelo-pale) 0%, var(--branco) 35%); }
.carousel-card:not(.featured):nth-of-type(4n+2) { border-top-color: var(--verde-claro); background: linear-gradient(180deg, var(--verde-pale) 0%, var(--branco) 35%); }
/* Featured (Pedro + Fernanda) — destaque maior */
.carousel-card.featured {
  border: 2px solid var(--coral);
  border-top: 6px solid var(--coral);
  background: linear-gradient(180deg, var(--coral-pale) 0%, var(--branco) 50%);
  box-shadow: 0 12px 28px -8px rgba(242,170,148,.4);
}
.carousel-card-header {
  display: flex;
  align-items: center;
  gap: 18px;
  position: relative;
  z-index: 1;
}
.carousel-card-photo {
  width: 120px;
  height: 120px;
  border-radius: 28px;
  object-fit: cover;
  object-position: center top;
  flex-shrink: 0;
  background: var(--nude);
  box-shadow: 0 6px 18px rgba(89,110,101,.12);
  border: 3px solid var(--branco);
}
.carousel-card.featured .carousel-card-photo {
  border-color: var(--coral-pale);
  box-shadow: 0 8px 24px rgba(242,170,148,.35);
}
.carousel-card-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 19px;
  color: var(--verde);
  line-height: 1.15;
  margin-bottom: 6px;
  letter-spacing: -.01em;
}
.carousel-card-spec {
  font-size: 12px;
  color: var(--coral);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  line-height: 1.3;
}
.carousel-card-bio {
  font-size: 14px;
  color: var(--cinza);
  line-height: 1.65;
  flex: 1;
  position: relative;
  z-index: 1;
}
.carousel-card-bio strong { color: var(--verde); font-weight: 600; }
.carousel-card-crm {
  font-size: 11.5px;
  color: var(--cinza-light);
  letter-spacing: .04em;
  border-top: 1px solid rgba(228,218,208,.6);
  padding-top: 14px;
  margin-top: auto;
  font-weight: 500;
  position: relative;
  z-index: 1;
}
.carousel-card.featured .carousel-card-crm { border-top-color: var(--coral-light); color: var(--coral); }
.carousel-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: var(--branco);
  color: var(--verde);
  border: 1px solid var(--nude);
  font-size: 22px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow);
  z-index: 2;
  transition: all .2s;
  cursor: pointer;
}
.carousel-nav:hover { background: var(--coral); color: var(--branco); border-color: var(--coral); transform: translateY(-50%) scale(1.05); }
.carousel-nav:disabled { opacity: .3; cursor: not-allowed; }
.carousel-nav.prev { left: -8px; }
.carousel-nav.next { right: -8px; }
.carousel-hint {
  text-align: center;
  font-size: 12px;
  color: var(--cinza);
  margin-top: 8px;
  letter-spacing: .04em;
}
@media (max-width: 768px) {
  .carousel-card { flex: 0 0 min(88vw, 380px); padding: 32px 26px; gap: 16px; }
  .carousel-card-photo { width: 110px; height: 110px; border-radius: 24px; }
  .carousel-card-name { font-size: 18px; }
  .carousel-card-spec { font-size: 12px; }
  .carousel-card-bio { font-size: 14px; }
  .carousel-nav { width: 44px; height: 44px; font-size: 20px; }
  .carousel-nav.prev { left: 8px; }
  .carousel-nav.next { right: 8px; }
}

/* ============ MOBILE — REORDENAR SEÇÕES ============ */
@media (max-width: 768px) {
  /* Mais contraste no hero mobile */
  .hero h1 { text-shadow: 0 2px 8px rgba(255,255,255,.85), 0 4px 24px rgba(255,255,255,.5); }
  .hero-script { text-shadow: 0 2px 12px rgba(255,255,255,.8); }
  .hero-sub { font-size: 15px; padding: 12px 20px; }
}

/* ============ ACESSIBILIDADE ============ */
:focus-visible { outline: 2px solid var(--coral); outline-offset: 3px; }
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
</content>
</invoke>
/* ============================================================
   TEMA SKEUMORPHISM — CONSOLIDADO (foi skeumorphism.css)
   ============================================================ */
/* ============================================================
   VIVA PEDIATRIA — TEMA SKEUMORPHISM
   Texturas de papel, sombras profundas, relevo realista,
   gradientes que imitam superfícies físicas, emboss tipográfico
   ============================================================ */

/* === Background do site com textura de papel === */
body {
  background:
    radial-gradient(ellipse at 20% 10%, rgba(247,201,191,.18) 0%, transparent 40%),
    radial-gradient(ellipse at 80% 90%, rgba(178,201,214,.15) 0%, transparent 40%),
    repeating-linear-gradient(45deg, transparent 0, transparent 2px, rgba(89,110,101,.012) 2px, rgba(89,110,101,.012) 4px),
    var(--nude-cream);
  background-attachment: fixed;
}

/* === Header — sticky com divisão sutil discreta === */
.site-header {
  background: rgba(252,247,239,.75) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(212,199,181,.4) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.85),
    0 1px 0 rgba(255,255,255,.5),
    0 4px 14px rgba(89,110,101,.04) !important;
  position: sticky !important;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  transition: background .3s, backdrop-filter .3s;
}
.nav-logo img {
  width: 220px !important;
  height: auto;
  filter:
    drop-shadow(0 8px 18px rgba(89,110,101,.25))
    drop-shadow(0 3px 6px rgba(89,110,101,.18))
    drop-shadow(0 1px 2px rgba(168,95,73,.2));
  transition: transform .3s cubic-bezier(.2,.8,.2,1);
}
.nav-logo:hover img {
  transform: scale(1.04) rotate(-2deg);
}
@media (max-width: 1024px) {
  .nav-logo img { width: 170px !important; }
}
@media (max-width: 480px) {
  .nav-logo img { width: 160px !important; }
}

/* Items do menu — relevo de tecla */
.nav-menu a {
  background: linear-gradient(180deg, #FFFFFF 0%, #F4EFE7 100%);
  border: 1px solid #D4C7B5;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -1px 0 rgba(89,110,101,.08),
    0 1px 2px rgba(89,110,101,.08);
  text-shadow: 0 1px 0 rgba(255,255,255,.7);
}
.nav-menu a:hover {
  background: linear-gradient(180deg, var(--coral-pale) 0%, #F2C9BD 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.6),
    inset 0 -1px 0 rgba(168,95,73,.12),
    0 2px 6px rgba(168,95,73,.18);
}
.nav-menu a.active {
  background: linear-gradient(180deg, #F4B69E 0%, var(--coral) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    inset 0 -2px 4px rgba(168,95,73,.3),
    0 2px 6px rgba(168,95,73,.25);
  color: #fff;
  text-shadow: 0 -1px 0 rgba(168,95,73,.4);
}

/* === Botão "Agendar" — botão 3D realista === */
.nav-cta, .btn-primary {
  background: linear-gradient(180deg, #6E8479 0%, var(--verde) 50%, #4D5F56 100%) !important;
  border: 1px solid #3F4E47 !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.25),
    inset 0 -2px 4px rgba(0,0,0,.2),
    0 4px 10px rgba(89,110,101,.35),
    0 1px 2px rgba(89,110,101,.4) !important;
  text-shadow: 0 -1px 0 rgba(0,0,0,.3);
}
.nav-cta:hover, .btn-primary:hover {
  background: linear-gradient(180deg, #7E9489 0%, #6E8479 50%, var(--verde) 100%) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.3),
    inset 0 -2px 4px rgba(0,0,0,.15),
    0 6px 14px rgba(89,110,101,.45),
    0 2px 4px rgba(89,110,101,.5) !important;
  transform: translateY(-1px);
}

.btn-coral {
  background: linear-gradient(180deg, #F8C5B6 0%, var(--coral) 50%, #DC8E76 100%) !important;
  border: 1px solid #BF7762;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.5),
    inset 0 -2px 4px rgba(168,95,73,.3),
    0 4px 10px rgba(168,95,73,.35) !important;
  text-shadow: 0 -1px 0 rgba(168,95,73,.3);
}
.btn-outline {
  background: linear-gradient(180deg, #FCFAF6 0%, #EFE9DD 100%);
  border: 1.5px solid var(--verde);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    inset 0 -1px 0 rgba(89,110,101,.06),
    0 2px 6px rgba(89,110,101,.12);
}
.btn-glass {
  background: linear-gradient(180deg, rgba(255,255,255,.85) 0%, rgba(244,239,231,.8) 100%) !important;
  border: 1px solid rgba(89,110,101,.3);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    0 4px 12px rgba(89,110,101,.18) !important;
}

/* === Hero — papel envelhecido com vinheta === */
.hero {
  box-shadow: inset 0 -8px 24px rgba(89,110,101,.08);
}
.hero h1 {
  text-shadow:
    0 1px 0 rgba(255,255,255,.6),
    0 2px 0 rgba(255,255,255,.4),
    0 4px 16px rgba(89,110,101,.2),
    0 8px 32px rgba(255,255,255,.4);
}
.hero-script {
  text-shadow:
    0 1px 0 rgba(255,255,255,.7),
    0 2px 6px rgba(168,95,73,.15);
}
.hero-sub {
  text-shadow: 0 1px 0 rgba(255,255,255,.95), 0 2px 4px rgba(89,110,101,.12);
}

/* === Cards (todos) — relevo de papel cartão suspenso === */
.card, .card-coral, .card-azul, .card-amarelo, .card-verde, .card-soft,
.value-card, .stakes-card, .contact-pill, .plano-step,
.faq-item, .doctor-card {
  background:
    linear-gradient(180deg, #FFFFFF 0%, #F8F4EC 100%);
  border: 1px solid #D4C7B5 !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -1px 0 rgba(89,110,101,.04),
    0 1px 2px rgba(89,110,101,.06),
    0 4px 8px rgba(89,110,101,.06),
    0 12px 24px rgba(89,110,101,.08) !important;
}

/* Stakes — cada card com cor + relevo */
.stakes-card.coral {
  background: linear-gradient(180deg, #FCEEE9 0%, #F7DDD2 100%);
  border-color: #E5A593 !important;
}
.stakes-card.azul {
  background: linear-gradient(180deg, #E5EEF3 0%, #C5D6E0 100%);
  border-color: #A1B5C1 !important;
}
.stakes-card.amarelo {
  background: linear-gradient(180deg, #FCF1C8 0%, #F4DD92 100%);
  border-color: #C9A852 !important;
}
.stakes-card.verde {
  background: linear-gradient(180deg, #ECEED7 0%, #C9CFAA 100%);
  border-color: #889071 !important;
}
.stakes-icon {
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.9), rgba(255,255,255,.4) 60%, transparent 75%) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    inset 0 -2px 4px rgba(89,110,101,.12),
    0 4px 10px rgba(89,110,101,.18);
  border: 1px solid rgba(89,110,101,.15);
}

/* === Footer — papel kraft com furos === */
.site-footer {
  background:
    repeating-linear-gradient(45deg, transparent 0, transparent 2px, rgba(0,0,0,.06) 2px, rgba(0,0,0,.06) 4px),
    linear-gradient(180deg, var(--verde) 0%, #4A5C53 100%);
  box-shadow: inset 0 4px 12px rgba(0,0,0,.18);
}

/* === Inputs e Iframes === */
.localizacao-map {
  border: 4px solid #FCFAF6;
  box-shadow:
    inset 0 0 0 1px #D4C7B5,
    0 8px 20px rgba(89,110,101,.18),
    0 2px 4px rgba(89,110,101,.12);
}

/* === Carrossel — cards como pequenos quadros emoldurados, cada um com sua cor === */
.carousel-card {
  background: linear-gradient(180deg, #FFFFFF 0%, #F8F4EC 100%) !important;
  border: 1px solid #D4C7B5 !important;
  border-top: 5px solid var(--coral-light) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 4px rgba(89,110,101,.08),
    0 8px 16px rgba(89,110,101,.10),
    0 16px 32px rgba(89,110,101,.06) !important;
}

/* Cores rotativas (4 ciclo) — cada card com matiz pastel + sombra colorida coordenada */
.carousel-card:not(.featured):nth-of-type(4n+3) {
  background: linear-gradient(180deg, #FCEEE9 0%, #F8DDD2 35%, #FFFFFF 100%) !important;
  border-color: #E5A593 !important;
  border-top-color: var(--coral) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -1px 0 rgba(168,95,73,.06),
    0 2px 4px rgba(228,165,147,.20),
    0 8px 16px rgba(228,165,147,.22),
    0 16px 32px rgba(228,165,147,.12) !important;
}

.carousel-card:not(.featured):nth-of-type(4n) {
  background: linear-gradient(180deg, #E5EEF3 0%, #CDD9E1 35%, #FFFFFF 100%) !important;
  border-color: #9BB0BD !important;
  border-top-color: #6F8B9C !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -1px 0 rgba(94,124,140,.06),
    0 2px 4px rgba(143,170,184,.22),
    0 8px 16px rgba(143,170,184,.22),
    0 16px 32px rgba(143,170,184,.12) !important;
}

.carousel-card:not(.featured):nth-of-type(4n+1) {
  background: linear-gradient(180deg, #FCF1C8 0%, #F4DD92 35%, #FFFFFF 100%) !important;
  border-color: #C9A852 !important;
  border-top-color: var(--amarelo) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -1px 0 rgba(120,90,15,.06),
    0 2px 4px rgba(220,180,40,.22),
    0 8px 16px rgba(220,180,40,.22),
    0 16px 32px rgba(220,180,40,.12) !important;
}

.carousel-card:not(.featured):nth-of-type(4n+2) {
  background: linear-gradient(180deg, #ECEED7 0%, #D2D7B6 35%, #FFFFFF 100%) !important;
  border-color: #889071 !important;
  border-top-color: var(--verde-claro) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -1px 0 rgba(70,90,75,.06),
    0 2px 4px rgba(140,160,130,.22),
    0 8px 16px rgba(140,160,130,.22),
    0 16px 32px rgba(140,160,130,.12) !important;
}

/* Featured (Pedro + Fernanda) — destaque coral mais saturado, mantendo aura especial */
.carousel-card.featured {
  background: linear-gradient(180deg, #FCEEE9 0%, #F8DDD2 50%, #FFFFFF 100%) !important;
  border: 2px solid var(--coral) !important;
  border-top: 6px solid var(--coral) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.7),
    0 4px 8px rgba(168,95,73,.25),
    0 12px 28px rgba(168,95,73,.30),
    0 24px 48px rgba(168,95,73,.14) !important;
}
.carousel-card-photo {
  border: 4px solid #FCFAF6 !important;
  box-shadow:
    inset 0 0 0 1px #D4C7B5,
    0 4px 10px rgba(89,110,101,.22),
    0 1px 2px rgba(89,110,101,.18) !important;
}
.carousel-nav {
  background: linear-gradient(180deg, #FCFAF6 0%, #EFE9DD 100%) !important;
  border: 1px solid #C9BBA7 !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    inset 0 -1px 0 rgba(89,110,101,.06),
    0 2px 6px rgba(89,110,101,.18),
    0 6px 14px rgba(89,110,101,.12) !important;
  text-shadow: 0 1px 0 rgba(255,255,255,.6);
}

/* === Plano (verde) — relevo escuro === */
.plano {
  background:
    repeating-linear-gradient(45deg, transparent 0, transparent 3px, rgba(0,0,0,.04) 3px, rgba(0,0,0,.04) 6px),
    linear-gradient(180deg, #6E8479 0%, var(--verde) 50%, #4A5C53 100%);
  box-shadow: inset 0 6px 18px rgba(0,0,0,.2), inset 0 -6px 18px rgba(0,0,0,.2);
}
.plano-step-num {
  background: radial-gradient(circle at 30% 30%, #F8C5B6, var(--coral) 70%, #BF7762) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    inset 0 -3px 6px rgba(168,95,73,.4),
    0 4px 10px rgba(168,95,73,.4),
    0 8px 18px rgba(168,95,73,.3);
  text-shadow: 0 -1px 0 rgba(168,95,73,.45);
}

/* === Tour grid — molduras de polaróide === */
.tour-grid > div {
  border: 6px solid #FCFAF6;
  box-shadow:
    inset 0 0 0 1px rgba(89,110,101,.12),
    0 2px 4px rgba(89,110,101,.12),
    0 8px 16px rgba(89,110,101,.18);
}
.tour-grid > div:nth-child(odd) { transform: rotate(-1deg); }
.tour-grid > div:nth-child(even) { transform: rotate(.8deg); }
.tour-grid > div:hover { transform: rotate(0) scale(1.03); }

/* === Instagram posts — molduras === */
.instagram-post {
  border: 4px solid #FCFAF6;
  box-shadow:
    inset 0 0 0 1px rgba(89,110,101,.1),
    0 6px 14px rgba(89,110,101,.16),
    0 2px 4px rgba(89,110,101,.1);
}
.instagram-handle, .instagram-cta {
  background:
    linear-gradient(180deg, rgba(255,255,255,.2) 0%, transparent 50%),
    linear-gradient(135deg, #F58529, #DD2A7B, #8134AF) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    inset 0 -2px 4px rgba(0,0,0,.18),
    0 4px 10px rgba(221,42,123,.4),
    0 8px 18px rgba(221,42,123,.25) !important;
  text-shadow: 0 -1px 0 rgba(0,0,0,.18);
}

/* === CTA Final — papel craft, conteúdo centralizado === */
.cta-final {
  background:
    repeating-linear-gradient(135deg, transparent 0, transparent 8px, rgba(89,110,101,.025) 8px, rgba(89,110,101,.025) 16px),
    linear-gradient(135deg, var(--coral-pale) 0%, #FCEFCC 50%, var(--azul-light) 100%);
  box-shadow: inset 0 8px 20px rgba(89,110,101,.1);
  text-align: center;
}
.cta-final h2 {
  text-shadow: 0 1px 0 rgba(255,255,255,.7), 0 2px 6px rgba(89,110,101,.15);
  text-align: center;
}
.cta-final p { text-align: center; }
.cta-final .hero-buttons {
  display: flex;
  gap: 16px;
  justify-content: center !important;
  flex-wrap: wrap;
  margin: 0 auto;
  max-width: 600px;
}

/* === Footer — centralizado no mobile === */
@media (max-width: 768px) {
  .site-footer .footer-grid > div { text-align: center; }
  .site-footer .footer-logo { margin: 0 auto 12px; }
  .site-footer .footer-tagline { text-align: center; }
}

/* === Fotos com moldura === */
.split-section img,
.doctor-card img {
  border: 4px solid #FCFAF6 !important;
  box-shadow:
    inset 0 0 0 1px rgba(89,110,101,.1),
    0 4px 10px rgba(89,110,101,.18),
    0 12px 24px rgba(89,110,101,.15) !important;
}

/* === Contact pills com ícones em relevo === */
.contact-pill .icon.whatsapp {
  background: radial-gradient(circle at 30% 30%, #56E48A, #25D366 60%, #1AAA52);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    inset 0 -2px 4px rgba(0,0,0,.2),
    0 4px 8px rgba(37,211,102,.4);
}
.contact-pill .icon.instagram {
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.3), transparent 50%),
    linear-gradient(135deg, #F58529, #DD2A7B, #8134AF);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    inset 0 -2px 4px rgba(0,0,0,.18),
    0 4px 8px rgba(221,42,123,.4);
}

/* === Eyebrow texts com letterpress === */
.eyebrow, .page-eyebrow {
  text-shadow: 0 1px 0 rgba(255,255,255,.7), 0 -1px 0 rgba(89,110,101,.04);
}

/* === Menu toggle (mobile) com botão físico — pequeno e discreto === */
.menu-toggle {
  background: linear-gradient(180deg, #F4B69E 0%, var(--coral) 50%, #BF7762 100%) !important;
  border: 1px solid #A85F49 !important;
  padding: 8px 14px !important;
  font-size: 11px !important;
  gap: 6px !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    inset 0 -2px 4px rgba(168,95,73,.3),
    0 4px 8px rgba(168,95,73,.35) !important;
  text-shadow: 0 -1px 0 rgba(168,95,73,.4);
}
.menu-toggle .menu-icon { width: 12px !important; gap: 2px !important; }

/* === WhatsApp float — botão circular volumoso === */
.whatsapp-float {
  background: radial-gradient(circle at 30% 30%, #56E48A, #25D366 60%, #1AAA52) !important;
  box-shadow:
    inset 0 2px 4px rgba(255,255,255,.4),
    inset 0 -3px 6px rgba(0,0,0,.2),
    0 6px 14px rgba(37,211,102,.45),
    0 12px 28px rgba(37,211,102,.35),
    0 2px 4px rgba(0,0,0,.18) !important;
}

/* === Ajuste de bordas e separadores === */
hr.divider, .footer-bottom {
  border-color: rgba(255,255,255,.18);
}

/* === Cursor do typewriter em coral relevo === */
.hero-script .typed-cursor {
  background: linear-gradient(180deg, var(--coral), #BF7762);
  box-shadow: 0 0 4px rgba(168,95,73,.4);
}

/* ============================================================
   HERO V3 — Centralizado, foto criança + fachada mescladas no fundo
   ============================================================ */
.hero {
  padding: 80px 24px 80px !important;
  min-height: 780px;
  position: relative;
  background:
    /* transição fluida pro stakes na base — sem corte seco */
    linear-gradient(180deg, transparent 0%, transparent 80%, var(--nude-cream) 100%),
    /* gradiente claro topo+bottom — destaca conteúdo */
    linear-gradient(180deg, rgba(252,247,239,.55) 0%, rgba(252,247,239,.15) 30%, rgba(252,247,239,.45) 100%),
    /* foto 18 (foguete) — mesclada à esquerda, baixa pra alinhar com fim do hero */
    url('../img/criancas/18.png') left 2% bottom -8%/auto 70% no-repeat,
    /* foto 11 (escada) — mesclada à direita */
    url('../img/criancas/11.png') right -3% bottom 0/auto 88% no-repeat,
    /* fachada — base */
    url('../img/ambientes/fachada-viva.JPG') center 30%/cover no-repeat !important;
}
@media (max-width: 768px) {
  .hero {
    min-height: 720px !important;
    background:
      /* transição fluida pro stakes na parte de baixo */
      linear-gradient(180deg, transparent 0%, transparent 75%, var(--nude-cream) 100%),
      linear-gradient(180deg, rgba(252,247,239,.55) 0%, rgba(252,247,239,.2) 30%, rgba(252,247,239,.4) 100%),
      /* foto 11 (astronauta) — ESQUERDA, MUITO MAIOR e DESTACADA, aparece acima dos stats */
      url('../img/criancas/11.png') left -10% bottom 5%/auto 75% no-repeat,
      /* foto 18 (foguete) — DIREITA inferior, menor */
      url('../img/criancas/18.png') right -12% bottom 8%/auto 38% no-repeat,
      url('../img/ambientes/fachada-viva.JPG') center 30%/cover no-repeat !important;
  }
  /* Tirar arco-íris no mobile (estava mal posicionado) */
  .hero-graphic.tr { display: none !important; }
}
.hero::before, .hero::after { z-index: 0; }

/* Conteúdo centralizado, com altura FIXA pra nada mover */
.hero-content {
  position: relative;
  z-index: 3;
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}
.hero h1 {
  text-align: center;
  font-size: clamp(40px, 5.6vw, 72px);
  margin-bottom: 8px;
  font-weight: 800;
}
.hero-eyebrow { display: inline-block; }

/* Wrap do typewriter — altura fixa absoluta + texto centralizado, sem cortar */
.hero-script-wrap {
  height: 7em;
  position: relative;
  margin: 16px 0 12px;
  overflow: visible;
}
.hero-script {
  position: absolute !important;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  max-width: 720px;
  text-align: center !important;
  line-height: 1.5 !important;
  margin: 0 !important;
  padding: 0.3em 0 !important;
  overflow: visible;
}
.hero-script .typed-text { display: inline; line-height: 1.5; }
@media (max-width: 768px) {
  .hero-script-wrap { height: 8.5em; }
  .hero-script { line-height: 1.5 !important; }
}

/* Stats — números centralizados */
.hero-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin: 24px auto 32px;
  max-width: 600px;
}
.hero-stat {
  text-align: center;
  background: linear-gradient(180deg, rgba(255,255,255,.95) 0%, rgba(252,247,239,.92) 100%);
  padding: 18px 12px;
  border-radius: 18px;
  border: 1px solid rgba(212,199,181,.7);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -1px 0 rgba(89,110,101,.06),
    0 2px 6px rgba(89,110,101,.12),
    0 8px 18px rgba(89,110,101,.1);
  transition: transform .25s;
}
.hero-stat:hover { transform: translateY(-3px); }
.hero-stat .num {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.6vw, 40px);
  font-weight: 800;
  color: var(--coral);
  line-height: 1;
  text-shadow:
    0 1px 0 rgba(255,255,255,.9),
    0 2px 6px rgba(168,95,73,.18);
  letter-spacing: -.02em;
}
.hero-stat .label {
  font-size: 11px;
  letter-spacing: .04em;
  color: var(--verde);
  font-weight: 600;
  margin-top: 8px;
  line-height: 1.35;
  text-shadow: 0 1px 0 rgba(255,255,255,.7);
}

/* Botões centralizados */
.hero-buttons {
  display: flex;
  gap: 14px;
  justify-content: center !important;
  flex-wrap: wrap;
}

@media (max-width: 768px) {
  .hero { padding: 40px 20px 40px !important; min-height: auto; }
  .hero-stat .num { font-size: 28px; }
  .hero-stat .label { font-size: 10px; }
}

/* ============================================================
   MENU MOBILE — abre à direita, ocupando ~85% da tela
   ============================================================ */
@media (max-width: 1024px) {
  .nav-menu.open {
    left: auto !important;
    right: 12px !important;
    top: calc(100% - 4px) !important;
    width: min(86vw, 360px);
    border-radius: 24px !important;
    background: linear-gradient(180deg, #FCFAF6 0%, #F2EDE5 100%) !important;
    border: 1px solid #D4C7B5 !important;
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,.95),
      0 12px 32px -8px rgba(89,110,101,.25),
      0 24px 48px -12px rgba(89,110,101,.18) !important;
    padding: 16px !important;
  }
  .nav-menu.open a {
    background: linear-gradient(180deg, #FFFFFF 0%, #F8F4EC 100%) !important;
    border: 1px solid #D4C7B5 !important;
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,.95),
      0 1px 2px rgba(89,110,101,.08),
      0 4px 8px rgba(89,110,101,.06) !important;
    text-shadow: 0 1px 0 rgba(255,255,255,.7);
    display: flex !important;
    flex-direction: row !important;
    justify-content: flex-end !important;
    align-items: center;
    gap: 12px;
    text-align: right;
  }
  .nav-menu.open a.active {
    background: linear-gradient(180deg, #F8C5B6 0%, var(--coral) 100%) !important;
    border-color: #BF7762 !important;
    color: var(--branco) !important;
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,.4),
      inset 0 -2px 4px rgba(168,95,73,.3),
      0 4px 10px rgba(168,95,73,.35) !important;
    text-shadow: 0 -1px 0 rgba(168,95,73,.4);
    font-weight: 700;
  }
  .nav-menu.open a.active .nav-icon {
    background: rgba(255,255,255,.3) !important;
    color: var(--branco) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.4) !important;
  }
  .nav-menu.open a .nav-icon {
    margin: 0 !important;
    order: 2;
  }
  .nav-menu.open .mobile-only-cta a {
    background: linear-gradient(180deg, #6E8479 0%, var(--verde) 50%, #4D5F56 100%) !important;
    color: #fff !important;
    border: 1px solid #3F4E47 !important;
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,.25),
      inset 0 -2px 4px rgba(0,0,0,.18),
      0 4px 10px rgba(89,110,101,.35) !important;
    text-shadow: 0 -1px 0 rgba(0,0,0,.25);
  }
}

/* ============================================================
   PLANO (3 passos) — bordas arredondadas, contraste corrigido
   ============================================================ */
.plano {
  border-radius: 36px;
  margin: 24px;
  overflow: hidden;
  box-shadow:
    inset 0 4px 12px rgba(0,0,0,.18),
    inset 0 -4px 12px rgba(0,0,0,.18),
    0 12px 32px rgba(89,110,101,.18);
}
.plano-step {
  background: linear-gradient(180deg, rgba(255,255,255,.12) 0%, rgba(255,255,255,.06) 100%);
  border-radius: 24px;
  padding: 28px 24px !important;
  border: 1px solid rgba(255,255,255,.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.25),
    inset 0 -1px 0 rgba(0,0,0,.18),
    0 4px 12px rgba(0,0,0,.18);
  transition: transform .25s;
}
.plano-step:hover {
  transform: translateY(-4px);
  background: linear-gradient(180deg, rgba(255,255,255,.18) 0%, rgba(255,255,255,.1) 100%);
}
.plano-step h4 {
  color: var(--branco) !important;
  text-shadow: 0 1px 2px rgba(0,0,0,.25);
  font-size: 22px !important;
}
.plano-step p {
  color: rgba(255,255,255,.92) !important;
  text-shadow: 0 1px 1px rgba(0,0,0,.18);
  font-size: 14px !important;
  opacity: 1 !important;
}
.plano-step-num {
  width: 72px !important;
  height: 72px !important;
  border-radius: 24px !important;
  font-size: 32px !important;
}
@media (max-width: 768px) {
  .plano { margin: 12px; border-radius: 28px; }
  .plano-step { padding: 24px 20px !important; }
}

/* ============================================================
   SEÇÃO GOOGLE REVIEWS — depoimentos com cara de Google
   ============================================================ */
.reviews-section {
  background:
    radial-gradient(ellipse at 20% 0%, rgba(66,133,244,.08) 0%, transparent 40%),
    radial-gradient(ellipse at 80% 100%, rgba(52,168,83,.06) 0%, transparent 40%),
    var(--branco);
}
.reviews-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(180deg, #FFFFFF 0%, #F8F4EC 100%);
  border: 1px solid #D4C7B5;
  padding: 10px 22px;
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  color: var(--verde);
  margin-bottom: 16px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 6px rgba(89,110,101,.1),
    0 6px 14px rgba(89,110,101,.08);
  text-shadow: 0 1px 0 rgba(255,255,255,.7);
}
.reviews-rating {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.rating-num {
  font-family: var(--font-display);
  font-size: 56px;
  font-weight: 800;
  color: #FBBC05;
  line-height: 1;
  text-shadow:
    0 1px 0 rgba(255,255,255,.9),
    0 3px 8px rgba(251,188,5,.3);
  letter-spacing: -.03em;
}
.rating-stars {
  font-size: 26px;
  color: #FBBC05;
  letter-spacing: .15em;
  text-shadow: 0 1px 2px rgba(251,188,5,.4);
}
.rating-count {
  font-size: 13px;
  color: var(--cinza);
  font-weight: 500;
}
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 1200px;
  margin: 0 auto;
}
.review-card {
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 22px;
  padding: 28px 26px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -1px 0 rgba(89,110,101,.05),
    0 2px 4px rgba(89,110,101,.08),
    0 8px 16px rgba(89,110,101,.10),
    0 16px 32px rgba(89,110,101,.06);
  transition: transform .25s;
  position: relative;
  overflow: hidden;
}
.review-card::before {
  content: """;
  position: absolute;
  top: -16px;
  right: 18px;
  font-size: 96px;
  font-family: Georgia, serif;
  color: rgba(247,201,191,.35);
  line-height: 1;
  font-weight: 700;
  pointer-events: none;
}
.review-card:hover {
  transform: translateY(-4px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 4px 8px rgba(89,110,101,.1),
    0 16px 32px rgba(89,110,101,.14),
    0 24px 48px rgba(89,110,101,.08);
}
.review-stars {
  font-size: 18px;
  color: #FBBC05;
  letter-spacing: .12em;
  text-shadow: 0 1px 2px rgba(251,188,5,.3);
}
.review-text {
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--verde);
  flex: 1;
  position: relative;
  z-index: 1;
}
.review-author {
  display: flex;
  align-items: center;
  gap: 12px;
  border-top: 1px solid #E4DAD0;
  padding-top: 14px;
  margin-top: auto;
}
.review-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--coral), var(--amarelo));
  color: var(--branco);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 18px;
  flex-shrink: 0;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    inset 0 -2px 4px rgba(0,0,0,.18),
    0 4px 8px rgba(168,95,73,.3);
  text-shadow: 0 -1px 0 rgba(0,0,0,.18);
}
.review-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  color: var(--verde);
}
.review-meta {
  font-size: 11.5px;
  color: var(--cinza);
  margin-top: 2px;
}
.reviews-cta-wrap {
  text-align: center;
  margin-top: 40px;
}
.reviews-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 28px;
  background: linear-gradient(180deg, #FFFFFF 0%, #F8F4EC 100%);
  border: 1px solid #D4C7B5;
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 14px;
  color: var(--verde);
  text-decoration: none;
  transition: all .25s;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -1px 0 rgba(89,110,101,.06),
    0 2px 6px rgba(89,110,101,.12),
    0 8px 18px rgba(89,110,101,.1);
}
.reviews-cta:hover {
  transform: translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 4px 10px rgba(89,110,101,.18),
    0 12px 24px rgba(89,110,101,.14);
}
@media (max-width: 1024px) {
  .reviews-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
}
@media (max-width: 640px) {
  .reviews-grid { grid-template-columns: 1fr; gap: 16px; }
  .rating-num { font-size: 44px; }
  .rating-stars { font-size: 22px; }
}

/* === Animação especial pra cards — sem overlap durante carregamento === */
@media (prefers-reduced-motion: no-preference) {
  [data-animate="card"] {
    opacity: 0;
    transform: translateY(14px);
    transition: opacity .65s cubic-bezier(.2,.8,.2,1), transform .65s cubic-bezier(.2,.8,.2,1);
    will-change: opacity, transform;
  }
  [data-animate="card"].is-visible {
    opacity: 1;
    transform: translateY(0);
  }
}

/* === Reviews Carousel — overrides pra não pegar cores rotativas === */
.reviews-wrap {
  padding: 0 64px;
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  overflow: hidden;
}
.reviews-carousel {
  padding: 16px 0 32px !important;
  gap: 20px !important;
  scroll-snap-type: x mandatory !important;
  scroll-padding: 0 !important;
}
.reviews-carousel .carousel-card,
.reviews-carousel .carousel-card:not(.featured):nth-of-type(4n),
.reviews-carousel .carousel-card:not(.featured):nth-of-type(4n+1),
.reviews-carousel .carousel-card:not(.featured):nth-of-type(4n+2),
.reviews-carousel .carousel-card:not(.featured):nth-of-type(4n+3) {
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%) !important;
  border: 1px solid #D4C7B5 !important;
  border-top: 5px solid #FBBC05 !important;
  flex: 0 0 calc((100% - 40px) / 3) !important;
  padding: 28px 26px !important;
  scroll-snap-align: start !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 4px rgba(89,110,101,.08),
    0 8px 16px rgba(89,110,101,.10),
    0 16px 32px rgba(89,110,101,.06) !important;
}
.reviews-carousel .carousel-card::before,
.reviews-carousel .carousel-card::after {
  display: none;
}
.reviews-carousel .review-card::before {
  content: """;
  position: absolute;
  top: -16px;
  right: 18px;
  font-size: 96px;
  font-family: Georgia, serif;
  color: rgba(247,201,191,.35);
  line-height: 1;
  font-weight: 700;
  pointer-events: none;
  display: block !important;
}
.reviews-wrap .carousel-nav.prev { left: 8px !important; }
.reviews-wrap .carousel-nav.next { right: 8px !important; }
@media (max-width: 768px) {
  .reviews-wrap {
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
  }
  .reviews-carousel {
    padding: 16px 0 64px !important;
    gap: 0 !important;
    scroll-snap-type: x mandatory !important;
    scroll-padding: 0 !important;
  }
  .reviews-carousel .carousel-card,
  .reviews-carousel .carousel-card:not(.featured):nth-of-type(4n),
  .reviews-carousel .carousel-card:not(.featured):nth-of-type(4n+1),
  .reviews-carousel .carousel-card:not(.featured):nth-of-type(4n+2),
  .reviews-carousel .carousel-card:not(.featured):nth-of-type(4n+3) {
    flex: 0 0 100% !important;
    max-width: none !important;
    padding: 24px 22px !important;
    margin: 0 !important;
    scroll-snap-align: center !important;
    scroll-snap-stop: always !important;
    box-sizing: border-box !important;
    /* simulando padding lateral via border transparente pra ficar 1 card por vez */
    border-left: 16px solid transparent !important;
    border-right: 16px solid transparent !important;
    border-top: 5px solid #FBBC05 !important;
  }
  .reviews-wrap .carousel-nav {
    position: absolute !important;
    top: auto !important;
    bottom: 12px !important;
    transform: none !important;
    width: 40px !important;
    height: 40px !important;
    font-size: 18px !important;
  }
  .reviews-wrap .carousel-nav.prev { left: calc(50% - 56px) !important; right: auto !important; }
  .reviews-wrap .carousel-nav.next { right: calc(50% - 56px) !important; left: auto !important; }
  .reviews-wrap .carousel-nav:hover {
    transform: scale(1.05) !important;
  }
}

/* ============================================================
   SEÇÃO GALERIA — Famílias do ninho (fotos das crianças)
   ============================================================ */
.galeria-section {
  background: linear-gradient(180deg, var(--branco) 0%, var(--nude-cream) 100%);
  position: relative;
  overflow: hidden;
}
.galeria-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;
  gap: 14px;
  max-width: 1100px;
  margin: 0 auto;
}
.galeria-photo {
  border-radius: 22px;
  overflow: hidden;
  background: var(--nude-cream);
  border: 4px solid #FCFAF6;
  box-shadow:
    inset 0 0 0 1px rgba(89,110,101,.1),
    0 4px 10px rgba(89,110,101,.18),
    0 12px 24px rgba(89,110,101,.14);
  transition: all .35s cubic-bezier(.2,.8,.2,1);
  position: relative;
}
.galeria-photo:hover {
  transform: translateY(-4px) scale(1.02);
  box-shadow:
    inset 0 0 0 1px rgba(89,110,101,.1),
    0 6px 14px rgba(89,110,101,.22),
    0 16px 32px rgba(89,110,101,.2);
}
.galeria-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  display: block;
}
/* Layout mosaico: foto 1 (big) ocupa 2x2, foto 6 (wide) ocupa 1x2 horizontal */
.galeria-photo.big {
  grid-row: span 2;
  grid-column: span 2;
}
.galeria-photo:nth-child(6) {
  grid-column: span 2;
}
@media (max-width: 1024px) {
  .galeria-grid { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 180px; }
  .galeria-photo.big { grid-row: span 2; grid-column: span 2; }
  .galeria-photo:nth-child(6) { grid-column: span 1; }
}
@media (max-width: 640px) {
  .galeria-grid {
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 90px;
    gap: 10px;
  }
  /* Mosaico mobile — alternando tamanhos */
  .galeria-photo.big { grid-row: span 3; grid-column: span 4; }       /* foto 1 — bem grande, full width */
  .galeria-photo:nth-child(2) { grid-row: span 2; grid-column: span 2; } /* foto 2 — quadrada */
  .galeria-photo:nth-child(3) { grid-row: span 2; grid-column: span 2; } /* foto 3 — quadrada */
  .galeria-photo:nth-child(4) { grid-row: span 2; grid-column: span 4; } /* foto 4 — horizontal full width */
  .galeria-photo:nth-child(5) { grid-row: span 2; grid-column: span 2; } /* foto 5 — quadrada */
  .galeria-photo:nth-child(6) { grid-row: span 2; grid-column: span 2; } /* foto 6 — quadrada */
  .galeria-photo:nth-child(7) { grid-row: span 3; grid-column: span 4; } /* foto 7 — vertical bem alta full width */
  .galeria-photo:nth-child(8) { grid-row: span 2; grid-column: span 4; } /* foto 8 — horizontal full width */
}

/* ============================================================
   SEÇÃO ESPECIALIDADES — grid de cards com ícone
   ============================================================ */
.especialidades-section {
  background: linear-gradient(180deg, var(--nude-cream) 0%, #F4EFE5 100%);
}
.especialidades-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  max-width: 1200px;
  margin: 0 auto;
}
.esp-card {
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 22px;
  padding: 28px 22px;
  text-align: center;
  transition: all .3s cubic-bezier(.2,.8,.2,1);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -1px 0 rgba(89,110,101,.06),
    0 2px 4px rgba(89,110,101,.08),
    0 6px 14px rgba(89,110,101,.08),
    0 12px 24px rgba(89,110,101,.06);
}
.esp-card:hover {
  transform: translateY(-6px) scale(1.02);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 6px 12px rgba(89,110,101,.15),
    0 16px 32px rgba(89,110,101,.18),
    0 28px 48px rgba(89,110,101,.1);
}
.esp-icon {
  width: 72px;
  height: 72px;
  border-radius: 22px;
  margin: 0 auto 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.85),
    inset 0 -2px 4px rgba(89,110,101,.1),
    0 4px 8px rgba(89,110,101,.18);
  transition: transform .3s;
}
.esp-card:hover .esp-icon { transform: scale(1.1) rotate(-4deg); }
.esp-icon.coral {
  background: linear-gradient(180deg, #FCEEE9 0%, #F8DDD2 100%);
  color: var(--coral);
  border-color: #E5A593;
}
.esp-icon.azul {
  background: linear-gradient(180deg, #E5EEF3 0%, #C5D6E0 100%);
  color: #5C7B8B;
  border-color: #A1B5C1;
}
.esp-icon.amarelo {
  background: linear-gradient(180deg, #FCF1C8 0%, #F4DD92 100%);
  color: #B58B14;
  border-color: #C9A852;
}
.esp-icon.verde {
  background: linear-gradient(180deg, #ECEED7 0%, #C9CFAA 100%);
  color: var(--verde);
  border-color: #889071;
}
.esp-card h4 {
  font-size: 16px !important;
  margin-bottom: 8px !important;
  color: var(--verde);
  text-shadow: 0 1px 0 rgba(255,255,255,.7);
  line-height: 1.2;
}
.esp-card p {
  font-size: 13px;
  color: var(--cinza);
  line-height: 1.55;
  margin: 0;
}
@media (max-width: 1024px) { .especialidades-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px) { .especialidades-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; } .esp-card { padding: 22px 16px; } .esp-icon { width: 60px; height: 60px; } }
@media (max-width: 480px) { .especialidades-grid { grid-template-columns: 1fr; } }

/* ============================================================
   SEÇÃO VIVA ECO — Ecocardiograma pediátrico (mini-LP na home)
   ============================================================ */
.eco-section {
  background: linear-gradient(135deg, var(--coral-pale) 0%, #FCEFCC 50%, var(--azul-light) 100%);
  position: relative;
  overflow: hidden;
}
.eco-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  max-width: 1100px;
  margin: 0 auto;
}
.eco-content { position: relative; z-index: 2; }
.eco-eyebrow {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  background: linear-gradient(180deg, #FFFFFF 0%, var(--coral-pale) 100%) !important;
  padding: 8px 18px !important;
  border-radius: 999px;
  border: 1px solid var(--coral-light);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 6px rgba(228,165,147,.25),
    0 6px 14px rgba(228,165,147,.15);
  color: #A85F49 !important;
  text-shadow: 0 1px 0 rgba(255,255,255,.7);
}
.eco-content h2 {
  font-size: clamp(28px, 4vw, 42px);
  margin: 16px 0 18px;
  text-shadow: 0 1px 0 rgba(255,255,255,.6), 0 2px 6px rgba(89,110,101,.1);
}
.eco-content p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--verde);
  margin-bottom: 20px;
  text-shadow: 0 1px 0 rgba(255,255,255,.6);
}
.eco-list {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.eco-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 14.5px;
  color: var(--verde);
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(4px);
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.6);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 1px 2px rgba(89,110,101,.06);
  text-align: left;
  line-height: 1.5;
}
.eco-list li > span:not(.eco-check) {
  flex: 1;
  display: block;
}
.eco-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 8px;
  background: linear-gradient(180deg, #F8C5B6 0%, var(--coral) 100%);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  flex-shrink: 0;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    0 2px 4px rgba(168,95,73,.3);
  text-shadow: 0 -1px 0 rgba(168,95,73,.4);
}
.eco-cta-wrap {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.eco-visual {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.eco-photo-main {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  border: 5px solid #FCFAF6;
  aspect-ratio: 16/10;
  box-shadow:
    inset 0 0 0 1px rgba(89,110,101,.1),
    0 8px 18px rgba(89,110,101,.22),
    0 18px 36px rgba(89,110,101,.18);
}
.eco-photo-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.eco-badge {
  position: absolute;
  top: 14px;
  right: 14px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: linear-gradient(180deg, #FFFFFF 0%, #F8F4EC 100%);
  color: var(--verde);
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 6px rgba(89,110,101,.18),
    0 6px 14px rgba(89,110,101,.15);
  border: 1px solid #D4C7B5;
}
.eco-badge svg { color: var(--coral); }
.eco-doctors {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.eco-photo-side {
  display: flex;
  align-items: center;
  gap: 12px;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid #D4C7B5;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 6px rgba(89,110,101,.12),
    0 8px 18px rgba(89,110,101,.1);
}
@media (max-width: 600px) {
  .eco-doctors { grid-template-columns: 1fr; }
}
.eco-photo-side img {
  width: 64px;
  height: 64px;
  border-radius: 18px;
  object-fit: cover;
  object-position: center top;
  border: 3px solid #FCFAF6;
  flex-shrink: 0;
  box-shadow:
    inset 0 0 0 1px rgba(89,110,101,.08),
    0 3px 6px rgba(89,110,101,.18);
}
.eco-photo-caption strong {
  display: block;
  font-family: var(--font-display);
  font-size: 15px;
  color: var(--verde);
}
.eco-photo-caption span {
  font-size: 11px;
  color: var(--coral);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
}
@media (max-width: 900px) {
  .eco-split { grid-template-columns: 1fr; gap: 32px; }
  .eco-content h2 { text-align: center; }
  .eco-cta-wrap { justify-content: center; }
  .eco-content { text-align: center; }
  .eco-list li { text-align: left; }
}

/* ============================================================
   GRAFISMOS DECORATIVOS — não ficam mais atrás de textos
   ============================================================ */
.graphic-bg { display: none !important; }
/* Garante que conteúdo de seção fica sobre qualquer decoração */
.section-header, .hero-content, .container > * {
  position: relative;
  z-index: 2;
}

/* ============================================================
   ILUSTRAÇÕES DO HERO — bem maiores, preenchendo a página
   ============================================================ */
.hero-graphic { z-index: 1 !important; }
.hero-illustration { z-index: 1 !important; }
.hero-graphic.tr { width: 280px !important; right: 4% !important; top: 40px !important; opacity: .65 !important; }
.hero-graphic.bl { width: 240px !important; bottom: 5% !important; left: 2% !important; opacity: .55 !important; }
.hero-graphic.tl { width: 160px !important; top: 100px !important; left: 4% !important; opacity: .55 !important; }
.hero-graphic.mr { width: 140px !important; right: 8% !important; opacity: .4 !important; }
.hero-illustration.left { width: 200px !important; bottom: 6% !important; left: 5% !important; opacity: .8 !important; }
.hero-illustration.right { top: 16% !important; right: 6% !important; width: 180px !important; opacity: .75 !important; }

@media (max-width: 768px) {
  .hero-graphic.tr { width: 90px !important; right: 8px !important; top: 60px !important; opacity: .5 !important; }
  .hero-graphic.bl { width: 75px !important; opacity: .45 !important; }
  .hero-graphic.tl { display: none !important; }
  .hero-graphic.mr { display: none !important; }
  .hero-illustration.left { display: none !important; }
  .hero-illustration.right { display: none !important; }
}

/* ============================================================
   FLOATING ILLUSTRATIONS — passarinhos, borboletas, flores
   ============================================================ */
.floating-illustration {
  position: absolute;
  pointer-events: none;
  z-index: 1;
  filter:
    drop-shadow(0 8px 18px rgba(89,110,101,.22))
    drop-shadow(0 3px 6px rgba(89,110,101,.16));
}
.floating-illustration.top-right {
  top: 6%;
  right: 3%;
  width: 220px;
  opacity: .85;
  animation: floatY 7s ease-in-out infinite;
}
.floating-illustration.bottom-left {
  bottom: 6%;
  left: 2%;
  width: 200px;
  opacity: .75;
  animation: floatY 8s ease-in-out infinite reverse;
}
.floating-illustration.top-left {
  top: 8%;
  left: 3%;
  width: 200px;
  opacity: .8;
  animation: floatY 6s ease-in-out infinite;
}
.floating-illustration.bottom-right {
  bottom: 8%;
  right: 4%;
  width: 200px;
  opacity: .75;
  animation: floatY 7s ease-in-out infinite reverse;
}
.sobre-section, .galeria-section, .reviews-section, .especialidades-section,
.plano, .cta-final {
  position: relative;
  overflow: hidden;
}
@media (max-width: 768px) {
  .floating-illustration { width: 90px !important; opacity: .55; }
}

/* ============================================================
   ILUSTRAÇÕES SKEUMORFICAS — sombra/relevo nas ilustrações
   ============================================================ */
.hero-graphic, .hero-illustration,
.value-card img,
.graphic-bg {
  filter:
    drop-shadow(0 4px 8px rgba(89,110,101,.18))
    drop-shadow(0 1px 2px rgba(89,110,101,.12));
}
.hero-illustration {
  filter:
    drop-shadow(0 8px 14px rgba(89,110,101,.22))
    drop-shadow(0 2px 4px rgba(89,110,101,.16));
}
.value-card img {
  filter:
    drop-shadow(0 6px 12px rgba(89,110,101,.2))
    drop-shadow(0 1px 2px rgba(89,110,101,.12));
}

/* ============================================================
   PAGE HERO — usado em /sobre, /equipe, /contato, /eco, /medicos
   ============================================================ */
.page-hero {
  padding: 80px 24px 60px;
  text-align: center;
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(ellipse at center, rgba(255,255,255,.55) 0%, rgba(255,255,255,0) 65%),
    linear-gradient(135deg, rgba(247,201,191,.55) 0%, rgba(250,247,239,.5) 50%, rgba(212,225,232,.6) 100%),
    var(--nude-cream);
  background-attachment: fixed, scroll, scroll;
}
.page-hero::after {
  content: "";
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 80px;
  background: linear-gradient(180deg, transparent 0%, var(--nude-cream) 100%);
  pointer-events: none;
}
.page-hero-content {
  position: relative;
  z-index: 2;
  max-width: 760px;
  margin: 0 auto;
}
.page-hero h1 {
  font-size: clamp(36px, 5vw, 60px);
  margin-bottom: 12px;
  text-shadow: 0 1px 0 rgba(255,255,255,.7), 0 2px 12px rgba(255,255,255,.4);
}
.page-hero-sub {
  font-size: clamp(16px, 1.8vw, 19px);
  color: var(--verde);
  max-width: 640px;
  margin: 16px auto 0;
  line-height: 1.6;
  font-weight: 500;
}

/* ============================================================
   /SOBRE — manifesto, founders, DNA, valores, categoria
   ============================================================ */

/* Manifesto block — horizontal no desktop, vertical no mobile */
.sobre-manifesto {
  background: linear-gradient(180deg, var(--nude-cream) 0%, var(--branco) 100%);
  position: relative;
  overflow: hidden;
}
.manifesto-block {
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 32px;
  padding: 56px 56px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 4px 12px rgba(89,110,101,.08),
    0 12px 28px rgba(89,110,101,.10),
    0 24px 48px rgba(89,110,101,.06);
  position: relative;
}
.manifesto-block .eyebrow { margin-bottom: 28px; display: inline-block; }
.manifesto-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  text-align: left;
  margin-bottom: 32px;
}
.manifesto-col p {
  font-size: 16px;
  line-height: 1.75;
  color: var(--cinza);
  margin: 14px 0;
}
.manifesto-block .manifesto-line {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.4vw, 26px);
  font-weight: 600;
  color: var(--coral);
  letter-spacing: -.02em;
  line-height: 1.25;
  margin-top: 0;
  margin-bottom: 16px;
  text-shadow: 0 1px 0 rgba(255,255,255,.7);
}
.manifesto-col .manifesto-line:not(:first-child) { margin-top: 24px; }
.manifesto-block .manifesto-key {
  font-family: var(--font-display);
  font-size: clamp(26px, 3vw, 36px);
  font-weight: 700;
  color: var(--verde);
  letter-spacing: -.025em;
  margin: 0 0 16px;
  text-shadow: 0 1px 0 rgba(255,255,255,.7);
}
.manifesto-col .manifesto-key:not(:first-child) { margin-top: 24px; }
.manifesto-footer {
  border-top: 1px solid var(--nude);
  padding-top: 28px;
  text-align: center;
}
.manifesto-block .manifesto-final {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.6vw, 26px);
  font-weight: 600;
  color: var(--verde);
  margin: 0 0 12px;
  letter-spacing: -.015em;
}
.manifesto-block .manifesto-signature {
  font-family: var(--font-script);
  font-size: clamp(24px, 2.4vw, 30px);
  color: var(--coral);
  margin: 0;
}
@media (max-width: 768px) {
  .manifesto-block { padding: 36px 24px; border-radius: 24px; }
  .manifesto-grid { grid-template-columns: 1fr; gap: 24px; text-align: center; }
  .manifesto-col p { font-size: 15px; }
  .manifesto-col .manifesto-line:not(:first-child),
  .manifesto-col .manifesto-key:not(:first-child) { margin-top: 0; }
}

/* Clínica grid — layout artístico variado, recepção + fachada destacadas */
.sobre-clinica {
  background: linear-gradient(180deg, var(--branco) 0%, var(--nude-cream) 100%);
  position: relative;
  overflow: hidden;
}
.clinica-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 200px;
  gap: 14px;
  max-width: 1200px;
  margin: 0 auto;
}
.clinica-photo {
  border-radius: 22px;
  overflow: hidden;
  background: var(--nude-cream);
  border: 4px solid #FCFAF6;
  box-shadow:
    inset 0 0 0 1px rgba(89,110,101,.1),
    0 4px 10px rgba(89,110,101,.18),
    0 12px 24px rgba(89,110,101,.14);
  transition: all .35s cubic-bezier(.2,.8,.2,1);
  position: relative;
}
.clinica-photo:hover {
  transform: translateY(-4px) scale(1.02);
  box-shadow:
    inset 0 0 0 1px rgba(89,110,101,.1),
    0 6px 14px rgba(89,110,101,.22),
    0 16px 32px rgba(89,110,101,.2);
  z-index: 2;
}
.clinica-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 45%;
  display: block;
}
/* Recepção — DESTAQUE big 2x2 (col 1-2, row 1-2) */
.clinica-photo.recepcao {
  grid-column: span 2;
  grid-row: span 2;
}
/* Fachada — DESTAQUE big 2x2 (col 1-2, row 3-4) */
.clinica-photo.fachada {
  grid-column: span 2;
  grid-row: span 2;
}
.clinica-photo.fachada img {
  object-position: center 60%;
}
/* Wide — span 2 cols, 1 row */
.clinica-photo.wide {
  grid-column: span 2;
}
/* Tablet */
@media (max-width: 1024px) {
  .clinica-grid { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 180px; }
  .clinica-photo.recepcao { grid-column: span 3; grid-row: span 2; }
  .clinica-photo.fachada { grid-column: span 3; grid-row: span 2; }
  .clinica-photo.wide { grid-column: span 3; }
}
/* Mobile — mosaico variado */
@media (max-width: 640px) {
  .clinica-grid {
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 90px;
    gap: 10px;
  }
  .clinica-photo.recepcao { grid-column: span 4; grid-row: span 3; }
  .clinica-photo.fachada { grid-column: span 4; grid-row: span 3; }
  .clinica-photo.wide { grid-column: span 4; grid-row: span 2; }
  .clinica-photo:not(.recepcao):not(.fachada):not(.wide) { grid-column: span 2; grid-row: span 2; }
}

/* Fundadores — split + cards */
.sobre-founders {
  background: var(--branco);
}
.founders-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  max-width: 1100px;
  margin: 0 auto 56px;
}
.founder-photo {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  border: 5px solid #FCFAF6;
  aspect-ratio: 4/5;
  box-shadow:
    inset 0 0 0 1px rgba(89,110,101,.1),
    0 8px 18px rgba(89,110,101,.22),
    0 18px 36px rgba(89,110,101,.18);
}
.founder-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.founder-photo-tag {
  position: absolute;
  bottom: 16px;
  left: 16px;
  background: linear-gradient(180deg, #FFFFFF 0%, #F8F4EC 100%);
  color: var(--verde);
  padding: 8px 16px;
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 13px;
  border: 1px solid #D4C7B5;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 6px rgba(89,110,101,.18);
}
.founder-text p {
  font-size: 17px;
  line-height: 1.75;
  color: var(--cinza);
  margin-bottom: 18px;
}
.founder-text p strong { color: var(--verde); }
.founder-signature {
  font-family: var(--font-script) !important;
  font-size: 22px !important;
  color: var(--coral) !important;
  line-height: 1.3 !important;
  margin-top: 24px !important;
}
@media (max-width: 900px) {
  .founders-split { grid-template-columns: 1fr; gap: 32px; }
  .founder-photo { aspect-ratio: 4/3; max-height: 480px; }
}

/* Cards dos fundadores (mais detalhado) */
.founders-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}
.founder-card {
  background: linear-gradient(180deg, #FCEEE9 0%, #F8DDD2 50%, #FFFFFF 100%);
  border: 2px solid var(--coral);
  border-top: 6px solid var(--coral);
  border-radius: 24px;
  padding: 36px 32px;
  text-align: center;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.7),
    0 4px 8px rgba(168,95,73,.22),
    0 12px 28px rgba(168,95,73,.28),
    0 24px 48px rgba(168,95,73,.12);
  transition: transform .3s cubic-bezier(.2,.8,.2,1);
}
.founder-card:hover { transform: translateY(-6px); }
.founder-card-photo {
  width: 140px;
  height: 140px;
  border-radius: 32px;
  object-fit: cover;
  object-position: center top;
  margin: 0 auto 18px;
  border: 4px solid var(--branco);
  box-shadow:
    inset 0 0 0 1px rgba(89,110,101,.08),
    0 8px 18px rgba(168,95,73,.3);
}
.founder-card h3 {
  font-size: 22px;
  margin-bottom: 4px;
  color: var(--verde);
}
.founder-card-spec {
  font-size: 12px !important;
  color: var(--coral) !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 16px !important;
}
.founder-card-bio {
  font-size: 14px !important;
  color: var(--cinza) !important;
  line-height: 1.65 !important;
  margin-bottom: 16px !important;
}
.founder-card-bio strong { color: var(--verde); }
.founder-card-crm {
  font-size: 11.5px !important;
  color: var(--coral) !important;
  letter-spacing: .04em;
  border-top: 1px solid var(--coral-light);
  padding-top: 14px;
  margin: 0 !important;
  font-weight: 600;
}
@media (max-width: 768px) { .founders-cards { grid-template-columns: 1fr; gap: 20px; } }

/* DNA grid */
.sobre-dna { background: linear-gradient(180deg, var(--branco) 0%, var(--nude-cream) 100%); }
.dna-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  max-width: 1100px;
  margin: 0 auto;
}
.dna-card {
  border-radius: 24px;
  padding: 32px 26px;
  text-align: center;
  border: 1px solid;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 6px rgba(89,110,101,.08),
    0 8px 18px rgba(89,110,101,.10),
    0 16px 32px rgba(89,110,101,.06);
  transition: transform .3s cubic-bezier(.2,.8,.2,1);
}
.dna-card:hover { transform: translateY(-6px); }
.dna-card.coral { background: linear-gradient(180deg, #FCEEE9 0%, #FFFFFF 60%); border-color: #E5A593; }
.dna-card.azul { background: linear-gradient(180deg, #E5EEF3 0%, #FFFFFF 60%); border-color: #A1B5C1; }
.dna-card.amarelo { background: linear-gradient(180deg, #FCF1C8 0%, #FFFFFF 60%); border-color: #C9A852; }
.dna-card.verde { background: linear-gradient(180deg, #ECEED7 0%, #FFFFFF 60%); border-color: #889071; }
.dna-card .dna-icon {
  font-size: 36px;
  margin-bottom: 14px;
  filter: drop-shadow(0 4px 8px rgba(89,110,101,.18));
}
.dna-card h4 {
  font-size: 18px !important;
  margin-bottom: 10px !important;
  color: var(--verde);
}
.dna-card p {
  font-size: 13.5px;
  color: var(--cinza);
  line-height: 1.65;
  margin: 0;
}
@media (max-width: 1024px) { .dna-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .dna-grid { grid-template-columns: 1fr; } }

/* Valores grid */
.sobre-valores {
  background: var(--nude-cream);
  position: relative;
  overflow: hidden;
}
.valores-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
}
.valor-card {
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 22px;
  padding: 32px 28px;
  position: relative;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 4px rgba(89,110,101,.08),
    0 8px 16px rgba(89,110,101,.10);
  transition: transform .3s cubic-bezier(.2,.8,.2,1);
}
.valor-card:hover { transform: translateY(-4px); }
.valor-num {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  background: linear-gradient(180deg, #F8C5B6 0%, var(--coral) 100%);
  color: var(--branco);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 22px;
  margin-bottom: 16px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    inset 0 -2px 4px rgba(168,95,73,.3),
    0 4px 10px rgba(168,95,73,.3);
  text-shadow: 0 -1px 0 rgba(168,95,73,.4);
}
.valor-card h4 {
  font-size: 19px !important;
  margin-bottom: 8px !important;
  color: var(--verde);
}
.valor-card p {
  font-size: 14.5px;
  color: var(--cinza);
  line-height: 1.65;
  margin: 0;
}
@media (max-width: 768px) {
  .valores-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .valor-card { padding: 24px 20px; }
}
@media (max-width: 480px) {
  .valores-grid { grid-template-columns: 1fr; }
}

/* Categoria — Ninho Pediátrico Multidisciplinar */
.sobre-categoria { background: var(--branco); }
.categoria-card {
  background: linear-gradient(135deg, var(--coral-pale) 0%, #FCEFCC 50%, var(--azul-light) 100%);
  border: 1px solid #D4C7B5;
  border-radius: 32px;
  padding: 64px 48px;
  text-align: center;
  max-width: 900px;
  margin: 0 auto;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.7),
    inset 0 -1px 0 rgba(89,110,101,.04),
    0 4px 12px rgba(89,110,101,.1),
    0 16px 36px rgba(89,110,101,.12);
  position: relative;
}
.categoria-card h2 {
  font-size: clamp(32px, 4.5vw, 48px);
  margin: 16px 0 16px;
  color: var(--verde);
  text-shadow: 0 1px 0 rgba(255,255,255,.7), 0 2px 8px rgba(89,110,101,.1);
}
.categoria-lead {
  font-size: 17px;
  color: var(--cinza);
  max-width: 600px;
  margin: 0 auto 32px;
  line-height: 1.6;
}
.categoria-checklist {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  max-width: 720px;
  margin: 0 auto;
  text-align: left;
}
.check-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(4px);
  border: 1px solid rgba(255,255,255,.6);
  border-radius: 14px;
  padding: 14px 16px;
  font-size: 14px;
  color: var(--verde);
  line-height: 1.5;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 1px 2px rgba(89,110,101,.06);
}
.check-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 8px;
  background: linear-gradient(180deg, #F8C5B6 0%, var(--coral) 100%);
  color: var(--branco);
  font-size: 13px;
  font-weight: 700;
  flex-shrink: 0;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    0 2px 4px rgba(168,95,73,.3);
}
@media (max-width: 768px) {
  .categoria-card { padding: 40px 28px; border-radius: 24px; }
  .categoria-checklist { grid-template-columns: 1fr; }
}

/* ============================================================
   /EQUIPE — stats, índice de navegação, categorias, grid de cards
   ============================================================ */

/* --- Stats da equipe (4 colunas no topo da página) --- */
.equipe-stats-section {
  padding: 64px 24px 48px;
  background: linear-gradient(180deg, var(--nude-cream) 0%, var(--branco) 100%);
}
.equipe-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
}
.equipe-stat {
  text-align: center;
  padding: 32px 20px;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 22px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 4px rgba(89,110,101,.06),
    0 8px 18px rgba(89,110,101,.08);
  transition: transform .25s ease, box-shadow .25s ease;
}
.equipe-stat:hover {
  transform: translateY(-3px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 4px 8px rgba(89,110,101,.08),
    0 14px 28px rgba(89,110,101,.12);
}
.equipe-stat .num {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(28px, 3.4vw, 42px);
  color: var(--coral);
  line-height: 1.05;
  letter-spacing: -.01em;
  text-shadow: 0 1px 0 rgba(255,255,255,.7);
  margin-bottom: 10px;
}
.equipe-stat:nth-child(2) .num { color: var(--verde); }
.equipe-stat:nth-child(3) .num {
  font-size: clamp(15px, 1.6vw, 19px);
  letter-spacing: .04em;
  color: var(--azul);
}
.equipe-stat:nth-child(4) .num { color: var(--amarelo); }
.equipe-stat .label {
  font-size: 12px;
  color: var(--cinza);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 600;
  line-height: 1.5;
}
@media (max-width: 768px) {
  .equipe-stats-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .equipe-stat { padding: 24px 14px; border-radius: 18px; }
}

/* --- Índice de categorias (pills com anchors) --- */
.equipe-index {
  padding: 28px 24px 12px;
  background: var(--nude-cream);
  position: sticky;
  top: 72px;
  z-index: 40;
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(212,199,181,.4);
}
.equipe-index-list {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0;
}
.equipe-index-list a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 18px;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  color: var(--verde);
  text-decoration: none;
  letter-spacing: .01em;
  transition: all .25s ease;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 1px 2px rgba(89,110,101,.06),
    0 3px 8px rgba(89,110,101,.06);
}
.equipe-index-list a:hover {
  transform: translateY(-2px);
  background: linear-gradient(180deg, var(--coral-pale) 0%, #FFFFFF 100%);
  border-color: var(--coral);
  color: var(--coral);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 4px rgba(168,95,73,.12),
    0 6px 14px rgba(168,95,73,.18);
}
@media (max-width: 768px) {
  .equipe-index {
    padding: 20px 16px 10px;
    position: static;
    top: auto;
    backdrop-filter: none;
  }
  .equipe-index-list { gap: 8px; }
  .equipe-index-list a { font-size: 12px; padding: 8px 14px; }
}

/* --- Seções de categoria (4 categorias) --- */
.equipe-categoria {
  position: relative;
  overflow: hidden;
  scroll-margin-top: 140px;
  padding: 80px 24px;
}
.equipe-categoria + .equipe-categoria {
  border-top: 1px solid rgba(212,199,181,.5);
}
.equipe-categoria-coral {
  background:
    radial-gradient(ellipse at top right, rgba(247,201,191,.35) 0%, transparent 60%),
    linear-gradient(180deg, #FCEEE9 0%, var(--nude-cream) 100%);
}
.equipe-categoria-azul {
  background:
    radial-gradient(ellipse at bottom left, rgba(155,180,200,.32) 0%, transparent 60%),
    linear-gradient(180deg, #E5EEF3 0%, var(--nude-cream) 100%);
}

/* Header centralizado de categoria */
.categoria-header {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 56px;
  position: relative;
  z-index: 2;
}
.categoria-header .eyebrow { margin-bottom: 16px; display: inline-block; }
.categoria-header h2 {
  font-size: clamp(28px, 3.6vw, 44px);
  margin-bottom: 16px;
  letter-spacing: -.01em;
  text-shadow: 0 1px 0 rgba(255,255,255,.6);
}
.categoria-header p {
  font-size: clamp(15px, 1.6vw, 17px);
  color: var(--verde);
  line-height: 1.65;
  max-width: 620px;
  margin: 0 auto;
  font-weight: 500;
}
.categoria-header p strong { color: var(--coral); font-weight: 700; }

/* Floating illustrations within categoria */
.floating-illustration {
  position: absolute;
  pointer-events: none;
  width: 110px;
  opacity: .55;
  z-index: 1;
  animation: floatY 7s ease-in-out infinite;
}
.floating-illustration.top-right { top: 60px; right: 5%; }
.floating-illustration.bottom-left {
  bottom: 60px;
  left: 4%;
  width: 90px;
  animation: floatY 8s ease-in-out infinite reverse;
}
@media (max-width: 900px) {
  .floating-illustration { width: 70px; opacity: .4; }
  .floating-illustration.top-right { top: 30px; right: 4%; }
  .floating-illustration.bottom-left { bottom: 30px; width: 60px; }
}

/* --- Grid de cards (4 cols desktop, 3 tablet, 2 small tablet, 1 mobile) --- */
.equipe-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  max-width: 1240px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
/* Override carousel-card flex behavior dentro do grid */
.equipe-grid .carousel-card {
  flex: initial !important;
  width: 100%;
  scroll-snap-align: none;
  padding: 28px 24px !important;
  gap: 14px !important;
  border-radius: 22px;
  height: 100%;
}
.equipe-grid .carousel-card-header {
  flex-direction: column;
  text-align: center;
  align-items: center;
  gap: 14px;
}
.equipe-grid .carousel-card-photo {
  width: 130px !important;
  height: 130px !important;
  border-radius: 28px;
}
.equipe-grid .carousel-card-name {
  font-size: 17px;
  margin-bottom: 4px;
}
.equipe-grid .carousel-card-spec {
  font-size: 11px;
  letter-spacing: .08em;
}
.equipe-grid .carousel-card-bio {
  font-size: 13.5px;
  line-height: 1.6;
  text-align: center;
}
.equipe-grid .carousel-card-crm {
  font-size: 10.5px;
  text-align: center;
  letter-spacing: .05em;
  padding-top: 12px;
}

/* Card destacado (Pedro / Fernanda) ocupa 2 colunas no grid quando primeiro */
.equipe-grid .carousel-card.featured {
  grid-column: span 2;
}
.equipe-grid .carousel-card.featured .carousel-card-header {
  flex-direction: row;
  text-align: left;
  align-items: center;
}
.equipe-grid .carousel-card.featured .carousel-card-bio,
.equipe-grid .carousel-card.featured .carousel-card-crm {
  text-align: left;
}
.equipe-grid .carousel-card.featured .carousel-card-photo {
  width: 140px !important;
  height: 140px !important;
}

@media (max-width: 1100px) {
  .equipe-grid { grid-template-columns: repeat(3, 1fr); gap: 22px; }
  .equipe-grid .carousel-card.featured { grid-column: span 3; }
}
@media (max-width: 800px) {
  .equipe-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .equipe-grid .carousel-card.featured { grid-column: span 2; }
  .equipe-grid .carousel-card { padding: 24px 18px !important; }
  .equipe-grid .carousel-card-photo { width: 110px !important; height: 110px !important; border-radius: 24px; }
}
@media (max-width: 520px) {
  .equipe-grid { grid-template-columns: 1fr; gap: 16px; }
  .equipe-grid .carousel-card.featured { grid-column: span 1; }
  .equipe-grid .carousel-card.featured .carousel-card-header {
    flex-direction: column;
    text-align: center;
  }
  .equipe-grid .carousel-card.featured .carousel-card-bio,
  .equipe-grid .carousel-card.featured .carousel-card-crm {
    text-align: center;
  }
  .equipe-categoria { padding: 60px 18px; }
  .categoria-header { margin-bottom: 40px; }
}

/* ============================================================
   /CONTATO — canais (cards), seção localização, FAQ accordion
   ============================================================ */

/* --- Grid de canais (WhatsApp em destaque ocupa 2 cols) --- */
.contato-canais {
  background: linear-gradient(180deg, var(--nude-cream) 0%, var(--branco) 100%);
}
.canais-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}
.canal-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 36px 32px;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 24px;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 4px rgba(89,110,101,.06),
    0 8px 18px rgba(89,110,101,.08),
    0 16px 32px rgba(89,110,101,.05);
}
.canal-card:hover {
  transform: translateY(-6px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 6px 12px rgba(89,110,101,.10),
    0 16px 36px rgba(89,110,101,.14),
    0 32px 60px rgba(89,110,101,.08);
}
.canal-icon {
  width: 64px;
  height: 64px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--branco);
  margin-bottom: 6px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.3),
    0 4px 10px rgba(89,110,101,.18),
    0 1px 2px rgba(89,110,101,.12);
}
.canal-icon svg { width: 32px; height: 32px; fill: currentColor; }

.canal-tag {
  position: absolute;
  top: 18px;
  right: 18px;
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 700;
  padding: 6px 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--coral), var(--amarelo));
  color: var(--branco);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    0 2px 6px rgba(168,95,73,.3);
}

.canal-card h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 24px;
  color: var(--verde);
  letter-spacing: -.01em;
  margin: 0;
  text-shadow: 0 1px 0 rgba(255,255,255,.6);
}
.canal-num {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 16px;
  color: var(--coral);
  letter-spacing: .01em;
  margin: -4px 0 6px;
}
.canal-desc {
  font-size: 14px;
  color: var(--cinza);
  line-height: 1.6;
  flex: 1;
  margin: 0;
}
.canal-cta {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 14px;
  color: var(--verde);
  letter-spacing: .01em;
  padding-top: 12px;
  border-top: 1px solid rgba(212,199,181,.5);
  margin-top: 8px;
  transition: color .25s ease, transform .25s ease;
}
.canal-card:hover .canal-cta {
  color: var(--coral);
  transform: translateX(4px);
}

/* WhatsApp destaque — ocupa 2 cols, fundo verde sutil */
.canal-whatsapp {
  grid-column: span 2;
  background: linear-gradient(135deg, #E8F5EA 0%, #FFFFFF 60%, #FCFAF6 100%);
  border: 2px solid #25D366;
  border-top-width: 5px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 4px 8px rgba(37,211,102,.18),
    0 14px 32px rgba(37,211,102,.18),
    0 28px 56px rgba(37,211,102,.10);
}
.canal-whatsapp .canal-icon {
  background: #25D366;
  width: 76px;
  height: 76px;
  border-radius: 22px;
}
.canal-whatsapp .canal-icon svg { width: 38px; height: 38px; }
.canal-whatsapp h3 { font-size: 32px; }
.canal-whatsapp .canal-num { font-size: 22px; color: #1ba452; }
.canal-whatsapp .canal-desc { font-size: 15px; max-width: 560px; }
.canal-whatsapp:hover {
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 8px 16px rgba(37,211,102,.22),
    0 22px 44px rgba(37,211,102,.22),
    0 40px 72px rgba(37,211,102,.14);
}

/* Cores dos ícones por canal */
.canal-telefone .canal-icon { background: var(--verde); }
.canal-instagram .canal-icon { background: linear-gradient(135deg, #F58529 0%, #DD2A7B 50%, #8134AF 100%); }
.canal-email .canal-icon { background: var(--coral); }

/* Variações de fundo sutis */
.canal-telefone { background: linear-gradient(180deg, #ECEED7 0%, #FFFFFF 50%); border-color: #889071; }
.canal-instagram { background: linear-gradient(180deg, #FCEEE9 0%, #FFFFFF 50%); border-color: #E5A593; }
.canal-email { background: linear-gradient(180deg, #FCF1C8 0%, #FFFFFF 50%); border-color: #C9A852; }

@media (max-width: 900px) {
  .canais-grid { grid-template-columns: repeat(2, 1fr); }
  .canal-whatsapp { grid-column: span 2; }
  .canal-whatsapp h3 { font-size: 28px; }
}
@media (max-width: 600px) {
  .canais-grid { grid-template-columns: 1fr; gap: 18px; }
  .canal-whatsapp { grid-column: span 1; }
  .canal-card { padding: 28px 24px; border-radius: 20px; }
  .canal-icon { width: 56px; height: 56px; border-radius: 16px; }
  .canal-icon svg { width: 28px; height: 28px; }
  .canal-whatsapp .canal-icon { width: 64px; height: 64px; }
  .canal-whatsapp .canal-icon svg { width: 32px; height: 32px; }
  .canal-card h3 { font-size: 22px; }
  .canal-whatsapp h3 { font-size: 26px; }
  .canal-num { font-size: 15px; }
  .canal-whatsapp .canal-num { font-size: 18px; }
  .canal-tag { top: 14px; right: 14px; font-size: 9px; padding: 5px 8px; }
}

/* --- Seção localização (where) --- */
.section-where {
  background:
    radial-gradient(ellipse at top right, rgba(247,201,191,.25) 0%, transparent 60%),
    var(--nude-cream);
}

/* --- FAQ accordion (skeumórfico) --- */
.faq-section {
  background: linear-gradient(180deg, var(--branco) 0%, var(--nude-cream) 100%);
}
.faq-list {
  max-width: 820px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.faq-item {
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 18px;
  overflow: hidden;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 4px rgba(89,110,101,.06),
    0 6px 14px rgba(89,110,101,.06);
  transition: box-shadow .25s ease, border-color .25s ease;
}
.faq-item[open] {
  border-color: var(--coral-light);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 4px 8px rgba(168,95,73,.10),
    0 12px 24px rgba(168,95,73,.10);
}
.faq-item summary {
  list-style: none;
  list-style-type: none;
  cursor: pointer;
  padding: 22px 26px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  user-select: none;
  transition: background .25s ease;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::marker { content: ""; font-size: 0; }
.faq-item > summary::-webkit-details-marker { display: none; }
.faq-item summary:hover { background: rgba(252,238,233,.4); }
.faq-q {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 17px;
  color: var(--verde);
  letter-spacing: -.005em;
  line-height: 1.4;
  flex: 1;
}
.faq-item summary::after {
  content: "+";
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 400;
  color: var(--coral);
  line-height: 1;
  flex-shrink: 0;
  transition: transform .3s cubic-bezier(.2,.8,.2,1);
  display: inline-block;
}
.faq-item[open] summary::after {
  transform: rotate(45deg);
}
.faq-a {
  padding: 0 26px 24px;
  border-top: 1px solid rgba(212,199,181,.4);
  margin-top: -1px;
}
.faq-a p {
  font-size: 15px;
  color: var(--cinza);
  line-height: 1.7;
  margin: 16px 0 0;
}
.faq-a p strong { color: var(--verde); font-weight: 600; }
.faq-a a { color: var(--coral); text-decoration: none; font-weight: 500; }
.faq-a a:hover { text-decoration: underline; }

@media (max-width: 600px) {
  .faq-item summary { padding: 18px 20px; gap: 12px; }
  .faq-q { font-size: 15px; }
  .faq-toggle { width: 28px; height: 28px; font-size: 18px; }
  .faq-a { padding: 0 20px 20px; }
  .faq-a p { font-size: 14px; }
}

/* ============================================================
   /ECO — LP do Viva Eco (cardiopediatria & ecocardiograma)
   ============================================================ */

/* Hero do Eco — sutil tom verde-coral pra remeter ao coração */
.eco-hero {
  background:
    radial-gradient(ellipse at center, rgba(255,255,255,.55) 0%, rgba(255,255,255,0) 65%),
    linear-gradient(135deg, rgba(247,201,191,.45) 0%, rgba(250,247,239,.5) 50%, rgba(212,225,232,.55) 100%),
    var(--nude-cream);
}

/* SVG icons dentro de dna-card (variação do .dna-icon que era texto/emoji) */
.dna-card .dna-icon svg {
  width: 36px;
  height: 36px;
  margin: 0 auto;
  display: block;
}

.dna-card.coral .dna-icon { color: var(--coral); }
.dna-card.azul .dna-icon { color: #6F8B9C; }
.dna-card.amarelo .dna-icon { color: #B89436; }
.dna-card.verde .dna-icon { color: var(--verde); }

/* --- Pillars (diferenciais Eco) --- */
.eco-pillars {
  background: linear-gradient(180deg, var(--nude-cream) 0%, var(--branco) 100%);
}

/* --- Exames grid (6 cards numerados) --- */
.eco-exames {
  background: linear-gradient(180deg, var(--branco) 0%, #FCEEE9 100%);
  position: relative;
  overflow: hidden;
}
.eco-exames::before {
  content: "";
  position: absolute;
  top: 10%; right: -5%;
  width: 360px; height: 360px;
  background: radial-gradient(circle, rgba(247,201,191,.35) 0%, transparent 70%);
  pointer-events: none;
}
.exames-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.exame-card {
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 22px;
  padding: 32px 28px;
  position: relative;
  transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 4px rgba(89,110,101,.06),
    0 8px 18px rgba(89,110,101,.08);
}
.exame-card:hover {
  transform: translateY(-4px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 4px 8px rgba(89,110,101,.08),
    0 14px 28px rgba(89,110,101,.12);
}
.exame-num {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  color: var(--coral);
  letter-spacing: .12em;
  margin-bottom: 10px;
  display: inline-block;
  padding: 6px 12px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--coral-pale) 0%, #FFFFFF 100%);
  border: 1px solid var(--coral-light);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    0 2px 4px rgba(168,95,73,.10);
}
.exame-card h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 20px;
  color: var(--verde);
  margin: 12px 0 12px;
  letter-spacing: -.005em;
  line-height: 1.2;
}
.exame-card p {
  font-size: 14px;
  color: var(--cinza);
  line-height: 1.65;
  margin: 0;
}
@media (max-width: 900px) {
  .exames-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
}
@media (max-width: 560px) {
  .exames-grid { grid-template-columns: 1fr; }
  .exame-card { padding: 28px 22px; }
}

/* --- Sala do Eco (split com fotos) --- */
.sala-eco-section {
  background: var(--nude-cream);
  position: relative;
  overflow: hidden;
}
.sala-eco-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
}
.sala-eco-content .eyebrow { display: inline-block; margin-bottom: 16px; }
.sala-eco-content h2 {
  font-size: clamp(28px, 3.6vw, 42px);
  letter-spacing: -.01em;
  margin-bottom: 16px;
  text-shadow: 0 1px 0 rgba(255,255,255,.6);
}
.sala-eco-content > p {
  font-size: 16px;
  color: var(--cinza);
  line-height: 1.7;
  margin-bottom: 24px;
}
.sala-features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.sala-features li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 16px;
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(212,199,181,.5);
  border-radius: 14px;
  font-size: 14px;
  color: var(--verde);
  line-height: 1.5;
  font-weight: 500;
  backdrop-filter: blur(4px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 1px 2px rgba(89,110,101,.06);
}
.sala-features .check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 7px;
  background: linear-gradient(180deg, #F8C5B6 0%, var(--coral) 100%);
  color: var(--branco);
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    0 2px 4px rgba(168,95,73,.3);
}

.sala-eco-photos {
  position: relative;
  height: 100%;
  min-height: 480px;
}
.sala-eco-photo-main {
  position: absolute;
  top: 0;
  left: 0;
  width: 78%;
  height: 78%;
  object-fit: cover;
  border-radius: 24px;
  border: 4px solid var(--branco);
  box-shadow:
    0 4px 12px rgba(89,110,101,.12),
    0 18px 40px rgba(89,110,101,.15);
}
.sala-eco-photo-detail {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 56%;
  height: 50%;
  object-fit: cover;
  border-radius: 22px;
  border: 4px solid var(--branco);
  box-shadow:
    0 4px 12px rgba(168,95,73,.18),
    0 16px 36px rgba(168,95,73,.20);
}
@media (max-width: 900px) {
  .sala-eco-grid { grid-template-columns: 1fr; gap: 40px; }
  .sala-eco-photos { min-height: 360px; }
}
@media (max-width: 560px) {
  .sala-eco-photos { min-height: 320px; }
  .sala-eco-photo-main { width: 82%; height: 75%; }
  .sala-eco-photo-detail { width: 60%; height: 50%; }
}

/* --- Convênios (chips) --- */
.convenios-section {
  background: linear-gradient(180deg, #E5EEF3 0%, var(--branco) 100%);
}
.convenios-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  max-width: 880px;
  margin: 0 auto 32px;
}
.convenio-chip {
  padding: 14px 24px;
  background: linear-gradient(180deg, #FFFFFF 0%, #F4F8FA 100%);
  border: 1px solid #A1B5C1;
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 14px;
  color: var(--verde);
  letter-spacing: .01em;
  transition: transform .25s ease, box-shadow .25s ease;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 4px rgba(94,124,140,.10),
    0 6px 14px rgba(94,124,140,.10);
}
.convenio-chip:hover {
  transform: translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 4px 8px rgba(94,124,140,.14),
    0 10px 24px rgba(94,124,140,.14);
}
.convenio-chip.particular {
  background: linear-gradient(135deg, var(--coral-pale) 0%, var(--branco) 60%);
  border-color: var(--coral-light);
  color: var(--coral);
}
.convenios-note {
  text-align: center;
  font-size: 14px;
  color: var(--cinza);
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.6;
}
.convenios-note a {
  color: var(--coral);
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px dashed var(--coral-light);
  padding-bottom: 1px;
}
.convenios-note a:hover { color: var(--verde); border-bottom-color: var(--verde); }

/* --- Como agendar (3 passos) --- */
.section-passos {
  background: linear-gradient(180deg, var(--branco) 0%, var(--nude-cream) 100%);
}
.passos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}
.passo-card {
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 24px;
  padding: 40px 32px;
  text-align: center;
  position: relative;
  transition: transform .3s cubic-bezier(.2,.8,.2,1);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 4px rgba(89,110,101,.06),
    0 8px 20px rgba(89,110,101,.08),
    0 18px 40px rgba(89,110,101,.05);
}
.passo-card:hover { transform: translateY(-5px); }
.passo-num {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--coral), var(--amarelo));
  color: var(--branco);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 28px;
  margin: 0 auto 20px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    inset 0 -2px 4px rgba(168,95,73,.2),
    0 4px 10px rgba(168,95,73,.3),
    0 10px 24px rgba(168,95,73,.18);
}
.passo-card:nth-child(2) .passo-num { background: linear-gradient(135deg, var(--verde-claro), var(--verde)); box-shadow: inset 0 1px 0 rgba(255,255,255,.4), inset 0 -2px 4px rgba(60,80,70,.2), 0 4px 10px rgba(89,110,101,.3), 0 10px 24px rgba(89,110,101,.18); }
.passo-card:nth-child(3) .passo-num { background: linear-gradient(135deg, #6F8B9C, var(--azul)); box-shadow: inset 0 1px 0 rgba(255,255,255,.4), inset 0 -2px 4px rgba(60,80,90,.2), 0 4px 10px rgba(94,124,140,.3), 0 10px 24px rgba(94,124,140,.18); }
.passo-card h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 22px;
  color: var(--verde);
  margin-bottom: 12px;
  letter-spacing: -.005em;
}
.passo-card p {
  font-size: 14.5px;
  color: var(--cinza);
  line-height: 1.65;
  margin: 0;
}
.passo-card p strong { color: var(--coral); font-weight: 600; }
@media (max-width: 800px) {
  .passos-grid { grid-template-columns: 1fr; gap: 18px; }
  .passo-card { padding: 32px 24px; }
}

/* ============================================================
   /MEDICOS — LP B2B (aluguel de consultório pediátrico)
   ============================================================ */

/* Pitch — split com fachada da clínica */
.medicos-pitch {
  background: linear-gradient(180deg, var(--nude-cream) 0%, var(--branco) 100%);
}
.pitch-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 56px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
}
.pitch-content .eyebrow { display: inline-block; margin-bottom: 16px; }
.pitch-content h2 {
  font-size: clamp(28px, 3.6vw, 44px);
  margin-bottom: 20px;
  letter-spacing: -.01em;
  text-shadow: 0 1px 0 rgba(255,255,255,.6);
}
.pitch-content > p {
  font-size: 16px;
  color: var(--cinza);
  line-height: 1.7;
  margin-bottom: 32px;
}
.pitch-content > p strong { color: var(--verde); font-weight: 600; }
.pitch-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.pitch-stat {
  text-align: center;
  padding: 20px 12px;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 16px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 4px rgba(89,110,101,.06),
    0 6px 14px rgba(89,110,101,.08);
}
.pitch-stat .num {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(24px, 2.6vw, 32px);
  color: var(--coral);
  line-height: 1.05;
  letter-spacing: -.01em;
  margin-bottom: 6px;
}
.pitch-stat:nth-child(2) .num { color: var(--verde); }
.pitch-stat:nth-child(3) .num { color: var(--azul); }
.pitch-stat .label {
  font-size: 11px;
  color: var(--cinza);
  letter-spacing: .06em;
  text-transform: uppercase;
  font-weight: 600;
  line-height: 1.4;
}
.pitch-photo img {
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
  object-position: center 60%;
  border-radius: 28px;
  border: 4px solid var(--branco);
  box-shadow:
    0 4px 12px rgba(89,110,101,.12),
    0 18px 40px rgba(89,110,101,.18);
}
@media (max-width: 900px) {
  .pitch-grid { grid-template-columns: 1fr; gap: 32px; }
  .pitch-photo img { min-height: 320px; }
}
@media (max-width: 480px) {
  .pitch-stats { grid-template-columns: 1fr; gap: 10px; }
  .pitch-stat { padding: 16px 12px; }
}

/* O que está incluso — 6 cards (override do dna-grid pra 3 cols com 6 itens) */
.incluso-section { background: var(--branco); }
.incluso-grid {
  grid-template-columns: repeat(3, 1fr) !important;
  max-width: 1200px !important;
}
@media (max-width: 1024px) {
  .incluso-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 600px) {
  .incluso-grid { grid-template-columns: 1fr !important; }
}

/* Tour pela clínica — galeria mosaico */
.tour-clinica {
  background:
    radial-gradient(ellipse at bottom left, rgba(247,201,191,.22) 0%, transparent 60%),
    var(--nude-cream);
  scroll-margin-top: 100px;
}
.medicos-galeria {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 200px;
  gap: 14px;
  max-width: 1200px;
  margin: 0 auto;
}
.medicos-galeria img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 18px;
  border: 3px solid var(--branco);
  box-shadow:
    0 2px 6px rgba(89,110,101,.10),
    0 10px 24px rgba(89,110,101,.12);
  transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease;
  background: var(--nude-cream);
}
.medicos-galeria img:hover {
  transform: scale(1.02);
  box-shadow:
    0 4px 8px rgba(89,110,101,.14),
    0 16px 36px rgba(89,110,101,.18);
}
/* Variação de tamanhos pra criar mosaico interessante */
.medicos-galeria img:nth-child(1) { grid-column: span 2; grid-row: span 2; }
.medicos-galeria img:nth-child(2) { grid-column: span 2; }
.medicos-galeria img:nth-child(5) { grid-column: span 2; }
/* Fachada — recortar mostrando o letreiro "viva" */
.medicos-galeria .galeria-fachada {
  object-position: center 65%;
}
@media (max-width: 900px) {
  .medicos-galeria { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; gap: 10px; }
  .medicos-galeria img:nth-child(1) { grid-column: span 2; grid-row: span 1; }
  .medicos-galeria img:nth-child(2) { grid-column: span 2; }
  .medicos-galeria img:nth-child(5) { grid-column: span 2; }
}

/* 4 passos no medicos (override do passos-grid) */
.passos-grid.passos-4 {
  grid-template-columns: repeat(4, 1fr);
  max-width: 1200px;
}
@media (max-width: 1000px) {
  .passos-grid.passos-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .passos-grid.passos-4 { grid-template-columns: 1fr; }
}
/* Cor extra pro 4º passo */
.passos-grid.passos-4 .passo-card:nth-child(4) .passo-num {
  background: linear-gradient(135deg, var(--amarelo), #C9A852);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    inset 0 -2px 4px rgba(120,90,15,.2),
    0 4px 10px rgba(220,180,40,.3),
    0 10px 24px rgba(220,180,40,.18);
}

/* Para quem é (parte-equipe-section override) */
.parte-equipe-section {
  background: linear-gradient(180deg, #FCEEE9 0%, var(--branco) 100%);
  position: relative;
  overflow: hidden;
  scroll-margin-top: 100px;
}

/* ============================================================
   /BLOG — index (listagem) e post (artigo individual)
   ============================================================ */

/* --- Filtro de categorias (pills) --- */
.blog-filters {
  background: var(--nude-cream);
  padding: 24px 24px 12px;
  border-bottom: 1px solid rgba(212,199,181,.4);
}
.blog-categorias {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0;
}
.cat-pill {
  display: inline-flex;
  align-items: center;
  padding: 10px 18px;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  color: var(--verde);
  text-decoration: none;
  letter-spacing: .01em;
  transition: all .25s ease;
  cursor: pointer;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 1px 2px rgba(89,110,101,.06),
    0 3px 8px rgba(89,110,101,.06);
}
.cat-pill:hover {
  transform: translateY(-2px);
  background: linear-gradient(180deg, var(--coral-pale) 0%, #FFFFFF 100%);
  border-color: var(--coral);
  color: var(--coral);
}
.cat-pill.active {
  background: linear-gradient(135deg, var(--coral) 0%, #B8634C 100%);
  color: var(--branco);
  border-color: var(--coral);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.3),
    0 2px 4px rgba(168,95,73,.2),
    0 6px 14px rgba(168,95,73,.25);
}
@media (max-width: 768px) {
  .blog-filters { padding: 18px 16px 8px; }
  .blog-categorias { gap: 8px; }
  .cat-pill { font-size: 12px; padding: 8px 14px; }
}

/* --- Tag de categoria (em cards e posts) --- */
.blog-cat {
  display: inline-block;
  padding: 5px 12px;
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--branco);
  background: var(--coral);
  margin-bottom: 14px;
  align-self: flex-start;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.3), 0 2px 4px rgba(168,95,73,.18);
}
.blog-cat-cardio { background: var(--coral); }
.blog-cat-pediatria { background: var(--verde); }
.blog-cat-especialidades { background: var(--azul); }
.blog-cat-desenvolvimento { background: linear-gradient(135deg, #6F8B9C, var(--azul)); }
.blog-cat-alimentacao { background: linear-gradient(135deg, var(--amarelo), #C9A852); }

/* --- Post em destaque (full-width card) --- */
.blog-featured-section { background: var(--branco); }
.blog-featured {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 0;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 28px;
  overflow: hidden;
  text-decoration: none;
  max-width: 1200px;
  margin: 0 auto;
  transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 4px 12px rgba(89,110,101,.08),
    0 16px 36px rgba(89,110,101,.12);
}
.blog-featured:hover {
  transform: translateY(-4px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 8px 18px rgba(89,110,101,.10),
    0 24px 50px rgba(89,110,101,.14);
}
.blog-featured-cover {
  position: relative;
  min-height: 380px;
  overflow: hidden;
}
.blog-featured-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}
.blog-featured:hover .blog-featured-cover img { transform: scale(1.04); }
.blog-featured-tag {
  position: absolute;
  top: 20px;
  left: 20px;
  padding: 8px 14px;
  background: linear-gradient(135deg, var(--coral), var(--amarelo));
  color: var(--branco);
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    0 4px 10px rgba(168,95,73,.3);
}
.blog-featured-content {
  padding: 48px 44px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.blog-featured-content h2 {
  font-size: clamp(24px, 2.6vw, 32px);
  color: var(--verde);
  letter-spacing: -.01em;
  line-height: 1.2;
  margin-bottom: 16px;
}
.blog-featured-content p {
  font-size: 15px;
  color: var(--cinza);
  line-height: 1.65;
  margin-bottom: 24px;
}
@media (max-width: 900px) {
  .blog-featured { grid-template-columns: 1fr; }
  .blog-featured-cover { min-height: 240px; }
  .blog-featured-content { padding: 32px 28px; }
}

/* --- Grid de posts (3 cols desktop) --- */
.blog-list-section { background: var(--nude-cream); }
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  max-width: 1200px;
  margin: 0 auto;
}
.blog-card {
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 22px;
  overflow: hidden;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 2px 4px rgba(89,110,101,.06),
    0 8px 18px rgba(89,110,101,.08);
}
.blog-card:hover {
  transform: translateY(-5px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 4px 8px rgba(89,110,101,.10),
    0 16px 32px rgba(89,110,101,.14);
}
.blog-card-cover {
  width: 100%;
  height: 200px;
  overflow: hidden;
  background: var(--nude-cream);
  position: relative;
}
.blog-card-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform .5s ease;
}
.blog-card:hover .blog-card-cover img { transform: scale(1.05); }
.blog-card-content {
  padding: 24px 24px 22px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.blog-card-content h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 19px;
  color: var(--verde);
  letter-spacing: -.005em;
  line-height: 1.25;
  margin-bottom: 12px;
}
.blog-card-content p {
  font-size: 14px;
  color: var(--cinza);
  line-height: 1.6;
  margin-bottom: 18px;
  flex: 1;
}

/* Meta (autor + tempo + data) */
.blog-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 12px;
  color: var(--cinza);
  letter-spacing: .02em;
  padding-top: 14px;
  border-top: 1px solid rgba(212,199,181,.5);
  margin-top: auto;
}
.meta-author {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: var(--verde);
}
.meta-author img {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center top;
  border: 2px solid var(--branco);
  box-shadow: 0 1px 3px rgba(89,110,101,.2);
}
.meta-dot { color: var(--cinza-light); }

@media (max-width: 1000px) {
  .blog-grid { grid-template-columns: repeat(2, 1fr); gap: 22px; }
}
@media (max-width: 640px) {
  .blog-grid { grid-template-columns: 1fr; }
}

.blog-empty-note {
  text-align: center;
  font-size: 14px;
  color: var(--cinza);
  margin: 40px auto;
  max-width: 560px;
  line-height: 1.6;
}
.blog-empty-note a {
  color: var(--coral);
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px dashed var(--coral-light);
}

/* ============================================================
   /BLOG — POST (artigo individual)
   ============================================================ */

.post {
  background: var(--branco);
}
.post-container {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 24px;
}

/* Hero do post */
.post-hero {
  padding: 56px 24px 36px;
  background: linear-gradient(180deg, var(--nude-cream) 0%, var(--branco) 100%);
  text-align: center;
}
.post-back {
  display: inline-block;
  margin-bottom: 24px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  color: var(--cinza);
  text-decoration: none;
  letter-spacing: .02em;
  transition: color .2s ease, transform .2s ease;
}
.post-back:hover { color: var(--coral); transform: translateX(-3px); }
.post-hero .blog-cat { margin: 0 auto 20px; display: inline-block; }
.post-hero h1 {
  font-size: clamp(28px, 4.2vw, 48px);
  letter-spacing: -.015em;
  line-height: 1.15;
  color: var(--verde);
  margin-bottom: 20px;
  text-shadow: 0 1px 0 rgba(255,255,255,.6);
}
.post-lead {
  font-size: clamp(16px, 1.8vw, 19px);
  color: var(--cinza);
  line-height: 1.65;
  margin-bottom: 28px;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.post-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  font-size: 13px;
  color: var(--cinza);
}
.post-meta .meta-author img {
  width: 32px;
  height: 32px;
}
.post-meta .meta-author strong { color: var(--verde); font-weight: 600; }

/* Cover do post */
.post-cover-wrap {
  background: linear-gradient(180deg, var(--branco) 50%, var(--nude-cream) 50%);
  padding: 0 0 0;
}
.post-cover {
  width: 100%;
  max-width: 1000px;
  height: clamp(240px, 40vw, 480px);
  object-fit: cover;
  border-radius: 24px;
  border: 4px solid var(--branco);
  box-shadow:
    0 4px 12px rgba(89,110,101,.10),
    0 18px 40px rgba(89,110,101,.14);
  margin: 0 auto;
  display: block;
}
.post-cover-wrap .post-container { max-width: 1000px; }

/* Body do post (typography) */
.post-body {
  background: var(--nude-cream);
  padding: 56px 0 64px;
}
.post-body p,
.post-body ul,
.post-body ol,
.post-body blockquote {
  font-size: 17px;
  color: var(--cinza);
  line-height: 1.75;
  margin-bottom: 24px;
}
.post-body p strong { color: var(--verde); font-weight: 600; }
.post-body h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(24px, 2.8vw, 30px);
  color: var(--verde);
  letter-spacing: -.01em;
  line-height: 1.25;
  margin: 48px 0 18px;
}
.post-body h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(19px, 2.2vw, 22px);
  color: var(--coral);
  letter-spacing: -.005em;
  line-height: 1.3;
  margin: 36px 0 14px;
}
.post-body ul, .post-body ol { padding-left: 24px; }
.post-body ul li, .post-body ol li { margin-bottom: 8px; line-height: 1.7; }
.post-body ul li::marker { color: var(--coral); }
.post-body ol li::marker { color: var(--coral); font-weight: 700; }

.post-body blockquote {
  border-left: 4px solid var(--coral);
  padding: 20px 24px 20px 28px;
  background: linear-gradient(135deg, var(--coral-pale) 0%, var(--branco) 100%);
  border-radius: 14px;
  margin: 32px 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-style: italic;
  color: var(--verde);
}
.post-body blockquote p { font-size: 19px; color: var(--verde); margin: 0; line-height: 1.55; }

.post-body a {
  color: var(--coral);
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1px dashed var(--coral-light);
}
.post-body a:hover { color: var(--verde); border-bottom-color: var(--verde); }

/* Card do autor */
.post-author-section {
  background: var(--nude-cream);
  padding: 0 0 64px;
}
.post-author-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 24px;
  align-items: center;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-left: 5px solid var(--coral);
  border-radius: 22px;
  padding: 32px 32px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 4px 12px rgba(89,110,101,.08),
    0 14px 32px rgba(89,110,101,.10);
}
.post-author-photo {
  width: 96px;
  height: 96px;
  border-radius: 24px;
  object-fit: cover;
  object-position: center top;
  border: 3px solid var(--branco);
  box-shadow: 0 4px 10px rgba(89,110,101,.18);
}
.post-author-label {
  font-size: 11px;
  color: var(--cinza);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 600;
}
.post-author-card h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 22px;
  color: var(--verde);
  margin: 4px 0 4px;
  letter-spacing: -.005em;
}
.post-author-spec {
  font-size: 12px;
  color: var(--coral);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: 12px;
}
.post-author-bio {
  font-size: 14px;
  color: var(--cinza);
  line-height: 1.65;
  margin-bottom: 14px;
}
.post-author-link {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  color: var(--coral);
  text-decoration: none;
  transition: transform .2s ease;
  display: inline-block;
}
.post-author-link:hover { transform: translateX(4px); color: var(--verde); }

@media (max-width: 600px) {
  .post-author-card { grid-template-columns: 1fr; text-align: center; padding: 28px 24px; }
  .post-author-photo { margin: 0 auto; }
}

/* Posts relacionados */
.related-posts-section {
  background: linear-gradient(180deg, var(--branco) 0%, var(--nude-cream) 100%);
  padding: 64px 24px;
}
.related-posts-section .categoria-header { margin-bottom: 40px; }
.related-grid { max-width: 1200px; }
.parte-equipe-card {
  max-width: 1100px;
  margin: 0 auto;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFAF6 100%);
  border: 1px solid #D4C7B5;
  border-radius: 32px;
  padding: 56px 56px 48px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 4px 12px rgba(89,110,101,.08),
    0 16px 36px rgba(89,110,101,.10),
    0 32px 64px rgba(89,110,101,.06);
  position: relative;
  z-index: 2;
}
.parte-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  margin-bottom: 36px;
}
.parte-grid h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 22px;
  color: var(--coral);
  margin-bottom: 16px;
  letter-spacing: -.005em;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--coral-light);
  display: inline-block;
}
.parte-grid > div:nth-child(2) h3 {
  color: var(--verde);
  border-bottom-color: var(--verde-claro);
}
.parte-lista {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.parte-lista li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 14.5px;
  color: var(--cinza);
  line-height: 1.6;
  padding: 4px 0;
}
.parte-lista .check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 7px;
  background: linear-gradient(180deg, #F8C5B6 0%, var(--coral) 100%);
  color: var(--branco);
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 2px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    0 2px 4px rgba(168,95,73,.3);
}
.parte-grid > div:nth-child(2) .parte-lista .check {
  background: linear-gradient(180deg, #B8C8A8 0%, var(--verde) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.4),
    0 2px 4px rgba(89,110,101,.3);
}
.parte-cta {
  text-align: center;
  padding-top: 32px;
  border-top: 1px solid rgba(212,199,181,.5);
}
.parte-cta p {
  font-size: 15px;
  color: var(--verde);
  font-weight: 500;
  max-width: 580px;
  margin: 0 auto;
  line-height: 1.6;
}

@media (max-width: 800px) {
  .parte-equipe-card { padding: 40px 28px 32px; border-radius: 24px; }
  .parte-grid { grid-template-columns: 1fr; gap: 36px; margin-bottom: 28px; }
  .parte-grid h3 { font-size: 19px; }
  .parte-cta { padding-top: 24px; }
}
