/* ============================================================
   M4 - DESPERTAR DO CONHECIMENTO (Kids 2) — Livro vermelho
   FECHADO = capa vermelha cobre tudo
   ABERTO  = capa gira pela lombada (esq), páginas aparecem
   ============================================================ */

.m4k2-wrap {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

/* ── Cena 3D ──────────────────────────────────────────────────
   ⚠️  AJUSTE top/left para posicionar no tapete k2
   ──────────────────────────────────────────────────────────── */
.m4k2-scene {
  position: absolute;
  top: 57%;    /* ← AJUSTE */
  left: 78%;   /* ← AJUSTE */
  width: 10%;
  height: 13%;
  transform: translate(-50%, -50%);
  transform: rotate(160deg);
  perspective: 800px;
  perspective-origin: 50% 50%;
}

/* ── Livro (container relativo) ─────────────────────────────── */
.m4k2-livro {
  position: relative;
  width: 100%;
  height: 100%;
}

/* ── Páginas (embaixo, sempre lá, escondidas pela capa fechada) */
.m4k2-paginas {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, #fdf6e3, #f0e0b0);
  border: 0.12vw solid #bbb;
  border-radius: 0.3vw;
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
  padding: 8% 12%;
}

.m4k2-paginas-linha {
  height: 0.15vw;
  background: rgba(0, 0, 0, 0.18);
  border-radius: 0.1vw;
}

/* ── Capa (FULL WIDTH, em cima, gira pela lombada esquerda) ───
   FECHADO: rotateY(0)   → cobre tudo (livro fechado = tudo vermelho)
   ABERTO:  rotateY(-175deg) → vira para a esquerda, páginas aparecem
   ──────────────────────────────────────────────────────────── */
.m4k2-capa-wrap {
  position: absolute;
  inset: 0;                         /* cobre 100% do livro */
  transform-origin: left center;    /* gira pela lombada (esquerda) */
  transform: rotateY(0deg);
  transition: transform 0.90s cubic-bezier(0.4, 0, 0.2, 1);
  transform-style: preserve-3d;
}

/* Face frontal — vermelha, visível quando fechado */
.m4k2-capa-frente {
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, #d42a00 0%, #991a00 55%, #6e1000 100%);
  border: 0.12vw solid rgba(0, 0, 0, 0.45);
  border-radius: 0.3vw;
  backface-visibility: hidden;

  /* Detalhe: sombra da lombada na capa */
  box-shadow: inset 0.5vw 0 0.6vw rgba(0, 0, 0, 0.25);
}

/* Face traseira — parte interna da capa (cor mais suave) */
.m4k2-capa-tras {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, #c8a46a, #b08040);
  border: 0.12vw solid rgba(0, 0, 0, 0.3);
  border-radius: 0.3vw;
  backface-visibility: hidden;
  transform: rotateY(180deg);       /* lado oposto da frente */
}

/* ── Estado ABERTO ────────────────────────────────────────────
   Classe adicionada pelo JS ao clicar em "Abrir Livro"
   ──────────────────────────────────────────────────────────── */
.m4k2-livro.aberto .m4k2-capa-wrap {
  transform: rotateY(-175deg);      /* capa vai para a esquerda */
}

/* ── Botão de abrir/fechar ───────────────────────────────────
   ⚠️  AJUSTE top/left para posicionar abaixo do livro
   ──────────────────────────────────────────────────────────── */
#m4k2-btn-abrir {
  position: absolute;
  top: 72%;     /* ← AJUSTE */
  left: 84%;    /* ← AJUSTE */
  transform: translateX(-50%);
  pointer-events: auto;
  cursor: pointer;
  user-select: none;

  background-color: var(--tbr-azul, #022d62);
  color: #fff !important;
  border: 2px solid rgba(255,255,255,0.2);
  padding: 8px 16px;
  border-radius: 12px;
  font-weight: 700;
  font-size: 0.9vw;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  font-family: 'Archivo', 'Montserrat', sans-serif;
  box-shadow: 0 4px 12px rgba(2, 45, 98, 0.3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

#m4k2-btn-abrir:hover {
  background-color: var(--tbr-verde, #00b144);
  transform: translateX(-50%) translateY(-3px) scale(1.05);
  box-shadow: 0 8px 20px rgba(0, 177, 68, 0.4);
  border-color: rgba(255,255,255,0.4);
}

#m4k2-btn-abrir:active {
  transform: translateX(-50%) translateY(-1px) scale(0.98);
}

/* Quando aberto: botão fica verde */
#m4k2-btn-abrir.aberto {
  background-color: var(--tbr-verde, #00b144);
  box-shadow: 0 0 15px rgba(0, 177, 68, 0.5);
}
