@charset "UTF-8";

/* ===== Paleta MaleFlow ===== */
:root{
  --primary:#335953;   /* teal */
  --terracota:#CC6A5A; /* acento */
  --bg:#ffffff;
  --soft:#f5f7f6;
  --border:#e6ecea;
  --gray-900:#1f2937;
  --gray-700:#4b5563;
  --glass: rgba(255,255,255,0.15);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--gray-900);font-family:'Rubik',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica,Arial}
html, body {overflow-x:hidden; touch-action: pan-y; max-width:100%;}
a{color:var(--primary);text-decoration:none}
.container{width:min(1120px,92vw);margin-inline:auto}

/* ===== Splash ===== */
#splash{
  position:fixed; inset:0; z-index:999;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  background:#f8f9f9;
  transition: opacity 1.2s ease, transform 1.2s ease;
}
#splash.fade-out{ opacity:0; transform:scale(1.03) translateY(-6px); pointer-events:none; }
.brand-splash{
  font-family:'Playfair Display', serif;
  font-size: 2.2rem;
  margin:.2rem 0;
  color:#0f1f1c;
}
#splash h2{
  font-family:'Rubik',sans-serif; font-size:1.05rem; color:#444; margin:0;
}

/* ===== Topbar / Header ===== */
.topbar{
  background: linear-gradient(90deg, #3A6A63, #2A4945);
  color:#fff; padding:.5rem 0; font-size:.95rem;
}
.topbar .container{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}

header{
  position:sticky; top:0; z-index:50;
  background: rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--border);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:.5rem 0}
.logo-img {
  height: auto;
  max-height: 72px;
  width: auto;
  max-width: 100%;
  display: block;
  object-fit: contain;
}
.nav-links{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}
.cta-header{
  padding:.7rem 1.1rem; border-radius:999px;
  background:var(--primary); color:#fff; font-weight:800;
  box-shadow:0 6px 16px rgba(51,89,83,.25);
}

/* ===== Hero ===== */
.hero{
  display:grid; grid-template-columns:1fr 1fr;
  grid-template-areas:"image text";
  gap:2rem; align-items:center; padding:3rem 0;
}
.hero-media{ grid-area:image; border-radius:18px; overflow:hidden; box-shadow:0 20px 40px rgba(51,89,83,.18); aspect-ratio:4/3; background:#fff; }
.hero-media picture,.hero-media img{width:100%;height:100%;display:block;object-fit:cover}
.hero-text{grid-area:text}
.kicker{letter-spacing:.1em;text-transform:uppercase;color:var(--primary);font-weight:900;font-size:.85rem}
h1{font-family:"Playfair Display",serif;line-height:1.05;margin:.4rem 0 1rem;font-size:clamp(1.9rem,3.2vw + 1rem,3.4rem)}
.sub{font-size:1.1rem;color:var(--gray-700)}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.25rem}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:1rem 1.25rem;border-radius:14px;font-weight:900;border:2px solid transparent;transition:.2s ease;cursor:pointer
}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 12px 24px rgba(51,89,83,.25)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 16px 28px rgba(51,89,83,.28)}
.btn-ghost{background:#fff;border-color:var(--border);color:var(--gray-900)}

/* ===== Seções e cartões ===== */
.section{padding:2.5rem 0}
.section h2{font-family:"Playfair Display",serif;font-size:clamp(1.4rem,2vw + .8rem,2.2rem);margin:0 0 .75rem;color:var(--primary)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:1.2rem;box-shadow:0 10px 24px rgba(51,89,83,.08)}

/* ===== Metodologia: vídeo + cards ===== */
.ff-section{background:var(--soft)}
.ff-container{max-width:1120px;margin:0 auto;padding:2.5rem 1rem}
.ff-title{font-family:"Playfair Display",serif;font-weight:800;font-size:clamp(1.6rem,2.3vw,2.4rem);color:var(--primary);margin:0 0 1.25rem}
.ff-layout{display:grid;grid-template-columns:1fr 1.1fr; gap:1.5rem; align-items:start}
.ff-video{border-radius:18px;overflow:hidden;background:#000;aspect-ratio:9/16;max-width:360px;margin:0 auto;box-shadow:0 16px 28px rgba(51,89,83,.15)}
.ff-video .video-player{width:100%;height:100%;object-fit:cover;display:block}
.ff-stack{display:flex;flex-direction:column;gap:1rem}
.ff-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:1.25rem;box-shadow:0 10px 24px rgba(51,89,83,.06)}
.ff-card h3{font-size:1.1rem;margin:0 0 .5rem;color:var(--gray-900);font-weight:800}
.ff-card p{color:var(--gray-700);line-height:1.55;margin:0}
.ff-link{display:inline-block;margin-top:.75rem;font-weight:800;color:var(--primary)}
.ff-link:hover{text-decoration:underline}

/* ===== Ofertas / Planos ===== */
.ofertas-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.8rem; padding:1rem 0;
}
.oferta{
  background: var(--glass);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,0.35);
  border-radius:20px; padding:2rem 1.8rem;
  transition: all .35s ease; box-shadow:0 8px 24px rgba(0,0,0,0.08);
  color:#1d3b38; position:relative;
}
.oferta:hover{ transform: translateY(-6px); box-shadow: 0 12px 36px rgba(0,0,0,0.12); }
.oferta-head h3{ font-family:'Rubik',sans-serif; color:var(--primary); font-size:1.25rem; margin-bottom:.3rem; }
.oferta-head .sub{ font-size:.95rem; color: rgba(0,0,0,.75); margin-bottom:.8rem; }
.badge{
  display:inline-block; font-size:.8rem; font-weight:700; color:#fff;
  background: var(--primary); border-radius:999px; padding:.25rem .6rem; margin-bottom:.4rem;
}
.price{ font-size:1.3rem; font-weight:900; color:var(--primary); margin-bottom:1.2rem; }
.price span{ font-weight:400; font-size:.9rem; opacity:.7; }

.offer-btn{
  display:inline-block; border:none; border-radius:40px; padding:.8rem 1.6rem;
  background: linear-gradient(135deg, var(--primary), var(--terracota));
  color:#fff; font-weight:800; text-align:center; transition:all .3s ease;
  box-shadow:0 8px 20px rgba(51,89,83,.18);
}
.offer-btn:hover{ background:#fff; color:var(--primary); transform:translateY(-3px); }

/* Destaques */
.oferta.destaque{ border-color: rgba(204,106,90,0.28); background: linear-gradient(135deg, rgba(51,89,83,0.08), rgba(204,106,90,0.18)); }
.oferta.premium{ border-color: rgba(204,106,90,0.32); background: linear-gradient(135deg, rgba(51,89,83,0.10), rgba(204,106,90,0.22)); }

/* Badge animada */
.badge.pulse{
  background: linear-gradient(135deg, var(--terracota), #EFBDA6);
  box-shadow: 0 0 10px rgba(204,106,90,0.5);
  animation: pulseGlow 2.5s ease-in-out infinite;
}
@keyframes pulseGlow{
  0%,100%{ transform:scale(1); box-shadow:0 0 10px rgba(204,106,90,0.4); opacity:1; }
  50%{ transform:scale(1.08); box-shadow:0 0 20px rgba(239,189,166,0.8); opacity:.95; }
}

/* ===== Benefícios ===== */
.benefits .card h3{ margin:.1rem 0 .35rem; color:var(--primary); }

/* ===== Footer ===== */
footer{ padding:3rem 0 4rem; background:linear-gradient(180deg,#eef3f2,#fff); }
.footgrid{ display:grid; grid-template-columns:2fr 1fr 1fr; gap:1rem; }
.small{ font-size:.92rem; color:#6b7280; }
.footnote{ margin-top:1rem; font-size:.85rem; color:#6b7280; }

/* ===== LGPD ===== */
.lgpd{
  position:fixed; left:0; right:0; bottom:0;
  background: linear-gradient(90deg, #335953, #2A4945);
  color:#fff; display:flex; flex-wrap:wrap; justify-content:center; align-items:center;
  gap:12px; padding:14px 10px; z-index:9999; box-shadow:0 -4px 10px rgba(0,0,0,.15);
}
.lgpd .lgpd-actions{ display:flex; gap:10px; flex-wrap:wrap; }
.lgpd button{
  background:#fff; color:#335953; border:none; border-radius:10px; padding:8px 16px; font-weight:800; cursor:pointer;
}
.lgpd button.ghost{ background:transparent; color:#fff; border:1px solid #fff; }

/* ===== Fade-in utilitário ===== */
.reveal{ opacity:0; transform: translateY(16px); transition: opacity .7s ease, transform .7s ease; }
.reveal.ready{ opacity:1; transform:none; }

/* ===== Efeito “splash highlight” nos botões principais ===== */
.btn-splash{
  position:relative; overflow:hidden;
}
.btn-splash::after{
  content:""; position:absolute; inset:auto -20% -40% -20%; height:200%;
  background: radial-gradient(ellipse at center, rgba(255,255,255,.25), transparent 60%);
  transform: translateY(60%) rotate(8deg);
  transition: transform .6s ease, opacity .6s ease; opacity:.0; pointer-events:none;
}
.btn-splash:hover::after{ transform: translateY(15%) rotate(8deg); opacity:.9; }
/* === Correção fotos seção Responsável Técnico e Círculo de Apoio === */

.bio picture img {
  width: 160px;
  height: 160px;
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid var(--primary);
  display: block;
  margin: 0 auto;
}

/* texto ao lado ou abaixo, mantendo proporção */
.bio {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  justify-content: center;
  text-align: center;
  margin-bottom: 2rem;
}

.bio-texto {
  flex: 1;
  min-width: 250px;
}

/* Ícone do Instagram: normaliza tamanho e remove moldura circular */
.bio-texto img[alt="Instagram"] {
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 0;
  object-fit: contain;
  background: none;
  box-shadow: none;
}


/* ===== Responsivo ===== */
@media (max-width:980px){
  .hero{ grid-template-columns:1fr; grid-template-areas:"image" "text"; }
  .grid-3{ grid-template-columns:1fr 1fr; }
  .ff-layout{ grid-template-columns:1fr; }
  .footgrid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:640px){
  .grid-3{ grid-template-columns:1fr; }
  .footgrid{ grid-template-columns:1fr; }
}


