/* ============================================================
   GRUPO DE LOUVOR — estilos específicos
   Complementa style.css (vars, nav, mobile-menu, footer)
============================================================ */

/* ── Hero ── */
.louvor-hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  padding: 100px 5% 80px;
  background: #0D2E14;
}

/* Gradiente de fundo */
.louvor-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 15% 30%, rgba(200,149,42,.18) 0%, transparent 55%),
    radial-gradient(ellipse 60% 70% at 85% 70%, rgba(45,122,58,.35) 0%, transparent 55%),
    radial-gradient(ellipse 50% 50% at 50% 50%, rgba(26,92,42,.6) 0%, transparent 80%);
  z-index: 0;
}

/* Notas musicais flutuantes */
.notes-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.note {
  position: absolute;
  font-size: 28px;
  opacity: 0;
  animation: floatNote var(--dur, 8s) ease-in-out var(--delay, 0s) infinite;
  color: rgba(200,149,42,.25);
}

@keyframes floatNote {
  0%   { opacity: 0; transform: translateY(0) rotate(-10deg); }
  15%  { opacity: 1; }
  85%  { opacity: .6; }
  100% { opacity: 0; transform: translateY(-80px) rotate(15deg); }
}

/* Conteúdo hero */
.louvor-hero-inner {
  position: relative;
  z-index: 1;
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
}

.louvor-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(200,149,42,.15);
  border: 1.5px solid rgba(200,149,42,.4);
  color: #C8952A;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  padding: 7px 18px;
  border-radius: 20px;
  margin-bottom: 28px;
}

.louvor-badge .dot {
  width: 6px; height: 6px;
  background: #C8952A;
  border-radius: 50%;
  animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: .4; transform: scale(1.6); }
}

.louvor-hero h1 {
  font-size: clamp(36px, 8vw, 72px);
  font-weight: 800;
  color: #fff;
  letter-spacing: -.5px;
  line-height: 1.08;
  margin-bottom: 22px;
}

.louvor-hero h1 .accent {
  background: linear-gradient(135deg, #C8952A, #E8C060);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.louvor-hero p {
  font-size: clamp(16px, 2.5vw, 20px);
  color: rgba(255,255,255,.72);
  line-height: 1.7;
  max-width: 540px;
  margin: 0 auto 48px;
}

/* Divisor decorativo */
.hero-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-bottom: 48px;
}

.hero-divider span {
  height: 1px;
  width: 60px;
  background: linear-gradient(90deg, transparent, rgba(200,149,42,.5));
}

.hero-divider span:last-child {
  background: linear-gradient(90deg, rgba(200,149,42,.5), transparent);
}

.hero-divider .icon {
  font-size: 20px;
  color: #C8952A;
}

/* Scroll hint */
.scroll-hint {
  position: absolute;
  bottom: 36px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: rgba(255,255,255,.4);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  animation: fadeInUp .8s 1.5s both;
}

.scroll-hint .arrow {
  width: 20px; height: 20px;
  border-right: 2px solid rgba(255,255,255,.3);
  border-bottom: 2px solid rgba(255,255,255,.3);
  transform: rotate(45deg);
  animation: bounce 1.8s ease-in-out infinite;
}

@keyframes bounce {
  0%, 100% { transform: rotate(45deg) translateY(0); }
  50%       { transform: rotate(45deg) translateY(5px); }
}

/* ── Cards Section ── */
.cards-section {
  padding: 100px 5%;
  background: var(--gray-bg);
  position: relative;
}

.cards-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 6px;
  background: linear-gradient(90deg, var(--green-dark), var(--gold), var(--green-mid));
}

.section-header {
  text-align: center;
  max-width: 560px;
  margin: 0 auto 64px;
}

.section-header .eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--green-mid);
  margin-bottom: 12px;
}

.section-header h2 {
  font-size: clamp(28px, 5vw, 44px);
  font-weight: 800;
  color: var(--text-dark);
  letter-spacing: -.5px;
  line-height: 1.15;
}

.section-header p {
  margin-top: 14px;
  font-size: 17px;
  color: var(--gray-mid);
  line-height: 1.7;
}

/* Grade de cards */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  gap: 28px;
  max-width: 840px;
  margin: 0 auto;
}

/* Card principal */
.main-card {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  background: var(--white);
  box-shadow: 0 2px 16px rgba(0,0,0,.06), 0 0 0 1px rgba(0,0,0,.04);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  transition: transform .3s cubic-bezier(.25,.46,.45,.94),
              box-shadow .3s cubic-bezier(.25,.46,.45,.94);
  cursor: pointer;
  animation: fadeInUp .6s both;
}

.main-card:nth-child(2) { animation-delay: .15s; }

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

.main-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 60px rgba(0,0,0,.13), 0 0 0 1px rgba(0,0,0,.04);
}

/* Topo colorido do card */
.card-top {
  height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
}

.card-top::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 40%, rgba(0,0,0,.25));
}

/* Card 1 — Acervo Musical */
.card-acervo .card-top {
  background: linear-gradient(135deg, #0D2E14 0%, #1A5C2A 50%, #2D7A3A 100%);
}

/* Card 2 — Coral */
.card-coral .card-top {
  background: linear-gradient(135deg, #3A2800 0%, #8B6010 50%, #C8952A 100%);
}

/* Ícone do card */
.card-icon-wrap {
  position: relative;
  z-index: 1;
  width: 80px; height: 80px;
  border-radius: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 38px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform .3s;
}

.card-acervo .card-icon-wrap {
  background: rgba(200,149,42,.25);
  border: 1.5px solid rgba(200,149,42,.4);
}

.card-coral .card-icon-wrap {
  background: rgba(255,255,255,.15);
  border: 1.5px solid rgba(255,255,255,.3);
}

.main-card:hover .card-icon-wrap {
  transform: scale(1.1) rotate(-4deg);
}

/* Corpo do card */
.card-body {
  padding: 28px 28px 32px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.card-tag {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 6px;
  margin-bottom: 14px;
}

.card-acervo .card-tag {
  background: rgba(26,92,42,.1);
  color: var(--green-dark);
}

.card-coral .card-tag {
  background: rgba(200,149,42,.12);
  color: var(--gold);
}

.card-body h3 {
  font-size: 24px;
  font-weight: 700;
  color: var(--text-dark);
  letter-spacing: -.3px;
  margin-bottom: 10px;
}

.card-body p {
  font-size: 15px;
  color: var(--gray-mid);
  line-height: 1.65;
  flex: 1;
}

.card-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 24px;
  font-size: 14px;
  font-weight: 600;
  padding: 10px 20px;
  border-radius: 980px;
  transition: gap .25s, background .25s, color .25s;
  align-self: flex-start;
}

.card-acervo .card-cta {
  background: var(--green-dark);
  color: #fff;
}

.card-acervo .card-cta:hover {
  background: var(--green-mid);
  gap: 12px;
}

.card-coral .card-cta {
  background: var(--gold);
  color: #fff;
}

.card-coral .card-cta:hover {
  background: var(--amber);
  gap: 12px;
}

.card-cta svg {
  width: 14px; height: 14px;
  transition: transform .25s;
}

.card-cta:hover svg {
  transform: translateX(3px);
}

/* ── Stats bar ── */
.stats-bar {
  background: var(--green-dark);
  padding: 48px 5%;
}

.stats-inner {
  max-width: 800px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}

.stat-item {
  text-align: center;
  padding: 12px 20px;
  position: relative;
}

.stat-item + .stat-item::before {
  content: '';
  position: absolute;
  left: 0; top: 20%; bottom: 20%;
  width: 1px;
  background: rgba(255,255,255,.15);
}

.stat-number {
  font-size: clamp(32px, 6vw, 52px);
  font-weight: 800;
  color: var(--gold);
  letter-spacing: -1px;
  line-height: 1;
  margin-bottom: 6px;
}

.stat-label {
  font-size: 13px;
  color: rgba(255,255,255,.6);
  font-weight: 500;
  letter-spacing: .5px;
}

/* ── Footer mínimo ── */
.louvor-footer {
  background: #0D2E14;
  padding: 24px 5%;
  text-align: center;
  font-size: 13px;
  color: rgba(255,255,255,.45);
}

.louvor-footer a {
  color: var(--olive-light);
  transition: color .2s;
}

.louvor-footer a:hover {
  color: var(--gold);
}

/* ── Responsivo ── */
@media (max-width: 768px) {
  .cards-grid {
    grid-template-columns: 1fr;
    max-width: 440px;
  }

  .stats-inner {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .stat-item + .stat-item::before { display: none; }

  .louvor-hero { min-height: 90vh; }
}
