/*
Theme Name: EMF Institucional
Theme URI: https://escolamariadefatima.participaativa.com.br
Author: Participaativa
Description: Tema institucional mobile-first da Escola Maria de Fátima — 26 anos transformando vidas.
Version: 1.0.0
Text Domain: emf
*/

:root{
  --vermelho:#E63946;
  --vermelho-escuro:#B81E2C;
  --azul:#1D3557;
  --azul-claro:#457B9D;
  --amarelo:#F4A521;
  --turquesa:#2EC4B6;
  --bg:#F8F9FA;
  --bg-claro:#FFFFFF;
  --txt:#1A1A1A;
  --txt-suave:#444;
  --whatsapp:#25D366;
  --shadow:0 4px 16px rgba(29,53,87,.10);
  --shadow-lg:0 8px 32px rgba(29,53,87,.18);
  --radius:14px;
  --radius-sm:8px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Nunito',system-ui,-apple-system,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  font-size:17px;
  line-height:1.6;
  color:var(--txt);
  background:var(--bg);
}
img{max-width:100%;height:auto;display:block}
a{color:var(--azul);text-decoration:none}
a:hover{color:var(--vermelho)}

.wrap{width:100%;max-width:1180px;margin:0 auto;padding:0 18px}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:var(--azul);
  color:#fff;
  box-shadow:var(--shadow);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:800;letter-spacing:.2px}
.brand-mark{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--vermelho),var(--amarelo) 60%,var(--turquesa));
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.4);
  flex-shrink:0;
  font-size:18px;
}
.brand-logo{
  width:48px;height:48px;border-radius:50%;
  object-fit:cover;
  background:#fff;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.4),0 2px 6px rgba(0,0,0,.18);
  flex-shrink:0;
}
@media (min-width:720px){ .brand-logo{ width:56px;height:56px } }
.brand-name{font-size:1.05rem;line-height:1.1}
.brand-name small{display:block;font-weight:600;color:var(--amarelo);font-size:.72rem;letter-spacing:.5px;text-transform:uppercase}

.nav-toggle{
  background:transparent;border:none;color:#fff;
  width:42px;height:42px;border-radius:8px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.nav-toggle:focus-visible{outline:2px solid var(--amarelo)}
.nav-toggle svg{width:26px;height:26px}

.main-nav{display:none;width:100%;flex-basis:100%}
.main-nav.open{display:block}
.main-nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px;border-top:1px solid rgba(255,255,255,.15);padding-top:10px;margin-top:8px}
.main-nav a{display:block;padding:10px 12px;color:#fff;border-radius:8px;font-weight:700}
.main-nav a:hover,.main-nav a:focus-visible{background:rgba(255,255,255,.10);color:var(--amarelo)}

/* ============ BOTÕES ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 22px;border-radius:999px;font-weight:800;
  border:none;cursor:pointer;text-decoration:none;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
  font-size:1rem;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-primary{background:var(--vermelho);color:#fff}
.btn-primary:hover{background:var(--vermelho-escuro);color:#fff}
.btn-wa{background:var(--whatsapp);color:#fff}
.btn-wa:hover{background:#1ebe57;color:#fff}
.btn-secondary{background:#fff;color:var(--azul);border:2px solid var(--azul)}
.btn-secondary:hover{background:var(--azul);color:#fff}

/* ============ HERO ============ */
.hero{
  position:relative;
  background:
    linear-gradient(135deg,rgba(29,53,87,.92) 0%,rgba(69,123,157,.78) 60%,rgba(46,196,182,.65) 100%),
    url(assets/img/hero.jpg) center/cover no-repeat;
  color:#fff;
  padding:64px 0 80px;
  overflow:hidden;
}
.hero::after{
  content:"";
  position:absolute;left:0;right:0;bottom:-1px;height:48px;
  background:radial-gradient(60% 100% at 50% 0%,var(--bg) 60%,transparent 61%);
}
.hero-content{position:relative;z-index:2;text-align:center;max-width:780px;margin:0 auto}
.hero-eyebrow{
  display:inline-block;background:var(--amarelo);color:var(--azul);
  padding:6px 14px;border-radius:999px;font-weight:800;font-size:.85rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:14px
}
.hero h1{
  font-size:2rem;line-height:1.15;margin:0 0 14px;font-weight:900;
  text-shadow:0 2px 12px rgba(0,0,0,.25);
}
.hero h1 .accent{color:var(--amarelo)}
.hero p.lead{font-size:1.12rem;margin:0 auto 26px;max-width:620px;opacity:.95}
.hero-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.hero-badges{
  display:flex;gap:10px;justify-content:center;flex-wrap:wrap;
  margin-top:30px;font-size:.92rem;
}
.hero-badge{
  background:rgba(255,255,255,.14);backdrop-filter:blur(6px);
  padding:8px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.22);
  display:inline-flex;align-items:center;gap:6px;
}

/* ============ SEÇÕES ============ */
section{padding:64px 0}
.section-head{text-align:center;max-width:720px;margin:0 auto 40px}
.section-head .eyebrow{
  display:inline-block;color:var(--vermelho);font-weight:800;text-transform:uppercase;
  letter-spacing:1.5px;font-size:.82rem;margin-bottom:8px
}
.section-head h2{
  font-size:1.75rem;line-height:1.2;margin:0 0 12px;color:var(--azul);font-weight:900;
}
.section-head p{color:var(--txt-suave);margin:0;font-size:1.04rem}

/* ============ DIFERENCIAIS ============ */
.diferenciais{background:#fff}
.cards{display:grid;grid-template-columns:1fr;gap:18px}
.card{
  background:var(--bg);border-radius:var(--radius);padding:24px 20px;
  box-shadow:var(--shadow);text-align:center;
  border-top:5px solid var(--vermelho);
  transition:transform .2s ease,box-shadow .2s ease;
}
.card:nth-child(6n+2){border-top-color:var(--azul-claro)}
.card:nth-child(6n+3){border-top-color:var(--amarelo)}
.card:nth-child(6n+4){border-top-color:var(--turquesa)}
.card:nth-child(6n+5){border-top-color:var(--azul)}
.card:nth-child(6n){border-top-color:var(--vermelho-escuro)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card-icon{
  width:64px;height:64px;margin:0 auto 14px;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--vermelho),var(--amarelo));color:#fff;
}
.card:nth-child(6n+2) .card-icon{background:linear-gradient(135deg,var(--azul-claro),var(--turquesa))}
.card:nth-child(6n+3) .card-icon{background:linear-gradient(135deg,var(--amarelo),var(--vermelho))}
.card:nth-child(6n+4) .card-icon{background:linear-gradient(135deg,var(--turquesa),var(--azul))}
.card:nth-child(6n+5) .card-icon{background:linear-gradient(135deg,var(--azul),var(--azul-claro))}
.card:nth-child(6n) .card-icon{background:linear-gradient(135deg,var(--vermelho-escuro),var(--amarelo))}
.card-icon svg{width:34px;height:34px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.card h3{margin:0 0 8px;color:var(--azul);font-size:1.12rem;font-weight:800}
.card p{margin:0;color:var(--txt-suave);font-size:.96rem}

/* ============ SOBRE ============ */
.sobre{background:linear-gradient(180deg,var(--bg) 0%,#fff 100%)}
.sobre-grid{display:grid;grid-template-columns:1fr;gap:28px;align-items:center}
.sobre-image{
  aspect-ratio:4/3;border-radius:var(--radius);
  background:linear-gradient(135deg,rgba(230,57,70,.25),rgba(46,196,182,.25));
  display:flex;align-items:flex-end;justify-content:center;
  box-shadow:var(--shadow-lg);
  position:relative;overflow:hidden;
}
.sobre-image img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;
}
.sobre-image .badge{
  position:relative;z-index:2;background:#fff;color:var(--azul);
  padding:16px 28px;border-radius:var(--radius);margin:0 0 18px;
  text-align:center;box-shadow:var(--shadow);
}
.sobre-image .badge strong{display:block;font-size:2.2rem;color:var(--vermelho);line-height:1}
.sobre-image .badge span{font-weight:700}
.sobre-text h3{font-size:1.4rem;margin:0 0 14px;color:var(--azul);font-weight:900}
.sobre-text p{margin:0 0 14px;color:var(--txt-suave)}
.sobre-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.pill{background:var(--azul);color:#fff;padding:6px 14px;border-radius:999px;font-size:.85rem;font-weight:700}
.pill.amarela{background:var(--amarelo);color:var(--azul)}
.pill.turq{background:var(--turquesa);color:#fff}
.pill.verm{background:var(--vermelho);color:#fff}

/* ============ NÍVEIS ============ */
.niveis{background:#fff}
.niveis-row{display:grid;grid-template-columns:1fr;gap:14px}
.nivel{
  display:flex;align-items:center;gap:14px;padding:18px;
  background:var(--bg);border-radius:var(--radius);box-shadow:var(--shadow);
  border-left:6px solid var(--turquesa);
}
.nivel:nth-child(2){border-left-color:var(--amarelo)}
.nivel:nth-child(3){border-left-color:var(--vermelho)}
.nivel:nth-child(4){border-left-color:var(--azul)}
.nivel-num{
  width:48px;height:48px;flex-shrink:0;border-radius:50%;
  background:var(--azul);color:#fff;font-weight:900;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
}
.nivel:nth-child(1) .nivel-num{background:var(--turquesa)}
.nivel:nth-child(2) .nivel-num{background:var(--amarelo);color:var(--azul)}
.nivel:nth-child(3) .nivel-num{background:var(--vermelho)}
.nivel h4{margin:0 0 4px;color:var(--azul);font-size:1.05rem}
.nivel p{margin:0;color:var(--txt-suave);font-size:.94rem}

/* ============ PASSEIOS ============ */
.passeios{background:linear-gradient(180deg,#fff 0%,var(--bg) 100%)}
.passeios-grid{display:grid;grid-template-columns:1fr;gap:16px}
.passeio{
  position:relative;aspect-ratio:4/3;border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);color:#fff;
  display:flex;align-items:flex-end;padding:18px;
  font-weight:800;font-size:1.05rem;
}
.passeio span{position:relative;z-index:2}
.passeio::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.65) 100%);
  z-index:1;
}
.passeio:nth-child(1){background:linear-gradient(135deg,var(--azul) 0%,var(--turquesa) 100%)}
.passeio:nth-child(2){background:linear-gradient(135deg,var(--turquesa) 0%,var(--amarelo) 100%)}
.passeio:nth-child(3){background:linear-gradient(135deg,var(--amarelo) 0%,var(--vermelho) 100%)}
.passeio:nth-child(4){background:linear-gradient(135deg,var(--vermelho) 0%,var(--azul) 100%)}
.passeio-icon{
  position:absolute;top:14px;right:14px;z-index:2;
  width:48px;height:48px;background:rgba(255,255,255,.18);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.3);
}
.passeio-icon svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:2}
.passeios-nota{
  text-align:center;margin-top:24px;color:var(--txt-suave);font-size:.9rem;
  font-style:italic;
}

/* ============ GALERIA INFANTIL ============ */
.galeria-infantil{background:#fff}
.galeria-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
}
.galeria-item{
  position:relative;margin:0;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:4/3;box-shadow:var(--shadow);
  background:linear-gradient(135deg,var(--azul-claro),var(--turquesa));
}
.galeria-item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .35s ease;
}
.galeria-item:hover img{transform:scale(1.05)}
.galeria-item figcaption{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.7) 100%);
  color:#fff;font-weight:800;padding:18px 14px 12px;font-size:.95rem;
}
@media (min-width:720px){
  .galeria-grid{grid-template-columns:repeat(3,1fr);gap:18px}
}

/* ============ DEPOIMENTOS ============ */
.depoimentos{background:var(--azul);color:#fff}
.depoimentos .section-head h2{color:#fff}
.depoimentos .section-head .eyebrow{color:var(--amarelo)}
.depoimentos .section-head p{color:rgba(255,255,255,.85)}
.depo-grid{display:grid;grid-template-columns:1fr;gap:18px}
.depo{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius);padding:24px;
  backdrop-filter:blur(6px);
}
.depo::before{
  content:"“";display:block;font-size:3rem;line-height:.5;color:var(--amarelo);
  margin-bottom:14px;font-family:Georgia,serif;
}
.depo p{margin:0 0 16px;font-style:italic;color:rgba(255,255,255,.95)}
.depo-author{display:flex;align-items:center;gap:12px}
.depo-avatar{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--vermelho),var(--amarelo));
  display:flex;align-items:center;justify-content:center;font-weight:900;
}
.depo-author strong{display:block}
.depo-author small{color:rgba(255,255,255,.7)}

/* ============ LOCALIZAÇÃO ============ */
.local{background:#fff}
.local-grid{display:grid;grid-template-columns:1fr;gap:20px;align-items:stretch}
.local-info{
  background:var(--bg);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);
}
.local-info h3{color:var(--azul);margin:0 0 14px;font-size:1.2rem}
.local-info .info-line{
  display:flex;gap:10px;margin-bottom:12px;align-items:flex-start;font-size:.98rem;
}
.local-info .info-line svg{
  flex-shrink:0;width:22px;height:22px;color:var(--vermelho);
  stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  margin-top:2px;
}
.local-map{
  aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(135deg,var(--azul) 0%,var(--turquesa) 100%);
  position:relative;display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow);
}
.local-map iframe{width:100%;height:100%;border:0;display:block}
.local-map .placeholder{color:#fff;text-align:center;padding:20px}
.local-map .placeholder svg{width:48px;height:48px;margin:0 auto 8px;stroke:#fff;fill:none;stroke-width:1.5}

/* ============ CTA FINAL ============ */
.cta-final{
  background:linear-gradient(135deg,var(--vermelho) 0%,var(--amarelo) 100%);
  color:#fff;text-align:center;
}
.cta-final h2{font-size:1.75rem;margin:0 0 12px;color:#fff;font-weight:900}
.cta-final p{max-width:560px;margin:0 auto 24px;font-size:1.05rem;color:rgba(255,255,255,.95)}

/* ============ FOOTER ============ */
.site-footer{background:var(--azul);color:rgba(255,255,255,.85);padding:40px 0 24px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-bottom:24px}
.footer-grid h4{color:#fff;margin:0 0 12px;font-size:1.05rem}
.footer-grid p,.footer-grid a{color:rgba(255,255,255,.8);font-size:.95rem}
.footer-grid a:hover{color:var(--amarelo)}
.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.social{display:flex;gap:10px;margin-top:12px}
.social a{
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.10);display:flex;align-items:center;justify-content:center;
  transition:background .15s ease,transform .15s ease;
}
.social a:hover{background:var(--amarelo);transform:translateY(-2px)}
.social svg{width:18px;height:18px;fill:#fff}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.15);padding-top:18px;
  text-align:center;font-size:.85rem;color:rgba(255,255,255,.6);
}

/* ============ FAB WHATSAPP ============ */
.fab-wa{
  position:fixed;bottom:18px;right:18px;z-index:60;
  width:58px;height:58px;border-radius:50%;
  background:var(--whatsapp);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(37,211,102,.45);
  transition:transform .15s ease;
}
.fab-wa:hover{transform:scale(1.06);color:#fff}
.fab-wa svg{width:32px;height:32px;fill:#fff}

/* ============ TABLET (>=640px) ============ */
@media (min-width:640px){
  body{font-size:18px}
  .hero{padding:96px 0 110px}
  .hero h1{font-size:2.6rem}
  .hero p.lead{font-size:1.2rem}
  section{padding:80px 0}
  .section-head h2{font-size:2.2rem}
  .cards{grid-template-columns:repeat(2,1fr);gap:22px}
  .niveis-row{grid-template-columns:repeat(2,1fr)}
  .passeios-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .depo-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .cta-final h2{font-size:2.2rem}
  .brand-name{font-size:1.15rem}
}

/* ============ DESKTOP (>=960px) ============ */
@media (min-width:960px){
  .nav-toggle{display:none}
  .main-nav{display:block;width:auto;flex-basis:auto}
  .main-nav ul{flex-direction:row;gap:6px;border:0;padding:0;margin:0}
  .main-nav a{padding:10px 14px}
  .hero h1{font-size:3.2rem}
  .cards{grid-template-columns:repeat(3,1fr)}
  .sobre-grid{grid-template-columns:1fr 1fr;gap:48px}
  .niveis-row{grid-template-columns:repeat(4,1fr)}
  .passeios-grid{grid-template-columns:repeat(4,1fr)}
  .depo-grid{grid-template-columns:repeat(3,1fr)}
  .local-grid{grid-template-columns:1fr 1.2fr}
  .footer-grid{grid-template-columns:2fr 1fr 1fr}
  .section-head h2{font-size:2.4rem}
}

/* Reduz movimento */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition:none!important;animation:none!important}
  html{scroll-behavior:auto}
}
