/* ============================================================
   BLOG — Intro Child  v3.0
   Dark / Light mode via body[data-scheme] CSS variables.
   Afeta apenas body.fp-is-blog (home.php do blog).
   ============================================================ */


/* ── Variáveis — Dark (padrão / fallback) ───────────────────── */
body.fp-is-blog,
body[data-scheme="dark"].fp-is-blog {
  --fp-bg:           #0d0d12;
  --fp-surface:      #13131c;
  --fp-surface-2:    #1a1a27;
  --fp-text:         #f0eeff;
  --fp-text-muted:   #9090aa;
  --fp-border:       rgba(255, 255, 255, .08);
  --fp-pill-bg:      rgba(255, 255, 255, .10);

  /* Constantes */
  --fp-purple:       #7c3aed;
  --fp-purple-hover: #6d28d9;
  --fp-purple-light: #8b5cf6;
  --fp-purple-pale:  #c4b5fd;
  --fp-accent-border:rgba(124, 58, 237, .22);
  --fp-radius:       .625rem;
  --fp-radius-pill:  999px;
  --fp-ease:         .22s ease;
}

/* ── Variáveis — Light ─────────────────────────────────────── */
body[data-scheme="light"].fp-is-blog {
  --fp-bg:         #ffffff;
  --fp-surface:    #f4f4f8;
  --fp-surface-2:  #eaeaf0;
  --fp-text:       #1a1a2e;
  --fp-text-muted: #555566;
  --fp-border:     rgba(0, 0, 0, .08);
  --fp-pill-bg:    rgba(0, 0, 0, .06);
  --fp-accent-border: rgba(124, 58, 237, .18);
}

/* ── Background do body ────────────────────────────────────── */
body.fp-is-blog {
  background-color: var(--fp-bg) !important;
  color: var(--fp-text);
}


/* ── Quebra o cs-container estreito do tema ─────────────────── */
/* Não afeta o container do header (.cs-header__container)      */
body.fp-is-blog .cs-site-content .cs-container,
body.fp-is-blog #content.cs-main-content {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

body.fp-is-blog .cs-main-content  { margin-top: 0 !important; }
body.fp-is-blog .cs-site-content  { margin: 0 !important; }
body.fp-is-blog .fp-blog-area,
body.fp-is-blog #primary.cs-content-area {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
}


/* ── Container único — largura 1200 px em toda a página ─────── */
.fp-blog {
  width: 100%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 2rem;
  padding-right: 2rem;
  padding-bottom: 5rem;
  box-sizing: border-box;
}

@media (min-width: 1264px) { .fp-blog { padding-left: 2.5rem; padding-right: 2.5rem; } }
@media (max-width: 639px)  { .fp-blog { padding-left: 1rem;   padding-right: 1rem;   } }


/* ── Cabeçalho ─────────────────────────────────────────────── */
.fp-blog__header {
  text-align: center;
  padding: 3.5rem 0 2.5rem;
}

.fp-blog__title {
  font-size: clamp(1.75rem, 4vw, 2.625rem);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -.025em;
  color: var(--fp-text);
  margin: 0 0 .875rem;
}

.fp-blog__subtitle {
  font-size: .9375rem;
  line-height: 1.65;
  color: var(--fp-text-muted);
  max-width: 54ch;
  margin-inline: auto;
}


/* ── Pill ──────────────────────────────────────────────────── */
.fp-blog__pill {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  padding: .2rem .7rem;
  border-radius: var(--fp-radius-pill);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  text-decoration: none !important;
  white-space: nowrap;
  background: rgba(124, 58, 237, .2);
  color: var(--fp-purple-pale);
  border: 1px solid var(--fp-accent-border);
  transition: background var(--fp-ease), color var(--fp-ease);
  cursor: default;
}

body[data-scheme="light"].fp-is-blog .fp-blog__pill {
  background: rgba(124, 58, 237, .12);
  color: var(--fp-purple);
  border-color: rgba(124, 58, 237, .2);
}

.fp-blog__pill--sm {
  font-size: .65rem;
  padding: .15rem .55rem;
}


/* ── Hero (slide do carousel) ──────────────────────────────── */
.fp-blog__hero {
  position: relative;
  min-height: 440px;
  display: flex;
  align-items: flex-end;
  background-color: var(--fp-surface);
  background-size: cover;
  background-position: center;
  width: 100%;
}

.fp-blog__hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, .88) 0%,
    rgba(0, 0, 0, .4)  55%,
    rgba(0, 0, 0, .06) 100%
  );
}

.fp-blog__hero-content {
  position: relative;
  z-index: 2;
  padding: 2.75rem 3rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
  max-width: 680px;
}

.fp-blog__hero-title {
  font-size: clamp(1.375rem, 3.2vw, 2.125rem);
  font-weight: 800;
  line-height: 1.18;
  letter-spacing: -.02em;
  margin: 0;
}

.fp-blog__hero-title a {
  color: #fff !important;
  text-decoration: none !important;
  transition: color var(--fp-ease);
}

.fp-blog__hero-title a:hover { color: var(--fp-purple-pale) !important; }

.fp-blog__hero-excerpt {
  font-size: .9375rem;
  line-height: 1.55;
  color: rgba(255, 255, 255, .8);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.fp-blog__hero-meta {
  display: flex;
  align-items: center;
  gap: .375rem;
  font-size: .8125rem;
  color: rgba(255, 255, 255, .6);
}

.fp-blog__hero-cta {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .5rem 1.25rem;
  border-radius: var(--fp-radius-pill);
  background: var(--fp-purple);
  color: #fff !important;
  text-decoration: none !important;
  font-size: .875rem;
  font-weight: 600;
  align-self: flex-start;
  margin-top: .25rem;
  transition: background var(--fp-ease), transform var(--fp-ease);
}

.fp-blog__hero-cta:hover {
  background: var(--fp-purple-hover);
  transform: translateY(-2px);
}

@media (max-width: 767px) {
  .fp-blog__hero         { min-height: 320px; }
  .fp-blog__hero-content { padding: 1.5rem; }
}


/* ── Carousel (CSS scroll-snap) ────────────────────────────── */
.fp-carousel {
  margin-bottom: 3rem;
}

/* Stage — contém a track e as setas */
.fp-carousel__stage {
  position: relative;
  border-radius: var(--fp-radius);
  overflow: hidden;
}

/* Track — scroll horizontal com snap */
.fp-carousel__track {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
  /* Sem border-radius aqui para não clipar os cantos do hero */
}

.fp-carousel__track::-webkit-scrollbar { display: none; }

/* Slide */
.fp-carousel__slide {
  flex: 0 0 100%;
  width: 100%;
  scroll-snap-align: start;
}

/* Setas — posicionadas no terço superior do hero, acima da área de texto */
.fp-carousel__arrow {
  position: absolute;
  top: 1.25rem;   /* canto superior, longe do título que fica na base */
  transform: none;
  z-index: 10;
  width: 2.375rem;
  height: 2.375rem;
  border-radius: 50%;
  background: rgba(0, 0, 0, .48);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, .2);
  cursor: pointer;
  font-size: 1.375rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--fp-ease), border-color var(--fp-ease), transform var(--fp-ease);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.fp-carousel__arrow--prev { left: .875rem; }
.fp-carousel__arrow--next { right: .875rem; }

.fp-carousel__arrow:hover {
  background: var(--fp-purple);
  border-color: var(--fp-purple);
  transform: scale(1.08);
}

/* Barra de progresso */
.fp-carousel__progress {
  height: 4px;
  background: rgba(255, 255, 255, .12);
  border-radius: 2px;
  overflow: hidden;
  margin-top: .875rem;
}

body[data-scheme="light"].fp-is-blog .fp-carousel__progress {
  background: rgba(0, 0, 0, .1);
}

@keyframes fp-progress {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

.fp-carousel__progress-bar {
  display: block;
  height: 100%;
  width: 100%;
  background: var(--fp-purple);
  transform-origin: left center;
  transform: scaleX(0);
  border-radius: 2px;
}

.fp-carousel__progress-bar.is-animating {
  animation: fp-progress 5s linear forwards;
}

.fp-carousel__progress-bar.is-paused {
  animation-play-state: paused;
}

@media (max-width: 767px) {
  .fp-carousel__arrow { display: none; }
}


/* ── Grid de posts ─────────────────────────────────────────── */
.fp-blog__posts {
  width: 100%;
}

.fp-blog__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.75rem;
  margin-bottom: 3rem;
}

@media (max-width: 1023px) { .fp-blog__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 599px)  { .fp-blog__grid { grid-template-columns: 1fr; gap: 1.25rem; } }


/* ── Card ──────────────────────────────────────────────────── */
.fp-blog-card {
  display: flex;
  flex-direction: column;
  background: var(--fp-surface);
  border-radius: var(--fp-radius);
  overflow: hidden;
  border: 1px solid var(--fp-border);
  transition: transform var(--fp-ease), box-shadow var(--fp-ease), border-color var(--fp-ease);
}

.fp-blog-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 40px rgba(0, 0, 0, .35);
  border-color: var(--fp-accent-border);
}

body[data-scheme="light"].fp-is-blog .fp-blog-card:hover {
  box-shadow: 0 8px 28px rgba(0, 0, 0, .1);
}

/* Imagem */
.fp-blog-card__img-wrap {
  display: block;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  background: var(--fp-surface-2);
  flex-shrink: 0;
}

.fp-blog-card__img-wrap img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center; /* JS aplica data-object-position se definido por post */
  transition: transform .4s ease;
}

.fp-blog-card:hover .fp-blog-card__img-wrap img { transform: scale(1.05); }

.fp-blog-card__no-img {
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, var(--fp-surface-2), rgba(124, 58, 237, .1));
}

/* Corpo */
.fp-blog-card__body {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  padding: 1.125rem 1.25rem 1.25rem;
  flex: 1;
}

.fp-blog-card__title {
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -.01em;
  margin: 0;
}

.fp-blog-card__title a {
  color: var(--fp-text) !important;
  text-decoration: none !important;
  transition: color var(--fp-ease);
}

.fp-blog-card__title a:hover { color: var(--fp-purple-light) !important; }

body[data-scheme="light"].fp-is-blog .fp-blog-card__title a:hover {
  color: var(--fp-purple) !important;
}

.fp-blog-card__excerpt {
  font-size: .875rem;
  line-height: 1.55;
  color: var(--fp-text-muted);
  margin: 0;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.fp-blog-card__footer {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: .78rem;
  color: var(--fp-text-muted);
  opacity: .75;
  padding-top: .75rem;
  border-top: 1px solid var(--fp-border);
}


/* ── Paginação ─────────────────────────────────────────────── */
.fp-blog__pagination {
  display: flex;
  justify-content: center;
  margin-bottom: 3rem;
}

.fp-blog__pagination-links {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .375rem;
  justify-content: center;
}

.fp-blog__pagination-links .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  height: 2.25rem;
  padding: 0 .75rem;
  border-radius: var(--fp-radius);
  font-size: .875rem;
  font-weight: 600;
  text-decoration: none !important;
  border: 1px solid var(--fp-border);
  color: var(--fp-text-muted);
  background: var(--fp-surface);
  transition: background var(--fp-ease), border-color var(--fp-ease), color var(--fp-ease);
}

.fp-blog__pagination-links .page-numbers:hover,
.fp-blog__pagination-links .page-numbers.current {
  background: var(--fp-purple);
  border-color: var(--fp-purple);
  color: #fff !important;
}

.fp-blog__pagination-links .page-numbers.dots {
  border: none;
  background: none;
  cursor: default;
}


/* ── Newsletter ────────────────────────────────────────────── */
.fp-blog__newsletter {
  padding: 3rem 2.5rem;
  border-radius: var(--fp-radius);
  background: linear-gradient(
    135deg,
    rgba(124, 58, 237, .14) 0%,
    var(--fp-surface) 60%
  );
  border: 1px solid var(--fp-accent-border);
}

body[data-scheme="light"].fp-is-blog .fp-blog__newsletter {
  background: linear-gradient(135deg, rgba(124, 58, 237, .07) 0%, var(--fp-surface) 60%);
}

.fp-blog__newsletter .cs-subscribe          { text-align: center; }
.fp-blog__newsletter .cs-subscribe__content { max-width: 520px; margin-inline: auto; }

.fp-blog__newsletter .cs-subscribe__heading,
.fp-blog__newsletter .cs-subscribe__subheading {
  color: var(--fp-text) !important;
}

.fp-blog__newsletter .cs-subscribe__form button {
  background: var(--fp-purple) !important;
  border-color: var(--fp-purple) !important;
  color: #fff !important;
  transition: background var(--fp-ease) !important;
}

.fp-blog__newsletter .cs-subscribe__form button:hover {
  background: var(--fp-purple-hover) !important;
  border-color: var(--fp-purple-hover) !important;
}

@media (max-width: 767px) { .fp-blog__newsletter { padding: 2rem 1.25rem; } }


/* ── Vazio ─────────────────────────────────────────────────── */
.fp-blog__empty {
  text-align: center;
  padding: 4rem 0;
  color: var(--fp-text-muted);
  font-size: 1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}
