:root{
      --bg:#0b0b10;          /* fundo profundo */
      --panel:#12121a;       /* painéis */
      --ink:#e8e6e3;         /* texto primário */
      --muted:#bcb8b1;       /* texto secundário */
      --gold:#FFD700;        /* dourado */
      --gold-2:#c9a227;      /* dourado escuro */
      --accent:#8bb8ff;      /* detalhe sutil azul arcano */
      --success:#18c29c;     /* selos/garantia */
      --danger:#ff6b6b;      /* alertas */
      --shadow:0 10px 30px rgba(0,0,0,.45);
    }
    *{box-sizing:border-box}
    html,body{height:100%;}

/* move o gradiente para o elemento raiz e fixa-o para ficar uniforme */
html{
  /* fundo sólido em vez de gradientes */
  background: var(--bg);
  scroll-behavior: smooth;
}

/* body usa apenas cor de base; evita repintura local do gradiente */
body{
  margin:0;
  font-family: 'Merriweather', serif;
  padding-top: 72px; /* ajuste esse valor conforme o header */
  /* tornar transparente para que o gradiente do html apareça no topo e durante a rolagem */
  background-color: transparent;
  min-height: 100vh;
  color:var(--ink);
}
    a{color:var(--accent);text-decoration:none}
    .container{width:min(1120px, 92%); margin-inline:auto}
    header{
      position:fixed;
      top:0;
      left:0;
      right:0;
      z-index:999;
      backdrop-filter:saturate(1.1) blur(10px);
      -webkit-backdrop-filter:blur(10px);
      /* tornar levemente mais translúcido para revelar o gradiente por baixo */
      background-color:rgba(11,11,16,.65);
      border-bottom:1px solid rgba(255,215,0,.15);
    }
    .nav{display:flex; align-items:center; justify-content:space-between; padding:14px 0}
    .brand{display:flex; align-items:center; gap:10px}
    .brand-mark{
      width:36px; height:36px; border-radius:8px; background:conic-gradient(from 200deg, var(--gold), var(--gold-2));
      box-shadow: inset 0 0 8px rgba(0,0,0,.35), 0 2px 8px rgba(0,0,0,.3);
      position:relative;
    }
    .brand-mark:after{
      content:''; position:absolute; inset:7px; border:2px solid #0e0e15; border-radius:6px;
    }
    .brand-title{font-family:'Cinzel', serif; font-weight:800; letter-spacing:.5px}
    .nav a{margin-left:14px; font-size:.95rem; color:var(--ink); opacity:.85}
    .btn{
      position:relative; /* necessário para o ::after do brilho */
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:8px;
      padding:10px 18px;
      border-radius:12px;
      border:1px solid rgba(255,180,0,.22); /* menos vibrante */
      background: linear-gradient(180deg, rgba(217,168,0,.12) 0%, rgba(193,135,0,.06) 100%); /* tom amarelo mais escuro/matizado */
      color: #0b0b10; /* texto escuro para melhor contraste */
      font-weight:700;
      text-decoration:none;
      cursor:pointer;
      box-shadow: 0 8px 18px rgba(0,0,0,.45); /* brilho reduzido */
      transition: transform .14s ease, box-shadow .18s ease, filter .12s ease;
      overflow:hidden; /* para o efeito de brilho */
    }

    /* brilho animado ao passar o mouse (reduzido) */
    .btn::after{
      content:"";
      position:absolute;
      top:0;
      left:0;
      width:28%;
      height:110%;
      background: linear-gradient(120deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.12) 50%, rgba(255,255,255,0) 100%);
      transform: translateX(-140%) rotate(6deg);
      transition: transform .75s cubic-bezier(.2,.8,.2,1);
      pointer-events:none;
      filter:blur(5px);
    }

    /* estado hover: leve elevação, brilho e saturação (mais sutil) */
    .btn:hover{
      transform: translateY(-3px);
      box-shadow: 0 16px 40px rgba(0,0,0,.52), 0 0 18px rgba(255,180,0,.04);
      filter: saturate(1.04);
    }
    .btn:hover::after{ transform: translateX(200%) rotate(6deg); }

    /* foco acessível */
    .btn:focus{
      outline:2px solid rgba(139,184,255,.18);
      outline-offset:4px;
      box-shadow:0 14px 36px rgba(0,0,0,.45), 0 0 28px rgba(139,184,255,.06);
    }

    /* estado ativo (clique) */
    .btn:active{ transform: translateY(-2px) scale(.997); }

    /* variante primária mais vibrante */
    .btn.btn-primary{
      background: linear-gradient(180deg, #d4a800 0%, #b88400 100%); /* dourado mais escuro */
      color: #0b0b10; /* texto escuro para legibilidade */
      border: 1px solid rgba(0,0,0,.12);
      box-shadow: 0 10px 30px rgba(0,0,0,.32), inset 0 -3px 8px rgba(255,255,255,.04);
    }
    .btn.btn-primary:hover{
      box-shadow: 0 22px 56px rgba(0,0,0,.36), 0 0 34px rgba(184,125,0,.06);
      transform: translateY(-4px);
    }
    .hero{padding:80px 0 40px; position:relative; overflow:hidden}
    .hero:before{
      content:''; position:absolute; inset:-20%; background:
        radial-gradient(900px 450px at 10% 25%, rgba(255,215,0,.04), transparent 70%),
        radial-gradient(900px 500px at 90% 10%, rgba(139,184,255,.03), transparent 70%);
      pointer-events:none; z-index:-1;
    }
    .hero h1{font-family:'Cinzel', serif; font-size:clamp(2.2rem, 5vw, 4rem); line-height:1.1; margin:0 0 12px; color:var(--gold)}
    .hero p.lead{font-size:clamp(1.05rem, 2.2vw, 1.25rem); color:var(--muted); max-width:840px}
    .hero-card{margin-top:24px; background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01)); border:1px solid rgba(255,215,0,.14);
      border-radius:18px; padding:22px; display:grid; grid-template-columns:1.3fr .9fr; gap:22px; box-shadow:var(--shadow)}
    .price{font-size:2.2rem; font-weight:900; color:var(--gold)}
    .badge{display:inline-flex; align-items:center; gap:8px; font-size:.9rem; padding:6px 10px; border-radius:999px; border:1px dashed rgba(255,215,0,.4); color:var(--muted)}
    .stamp{
      display:inline-block; /* permite margin vertical em spans */
      color:#111;
      background:linear-gradient(180deg, var(--gold), var(--gold-2));
      border-radius:999px;
      padding:8px 12px;     /* levemente maior para destaque */
      font-weight:900;
      letter-spacing:.3px;
      margin:10px 0;        /* espaço acima e abaixo */
    }
    .mock {
      height: 600px; /* aumenta o espaço vertical */
      border-radius: 14px;
      background: radial-gradient(200px 140px at 30% 20%, rgba(255,215,0,.22), transparent 60%), #0f0f16;
      border: 1px solid rgba(255,215,0,.2);
      position: relative;
      overflow: hidden;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-top: auto;
      margin-bottom: auto;
    }
    .mock-img {
      width: 100%;
      height: 100%;
      object-fit: contain;
      border-radius: 12px;
      display: block;
      background: #0f0f16; /* opcional: cor de fundo para bordas */
    }
    .mock:after{
      /* remove texto sobre a prévia */
      display: none;
    }
    .grid{display:grid; gap:18px}
    .grid.cols-3{grid-template-columns:repeat(3, 1fr)}
    .section{padding:64px 0; border-top:1px solid rgba(255,255,255,.06)}
    h2{font-family:'Cinzel', serif; font-size:clamp(1.6rem, 3.2vw, 2.2rem); color:var(--gold); margin:0 0 18px}
    h3{font-family:'Cinzel', serif; font-size:1.15rem; margin:0 0 8px}
    .card{background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.02)); border:1px solid rgba(255,215,0,.12); border-radius:16px; padding:18px; box-shadow:var(--shadow)}
    ul.clean{list-style:none; padding:0; margin:0}
    ul.clean li{display:flex; gap:10px; padding:8px 0; color:var(--ink)}
    ul.clean li:before{content:'✦'; color:var(--gold); margin-top:1px}
    .faq details{background:#0f0f16; border:1px solid rgba(255,215,0,.12); border-radius:12px; padding:14px 16px}
    .faq details+details{margin-top:12px}
    .faq summary{cursor:pointer; font-weight:700; font-family:'Merriweather',serif}
    .kicker{color:var(--muted); letter-spacing:.08em; text-transform:uppercase; font-size:.8rem}
    .guarantee{display:flex; align-items:center; gap:12px; background:linear-gradient(180deg, rgba(24,194,156,.15), rgba(24,194,156,.08)); border:1px solid rgba(24,194,156,.35); border-radius:14px; padding:14px 16px}
    .testi{font-style:italic; color:var(--muted)}
    .footer{padding:36px 0; color:var(--muted); text-align:center; border-top:1px solid rgba(255,255,255,.06)}
    @media (max-width:900px){
      .hero-card{grid-template-columns:1fr;}
      .grid.cols-3{grid-template-columns:1fr}
    }
    /* ===== Memory Game (Jogo da Memória) — tamanho levemente maior ===== */
#memory-game{
  display:grid;
  grid-template-columns: repeat(4,1fr);
  gap:18px;
  max-width:860px;    /* ligeiro aumento para comportar cartas maiores */
  margin:22px auto;
}
.card-game{
  position:relative;
  aspect-ratio:3/4;
  border-radius:14px;
  perspective:1000px;
  cursor:pointer;
  height:250px;       /* aumento sutil (de 200px → 210px) */
}

/* Verso padrão das cartas */
.card-game .front{
  background-image: url("Cards/Verso.webp"); /* troque o arquivo aqui */
  background-size: cover;
  background-position: center;
  border-radius: 12px; /* igual ao seu card */
}

.card-game .inner{
  position:absolute;
  inset:0;
  transition:transform .5s;
  transform-style:preserve-3d;
  border:1px solid rgba(255,215,0,.18);
  border-radius:14px;
  box-shadow:0 9px 22px rgba(0,0,0,.42);
}
.card-game.flipped .inner{transform:rotateY(180deg)}
.face{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  backface-visibility:hidden; border-radius:14px; font-size:2rem;
}
.front{background:linear-gradient(180deg, rgba(255,215,0,.22), rgba(255,215,0,.08))}
.back{transform:rotateY(180deg); background:#0f0f16;}
.card-game img{width:100%; height:100%; object-fit:contain; border-radius:12px}

/* responsividade: cartas um pouco menores em telas pequenas */
@media (max-width:900px){
  #memory-game{ grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap:12px; max-width:640px; }
  .card-game{ height:170px; }
}
    /* Botões principais na hero-card */
.hero-card .btn,
.hero-card .btn.btn-primary {
  color: #fff;
}

/* Botão "Quero meu E‑book" */
.section .btn.btn-primary {
  color: #fff;
}

/* Rolagem suave para âncoras internas */
html {
  scroll-behavior: smooth;
}

/* Espaço extra ao posicionar alvos para não ficarem cobertos pelo header fixo */
.section {
  scroll-margin-top: 88px; /* ajuste esse valor para a altura real do seu header (ex.: 72px) */
}

/* destacar o link do jogo no cabeçalho */
.nav a[href="#jogo"]{
  color: var(--gold);
  font-weight:700;
  transition:color .18s;
}
.nav a[href="#jogo"]:hover{ opacity:.95 }
.nav a.is-active{
  color: var(--gold);
  font-weight:800;
  box-shadow: inset 0 -2px 0 rgba(255,215,0,.18); /* indicador sutil */
}

/* Amostras / pré‑visualizações - miniaturas um pouco menores */
#amostras .preview-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(10px,1fr)); /* menor min-width */
  gap:12px; /* espaço levemente reduzido */
  margin-top:16px;
  align-items:start;
}
.preview-thumb{
  background:transparent;
  border:1px solid rgba(255,255,255,.04);
  padding:4px;                /* padding reduzido para encolher visualmente */
  border-radius:8px;
  cursor:pointer;
  display:block;
  max-width:260px;           /* evita thumbs muito largas em telas grandes */
  margin-inline:auto;
}
.preview-thumb img{
  width:100%;
  height:180px;              /* altura fixa menor */
  object-fit:cover;
  display:block;
  border-radius:6px;
  box-shadow:var(--shadow);
  transition:transform .15s ease, box-shadow .15s;
}
/* hover mantém o efeito porém mais sutil */
.preview-thumb:hover img{ transform:translateY(-3px); box-shadow:0 14px 36px rgba(0,0,0,.45); }

/* Modal simples */
.preview-modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.72);
  z-index:2200;
  padding:20px;
}
.preview-modal.open{ display:flex; }
.preview-modal img{
  /* tamanho mais contido para evitar ocupar toda a tela */
  max-width:1000px;    /* largura máxima desejada (ajuste se precisar) */
  width:100%;         /* responsivo até o max-width */
  height:auto;        /* manter proporção */
  max-height:80vh;    /* não ultrapassar 80% da altura da viewport */
  border-radius:8px;
  box-shadow:0 30px 80px rgba(0,0,0,.6);
}
/* Close */
.preview-modal .close{
  position:absolute;
  top:18px;
  right:22px;
  background:transparent;
  border:0;
  color:var(--ink);
  font-size:1.6rem;
  cursor:pointer;
  padding:8px;
}
/* Navegação (setas) */
.preview-modal .nav{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  pointer-events:none; /* permite overlay clicável exceto nos botões */
}
.preview-modal .nav button{
  pointer-events:auto;
  background:rgba(11,11,16,.6);
  border:1px solid rgba(255,255,255,.06);
  color:var(--ink);
  width:44px;
  height:44px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:20px;
  transition:transform .12s ease, background .12s;
  backdrop-filter: blur(6px);
}
.preview-modal .nav button:hover{ transform:translateY(-2px); background:rgba(255,215,0,.08) }
.preview-modal .nav button:focus{ outline:2px solid rgba(139,184,255,.18); outline-offset:3px; }
/* evitar que imagem capture clique nos botões visuais */
.preview-modal .content{ position:relative; z-index:2; }
/* acessibilidade: botão visível ao foco */
.preview-thumb:focus{ outline:2px solid rgba(139,184,255,.18); outline-offset:3px; }
/* header: botão Comprar com mesmo visual do "Comprar agora" */
header .btn{
  background: linear-gradient(180deg, #d4a800 0%, #b88400 100%);
  color: #fff;
  border: 1px solid rgba(0,0,0,.12);
  box-shadow: 0 10px 30px rgba(0,0,0,.32), inset 0 -3px 8px rgba(255,255,255,.04);
  padding: 10px 16px;
  border-radius: 12px;
  transition: transform .14s ease, box-shadow .18s ease;
}
header .btn:hover{
  box-shadow: 0 22px 56px rgba(0,0,0,.36), 0 0 34px rgba(184,125,0,.06);
  transform: translateY(-4px);
}

/* centralizar botão Reiniciar novamente */
.actions{ text-align:center; }
#restart{
  display:inline-block;
  margin:20px auto;
  color:#fff; /* mantém texto em branco */
}

/* Opcional: leve vinheta para profundidade sem usar gradientes grandes */
html::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background: radial-gradient(60% 60% at 50% 40%, rgba(255,255,255,0.02), transparent 30%),
              radial-gradient(80% 50% at 50% 110%, rgba(0,0,0,0.25), transparent 40%);
  mix-blend-mode:overlay;
  z-index:1;
}

/* === Overrides de refino (reconstruído) === */

:root{
  --radius-lg: 14px;
  --radius-xl: 18px;
  --radius-2xl: 22px;
  --shadow-soft: 0 10px 30px rgba(0,0,0,.35);
  --shadow-hero: 0 30px 80px rgba(0,0,0,.55);
  --ring-amber: 0 0 0 2px rgba(255,215,0,.55), 0 0 0 6px rgba(255,215,0,.12);
}
body{
  background-image:
    radial-gradient(80% 65% at 50% -10%, rgba(255,215,0,.07), transparent 60%),
    radial-gradient(60% 40% at 20% 0%, rgba(139,184,255,.04), transparent 60%);
  background-size: cover;
  background-repeat: no-repeat;
  background-attachment: scroll;
  text-rendering: optimizeLegibility;
}
h1{ text-shadow: 0 1px 0 rgba(0,0,0,.65), 0 16px 40px rgba(255,215,0,.06); }
h2{ position:relative; display:inline-block; letter-spacing:.3px; }
h2::after{
  content:"";
  position:absolute; left:0; bottom:-10px;
  width:76px; height:3px;
  background: linear-gradient(90deg, var(--gold), transparent);
  border-radius:999px;
  box-shadow: 0 0 10px rgba(255,215,0,.35);
}
.section{ 
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.04));
  scroll-margin-top: 92px;
}
.card{
  border-radius: var(--radius-2xl);
  border:1px solid rgba(255,215,0,.14);
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  box-shadow: var(--shadow-soft);
}
.hero{ padding: 96px 0 54px; }
.hero:before{ filter: saturate(1.05); opacity:.95; }
.hero .lead{ color: color-mix(in oklab, var(--muted) 92%, white); }
.mock{ box-shadow: var(--shadow-hero); border-radius: var(--radius-xl); }
.mock-img{
  border-radius: var(--radius-lg);
  image-rendering: auto;
  content-visibility: auto;
  contain-intrinsic-size: 400px 260px;
}
.btn{ border-radius: 14px; }
.btn.btn-primary{ color:#111; }
header .btn{ color:#111; }
.btn--ghost{ background:transparent; color:var(--gold); border:1px solid rgba(255,215,0,.28); }
:where(a, button, .btn):focus-visible{ outline: none; box-shadow: var(--ring-amber); }
.nav a{ transition: color .15s ease, opacity .15s ease; }
.nav a:hover{ opacity: 1; color: var(--gold) }
ul.clean li:before{ content:'✧'; opacity:.9; }
.faq details{ transition: background .2s ease, border-color .2s ease }
@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; animation:none !important; scroll-behavior:auto !important }
}
.testi{ color: var(--muted); border-left: 3px solid rgba(255,215,0,.25); padding-left: 12px; }
a:focus-visible{ box-shadow: var(--ring-amber); border-radius: 10px }
img{ border-radius: 12px }
img[loading="lazy"]{ content-visibility: auto }
.preview-thumb:focus{ box-shadow: var(--ring-amber) }
.preview-modal{ backdrop-filter: blur(2px) }
.preview-modal .nav button{ border-color: rgba(255,215,0,.22); }
.preview-modal .nav button:hover{ background: rgba(255,215,0,.12); }
.face{ border: 1px solid rgba(255,215,0,.14) }
.front{ background: linear-gradient(180deg, rgba(255,215,0,.18), rgba(255,215,0,.06)) }
.back{ background: #0f0f16; }
.footer{ color: var(--muted); background: linear-gradient(180deg, rgba(255,255,255,.01), rgba(0,0,0,.05)); }


/* === Sobre o Autor — imagem ao lado do texto === */
#autor .grid.cols-2{
  display:grid;
  grid-template-columns: 320px 1fr; /* foto | texto */
  gap:24px;
  align-items:center;
}
@media (max-width: 799px){
  #autor .grid.cols-2{ grid-template-columns: 1fr; }
}
#autor img{
  width:100%;
  max-width:280px;
  height:auto;
  display:block;
}


/* === FAQ — transição suave de abertura/fechamento === */
.faq details{
  border:1px solid rgba(255,215,0,.25);
  border-radius: 14px;
  padding:.75rem 1rem;
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.05));
}
.faq summary{
  display:flex; align-items:center; gap:.6rem;
  cursor:pointer; user-select:none;
  font-weight:700; color:#e8e6e3;
}
.faq summary::-webkit-details-marker{display:none}
.faq .chev{ transition: transform .28s ease }
.faq details[open] .chev{ transform: rotate(180deg) }
/* o conteúdo é controlado via JS (altura animada) */
.faq .faq-content{
  height:0; overflow:hidden; will-change:height;
}
@media (prefers-reduced-motion: reduce){
  .faq .faq-content{ transition:none !important }
}

/* Selo diagonal no herói */
.epic-ribbon{
  position:absolute; top:12px; right:-48px;
  transform:rotate(45deg);
  background:linear-gradient(90deg,#3b2b12,#a37b2a,#3b2b12);
  color:#fff; padding:6px 64px; letter-spacing:.08em;
  font-weight:700; text-shadow:0 1px 2px rgba(0,0,0,.4);
  box-shadow:0 6px 18px rgba(0,0,0,.35);
  border:1px solid rgba(255,215,0,.35);
  z-index: 2;
}

/* Alternância de plano */
.plan-switch{display:flex; gap:8px; margin:8px 0 12px;}
.plan-btn{border:1px solid var(--line); background:#161514; color:#ddd; padding:8px 12px; border-radius:10px; cursor:pointer}
.plan-btn.is-active,.plan-btn:hover{border-color:#d4af37;color:#fff; box-shadow:0 0 0 2px rgba(212,175,55,.15) inset}

/* Mostrar/ocultar CTAs por plano */
.show-if-epica{display:none}
body.plan-epica .show-if-epica{display:inline-flex}
body.plan-epica .show-if-basica{display:none}

/* Seção épica */
.highlight-epic{background:radial-gradient(1200px 400px at 50% 0, rgba(212,175,55,.08), transparent 60%)}
.highlight-epic .gold{color:#d4af37}
.perk h3{color:#f5d37a}
.compare{margin:20px 0; border:1px solid var(--line); border-radius:14px; overflow:hidden}
.compare-header, .compare .row{display:grid; grid-template-columns:1.2fr .4fr .4fr; align-items:center}
.compare-header{background:#141312; color:#c9a646; font-weight:800; letter-spacing:.04em}
.compare .row:nth-child(even){background:rgba(255,255,255,.02)}
.compare .row > div{padding:12px 14px}
.compare .is-epic{color:#f2d17b; font-weight:700}
.center{text-align:center}
.btn.pulse{animation:pulse 2.2s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(212,175,55,.35)}50%{box-shadow:0 0 0 12px rgba(212,175,55,0)}}

.cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px; /* ou 16px para mais respiro */
  margin-top: 14px; /* dá um leve respiro acima */
}

/* ===== Ribbon Épica: sempre acima do header ===== */
:root{
  --z-header: 1000;   /* ajuste se seu header usar outro valor */
  --z-ribbon: 99999;  /* bem acima de qualquer coisa do site */
}

.epic-ribbon{
  position: fixed;            /* fixa na viewport, fora do fluxo da hero */
  top: 40px;
  right: -64px;               /* puxa para fora para girar sem cortar */
  transform: rotate(35deg);
  z-index: var(--z-ribbon);
  pointer-events: none;       /* não bloquear cliques do menu */
  display: none;              /* só mostra quando for épica */
}

body.plan-epica .epic-ribbon{ display: block; }

.epic-ribbon{
  font: 700 14px/1.1 "Cinzel", serif;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #111;
  padding: 10px 80px;
  background: linear-gradient(180deg,#ffd969,#e9b640);
  border: 1px solid #b78a2a;
  box-shadow: 0 6px 14px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.5);
}

/* mobile */
@media (max-width: 640px){
  .epic-ribbon{ top: 12px; right: -56px; }
  .epic-ribbon{ padding: 8px 60px; font-size: 12px; }
}

/* ===== Amostras do Deck ===== */
.amostras-cards{
  position: relative;
  padding: clamp(2.5rem, 4vw, 4rem) 0;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(255,217,105,.06), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.02));
  border-top: 1px solid rgba(255,217,105,.15);
  border-bottom: 1px solid rgba(255,217,105,.08);
}

.amostras-head{
  text-align: center;
  margin-bottom: 1.75rem;
}

.amostras-title{
  font-family: "Cinzel Decorative", serif;
  font-weight: 700;
  font-size: clamp(1.4rem, 2.2vw, 1.9rem);
  letter-spacing: .04em;
  color: #ffd969;
  text-shadow: 0 0 6px rgba(255,215,0,.35);
  margin: 0 0 .4rem;
}

.amostras-sub{
  font-family: "Merriweather", serif;
  color: #dcdcdc;
  opacity: .9;
  max-width: 780px;
  margin: 0 auto;
}

/* grid responsivo bonito */
.cards-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: clamp(1rem, 1.6vw, 1.4rem);
  align-items: start;
  margin-top: 1.25rem;
}

/* miniatura da carta */
.card-thumb{
  margin: 0;
  text-align: center;
}

.card-thumb img{
  display: block;
  width: 100%;
  height: auto;
  border-radius: 10px;
  box-shadow:
    0 10px 24px rgba(0,0,0,.55),
    0 0 0 1px rgba(183,138,42,.35) inset;
  transform: translateZ(0);
  transition: transform .28s ease, box-shadow .28s ease, filter .28s ease;
  will-change: transform;
}

/* legenda */
.card-thumb figcaption{
  margin-top: .55rem;
  font-family: "Merriweather", serif;
  font-size: .95rem;
  color: #eee;
  letter-spacing: .02em;
  opacity: .95;
}

/* hover com “brilho dourado” sutil, alinhado aos seus botões */
.card-thumb:hover img{
  transform: translateY(-6px) scale(1.03);
  box-shadow:
    0 16px 36px rgba(0,0,0,.6),
    0 0 0 1px rgba(255,217,105,.6) inset,
    0 0 22px rgba(255,217,105,.25);
  filter: saturate(1.06);
}

/* mobile: dá respiro da hero */
@media (max-width: 640px){
  .amostras-cards{ padding: 2rem 0 2.4rem; }
  .amostras-sub{ padding: 0 1rem; }
}

/* acessibilidade: respeitar prefers-reduced-motion */
@media (prefers-reduced-motion: reduce){
  .card-thumb img{ transition: none; }
}

/* Cria respiro após a hero, antes das amostras */
.hero {
  position: relative;
  z-index: 10; /* garante que a faixa da versão épica fique certa */
  margin-bottom: 4rem; /* afasta da próxima seção */
}

/* Garante que a seção de amostras venha abaixo do header */
.amostras-cards {
  position: relative;
  z-index: 1;  /* abaixo da ribbon e do header */
  padding-top: 3rem; /* respiro extra no topo */
}
/* ===== Correção do espaçamento no topo ===== */

/* 1) Zera o margin padrão do body (às vezes volta em refactors) */
html, body { margin: 0; }

/* 2) Garante que o header encoste no topo da janela */
header{
  position: fixed; /* ou fixed, se você usa assim */
  top: 0;
  margin-top: 0 !important;
}

/* 3) Evita que wrappers adicionem padding-top global */
main, .site, .site-wrap, .page, .container.nav {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* ===== Tokens do gradiente arcano (mesmo da seção Amostras) ===== */
:root{
  --arcana-grad:
    radial-gradient(120% 80% at 50% 0%, rgba(255,217,105,.06), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.02));
  --arcana-btop: rgba(255,217,105,.15);
  --arcana-bbot: rgba(255,217,105,.08);
}

/* Refatora Amostras para usar os tokens (nada muda visualmente) */
.amostras-cards{
  background: var(--arcana-grad);
  border-top: 1px solid var(--arcana-btop);
  border-bottom: 1px solid var(--arcana-bbot);
}

/* ===== Aplicar o mesmo gradiente na PRIMEIRA SEÇÃO (hero) ===== */
/* Opção segura: overlay via ::before (não altera a imagem/fundo que você já tem) */
.hero{
  position: relative; /* ancora o ::before */
}
.hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background: var(--arcana-grad);
  opacity: .55;          /* ajuste: 0.35–0.7 conforme preferir */
  pointer-events: none;  /* não bloqueia cliques */
  z-index: 0;            /* fica atrás do conteúdo */
}
/* garante que o conteúdo da hero fique acima do overlay */
.hero > *{ position: relative; z-index: 1; }

/* ===== Aplicar o mesmo gradiente na seção "Porque a versão épica" ===== */
/* Use o(s) seletor(es) que existir(em) no seu HTML */
#porque-epica,
#porque,
.porque-epica{
  background: var(--arcana-grad);
  border-top: 1px solid var(--arcana-btop);
  border-bottom: 1px solid var(--arcana-bbot);
}

/* Se essa seção também tem imagem de fundo e você prefere overlay como na hero: */
#porque-epica.overlay::before,
#porque.overlay::before,
.porque-epica.overlay::before{
  content: "";
  position: absolute;
  inset: 0;
  background: var(--arcana-grad);
  opacity: .55;
  pointer-events: none;
}
#porque-epica.overlay,
#porque.overlay,
.porque-epica.overlay{ position: relative; }

/* ===== Capa do e-book — mesmo efeito das cartas ===== */
.mock-img{
  display: block;
  width: clamp(360px, 22vw, 320px);
  height: auto;
  border-radius: 10px;
  box-shadow:
    0 10px 24px rgba(0,0,0,.55),
    0 0 0 1px rgba(183,138,42,.35) inset;
  transition: transform .28s ease, box-shadow .28s ease, filter .28s ease;
}

/* Hover: mesmo brilho e ressalto das amostras */
.mock-img:hover{
  transform: translateY(-6px) scale(1.03);
  box-shadow:
    0 16px 36px rgba(0,0,0,.6),
    0 0 0 1px rgba(255,217,105,.6) inset,
    0 0 22px rgba(255,217,105,.25);
  filter: saturate(1.06);
}
