/* ===========================
   Reset e variáveis
=========================== */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
:root{
  /* Paleta base (azuis JIFA) */
  --brand:#042761;
  --brand-2:#0d549d;
  --brand-3:#2aa4e1;

  --ink:#1f2430;
  --muted:#3b4a66;
  --gutter: 28px;

  /* Offset do alinhamento do hero (ajustado por JS) */
  --hero-calha-offset: 300px;
}
body {
  font-family: 'Segoe UI', Roboto, Arial, system-ui, -apple-system, sans-serif;
  line-height: 1.6;
  color: var(--ink);
  background: #fff;
}
img { max-width: 100%; height: auto; display: block; }
.container { width: min(1240px, 90%); margin: 0 auto; padding-inline: var(--gutter); }

/* ===========================
   Header / Navegação
=========================== */
.site-header { background: #082c5a; position: sticky; top: 0; z-index: 1000; }
.header-row { display: flex; align-items: center; gap: 16px; padding: 14px 0; }

/* Marca (logo + texto) */
.brand { display: flex; align-items: center; gap: 14px; text-decoration: none; }

/* ——— FORÇAR TAMANHO DO LOGO (evita “explodir”) ——— */
.brand-logo{
  width:56px !important; height:56px !important;
  min-width:56px !important; min-height:56px !important;
  object-fit:contain; border-radius:8px; background:#fff;
}

/* Meta da marca */
.brand-meta{ display:flex; flex-direction:column; gap:2px; color:#fff; }
.brand-meta strong{ font-weight:800; }
.brand-meta small{ opacity:.85; }
.brand-underline{
  height:6px; width:240px; border-radius:6px;
  background:linear-gradient(90deg,#90d3f3,#2aa4e1,#0d549d);
}

/* Nav desktop */
.main-nav{ margin-left:auto; position:relative; z-index:1050; }
.main-nav ul{ list-style:none; display:flex; gap:18px; align-items:center; }
.main-nav a{
  color:#fff; text-decoration:none; font-weight:700;
  border-radius:12px; padding:8px 12px;
}
.main-nav a:hover, .main-nav a.active{ background:rgba(255,255,255,.08); }

/* CTA inscrição — visível e com texto garantido */
.btn-inscricao{
  display:inline-block; margin-left:12px;
  padding:10px 16px; font-size:1rem; font-weight:800; line-height:1;
  text-transform:lowercase; text-decoration:none;
  background:#fff; color:var(--brand); border:2px solid #fff; border-radius:14px;
  transition:all .2s ease;
}
.btn-inscricao:hover{ filter:brightness(.95); }
.btn-inscricao-desktop{ display:inline-block; }

/* Hambúrguer / Mobile menu */
.hamburger{ display:none; margin-left:auto; background:none; border:0; cursor:pointer; position:relative; z-index:1100; }
.hamburger-box{ width:28px; height:20px; display:inline-block; position:relative; }
.hamburger-inner,.hamburger-inner::before,.hamburger-inner::after{
  width:28px; height:2px; background:#fff; position:absolute; left:0; transition:transform .2s, opacity .2s;
}
.hamburger-inner{ top:9px; }
.hamburger-inner::before{ content:""; top:-8px; }
.hamburger-inner::after{ content:""; top:8px; }
.nav-open .hamburger-inner{ transform:rotate(45deg); }
.nav-open .hamburger-inner::before{ transform:rotate(90deg) translateX(0); top:0; }
.nav-open .hamburger-inner::after{ opacity:0; }

/* 1 CTA apenas */
.nav-cta-mobile{ display:none; }

@media (max-width:900px){
  .hamburger{ display:inline-block; }
  .btn-inscricao-desktop{ display:none; }
  .nav-cta-mobile{ display:block; }

  .main-nav{ position:absolute; left:0; right:0; top:100%; }
  .main-nav ul{
    display:none; flex-direction:column; gap:0;
    background:#082c5a; border-bottom:1px solid rgba(255,255,255,.12);
    padding:8px var(--gutter) 12px;
  }
  .main-nav li{ width:100%; }
  .main-nav a{ display:block; padding:12px 4px; border-radius:8px; }
  .main-nav a:hover,.main-nav a.active{ background:rgba(255,255,255,.08); }
  .nav-open #primary-nav ul{ display:flex; }
  .nav-cta-mobile .btn-inscricao{
    display:inline-block; width:100%; text-align:center;
    background:#fff; color:var(--brand); border-color:#fff;
  }
}

/* ===========================
   Hero (alinhado pela “calha” do logo+texto)
=========================== */
.hero{
  position:relative; min-height:360px;
  background-size:cover; background-position:center;
  display:flex; align-items:flex-end;
}
.hero::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(8,44,90,.75) 0%, rgba(8,44,90,.55) 40%, rgba(8,44,90,.25) 75%, rgba(8,44,90,0) 100%);
  z-index:1;
}
.hero-overlay{ position:relative; z-index:2; padding:64px 0; }
.hero-overlay .container{ text-align:left; }

/* offset definido em :root e recalculado em JS */
.hero-align{ margin-left:var(--hero-calha-offset); max-width:1000px; }
@media (max-width:740px){ .hero-align{ margin-left:0; } }

.hero-title{
  color:#fff; margin:0 0 8px; font-weight:900;
  font-size:clamp(28px, 3vw + 14px, 44px);
}
.hero-subtitle{ color:#e8f4ff; margin:0; }

/* ===========================
   Secção “O que trabalhamos” / Work cards
=========================== */
.section-work{ padding:56px 0 70px; background:#fff; }
.section-work .lead{ color:var(--muted); margin-bottom:18px; }
.work-grid{ display:grid; gap:20px; grid-template-columns:repeat(12,1fr); }
.work-card{
  grid-column:span 4; background:#fff; border:1px solid #e6eef7; border-radius:16px;
  padding:18px; box-shadow:0 10px 28px rgba(9,30,66,.08);
}
.work-icon{
  width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
  background:#eaf5ff; color:var(--brand-2); margin-bottom:12px;
}
.work-card h3{ margin:0 0 6px; color:var(--brand); font-size:1.05rem; }
.work-card p{ margin:0; color:var(--muted); }
@media (max-width:1200px){ .work-card{ grid-column:span 6; } }
@media (max-width:720px){ .work-card{ grid-column:span 12; } }

/* ===========================
   Secção Paixão (texto livre)
=========================== */
.section-paixao{ padding:56px 0; background:#f7fbff; }
.lead{ font-size:1.06rem; }

/* ===========================
   MVV — Missão, Valores, Visão (página sobre)
=========================== */
.mvv-section{ padding:56px 0 70px; background:#0b2c5a; }
.mvv-head{ color:#fff; margin-bottom:18px; }
.mvv-grid{ display:grid; gap:18px; grid-template-columns:repeat(12,1fr); }
.mvv-card{
  grid-column:span 4;
  background:linear-gradient(180deg,#0e346b,#0a2343);
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px; color:#e8f4ff; padding:18px;
  box-shadow:0 20px 40px rgba(0,0,0,.25);
}
.mvv-card h3{ margin:0 0 8px; color:#fff; }
.mvv-card p{ margin:0; opacity:.95; }
@media (max-width:1200px){ .mvv-card{ grid-column:span 6; } }
@media (max-width:720px){ .mvv-card{ grid-column:span 12; } }

/* ===========================
   KPIs — “o JIFA em números”
=========================== */
.kpi-section{
  padding:56px 0 70px;
  background:linear-gradient(180deg,#081e3f 0%, #0b2c5a 60%, #0a2343 100%);
}
.kpi-head h2{ color:#fff; margin:0 0 6px; }
.kpi-head .lead{ color:#cfe4ff; margin:0 0 20px; }

.kpi-grid{
  display:grid; gap:18px;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
}
.kpi-card{
  background:linear-gradient(180deg,#f2f4f7,#e6e9ee);
  border:1px solid #d7dde8; border-radius:16px;
  padding:20px 18px; box-shadow:0 18px 40px rgba(0,0,0,.25);
  text-align:center;
}
.kpi-number{ font-size:clamp(28px, 4vw + 8px, 44px); font-weight:900; color:var(--brand); line-height:1; }
.kpi-label{ margin-top:6px; font-weight:800; color:#10213f; text-transform:lowercase; }
.kpi-note{ margin-top:6px; font-size:.95rem; color:#3b4a66; }

/* ===========================
   Galeria (página galeria e grelha genérica)
=========================== */
.gallery{ padding:56px 0 72px; background:#f7fbff; }
.gallery h2{ color:var(--brand); margin:0 0 18px; }
.gallery p.lead{ color:var(--muted); margin:0 0 28px; }
.gallery-grid{ display:grid; gap:18px; grid-template-columns:repeat(12,1fr); }
.gallery-item{
  grid-column:span 4; border-radius:16px; overflow:hidden;
  box-shadow:0 10px 28px rgba(9,30,66,.08);
  background:#fff; border:1px solid #e6eef7;
}
.gallery-item img{ width:100%; height:260px; object-fit:cover; display:block; }
.gallery-item .meta{ padding:12px 14px 16px; }
.gallery-item .meta h3{ margin:0 0 6px; font-size:1rem; color:var(--brand); }
.gallery-item .meta small{ color:#5c6f8f; }
@media (max-width:1200px){ .gallery-item{ grid-column:span 6; } }
@media (max-width:720px){ .gallery-item{ grid-column:span 12; } }

/* ===========================
   Transparência — cartões formais
=========================== */
.downloads-dark{
  padding:56px 0 70px;
  background:linear-gradient(180deg, #0b2c5a 0%, #071a33 60%, #000 100%);
}
.downloads-dark .head{ color:#fff; margin-bottom:18px; }
.download-grid{ display:grid; gap:18px; grid-template-columns:repeat(12,1fr); }
.download-card{
  grid-column:span 4;
  background:linear-gradient(180deg,#f2f4f7,#e6e9ee);
  border:1px solid #d7dde8; border-radius:16px; padding:18px;
  box-shadow:0 18px 40px rgba(0,0,0,.30);
}
.download-card h3{ margin:0 0 8px; color:#0f1f3b; }
.download-card p{ margin:0 0 12px; color:#31415c; }
.download-card a{
  display:inline-block; text-decoration:none; font-weight:800;
  background:#fff; color:var(--brand); border:2px solid var(--brand);
  padding:10px 14px; border-radius:12px; transition:all .2s ease;
}
.download-card a:hover{ background:var(--brand); color:#fff; }
@media (max-width:1200px){ .download-card{ grid-column:span 6; } }
@media (max-width:720px){ .download-card{ grid-column:span 12; } }

/* ===========================
   Formulários (Inscrições)
=========================== */
.section-form{ padding:56px 0 72px; background:#f6f9fc; }
.section-form h2{ color:var(--brand); margin:0 0 8px; }
.section-form .form-intro{ color:var(--muted); margin:0 0 28px; }
.jifa-form{
  max-width:980px; margin:0 auto; background:#fff; border:1px solid #e7eef6;
  border-radius:16px; padding:28px; box-shadow:0 8px 30px rgba(4,39,97,.06);
}
.jifa-form fieldset{ border:0; margin:0 0 28px; padding:0; }
.jifa-form legend{ font-weight:700; color:var(--brand); margin-bottom:16px; }
.jifa-form label{ display:block; font-weight:600; color:#253a52; margin:14px 0 6px; }
.jifa-form input[type="text"], .jifa-form input[type="tel"],
.jifa-form input[type="email"], .jifa-form input[type="date"],
.jifa-form select, .jifa-form textarea{
  width:100%; border:1px solid #dfe8f2; border-radius:12px; padding:12px 14px;
  font:inherit; outline:0; transition:.15s border-color ease; background:#fff;
}
.jifa-form textarea{ min-height:96px; resize:vertical; }
.jifa-form input:focus, .jifa-form select:focus, .jifa-form textarea:focus{ border-color:var(--brand-2); }
.checkbox-line{ display:flex; gap:10px; align-items:flex-start; color:#253a52; }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:900px){ .form-grid{ grid-template-columns:1fr; } }
.form-actions{ display:flex; gap:12px; margin-top:12px; }
.btn-primary{
  background:var(--brand); color:#fff; border:0; padding:12px 18px;
  border-radius:12px; cursor:pointer; font-weight:700; text-decoration:none; display:inline-block;
}
.btn-primary:hover{ filter:brightness(.95); }

/* ===========================
   Footer
=========================== */
.site-footer{ background:#082c5a; color:#fff; padding:28px 0; }
.footer-row{ display:flex; gap:24px; align-items:center; justify-content:space-between; }
.footer-logo{
  width:48px !important; height:48px !important;
  min-width:48px !important; min-height:48px !important;
  object-fit:contain; background:#fff; border-radius:8px;
}


/* Secção Crianças */
.criancas-section {
  padding: 60px 0;
  background: #f9f9f9;
}

.criancas-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 40px;
}

.criancas-text h2 {
  color: #042761;
  margin-bottom: 16px;
  font-size: 2rem;
}

.criancas-text .lead {
  font-size: 1.125rem;
  line-height: 1.6;
  color: #333;
}

.criancas-img img {
  width: 100%;
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}

@media (max-width: 768px) {
  .criancas-grid {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .criancas-text {
    order: 2;
  }
  .criancas-img {
    order: 1;
  }
}


.site-footer {
  background: #001f3f;
  color: white;
  padding: 40px 20px 20px;
  font-size: 14px;
}

.footer-container {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 40px;
  flex-wrap: wrap;
  max-width: 1200px;
  margin: 0 auto;
}

.footer-col {
  flex: 1;
  min-width: 220px;
}

.footer-brand {
  flex: 0 0 auto; /* ocupa só o necessário */
}

.footer-logo img {
  max-width: 180px;
  height: auto;
  margin-bottom: 10px;
}

.footer-col h4 {
  margin-bottom: 15px;
  font-size: 16px;
  font-weight: bold;
}

.footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-col ul li {
  margin-bottom: 8px;
}

.footer-col ul li a {
  color: white;
  text-decoration: none;
}

.footer-col ul li a:hover {
  text-decoration: underline;
}

.footer-col i {
  margin-right: 8px;
  color: white; /* ícones em branco */
}

.footer-bottom {
  text-align: center;
  margin-top: 20px;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  padding-top: 10px;
  font-size: 13px;
}