/* ============================================================
   SANTOROSARIO.COM.BR — MELHORIAS (carregar sempre após patch.css)
   1. Menu visual: barra com menus suspensos no desktop, gaveta no celular
   2. Banner de sites parceiros
   3. Cards "Por onde começar" inteiros clicáveis
   ============================================================ */


/* ─── 1. MENU (.navbar) ────────────────────────────────────── */
.navbar {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: #fffaf0;
  border-bottom: 2px solid var(--dourado, #d7a83f);
  box-shadow: 0 3px 14px rgba(5, 11, 31, 0.10);
  font-family: var(--fonte-acento, sans-serif);
}
.navbar-inner {
  max-width: 1140px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0 1rem;
  flex-wrap: wrap;
}
.navbar-home {
  font-size: 0.74rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--sr-azul-menu, #0b2d73);
  text-decoration: none;
  padding: 0.8rem 0.7rem;
}
.navbar-home:hover { color: var(--dourado-escuro, #8f6416); }

.navbar-toggle {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: transparent;
  border: 1.5px solid var(--sr-dourado-escuro, #8f6416);
  border-radius: 4px;
  padding: 0.45rem 0.8rem;
  color: var(--sr-azul-menu, #0b2d73);
  cursor: pointer;
  font-family: inherit;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
}
.navbar-toggle:hover { background: var(--sr-azul-menu, #0b2d73); color: #fffaf0; }
.navbar-toggle-bars { display: inline-flex; flex-direction: column; gap: 3px; }
.navbar-toggle-bars i { display: block; width: 18px; height: 2px; background: currentColor; }

.navbar-menu {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 0.1rem;
  margin: 0;
  padding: 0;
}
.navbar-menu > li { position: relative; margin: 0; padding: 0; list-style: none; }
.navbar-menu > li::marker { content: ""; }

.nav-rezar {
  display: inline-block;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.78rem;
  font-weight: 700;
  padding: 0.5rem 1rem;
  border-radius: 4px;
  background: linear-gradient(135deg, var(--dourado, #d7a83f), var(--dourado-escuro, #8f6416));
  color: #1a1208;
  margin-right: 0.35rem;
}
.nav-rezar:hover { filter: brightness(1.06); color: #1a1208; }

.navbar-label {
  background: none;
  border: 0;
  cursor: pointer;
  font-family: inherit;
  color: var(--sr-azul-menu, #0b2d73);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.78rem;
  font-weight: 600;
  padding: 0.9rem 0.85rem;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}
.navbar-label::after {
  content: "";
  width: 0; height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid currentColor;
  opacity: 0.65;
}
.navbar-label:hover { color: var(--dourado-escuro, #8f6416); }

.navbar-drop {
  list-style: none;
  margin: 0;
  padding: 0.4rem 0;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 240px;
  background: #fffaf0;
  border: 1px solid rgba(215, 168, 63, 0.5);
  border-top: 2px solid var(--dourado, #d7a83f);
  border-radius: 0 0 6px 6px;
  box-shadow: 0 10px 24px rgba(5, 11, 31, 0.16);
  display: none;
}
.navbar-menu > li:hover > .navbar-drop,
.navbar-menu > li:focus-within > .navbar-drop { display: block; }
.navbar-drop li { margin: 0; padding: 0; list-style: none; }
.navbar-drop li::marker { content: ""; }
.navbar-drop a {
  display: block;
  padding: 0.55rem 1.1rem;
  color: var(--sr-azul-menu, #0b2d73);
  text-decoration: none;
  font-family: var(--fonte-display, Georgia, serif);
  font-size: 0.95rem;
  white-space: nowrap;
}
.navbar-drop a:hover { background: rgba(215, 168, 63, 0.14); color: var(--sr-azul-noite, #050b1f); }

/* Desktop: esconde o botão de menu */
@media (min-width: 860px) {
  .navbar-toggle { display: none; }
}

/* Celular: vira gaveta */
@media (max-width: 859px) {
  .navbar-inner { padding: 0.55rem 1rem; }
  .navbar-menu {
    display: none;
    width: 100%;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding-top: 0.6rem;
  }
  .navbar.aberto .navbar-menu { display: flex; }
  .navbar-menu > li { position: static; }
  .nav-rezar { display: block; text-align: center; margin: 0.3rem 0 0.6rem; }
  .navbar-label {
    width: 100%;
    justify-content: flex-start;
    border-top: 1px solid rgba(215, 168, 63, 0.28);
    color: var(--dourado-escuro, #8f6416);
    font-size: 0.72rem;
    letter-spacing: 0.16em;
    cursor: default;
    padding: 0.9rem 0.6rem 0.4rem;
  }
  .navbar-label::after { display: none; }
  .navbar-drop {
    position: static;
    display: block;
    box-shadow: none;
    border: 0;
    min-width: 0;
    padding: 0 0 0.4rem;
  }
  .navbar-drop a { padding: 0.5rem 0.7rem; }
}


/* ─── 2. BANNER DE SITES PARCEIROS ─────────────────────────── */
.parceiros {
  background: linear-gradient(180deg, #fffaf0 0%, #f4ecd8 100%);
  border-top: 2px solid var(--dourado, #d7a83f);
  padding: 2.3rem 1.5rem;
  text-align: center;
}
.parceiros-titulo {
  font-family: var(--fonte-acento, sans-serif);
  font-size: 0.74rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--dourado-escuro, #8f6416);
  margin: 0 0 1.3rem;
}
.parceiros-grade {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 1rem;
  max-width: 1000px;
  margin: 0 auto;
}
.parceiros-grade a {
  display: block;
  text-decoration: none;
  background: #fffaf0;
  border: 1px solid rgba(215, 168, 63, 0.45);
  border-radius: 5px;
  padding: 0.95rem 1rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.parceiros-grade a:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(5, 11, 31, 0.12);
  border-color: var(--dourado, #d7a83f);
}
.parceiros-grade b {
  display: block;
  font-family: var(--fonte-titulo, serif);
  font-weight: 400;
  font-size: 1.06rem;
  letter-spacing: 0.02em;
  color: var(--azul-mariano, #0b2d73);
}
.parceiros-grade span {
  display: block;
  font-family: var(--fonte-corpo, serif);
  font-size: 0.82rem;
  color: var(--cinza-suave, #7a7d8c);
  margin-top: 0.2rem;
}


/* ─── 3. CARDS "POR ONDE COMEÇAR" INTEIROS CLICÁVEIS ──────── */
a.card { display: block; text-decoration: none; color: inherit; }
a.card:hover, a.card:focus { text-decoration: none; }
a.card h3 { color: var(--azul-mariano, #0b2d73); }
a.card:focus-visible { outline: 2px solid var(--dourado, #d7a83f); outline-offset: 3px; }
