/* BE-CLONE — Homepage Compat Layer (sp- → be- equivalents)
   Mantém compatibilidade com classes sp-* dos blocos Gutenberg existentes
   sem precisar editar o conteúdo da página.
   Será removido quando migrarmos os blocos para classes be-.
   ========================================= */

/* ── Hero (full-bleed) ── */
.sp-hero {
  position: relative;
  overflow: hidden;
  background-color: var(--color-accent);
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-top: 50%;
}
.sp-hero img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }
.sp-hero::after { content: ''; position: absolute; inset: 0; background: rgba(0,0,0,0.25); z-index: 1; }
.sp-hero-content { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); text-align: center; color: var(--color-btn-text); z-index: 2; width: 90%; max-width: 600px; }
.sp-hero-content h1 { font-family: var(--font-heading); font-size: 64px; text-transform: var(--caps-heading); color: #ffffff; margin-bottom: 10px; font-weight: var(--font-weight-regular); letter-spacing: var(--ls-heading); line-height: 1.1; }
.sp-hero-content p { font-family: var(--font-body); font-size: 16px; line-height: 1.56; margin-bottom: 24px; font-style: italic; font-weight: var(--font-weight-regular); color: #ffffff; }

/* ── Buttons ── */
.sp-btn-primary { background-color: var(--color-btn-bg); color: var(--color-btn-text); border: 1px solid var(--color-btn-text); display: inline-block; text-decoration: none; cursor: pointer; font-family: var(--font-button); font-size: 13px; letter-spacing: 0.96px; text-transform: var(--caps-button); padding: 14px 28px; font-weight: var(--font-weight-regular); border-radius: var(--radius-btn, 10px); }
.sp-btn-primary:hover { background-color: rgba(255,255,255,0.2); color: var(--color-btn-text); }
.sp-btn-dark { background-color: var(--color-btn-bg); color: var(--color-btn-text); border: 1px solid var(--color-btn-bg); display: inline-block; text-decoration: none; cursor: pointer; font-family: var(--font-button); font-size: 13px; letter-spacing: 0.96px; text-transform: var(--caps-button); padding: 14px 28px; font-weight: var(--font-weight-regular); border-radius: var(--radius-btn, 10px); }
.sp-btn-dark:hover { background-color: #1a1a1a; color: var(--color-btn-text); }

/* ── Categories Grid (full-bleed) ── */
.sp-categories-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px;
  padding: 3px 0;
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
.sp-categories-grid a { text-decoration: none; }
.sp-category-card { position: relative; overflow: hidden; aspect-ratio: 1; border-radius: 10px; }
.sp-category-card img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; border-radius: 10px; }
.sp-category-card:hover img { transform: scale(1.05); }
.sp-category-card-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 30px; background: linear-gradient(to top, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.45) 45%, rgba(0,0,0,0) 100%); color: var(--color-btn-text); border-radius: 0 0 10px 10px; }
.sp-category-card-content h3 { font-family: var(--font-heading); font-size: 1.4rem; text-transform: uppercase; color: var(--color-btn-text); margin-bottom: 12px; }

/* ── Essentials Banner (full-bleed) ── */
.sp-essentials-banner {
  position: relative;
  overflow: hidden;
  margin: 4px 0;
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
.sp-essentials-banner img { width: 100%; height: auto; display: block; }
.sp-essentials-content { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); text-align: center; color: #fff; width: 90%; max-width: 600px; }
.sp-essentials-content h1,
.sp-essentials-content h2 { font-family: var(--font-heading); font-size: 64px; text-transform: none; letter-spacing: normal; font-weight: 400; margin-bottom: 10px; line-height: 1; color: #fff; }
.sp-essentials-content p { font-family: var(--font-body); font-size: 16.8px; line-height: 1.56; margin-bottom: 18px; color: #fff; font-weight: 400; letter-spacing: normal; }

/* ── Section Header ── */
.sp-section-header {
  text-align: left;
  padding: 100px max(20px, calc((100vw - 1160px) / 2)) 20px;
  background-color: var(--color-bg);
}
.sp-section-header h2 {
  font-family: 'Oswald', var(--font-heading);
  font-size: 69px;
  font-weight: 400;
  text-transform: none;
  letter-spacing: normal;
  line-height: 1;
  color: #0b0b0b;
  margin-bottom: 8px;
}
.sp-section-header p {
  font-family: 'Open Sans', var(--font-body);
  font-size: 16.8px;
  line-height: 1.56;
  font-weight: 400;
  color: #0b0b0b;
  font-style: italic;
  letter-spacing: normal;
}

/* ── About Section ── */
.sp-about {
  padding: 60px 0;
  background-color: var(--color-bg);
}

.sp-about__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: stretch;
  padding: 0 max(24px, calc((100vw - 1160px) / 2));
}

.sp-about__media {
  width: 100%;
  min-height: 400px;
  border-radius: 10px;
  overflow: hidden;
}

.sp-about__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sp-about__content {
  display: flex;
  align-items: center;
  justify-content: center;
}

.sp-about__inner {
  width: 100%;
  max-width: 480px;
  text-align: left;
}

.sp-about__inner h2 {
  font-family: 'Oswald', var(--font-heading);
  font-size: 69px;
  font-weight: 400;
  text-transform: none;
  letter-spacing: normal;
  line-height: 1;
  color: #0b0b0b;
  margin: 0 0 20px;
}

.sp-about__inner p {
  font-family: 'Open Sans', var(--font-body);
  font-size: 16.8px;
  line-height: 1.56;
  font-weight: 400;
  color: #0b0b0b;
  font-style: italic;
  letter-spacing: normal;
  margin: 0 0 28px;
}

/* ── Announcement bar (sp- legacy) ── */
.sp-announcement-bar { background-color: var(--announcement-bg); color: var(--announcement-text); text-align: center; padding: 8px 0; font-size: var(--announcement-font-size); font-family: var(--font-body); letter-spacing: var(--announcement-ls); font-weight: var(--font-weight-regular); text-transform: none; width: 100%; border-bottom: var(--border-width) solid var(--border-color); overflow: hidden; white-space: nowrap; }
.sp-announcement-marquee { display: inline-block; animation: be-marquee var(--announcement-speed) linear infinite; }
.sp-announcement-marquee span { padding: 0 60px; }

/* ── Responsive ── */
@media (max-width: 768px) {
  /* Hero parity: tighter viewport and centered CTA */
  .sp-hero { padding-top: 118%; }
  .sp-hero-content { top: 58%; width: 88%; }
  .sp-hero-content h1 { font-size: 42px; line-height: 1.02; margin-bottom: 8px; }
  .sp-hero-content p { font-size: 14px; margin-bottom: 16px; }
  .sp-hero-content .sp-btn { padding: 12px 22px; }

  /* Cards below hero: compact 3-up row with less vertical space */
  .sp-categories-grid {
    grid-template-columns: 1fr;
    gap: 2px;
    padding: 2px 0;
  }
  .sp-category-card { aspect-ratio: 1; }
  .sp-category-card-content { padding: 16px 16px 18px; }
  .sp-category-card-content h3 { font-size: 2.1rem; margin-bottom: 10px; line-height: 1.15; }
  .sp-category-card-content .sp-btn { font-size: 0.92rem !important; padding: 10px 18px !important; border-radius: 12px; }

  .sp-section-header { padding: 60px 16px 16px; }
  .sp-section-header h2 { font-size: 40px; }
  .sp-section-header p { font-size: 14px; }

  /* Essentials parity: keep overlay and tune mobile ratio */
  .sp-essentials-banner img { aspect-ratio: 16 / 10; object-fit: cover; }
  .sp-essentials-content {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    padding: 0 14px;
    max-width: 82%;
  }
  .sp-essentials-content h2 { font-size: 46px; margin-bottom: 6px; }
  .sp-essentials-content p { font-size: 14px; margin-bottom: 12px; }

  .sp-about__grid { grid-template-columns: 1fr; gap: 24px; padding: 0 16px; }
  .sp-about__media { min-height: 280px; }
  .sp-about__inner h2 { font-size: 40px; }
  .sp-about__content { justify-content: flex-start; }
}

@media (max-width: 480px) {
  .sp-hero { padding-top: 128%; }
  .sp-hero-content { top: 59%; width: 90%; }
  .sp-hero-content h1 { font-size: 36px; }
  .sp-category-card-content { padding: 14px 14px 16px; }
  .sp-category-card-content h3 { font-size: 1.92rem; }
  .sp-essentials-content h2 { font-size: 38px; }
}
