/*
Theme Name:   Apicem Tema
Theme URI:    https://apicem.com.br
Description:  Tema filho da Apicem — design system da marca sobre TwentyTwentyFive.
Author:       Riccó / Apicem
Version:      1.0.0
Template:     twentytwentyfive
License:      GPL-2.0-or-later
Text Domain:  apicem-tema
*/

html { scroll-behavior: smooth; }

/* Header sticky — forçado via CSS porque o bloco WordPress não aplica position:sticky no render */
.apicem-header {
  position: sticky;
  top: 0;
  z-index: 300;
}

/* Remove gaps around configurador */
.wp-block-group:has(> #apicem-configurador) { margin-top: 0; margin-bottom: 0; padding-bottom: 0; display: flex; flex-direction: column; gap: 0 !important; }
.wp-block-group:has(> #apicem-configurador) > .wp-block-html { margin-block: 0 !important; }
#apicem-configurador { margin-top: 0; margin-bottom: 0; }
footer.apicem-footer  { margin-top: 0 !important; margin-block-start: 0 !important; }
.wp-site-blocks:has(#apicem-configurador) { gap: 0 !important; }

/* ── Hero da home — split viewport ────────────────────────── */

.apicem-home-hero {
  display: grid;
  grid-template-columns: 55fr 45fr;
  min-height: calc(100svh - var(--apicem-header-h, 61px)); /* medido via JS em syncHeaderH */
}

.apicem-hero-text {
  background: var(--wp--preset--color--cafe, #2B2420);
  color: var(--wp--preset--color--linho, #F5EFE6);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(48px, 7vw, 96px) clamp(32px, 5vw, 72px);
}

.apicem-hero-text .apicem-kicker {
  color: var(--wp--preset--color--argila, #BD5D3A);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin: 0 0 20px;
}

.apicem-hero-text .apicem-hero-h1 {
  font-family: "Orelega One", Georgia, serif;
  font-size: clamp(32px, 5vw, 56px);
  line-height: 1.06;
  color: var(--wp--preset--color--linho, #F5EFE6);
  margin: 0 0 20px;
}

.apicem-hero-text .apicem-hero-lead {
  font-size: clamp(18px, 2.1vw, 22px);
  line-height: 1.6;
  color: var(--wp--preset--color--linho, #F5EFE6);
  opacity: .82;
  margin: 0;
}

.apicem-home-cta {
  display: inline-block;
  background: var(--wp--preset--color--argila, #BD5D3A);
  color: var(--wp--preset--color--linho, #F5EFE6);
  padding: 14px 32px;
  border-radius: 40px;
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  margin-top: 32px;
  align-self: flex-start;
  transition: background .2s;
}

.apicem-home-cta:hover,
.apicem-home-cta:focus-visible {
  background: #9A4A2D;
  color: var(--wp--preset--color--linho, #F5EFE6);
}

.apicem-hero-video {
  position: relative;
  overflow: hidden;
  background: #111;
}

.apicem-hero-video video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Scroll offset para o header sticky */
#apicem-configurador {
  scroll-margin-top: var(--apicem-header-h, 61px);
}

/* Mobile: vídeo em cima, texto embaixo */
@media (max-width: 760px) {
  .apicem-home-hero {
    grid-template-columns: 1fr;
    grid-template-rows: 62vw auto;
    min-height: auto;
  }
  .apicem-home-hero .apicem-hero-text  { order: 2; }
  .apicem-home-hero .apicem-hero-video { order: 1; height: 62vw; }
  .apicem-hero-video video { position: absolute; }
}

/* ── Seções da home — utilidades ─────────────────────────────── */

.apicem-kicker {
  color: var(--wp--preset--color--argila, #BD5D3A);
  font-family: "Hanken Grotesk", sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin: 0 0 16px;
}

.apicem-section {
  padding-block: clamp(64px, 8vw, 96px);
}

.apicem-section-inner {
  max-width: 1080px;
  margin-inline: auto;
  padding-inline: clamp(24px, 5vw, 48px);
}

.apicem-section-inner--centrado {
  text-align: center;
  max-width: 640px;
}

.apicem-section-h2 {
  font-family: "Orelega One", Georgia, serif;
  font-size: clamp(26px, 3.5vw, 42px);
  line-height: 1.15;
  color: var(--wp--preset--color--cafe, #2B2420);
  margin: 0 0 20px;
}

.apicem-section-body {
  font-size: clamp(15px, 1.6vw, 18px);
  line-height: 1.65;
  color: var(--wp--preset--color--cafe, #2B2420);
  opacity: .82;
  max-width: 60ch;
  margin: 0;
}

.apicem-section-aside {
  font-size: 14px;
  color: var(--wp--preset--color--cinza, #8C8378);
  border-left: 2px solid var(--wp--preset--color--argila, #BD5D3A);
  padding-left: 14px;
  margin-block: 24px 32px;
}

.apicem-link-arrow {
  display: inline-block;
  margin-top: 24px;
  color: var(--wp--preset--color--argila, #BD5D3A);
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
}
.apicem-link-arrow:hover { text-decoration: underline; }

.apicem-microcopy {
  font-size: 13px;
  letter-spacing: .02em;
  opacity: .65;
  margin-top: 16px;
}

.apicem-img-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: var(--wp--preset--color--areia, #E7DBC9);
  font-size: 13px;
  font-style: normal;
  color: var(--wp--preset--color--cinza, #8C8378);
  text-align: center;
  margin: 0;
}
.apicem-img-placeholder small { opacity: .7; }
.apicem-img-placeholder--sepia { background: #DDD0B5; }

/* ── Seção 2 · Contraste ──────────────────────────────────────── */

.apicem-section-contraste {
  background: var(--wp--preset--color--creme, #FBF8F3);
  text-align: center;
  padding-block: 0;
}
.apicem-section-contraste .apicem-section-inner {
  padding-top: clamp(64px, 8vw, 96px);
  padding-bottom: 36px;
}
.apicem-section-contraste .apicem-section-body { margin-inline: auto; }

.apicem-swatch-strip {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 560px;
  margin-inline: auto;
  padding-inline: 24px;
  padding-bottom: clamp(64px, 8vw, 96px);
}
.apicem-swatch {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--hex);
  border: 1.5px solid rgba(43,36,32,.12);
  flex-shrink: 0;
}

/* ── Seção 3 · Personalização ─────────────────────────────────── */

.apicem-section-personalizacao {
  background: var(--wp--preset--color--linho, #F5EFE6);
}

.apicem-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-block: 32px;
}
.apicem-card {
  background: var(--wp--preset--color--creme, #FBF8F3);
  border-radius: 18px;
  padding: 28px 24px;
}
.apicem-card-titulo {
  font-family: "Orelega One", Georgia, serif;
  font-size: 20px;
  color: var(--wp--preset--color--cafe, #2B2420);
  margin: 0 0 12px;
}
.apicem-card-corpo {
  font-size: 14px;
  line-height: 1.6;
  color: var(--wp--preset--color--cafe, #2B2420);
  opacity: .75;
  margin: 0;
}

@media (max-width: 760px) {
  .apicem-cards-grid { grid-template-columns: 1fr; }
}

/* ── Seção 4 · Bem-estar ──────────────────────────────────────── */

.apicem-section-bemestar {
  display: grid;
  grid-template-columns: 45fr 55fr;
  background: var(--wp--preset--color--cafe, #2B2420);
  padding-block: 0;
}
.apicem-section-bemestar .apicem-img-placeholder {
  min-height: 420px;
}

.apicem-bemestar-video-wrap {
  position: relative;
  overflow: hidden;
  min-height: 420px;
  background: #111;
}
.apicem-bemestar-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.apicem-section-bemestar .apicem-section-inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-block: clamp(64px, 8vw, 96px);
}
.apicem-section-bemestar .apicem-kicker { color: var(--wp--preset--color--argila, #BD5D3A); }
.apicem-section-bemestar .apicem-section-h2,
.apicem-section-bemestar .apicem-section-body { color: var(--wp--preset--color--linho, #F5EFE6); }
.apicem-section-bemestar .apicem-section-body { opacity: .78; }

@media (max-width: 760px) {
  .apicem-section-bemestar {
    grid-template-columns: 1fr;
  }
  .apicem-section-bemestar .apicem-img-placeholder { min-height: 260px; }
  .apicem-bemestar-video-wrap { min-height: 260px; }
}

/* ── Seção 5 · Marcenaria ─────────────────────────────────────── */

.apicem-section-marcenaria {
  display: grid;
  grid-template-columns: 55fr 45fr;
  background: var(--wp--preset--color--linho, #F5EFE6);
  padding-block: 0;
}
.apicem-section-marcenaria .apicem-img-placeholder {
  min-height: 420px;
}

.apicem-marcenaria-img-wrap {
  overflow: hidden;
  min-height: 420px;
}
.apicem-marcenaria-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.apicem-section-marcenaria .apicem-section-inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-block: clamp(64px, 8vw, 96px);
}

@media (max-width: 760px) {
  .apicem-section-marcenaria {
    grid-template-columns: 1fr;
  }
  .apicem-section-marcenaria .apicem-img-placeholder { min-height: 260px; }
  .apicem-marcenaria-img-wrap { min-height: 260px; }
}

/* ── Seção 6 · Confiança & Entrega ───────────────────────────── */

.apicem-section-confianca {
  background: var(--wp--preset--color--creme, #FBF8F3);
}
.apicem-section-confianca .apicem-section-inner {
  max-width: 900px;
  text-align: center;
}
.apicem-section-confianca .apicem-kicker,
.apicem-section-confianca .apicem-section-h2 {
  margin-inline: auto;
}

.apicem-badges-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px 32px;
  margin-top: 48px;
}
.apicem-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
}
.apicem-badge-icon {
  width: 44px;
  height: 44px;
  fill: none;
  stroke: var(--wp--preset--color--argila, #BD5D3A);
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}
.apicem-badge p {
  font-size: 15px;
  line-height: 1.6;
  color: var(--wp--preset--color--cafe, #2B2420);
  margin: 0;
}

@media (max-width: 760px) {
  .apicem-badges-grid { grid-template-columns: repeat(2, 1fr); gap: 28px 20px; }
}

/* ── Seção 7 · CTA Final ──────────────────────────────────────── */

.apicem-section-cta-final {
  background: var(--wp--preset--color--argila, #BD5D3A);
}
.apicem-section-cta-final .apicem-section-h2,
.apicem-section-cta-final .apicem-section-body,
.apicem-section-cta-final .apicem-microcopy {
  color: var(--wp--preset--color--linho, #F5EFE6);
}
.apicem-section-cta-final .apicem-section-body { opacity: .85; margin-inline: auto; }
.apicem-section-cta-final .apicem-home-cta {
  background: var(--wp--preset--color--linho, #F5EFE6);
  color: var(--wp--preset--color--cafe, #2B2420);
}
.apicem-section-cta-final .apicem-home-cta:hover,
.apicem-section-cta-final .apicem-home-cta:focus-visible {
  background: var(--wp--preset--color--creme, #FBF8F3);
  color: var(--wp--preset--color--cafe, #2B2420);
}

/* ════════════════════════════════════════════════════════════════
   SEÇÕES DE INFORMAÇÃO — #apicem-info-sections
   ════════════════════════════════════════════════════════════════ */

#apicem-info-sections {
  isolation: isolate;
}

/* ── Barra de abas sticky ─────────────────────────────────────── */

.apicem-tabs-bar {
  position: sticky;
  top: 0;
  z-index: 200;
  background: var(--wp--preset--color--creme, #FBF8F3);
  border-top: 1px solid rgba(43,36,32,.1);
  border-bottom: 1px solid rgba(43,36,32,.1);
  transition: box-shadow .2s;
}
.apicem-tabs-bar.is-detached {
  box-shadow: 0 2px 16px rgba(43,36,32,.08);
}
/* Compensa o admin bar do WordPress (32px) — só afeta usuários logados */
html.admin-bar .apicem-tabs-bar     { top: 32px; }
html.admin-bar .apicem-info-section { scroll-margin-top: 84px; }
html.admin-bar #apicem-configurador { scroll-margin-top: calc(var(--apicem-header-h, 61px) + 32px); }
.apicem-tabs-list {
  display: flex;
  max-width: 1080px;
  margin-inline: auto;
  padding-inline: clamp(24px, 5vw, 48px);
  overflow-x: auto;
  scrollbar-width: none;
}
.apicem-tabs-list::-webkit-scrollbar { display: none; }
.apicem-tab {
  font-family: "Hanken Grotesk", sans-serif;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .01em;
  color: var(--wp--preset--color--cinza, #8C8378);
  text-decoration: none;
  padding: 20px 28px;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color .15s, border-color .15s;
  flex-shrink: 0;
}
.apicem-tab.is-active,
.apicem-tab[aria-current="true"] {
  color: var(--wp--preset--color--cafe, #2B2420);
  border-bottom-color: var(--wp--preset--color--argila, #BD5D3A);
}
.apicem-tab:hover {
  color: var(--wp--preset--color--cafe, #2B2420);
}

/* ── Seções de informação — base ──────────────────────────────── */

.apicem-info-section {
  scroll-margin-top: 52px; /* altura da barra de abas */
}
.apicem-info-h3 {
  font-family: "Orelega One", Georgia, serif;
  font-size: clamp(18px, 2vw, 24px);
  line-height: 1.2;
  color: var(--wp--preset--color--cafe, #2B2420);
  margin: 40px 0 14px;
}
.apicem-fine-print {
  font-size: 13px;
  line-height: 1.6;
  color: var(--wp--preset--color--cinza, #8C8378);
  margin-top: 12px;
}
.apicem-ricco-selo {
  font-family: "Hanken Grotesk", sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--wp--preset--color--cinza, #8C8378);
  margin-top: 32px;
  display: block;
}

/* ── Seção backgrounds ────────────────────────────────────────── */

.apicem-info-a-sua-mesa { background: var(--wp--preset--color--linho, #F5EFE6); }
.apicem-info-engenharia { background: var(--wp--preset--color--creme, #FBF8F3); }
.apicem-info-ricco      { background: var(--wp--preset--color--linho, #F5EFE6); }
.apicem-info-entrega    { background: var(--wp--preset--color--creme, #FBF8F3); }

/* ── Checklist ────────────────────────────────────────────────── */

.apicem-checklist {
  list-style: none;
  padding: 0;
  margin: 0 0 40px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.apicem-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 15px;
  line-height: 1.55;
  color: var(--wp--preset--color--cafe, #2B2420);
}
.apicem-check-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: var(--wp--preset--color--argila, #BD5D3A);
  margin-top: 2px;
}

/* ── Cards de 3 passos ────────────────────────────────────────── */

.apicem-steps-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-block: 32px 40px;
}
.apicem-step-card {
  background: var(--wp--preset--color--creme, #FBF8F3);
  border-radius: 18px;
  padding: 28px 24px;
}
.apicem-info-engenharia .apicem-step-card,
.apicem-info-entrega .apicem-step-card {
  background: var(--wp--preset--color--linho, #F5EFE6);
}
.apicem-step-num {
  font-family: "Orelega One", Georgia, serif;
  font-size: 36px;
  color: var(--wp--preset--color--argila, #BD5D3A);
  line-height: 1;
  margin: 0 0 14px;
}
.apicem-step-titulo {
  font-weight: 700;
  font-size: 15px;
  color: var(--wp--preset--color--cafe, #2B2420);
  margin: 0 0 8px;
}
.apicem-step-corpo {
  font-size: 14px;
  line-height: 1.6;
  color: var(--wp--preset--color--cafe, #2B2420);
  opacity: .75;
  margin: 0;
}

/* ── Specs / fatos grid ───────────────────────────────────────── */

.apicem-specs-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(43,36,32,.1);
  border-radius: 16px;
  overflow: hidden;
  margin-block: 48px;
}
.apicem-spec-item {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 28px 24px;
  border-right: 1px solid rgba(43,36,32,.1);
}
.apicem-spec-item:last-child { border-right: none; }
.apicem-spec-icon {
  width: 28px;
  height: 28px;
  fill: none;
  stroke: var(--wp--preset--color--argila, #BD5D3A);
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}
.apicem-spec-number {
  font-family: "Orelega One", Georgia, serif;
  font-size: clamp(18px, 2vw, 24px);
  color: var(--wp--preset--color--cafe, #2B2420);
  line-height: 1.1;
  margin: 0;
}
.apicem-spec-label {
  font-size: 13px;
  line-height: 1.5;
  color: var(--wp--preset--color--cinza, #8C8378);
  margin: 0;
}

/* ── Dois colunas — materiais ─────────────────────────────────── */

.apicem-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px 56px;
  margin-top: 16px;
}
.apicem-two-col-item .apicem-info-h3 { margin-top: 0; }

/* ── Bloco de garantia ────────────────────────────────────────── */

.apicem-garantia-bloco {
  margin-top: 40px;
  padding: 32px 36px;
  background: var(--wp--preset--color--creme, #FBF8F3);
  border-radius: 18px;
  border-left: 3px solid var(--wp--preset--color--argila, #BD5D3A);
}
.apicem-garantia-bloco .apicem-info-h3 { margin-top: 0; }

/* ── Faixa de fechamento ──────────────────────────────────────── */

.apicem-info-closing {
  background: var(--wp--preset--color--cafe, #2B2420);
  padding-block: clamp(80px, 10vw, 120px);
  text-align: center;
}
.apicem-info-closing .apicem-section-h2 {
  color: var(--wp--preset--color--linho, #F5EFE6);
  margin-bottom: 32px;
}
.apicem-info-closing .apicem-home-cta {
  background: var(--wp--preset--color--linho, #F5EFE6);
  color: var(--wp--preset--color--cafe, #2B2420);
}
.apicem-info-closing .apicem-home-cta:hover,
.apicem-info-closing .apicem-home-cta:focus-visible {
  background: var(--wp--preset--color--areia, #E7DBC9);
  color: var(--wp--preset--color--cafe, #2B2420);
}
.apicem-info-closing .apicem-ricco-selo {
  color: rgba(245,239,230,.4);
  margin-top: 24px;
}

/* ── Reveal on scroll ─────────────────────────────────────────── */

@media (prefers-reduced-motion: no-preference) {
  .apicem-reveal {
    opacity: 0;
    transform: translateY(26px);
    transition: opacity .9s ease, transform .9s ease;
  }
  .apicem-reveal.is-visible {
    opacity: 1;
    transform: none;
  }
}

/* ── Mobile — #apicem-info-sections ──────────────────────────── */

@media (max-width: 760px) {
  .apicem-steps-grid { grid-template-columns: 1fr; }
  .apicem-two-col    { grid-template-columns: 1fr; gap: 0; }
  .apicem-specs-grid {
    grid-template-columns: repeat(2, 1fr);
    border-radius: 12px;
  }
  .apicem-spec-item:nth-child(2) { border-right: none; }
  .apicem-spec-item:nth-child(1),
  .apicem-spec-item:nth-child(2) { border-bottom: 1px solid rgba(43,36,32,.1); }
  .apicem-spec-item { padding: 20px 18px; }
  .apicem-garantia-bloco { padding: 24px 20px; }
  .apicem-tab { padding: 16px 20px; font-size: 14px; }
}
