/* style.css - Estilo principal do site institucional
   Feito com HTML5, CSS3 e JS puro. Paleta suave e design acessível.
*/

:root{
  --bg:#f7faf6;
  --surface:#ffffff;
  --muted:#6b7280;
  --primary:#4a7c59; /* tom suave verde */
  --accent:#7fbf9a;
  --shadow: 0 6px 18px rgba(74,124,89,0.08);
  --max-width:1100px;
  --radius:10px;
  --gap:1.25rem;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background:var(--bg);
  color:#21323a;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.6;
}
.container{max-width:var(--max-width);margin:0 auto;padding:0 1rem}
.section{padding:3rem 0}
.wrap{padding-top:2.5rem}

/* Header */
.site-header{position:fixed;left:0;right:0;top:0;background:rgba(255,255,255,0.8);backdrop-filter:blur(6px);border-bottom:1px solid rgba(10,10,10,0.04);z-index:60}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0}
.brand a{display:flex;align-items:center;gap:.6rem;color:var(--primary);text-decoration:none;font-weight:700}
.logo{font-size:1.4rem}
.site-title{font-size:1rem}

/* Nav */
.nav-list{list-style:none;margin:0;padding:0;display:flex;gap:1rem}
.nav-list a{color:inherit;text-decoration:none;padding:.45rem .6rem;border-radius:6px;transition:background .2s}
.nav-list a:hover{background:rgba(74,124,89,0.06)}

/* Mobile nav toggle */
.nav-toggle{display:none;background:transparent;border:0;padding:.4rem;margin-right:.25rem}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--primary);margin:4px 0;border-radius:2px}

/* Skip link */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:static;width:auto;height:auto;padding:.5rem 1rem;background:var(--primary);color:white;border-radius:6px}

/* Hero */
.hero{min-height:60vh;display:flex;align-items:center;position:relative;margin-top:64px}
.hero-overlay{position:absolute;inset:0;background-image:linear-gradient(135deg, rgba(74,124,89,0.15), rgba(127,191,154,0.06));}
.hero-overlay{ /* ensure there is a visible dim layer over background images */
  background-color: rgba(0,0,0,0.35);
  mix-blend-mode: normal;
}
.hero{ /* allow background image to be visible behind overlay */
  background-repeat:no-repeat;
  background-size:cover;
  background-position:center center;
}

/* Specific hero background image for the home section */
/**#home{background-image: url("img/9972022d-debb-44aa-b57f-adfe309e9665.jpeg");}**/

/**#home{background-image: url("img/fundo_site0001.png");}**/
#home{background-image: url("img/fundo_01.JPG");}
#home-overlay-subpage{background-color: rgba(0,0,0,0);mix-blend-mode: normal; height: 100px;}

/* Make sure hero text is readable on the image */
#home .hero-title{color: #ffffff}
#home .hero-sub{color: rgba(255,255,255,0.92)}
.hero-content{position:relative;padding:3rem 0;text-align:center}
.hero-title{font-size:2.25rem;margin:0;color:var(--primary)}
.hero-sub{color:var(--muted);margin:.6rem 0 1.4rem}
.btn{display:inline-block;background:var(--surface);color:var(--primary);padding:.6rem 1rem;border-radius:8px;text-decoration:none;border:1px solid rgba(74,124,89,0.08)}
.btn.primary{background:var(--primary);color:white;border:none;box-shadow:var(--shadow)}

/* Quem Somos */
.quem-grid{display:grid;grid-template-columns:1fr 320px;gap:2rem;align-items:start}
.quem-text h3{margin-bottom:.25rem}
.values{display:flex;gap:.5rem;flex-wrap:wrap;padding:0;margin:0;list-style:none}
.values li{background:rgba(74,124,89,0.08);padding:.25rem .5rem;border-radius:6px}

.quem-icons{width:320px;max-width:100%;overflow:hidden;display:block}
.quem-icons .icon{display:flex;flex-direction:column;align-items:center;text-align:center;padding:.8rem}
.quem-image{width:100%;height:auto;display:block;object-fit:cover;border-radius:12px;box-shadow:var(--shadow);max-width:100%;overflow:hidden}
.icon-row{display:flex;gap:1rem}

/* Carousel */
.carousel{display:flex;align-items:center;gap:.5rem}
.carousel-track-wrap{overflow:hidden;width:100%}
.carousel-track{display:flex;gap:1rem;padding:0;margin:0;list-style:none;transition:transform .45s cubic-bezier(.2,.9,.3,1)}
.card{background:var(--surface);border-radius:10px;box-shadow:var(--shadow);overflow:hidden;min-width:260px;max-width:320px}
.pastor-card .photo img{width:100%;height:200px;object-fit:cover;display:block;cursor:pointer}
.card-body{padding:1rem}
.card h3{margin:.25rem 0}
.role{color:var(--muted);font-size:.9rem;margin-bottom:.5rem}
.carousel-btn{background:transparent;border:0;font-size:1.6rem;padding:.4rem;cursor:pointer}

.modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.8);
  display:none;
  align-items:center;
  justify-content:center;
  padding:1.5rem;
  z-index:120;
}
.modal-overlay.show{display:flex}
.modal-content{
  position:relative;
  max-width:95%;
  max-height:95%;
  width:100%;
  border-radius:18px;
  overflow:hidden;
  background:#111;
  box-shadow:0 30px 80px rgba(0,0,0,0.35);
}
.modal-image{
  display:block;
  width:auto;
  height:auto;
  max-width:100%;
  max-height:100%;
  margin:0 auto;
}
.modal-close{
  position:absolute;
  top:1rem;
  right:1rem;
  width:2.6rem;
  height:2.6rem;
  background:rgba(255,255,255,0.15);
  border:none;
  color:#fff;
  border-radius:50%;
  cursor:pointer;
  font-size:1.4rem;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform .2s ease, background .2s ease;
}
.modal-close:hover{background:rgba(255,255,255,0.25);transform:scale(1.05)}

/* Localização */
.local-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.map-wrap iframe{width:100%;height:260px;border:0;border-radius:10px}

#estatuto .container {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

#estatuto .container .btn {
  margin-top: 1rem;
}

/* Contato social links */
.socials{
  display:flex;
  flex-wrap:wrap;
  gap:0.85rem;
  margin-top:1rem;
  justify-content:center;
}
.social{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.7rem 1rem;
  border-radius:999px;
  color:var(--primary);
  background:rgba(74,124,89,0.08);
  text-decoration:none;
  border:1px solid rgba(74,124,89,0.12);
  transition:background .2s ease,color .2s ease,transform .2s ease;
}
.social svg{display:block;flex-shrink:0;}
.social:hover{background:rgba(74,124,89,0.16);color:#2d513f;transform:translateY(-1px);}
.social:focus{outline:3px solid rgba(127,191,154,0.3);outline-offset:3px;}

/* Footer */
.site-footer{background:var(--surface);border-top:1px solid rgba(0,0,0,0.04);padding:1.25rem 0}
.footer-inner{display:flex;gap:1rem;align-items:center;justify-content:space-between}
.footer-links a{display:inline-block;margin-right:.6rem;color:var(--muted);text-decoration:none}

/* Floating buttons */
.whatsapp-fab{position:fixed;right:1rem;bottom:4.5rem;background:var(--accent);color:#fff;padding:.6rem .7rem;border-radius:999px;box-shadow:var(--shadow);text-decoration:none;font-size:1.1rem}
.back-to-top{position:fixed;right:1rem;bottom:1rem;background:var(--primary);color:#fff;border:0;padding:.6rem .7rem;border-radius:8px;display:none}

/* Ao vivo (YouTube) */
.ao-vivo-section {
  background: linear-gradient(135deg, rgba(74,124,89,0.05) 0%, rgba(127,191,154,0.08) 100%);
}

#ao-vivo .container {
  display: flex;
  justify-content: center;
}

.youtube-banner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: linear-gradient(135deg, #cd201f 0%, #1f1f2e 100%);
  color: white;
  padding: 3rem;
  border-radius: 16px;
  box-shadow: 0 12px 32px rgba(205,32,31,0.15);
  gap: 2rem;
}

.youtube-content {
  flex: 1;
}

.youtube-icon {
  font-size: 2.5rem;
  margin-bottom: 0.5rem;
  display: inline-block;
}

.youtube-banner h2 {
  font-size: 1.8rem;
  margin: 0.5rem 0 1rem;
  line-height: 1.3;
}

.youtube-banner p {
  font-size: 1rem;
  margin-bottom: 1.5rem;
  opacity: 0.95;
  line-height: 1.6;
}

.youtube-btn {
  background: white;
  color: #cd201f;
  font-weight: 600;
  padding: 0.8rem 1.6rem;
  transition: all 0.3s ease;
}

.youtube-btn:hover {
  transform: scale(1.05);
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
}

.youtube-graphic {
  flex-shrink: 0;
  color: white;
  opacity: 0.8;
  animation: float 3s ease-in-out infinite;
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* Responsive */
@media (max-width:900px){
  .quem-grid{grid-template-columns:1fr}
  .quem-icons{order:2;width:100%;max-width:100%;height:400px;overflow:hidden;display:block}
  .quem-image{width:100%;height:100%;object-fit:cover;max-width:100%;max-height:400px;display:block;overflow:hidden}
  .carousel-track{gap:.75rem}
}

@media (max-width:720px){
  .nav-list{display:none;position:fixed;top:64px;right:12px;background:var(--surface);flex-direction:column;padding:1rem;border-radius:8px;box-shadow:var(--shadow)}
  .nav-list.show{display:flex}
  .nav-toggle{display:block}
  .hero-title{font-size:1.6rem}
  .carousel{gap:.25rem}
  .carousel-track{padding-bottom:1rem}
  .local-grid{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;gap:.75rem;text-align:center}
  .youtube-banner{flex-direction:column;text-align:center;padding:2rem}
  .youtube-banner h2{font-size:1.4rem}
  .youtube-graphic{margin-top:1rem}
  .quem-icons{width:100%;max-width:100%;height:300px;overflow:hidden;display:block}
  .quem-image{width:100%;height:100%;object-fit:cover;max-width:100%;max-height:300px;display:block;overflow:hidden}
}

/* small tweaks */
.muted{color:var(--muted)}

/* Ensure focus styles for accessibility */
a:focus,button:focus{outline:3px solid rgba(127,191,154,0.25);outline-offset:3px}
