.elementor-30368 .elementor-element.elementor-element-75cb521{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:-50px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}.elementor-30368 .elementor-element.elementor-element-75cb521.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-30368 .elementor-element.elementor-element-6cc1f8b{width:100%;max-width:100%;}.elementor-30368 .elementor-element.elementor-element-6cc1f8b > .elementor-widget-container{margin:0px 0px 0px 0px;}.elementor-30368 .elementor-element.elementor-element-6cc1f8b.elementor-element{--order:-99999 /* order start hack */;}.elementor-30368 .elementor-element.elementor-element-1872bf0{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}:root{--page-title-display:none;}@media(max-width:768px){.elementor-30368 .elementor-element.elementor-element-75cb521{--margin-top:-56px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}}@media(min-width:769px){.elementor-30368 .elementor-element.elementor-element-75cb521{--width:100.567%;}}/* Start custom CSS for html, class: .elementor-element-6cc1f8b */@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@700;900&family=Crimson+Text:ital,wght@0,400;0,600;1,400&display=swap');
 
/* ── Reset apenas no escopo do componente ── */
.sb-wrapper, .sb-wrapper * { box-sizing: border-box; }
.sb-wrapper { margin: 0; padding: 0; }
 
:root {
  --sb-ouro:        #C9A84C;
  --sb-ouro-claro:  #E8C96A;
  --sb-ouro-escuro: #8B6914;
  --sb-fundo:       #110900;
  --sb-texto:       #F0E6CC;
}
 
/* ── WRAPPER ── */
.sb-wrapper {
  font-family: 'Crimson Text', Georgia, serif;
  background: var(--sb-fundo);
  color: var(--sb-texto);
  width: 100%;
  overflow-x: hidden;
}
 
/* ── HERO ── */
.sb-hero {
  position: relative;
  width: 100%;
  background:
    linear-gradient(to bottom, rgba(8,4,0,0.50) 0%, rgba(8,4,0,0.25) 35%, rgba(8,4,0,0.65) 100%),
    url('https://consagradosdefatima.org/wp-content/uploads/2026/03/Backgroun-Chaveiro-sb-consagrados.jpg') center top / cover no-repeat;
  padding-bottom: 48px;
}
.sb-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 45% 100% at 0% 50%, rgba(5,2,0,0.55) 0%, transparent 70%),
    radial-gradient(ellipse 45% 100% at 100% 50%, rgba(5,2,0,0.55) 0%, transparent 70%),
    radial-gradient(ellipse 100% 25% at 50% 100%, rgba(5,2,0,0.85) 0%, transparent 80%);
  pointer-events: none;
  z-index: 0;
}
.sb-hero > * { position: relative; z-index: 2; }
 
/* ── BLOCO TÍTULO ── */
.sb-title-block {
  max-width: 1280px;
  margin: 0 auto;
  padding: 40px 32px 0;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.sb-title {
  font-family: 'Cinzel', serif;
  font-weight: 800;
  font-size: clamp(2.2rem, 5.5vw, 5rem);
  line-height: 1.05;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: linear-gradient(180deg, #F8ECA8 0%, #D4A843 45%, #8B6914 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: block;
  text-align: center;
  width: 100%;
}
.sb-subtitle {
  font-family: 'Crimson Text', Georgia, serif;
  font-style: italic;
  font-weight: 600;
  font-size: clamp(1rem, 2vw, 1.8rem);
  color: #fff;
  letter-spacing: 0.03em;
  line-height: 1.4;
  text-shadow: 0 1px 8px rgba(0,0,0,0.9);
  margin-top: 8px;
  display: block;
  text-align: center;
  width: 100%;
}
.sb-title-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 12px 0 0;
  width: 100%;
}
.sb-title-divider span {
  height: 1px;
  width: 100px;
  background: linear-gradient(90deg, transparent, var(--sb-ouro), transparent);
}
.sb-title-divider i { color: var(--sb-ouro); font-size: 14px; font-style: normal; }
 
/* ── CABEÇALHO ACIMA CARROSSEL (tablet + mobile) ── */
.sb-card-header-top {
  display: none;
  text-align: center;
  padding: 0 4px 14px;
}
.sb-card-header-top h2 {
  font-family: 'Cinzel', serif;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--sb-texto);
  text-align: center;
  line-height: 1.4;
  margin: 0;
}
.sb-card-header-top h2 span { color: var(--sb-ouro); display: block; }
 
/* ── BOTÃO ABAIXO CARROSSEL ── */
.sb-btn-below-carousel {
  display: none;
  margin-top: 16px;
  width: 100%;
}
 
/* ── BOTÃO MOBILE TOPO ── */
.sb-btn-mobile-top {
  display: none;
  max-width: calc(100% - 32px);
  margin: 16px auto 0;
  padding: 0;
}
 
/* ── HERO GRID ── */
.sb-hero-grid {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 28px;
  max-width: 1280px;
  margin: 0 auto;
  padding: 24px 32px 0;
  align-items: start;
}
 
/* ── CARROSSEL ── */
.sb-carousel-wrap { position: relative; }
 
.sb-carousel {
  /* position:relative é o pai das setas — CRÍTICO */
  position: relative !important;
  display: block !important;
  border-radius: 16px;
  overflow: hidden;
  background: transparent;
  aspect-ratio: 4/3;
  width: 100%;
}
 
.sb-slide {
  position: absolute !important;
  top: 0 !important; right: 0 !important;
  bottom: 0 !important; left: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 0;
  transition: opacity 0.6s ease;
  pointer-events: none;
  background: transparent;
  margin: 0 !important; padding: 0 !important;
}
.sb-slide.active { opacity: 1 !important; pointer-events: auto; }
.sb-slide img {
  max-width: 82%;
  max-height: 90%;
  object-fit: contain;
  filter: drop-shadow(0 8px 32px rgba(201,168,76,0.4));
  display: block;
}
.sb-slide.active img { animation: sbFloat 6s ease-in-out infinite; }
@keyframes sbFloat {
  0%,100% { transform: translateY(0) rotate(0deg); }
  50%      { transform: translateY(-8px) rotate(1deg); }
}
 
/* ── SETAS — totalmente isoladas do tema ──
   Usamos all:unset para zerar qualquer CSS do Elementor/tema
   e redefinimos só o que precisamos                          */
.sb-carousel .sb-arrow {
  /* Zera TUDO que o tema possa ter injetado */
  all: unset !important;
 
  /* Redefine o essencial */
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 20 !important;
 
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
 
  width: 44px !important;
  height: 64px !important;
  cursor: pointer !important;
  user-select: none !important;
 
  /* Cor e sombra */
  color: #ffffff !important;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.9)) !important;
 
  /* Sem fundo, sem borda */
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
  outline: none !important;
  padding: 0 !important;
  margin: 0 !important;
 
  transition: color 0.2s, filter 0.2s !important;
}
.sb-carousel .sb-arrow:hover {
  color: var(--sb-ouro) !important;
  filter: drop-shadow(0 2px 8px rgba(201,168,76,0.8)) !important;
}
 
/* Posição esquerda/direita */
.sb-carousel .sb-arrow.prev { left: 10px !important; right: auto !important; }
.sb-carousel .sb-arrow.next { right: 10px !important; left: auto !important; }
 
/* SVG interno */
.sb-carousel .sb-arrow svg {
  display: block !important;
  width: 30px !important;
  height: 30px !important;
  stroke: currentColor !important;
  stroke-width: 2.8 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
  fill: none !important;
}
 
/* ── MINIATURAS ── */
.sb-thumbs {
  display: flex;
  gap: 6px;
  margin-top: 12px;
  width: 100%;
  padding-bottom: 2px;
}
.sb-thumb {
  flex: 1 1 0;
  min-width: 0;
  aspect-ratio: 1/1;
  border-radius: 6px;
  overflow: hidden;
  border: 2px solid transparent;
  cursor: pointer;
  background: transparent;
  position: relative;
  transition: border-color 0.2s, transform 0.2s;
}
.sb-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.75) saturate(0.7);
  transition: filter 0.2s;
  display: block;
}
.sb-thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(201,168,76,0);
  border-radius: 4px;
  transition: background 0.3s;
}
.sb-thumb.active { border-color: var(--sb-ouro); transform: scale(1.05); }
.sb-thumb.active img { filter: brightness(1) saturate(1); }
.sb-thumb.active::after { background: rgba(201,168,76,0.22); }
 
/* ── CARD INFO ── */
.sb-info-card {
  background: rgba(18,10,2,0.40);
  border-radius: 16px;
  padding: 28px 24px;
  backdrop-filter: blur(10px);
}
.sb-info-card h2 {
  font-family: 'Cinzel', serif;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--sb-texto);
  text-align: center;
  line-height: 1.4;
  margin-bottom: 4px;
}
.sb-info-card h2 span { color: var(--sb-ouro); display: block; }
.sb-info-card p {
  font-size: 0.95rem;
  line-height: 1.65;
  color: #e8d8b0;
  text-align: justify;
  margin-bottom: 14px;
}
.sb-info-card p em { color: var(--sb-ouro); font-style: normal; font-weight: 600; }
.sb-divider-line {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,0.4), transparent);
  margin: 16px 0;
}
 
/* ── BOTÃO CTA ── */
.sb-btn {
  display: block !important;
  width: 100% !important;
  background: linear-gradient(135deg, #C9A84C 0%, #E8C96A 40%, #C9A84C 70%, #8B6914 100%) !important;
  color: #1A0E00 !important;
  font-family: 'Cinzel', serif !important;
  font-weight: 900 !important;
  font-size: 1.05rem !important;
  text-align: center !important;
  padding: 16px 20px !important;
  border-radius: 50px !important;
  text-decoration: none !important;
  cursor: pointer !important;
  border: none !important;
  letter-spacing: 0.03em !important;
  box-shadow: 0 4px 20px rgba(201,168,76,0.5) !important;
  transition: all 0.25s !important;
  position: relative !important;
  overflow: hidden !important;
  line-height: 1.3 !important;
}
.sb-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.22) 0%, transparent 60%);
  border-radius: inherit;
  pointer-events: none;
}
.sb-btn:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 30px rgba(201,168,76,0.65) !important;
}
 
/* ── FEATURES ── */
.sb-features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  max-width: 1280px;
  margin: 0 auto;
  padding: 32px 32px 48px;
}
.sb-feature-card {
  background: rgba(20,12,3,0.40);
  border-radius: 12px;
  padding: 20px 18px;
  backdrop-filter: blur(4px);
  transition: transform 0.3s;
}
.sb-feature-card:hover { transform: translateY(-3px); }
.sb-feature-card h3 {
  font-family: 'Cinzel', serif;
  font-size: 0.85rem;
  color: var(--sb-ouro);
  margin-bottom: 8px;
  letter-spacing: 0.03em;
}
.sb-feature-card p {
  font-size: 0.88rem;
  line-height: 1.55;
  color: #d0bc90;
  text-align: justify;
  margin: 0;
}
 
/* ══════════════════════════════════════════════════════
   TABLET 769 – 1024px
══════════════════════════════════════════════════════ */
@media (min-width: 769px) and (max-width: 1024px) {
  .sb-btn-mobile-top       { display: none !important; }
  .sb-card-header-top      { display: block; }
  .sb-info-card h2,
  .sb-info-card .sb-divider-line,
  .sb-info-card .sb-btn    { display: none !important; }
  .sb-btn-below-carousel   { display: block; }
 
  .sb-title-block { padding: 32px 24px 0; }
  .sb-title       { font-size: clamp(2rem, 5vw, 3.2rem); }
  .sb-subtitle    { font-size: clamp(0.95rem, 1.8vw, 1.35rem); }
 
  .sb-hero-grid {
    grid-template-columns: 1fr 300px;
    padding: 20px 24px 0;
    gap: 20px;
    max-width: 100%;
  }
  .sb-info-card { padding: 22px 18px; }
  .sb-features  { padding: 28px 24px 40px; max-width: 100%; }
}
 
/* ══════════════════════════════════════════════════════
   MOBILE ≤ 768px
══════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .sb-subtitle             { display: none; }
  .sb-card-header-top      { display: block; }
  .sb-info-card h2,
  .sb-info-card .sb-divider-line,
  .sb-info-card .sb-btn    { display: none !important; }
  .sb-btn-mobile-top       { display: block; }
  .sb-btn-below-carousel   { display: block; }
 
  .sb-title { font-size: clamp(2rem, 9vw, 3rem); letter-spacing: 0.04em; white-space: normal; }
  .sb-title-block { padding: 24px 16px 0; }
  .sb-title-divider span { width: 60px; }
 
  .sb-hero-grid {
    grid-template-columns: 1fr;
    grid-template-areas: "carousel" "info";
    padding: 16px 16px 0;
    gap: 16px;
    max-width: 100%;
  }
  .sb-carousel-wrap { grid-area: carousel; }
  .sb-info-card     { grid-area: info; padding: 20px 16px; }
 
  .sb-carousel { aspect-ratio: 1/1; }
  .sb-thumbs   { display: none; }
 
  .sb-features {
    grid-template-columns: 1fr;
    padding: 20px 16px 36px;
    gap: 12px;
    max-width: 100%;
  }
}/* End custom CSS */