/* =========================================================
   BASE & TOKENS
   ========================================================= */
html, body {
  overflow-x: hidden !important;
  width: 100% !important;
  font-family: 'Poppins', sans-serif;
}

:root {
  /* layout geral e cartões */
  --adf-card-h: 560px;
  --adf-card-pad-bot: 36px;
  --adf-gap-img-title: 18px;
  --adf-gap-title-desc: 10px;
  --adf-gap-desc-cta: 12px;

  /* gutters/carrossel */
  --adf-gutter: 40px;
}

/* Tarja EXCLUSIVO (topo) */
.tarja-assinante{
  position:absolute; top:0; left:0; right:0;
  height:32px; background:#f6eec2; color:#000;
  font: 600 13px/32px 'Crimson Text', serif;
  display:flex; align-items:center; justify-content:center;
  z-index:10; pointer-events:none;
}
.tarja-assinante.tarja-anual .tarja-highlight{ color:#cba731; font-weight:700; }

/* =========================================================
   TÍTULO DE CATEGORIA + CTAs
   ========================================================= */
.adf-categoria-titulo{
  display:flex; align-items:center; gap:20px;
  margin:40px 40px 10px 10px;
  font: 700 2rem 'Crimson Text', serif;
  text-transform:uppercase; color:#572c22;
}
.adf-categoria-titulo:first-of-type{ margin-top:80px; }

.adf-categoria-nome{
  border-left:4px solid #cba731; padding-left:12px;
}

.btn-assinar-agora, .btn-assinar-liberados{
  font-size:14px; padding:10px 22px; border-radius:40px;
  text-decoration:none; font-weight:700; text-transform:uppercase; letter-spacing:.5px;
  border:0; cursor:pointer; background:#572c22; color:#fff;
  box-shadow:0 4px 10px rgba(0,0,0,.25); transition:.3s ease;
  display:inline-block;
}
.btn-assinar-agora:hover, .btn-assinar-liberados:hover{
  background:#3d1e16; color:#fff6dd; transform:scale(1.05);
}
.btn-assinar-liberados{ margin-top:12px !important; padding-right:38px; }

.adf-categoria-linha{
  flex:1; height:2px; background:#cba731; position:relative;
  display:flex; align-items:center; justify-content:flex-end;
}
.adf-categoria-linha::after{
  content:''; width:24px; height:24px;
  background:url('../images/seta.png') center/contain no-repeat;
}

/* =========================================================
   ESTADO DE CARREGAMENTO & ALERTAS
   ========================================================= */
#adf-results.loading{ visibility:hidden; opacity:0; height:1px; overflow:hidden; }
#adf-results.loaded{ visibility:visible; opacity:1; height:auto; transition:opacity .3s ease; }

.adf-alert{
  background:#fff8e1; color:#9e6f00; border:1px solid #ffe082;
  padding:16px; margin:20px auto; text-align:center; border-radius:6px;
  font-weight:700; max-width:600px;
}

/* Container geral */
.adf-library-container{
  max-width:1400px; margin:40px auto; padding:30px 60px !important;
  background:#fcf9f4; border-radius:20px; box-shadow:0 0 20px rgba(0,0,0,.07);
}

/* =========================================================
   ABA SUPERIOR (FULL WIDTH) + TABS + FILTROS
   ========================================================= */
.adf-fullwidth-tabs{
  position:relative; width:100vw; left:50%; right:50%;
  margin-left:-50vw; margin-right:-50vw;
  background:#653d2e; padding:30px 0; box-sizing:border-box; z-index:1;
}

.adf-tabs{
  display:flex; justify-content:center; align-items:center; flex-wrap:wrap; gap:40px;
  max-width:1200px; margin:0 auto;
}
.adf-tabs button{
  background:none; border:0; color:#fff;
  font: 700 14px 'Poppins', serif; text-align:center; cursor:pointer;
  display:flex; flex-direction:column; align-items:center; gap:6px;
  transition:transform .2s ease; min-width:100px;
}
.adf-tabs button:hover{ background:rgba(255,240,200,.1); color:#fff; transform:scale(1.05); }
.adf-tabs button.active{ color:#fbeac6; }
.adf-tab-icon img{ max-width:48px; max-height:48px; width:auto; height:auto; object-fit:contain; display:block; }

/* Filtros */
#adf-search-wrapper{ margin-top:30px; }
.adf-filters{
  display:flex; justify-content:center; gap:24px; margin-bottom:30px; flex-wrap:wrap;
}
.adf-filters input{ border-radius:12px !important; }
.adf-filters select{
  padding:12px 20px; border-radius:12px; border:1px solid #ddd; min-width:220px; font-size:15px;
}

/* =========================================================
   CARDS (LISTA PADRÃO)
   ========================================================= */
.adf-card, .adf-card--assinatura, .adf-plan-card{
  background:#fff; border-radius:4px; width:220px;
  padding:16px 12px; margin:24px 12px; text-align:center;
  box-shadow:8px 8px 10px rgba(0,0,0,.25), 8px 8px 10px rgba(0,0,0,.15);
  font-family:'Crimson Text', serif; position:relative; overflow:hidden;
  transition:transform .3s ease; display:flex; flex-direction:column;
  height:var(--adf-card-h); padding-bottom:var(--adf-card-pad-bot) !important;
}
.adf-card:hover{ transform:translateY(-8px); }

/* Thumb */
.adf-thumb{ display:flex; justify-content:center; align-items:center; padding:50px 18px 14px !important; position:relative; }
.adf-thumb img{ width:auto; max-width:200px; max-height:240px; object-fit:cover; background:#fff; }

/* Favorito (ícone por máscara, com estados) */
.adf-thumb .adf-fav-btn{
  --fav-normal:#F3EABB; --fav-hover:#E6D87F; --fav-active:#C0392B; --fav-active-hover:#D44A3D;
  position:absolute; top:10px; right:10px; width:32px; height:32px;
  display:inline-flex; align-items:center; justify-content:center; padding:0; border:0;
  background:transparent !important; box-shadow:none !important; cursor:pointer; z-index:40;
  color:var(--fav-normal); transition: color .15s ease, transform .15s ease, filter .2s ease;
}
.adf-thumb .adf-fav-btn img{ display:none; }
.adf-thumb .adf-fav-btn::before{
  content:""; width:24px; height:24px; display:block; background:currentColor;
  -webkit-mask:url('/wp-content/plugins/arquivo-da-fe/assets/images/favoritos.png') no-repeat center / contain;
          mask:url('/wp-content/plugins/arquivo-da-fe/assets/images/favoritos.png') no-repeat center / contain;
}
.adf-thumb .adf-fav-btn.active{ color:var(--fav-active); }
.adf-thumb .adf-fav-btn:not(.active):not(.adf-fav-disabled):hover{ color:var(--fav-hover); transform:translateY(-1px); filter:drop-shadow(0 1px 2px rgba(0,0,0,.18)); }
.adf-thumb .adf-fav-btn.active:not(.adf-fav-disabled):hover{ color:var(--fav-active-hover); transform:translateY(-1px); filter:drop-shadow(0 1px 2px rgba(192,57,43,.35)); }
.adf-thumb .adf-fav-btn.adf-fav-disabled{ opacity:.6; pointer-events:none; cursor:not-allowed; }
.adf-thumb .adf-fav-btn:focus-visible{ outline:2px solid currentColor; outline-offset:2px; }

/* Conteúdo do card */
.adf-card-content{ display:flex; flex-direction:column; flex:1 1 auto; height:auto !important; padding:14px 8px 0; font-family:'Crimson Text', serif; }

.adf-card-content h4{
  font:700 19px/1.4 'Crimson Text', serif; color:#5a4434;
  margin:0; padding:20px 0 0; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
  overflow:hidden; min-height:calc(1em * 1.4 * 2);
}

.adf-excerpt{
  font-size:17px; color:#5a4434; line-height:1.5; margin:0; padding:0 8px;
  flex:1 1 auto; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
  min-height:calc(1em * 1.5 * 3);
}

.adf-card-content .cat{
  font-size:13px; font-weight:700; color:#814e1c; margin:10px 0 5px; letter-spacing:.5px; text-transform:uppercase;
}

/* Ações */
.adf-actions{ margin-top:auto; padding-top:16px !important; }
.adf-actions a{ min-width:160px; text-align:center; margin-bottom:0; }

/* Botões padrão de card */
.btn-acessar{
  background:#cba731; color:#fff; font-weight:700; text-transform:uppercase;
  padding:10px 24px; font-size:15px; border:0; border-radius:4px;
  box-shadow:0 2px 6px rgba(0,0,0,.15); display:inline-block; text-align:center; transition:background .3s ease;
}
.btn-acessar:hover{ background:#b8941e; color:#1a1a1a; }

.btn-saiba-mais{
  background:transparent; color:#572c22; padding:11.5px 23px; min-width:160px;
  border:2px solid #572c22; border-radius:4px; font:700 15px 'Crimson Text', serif;
  text-transform:uppercase; text-align:center; display:inline-block;
  transition:background .3s, color .3s; box-shadow:0 2px 6px rgba(0,0,0,.1); line-height:1.2;
}
.btn-saiba-mais:hover{ background:#572c22; color:#fff1e5; }

/* =========================================================
   CARROSSEL / SLICK
   ========================================================= */
.adf-categoria-bloco{ max-width:1300px; margin:0 auto 40px; padding:0 40px; }
.adf-carousel-wrapper{ position:relative; overflow:hidden; }
.adf-carousel-wrapper::after{
  content:""; position:absolute; top:0; right:0; width:200px; height:100%;
  background:linear-gradient(to left, #fcf9f4 0%, rgba(252,249,244,0) 20%); z-index:10; pointer-events:none;
}
.slick-slide{ padding:0; box-sizing:border-box; overflow:visible; }
.slick-dots{
  display:flex !important; justify-content:center; align-items:center; gap:10px; margin-top:30px;
  padding:0; list-style:none;
}
.slick-dots li{ display:inline-block; margin:0; }
.slick-dots li button{
  border:0; background:#f0dfb2; width:12px; height:12px; border-radius:50%;
  padding:0; cursor:pointer; font-size:0; transition:background .3s;
}
.slick-dots li.slick-active button{ background:#9c7422; }
.slick-track{ margin-left:0 !important; }

/* mesma altura dentro do slick */
.slick-slide .adf-card,
.slick-slide .adf-card--assinatura,
.slick-slide .adf-plan-card{ height:var(--adf-card-h); }

/* Setas posicionadas no “gutter” */
.adf-carousel-wrapper .adf-slick-arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  background:transparent; border:0; font-size:34px; line-height:1; color:#653d2e;
  padding:6px 10px; z-index:20; cursor:pointer;
}
.adf-carousel-wrapper .slick-prev{ left: calc(-1 * var(--adf-gutter) + 8px); }
.adf-carousel-wrapper .slick-next{ right:calc(-1 * var(--adf-gutter) + 8px); }
.adf-carousel-wrapper .adf-slick-arrow:hover, .adf-carousel-wrapper .adf-slick-arrow:focus{ color:#9c7422; outline:0; }
.adf-carousel-wrapper .adf-slick-arrow.slick-disabled{ opacity:.35; cursor:default; }

@media (max-width:1280px){ :root{ --adf-gutter:28px; } }

/* Overlay de navegação (quando usado) */
.adf-slick-nav{ position:absolute; inset:0; pointer-events:none; z-index:30; }
.adf-slick-nav .adf-slick-arrow{
  pointer-events:auto; position:absolute; top:50%; transform:translateY(-50%);
  background:transparent; border:0; font-size:34px; line-height:1; color:#653d2e; padding:8px 12px;
}
.adf-slick-nav .slick-prev{ left:8px; } .adf-slick-nav .slick-next{ right:8px; }
.adf-slick-nav .adf-slick-arrow:hover{ color:#9c7422; }
.adf-slick-nav .adf-slick-arrow.slick-disabled{ opacity:.35; cursor:default; }

/* Loader */
.adf-loader{
  border:2px solid #f3f3f3; border-top:2px solid #D4A74F; border-radius:50%;
  width:20px; height:20px; animation:adf-spin .8s linear infinite; margin:auto;
}
@keyframes adf-spin{ to{ transform:rotate(360deg); } }

/* =========================================================
   RIBBON "EM BREVE" (única)
   ========================================================= */
.adf-card .adf-ribbon-soon,
.adf-card--cover .adf-ribbon-soon{
  position:absolute; top:20px; left:-45px; transform:rotate(-35deg);
  z-index:60; pointer-events:none;
  height:22px; line-height:22px; padding:0 56px; min-width:150px; white-space:nowrap;
  background:linear-gradient(to bottom, #e9c97c, #caa85e);
  color:#2c0d08; font-weight:800; font-size:11px; letter-spacing:.04em; text-transform:uppercase; text-align:center;
  border-radius:6px; border:1px solid rgba(44,13,8,.15); box-shadow:0 6px 16px rgba(0,0,0,.16);
}
.adf-card .adf-ribbon-soon::before,
.adf-card .adf-ribbon-soon::after{ content:none !important; }
.btn-em-breve{ background:#cfcfcf; color:#555; cursor:default; opacity:.9; padding:10px 18px; border-radius:6px; border:0; font-weight:700; }

/* =========================================================
   CARD FULL-COVER + OVERLAY (consolidado)
   ========================================================= */
.adf-card--cover{
  position:relative; border:1px solid var(--line, #e6e8ef);
  border-radius:16px; overflow:hidden; padding:0 !important;
  background:#fff !important; aspect-ratio:3 / 4.8;
  /* sombra só direita/baixo (profundidade elegante) */
  box-shadow: 8px 4px 24px rgba(0,0,0,.25), inset 0 0 12px rgba(255,255,255,.2);
}
.adf-card--cover .adf-cover{ position:relative; width:100%; height:100%; }
.adf-card--cover .adf-cover__img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transform:scale(1);
  transition: transform .5s ease, filter .5s ease; z-index:1;
}
.adf-card--cover:hover .adf-cover__img,
.adf-card--cover:focus-within .adf-cover__img{
  filter:brightness(.65); transform:scale(1.05);
}

/* Favorito (aparece no hover) */
.adf-card--cover .adf-fav-btn{
  position:absolute; top:10px; right:10px; z-index:40; background:none !important; border:0; box-shadow:none;
  width:32px; height:32px; padding:0; display:inline-flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .25s ease, visibility .25s ease, transform .2s ease;
}
.adf-card--cover:hover .adf-fav-btn,
.adf-card--cover:focus-within .adf-fav-btn{ opacity:1; visibility:visible; transform:translateY(0); }
.adf-card--cover .adf-fav-btn img{ width:24px; height:24px; filter:none; }

/* Tarja assinante acima de tudo */
.adf-card--cover .tarja-assinante{ left:0; top:12px; z-index:60 !important; }

/* Overlay do rodapé */
.adf-card--cover .adf-overlay{
  position:absolute; left:0; right:0; bottom:0; transform:translateY(100%);
  background:#000; color:#fff; padding:18px 18px 20px;
  border-bottom-left-radius:16px; border-bottom-right-radius:16px;
  transition:transform .45s ease-in-out; z-index:20;
}
.adf-card--cover:hover .adf-overlay,
.adf-card--cover:focus-within .adf-overlay{ transform:translateY(0); }

.adf-card--cover .adf-overlay__content{ display:grid; gap:10px; }
.adf-card--cover .adf-overlay__title{
  margin:0 0 6px; color:#fff; font-weight:700; font-size:19px; line-height:1.3;
  text-shadow:0 2px 10px rgba(0,0,0,.4);
}
.adf-card--cover .adf-overlay__excerpt{
  margin:0; color:#eee; font-size:14px; line-height:1.45;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}
.adf-card--cover .adf-overlay__actions{ display:flex; justify-content:center; margin-top:10px; }

.adf-card--cover .btn{
  appearance:none; border:1px solid rgba(255,255,255,.35);
  background:#111; color:#fff; font-size:13px; line-height:1;
  font-weight:600; padding:10px 14px; border-radius:12px; text-decoration:none; cursor:pointer;
  transition: background .2s ease, transform .2s ease, border-color .2s ease;
}
.adf-card--cover .btn:hover{ background:#1b1b1b; border-color:#555; transform:translateY(-1px); }
.adf-card--cover .btn:disabled{ opacity:.75; cursor:not-allowed; }
.adf-card--cover .btn-acessar{ background:rgba(16,185,129,.85); border-color:transparent; }
.adf-card--cover .btn-acessar:hover{ background:rgba(16,185,129,1); }
.adf-card--cover .btn-assinar{ background:rgba(108,99,255,.9); border-color:transparent; }
.adf-card--cover .btn-assinar:hover{ background:rgba(88,75,255,1); }
.adf-card--cover .btn-em-breve{ background:rgba(0,0,0,.35); }

/* Esconde áreas antigas do card dentro do modo cover */
.adf-card--cover > .adf-card-content,
.adf-card--cover .adf-card-content,
.slick-slide .adf-card--cover .adf-card-content{ display:none !important; height:0 !important; margin:0 !important; padding:0 !important; border:0 !important; background:transparent !important; }

/* =========================================================
   MOBILE
   ========================================================= */
@media (max-width:768px){
  :root{
    --adf-card-h: 480px;
    --adf-card-pad-bot: 8px;
    --adf-gap-img-title: 14px;
    --adf-gap-title-desc: 8px;
    --adf-gap-desc-cta: 12px;
  }

  body{ font-size:15px; }

  .adf-categoria-titulo{
    flex-direction:row !important; align-items:center !important; justify-content:flex-start !important;
    margin:60px 16px 10px !important; gap:16px !important; font-size:26px !important;
    flex-wrap:wrap; column-gap:20px; row-gap:4px;
  }
  .adf-categoria-nome{
    flex:0 1 auto; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  }
  .adf-categoria-titulo .btn-assinar-agora{ flex:0 0 auto; margin-top:-4px !important; margin-left:calc(12px + 4px); }
  .btn-assinar-agora{ margin-top:4px !important; font-size:11px; padding:8px 10px; border-radius:24px; letter-spacing:.3px; text-align:center; }
  .btn-assinar-liberados{ font-size:14px; margin-top:12px !important; padding:8px 28px 8px 12px; }

  .adf-categoria-linha{
    flex:1 1 150px; min-width:150px; height:2px; background:#cba731; display:flex; align-items:center; justify-content:flex-end; margin-left:10px !important;
  }
  .adf-categoria-linha::after{
    content:''; width:24px; height:24px; background:url('../images/seta.png') center/contain no-repeat;
  }

  .adf-library-container{ padding:20px 16px !important; border-radius:12px; margin:20px 10px; }

  .adf-fullwidth-tabs{
    width:100vw; left:50%; right:50%; margin-left:-50vw; margin-right:-50vw;
    background:#653d2e; padding:16px 8px; box-sizing:border-box; z-index:1;
  }
  .adf-tabs{
    display:flex !important; flex-wrap:nowrap !important; justify-content:space-between !important;
    gap:4px !important; padding:0 !important; margin:0 auto;
  }
  .adf-tabs button{
    flex:1 1 auto !important; min-width:0 !important; padding:6px 2px !important;
    font-size:clamp(10px, 2.5vw, 12px) !important; white-space:nowrap !important; overflow:hidden !important; text-overflow:ellipsis !important;
    display:flex !important; flex-direction:column !important; align-items:center !important; gap:4px !important;
  }
  .adf-tab-icon img{ max-width:20px !important; max-height:20px !important; height:auto !important; }
  .adf-tabs button.active{ font-weight:700 !important; border-bottom:2px solid #cba731 !important; }

  .adf-filters{ flex-direction:column; gap:12px; margin:0 10px 20px; }
  .adf-filters input, .adf-filters select{ width:100%; font-size:14px; padding:10px 14px; }

  .adf-card{ position:relative; overflow:hidden; flex:0 0 80%; max-width:260px; scroll-snap-align:start; }
  .adf-thumb img{ max-width:200px; max-height:240px; }
  .adf-card-content{ padding:10px 4px; }
  .adf-card-content h4{ font-size:16px; }
  .adf-excerpt{ font-size:15px; padding:0 6px; }

  .adf-actions a{ font-size:13px; padding:8px 16px; min-width:100%; }
  .adf-actions .btn-saiba-mais, .adf-actions .btn-acessar{
    font-size:13px !important; padding:8px 14px !important; line-height:1.2 !important; min-width:auto !important; width:auto !important; display:inline-block !important;
  }

  .adf-carousel-wrapper::after{ width:80px; }

  .adf-modal .adf-modal-content{ margin:40px auto; border-radius:16px; }
  #adf-modal h2{ font-size:22px; }
  #modal-price .preco-por{ font-size:24px; }

  /* Modal em colunas empilhadas */
  .adf-modal-body.estilo-claro{ flex-direction:column; }
  .modal-coluna-esquerda, .modal-coluna-direita{ width:100%; padding-top:10px !important; }
  .modal-coluna-esquerda{ padding:10px 20px 0 !important; }
  #modal-category{ margin-top:0 !important; }

  .adf-close{ top:12px !important; right:16px !important; z-index:10000; }

  /* Scroll horizontal suave quando sem slick */
  .slick-container{
    display:flex; flex-wrap:nowrap; overflow-x:auto; scroll-snap-type:x mandatory; gap:16px;
    padding-left:24px; padding-right:16px; scroll-padding-left:24px;
  }
  .slick-container .adf-card{ flex:0 0 85%; max-width:85%; scroll-snap-align:start; }
  .slick-container::-webkit-scrollbar{ height:8px; }
  .slick-container::-webkit-scrollbar-thumb{ background:#cba731; border-radius:8px; }
  .slick-container::-webkit-scrollbar-track{ background:transparent; }

  .adf-categoria-titulo.sem-linha .adf-categoria-linha{ display:none !important; }

  .adf-ribbon-soon{ font-size:clamp(12px, 2.6vw, 14px); }
  .tarja-assinante{
    height:auto; line-height:1.1; white-space:normal; padding:6px 8px;
  }
  .tarja-assinante.tarja-anual{ font-size:11px; letter-spacing:.2px; }
}

/* Redução de movimento (acessibilidade) */
@media (prefers-reduced-motion: reduce){
  .adf-thumb .adf-fav-btn,
  .adf-card--cover .adf-cover__img,
  .adf-card--cover .adf-overlay,
  .adf-card--cover .adf-fav-btn{ transition:none !important; }
}

.adf-card--cover .adf-overlay{
  background: linear-gradient(to top, rgba(120,90,40,0.95), rgba(80,60,30,0.9));
}

.adf-card--cover .btn {
  background: #E8D39F;      /* dourado claro */
  color: #2C0D08;           /* marrom institucional */
  border: 1px solid #C4A968;
  font-weight: 700;
  transition: all .3s ease;
}
.adf-card--cover .btn:hover {
  background: #D9BF7B;      /* dourado médio */
  color: #1a0a05;
  transform: translateY(-2px);
}

.adf-card--cover .btn,
.adf-actions a {
  text-transform: uppercase !important;
  letter-spacing: 0.6px;
  font-weight: 700;
}

@media (max-width: 768px) {
  /* Diminui altura e largura mantendo proporção */
  .adf-card--cover {
    max-width: 240px;     /* largura menor */
    box-shadow: 6px 3px 18px rgba(0,0,0,0.18); /* suaviza a sombra */
  }

  /* Mantém a imagem ajustada corretamente */
  .adf-card--cover .adf-cover__img {
    object-fit: contain;
    width: 100%;
    height: 100%;
  }

  /* Reduz um pouco o overlay e os textos */
  .adf-card--cover .adf-overlay {
    padding: 14px 14px 16px;
  }

  .adf-card--cover .adf-overlay__title {
    font-size: 16px;
  }

  .adf-card--cover .adf-overlay__excerpt {
    font-size: 13px;
    line-height: 1.4;
  }

  .adf-card--cover .btn {
    padding: 8px 14px;
    font-size: 12px;
    border-radius: 8px;
  }
}

/* Ícone padrão (dourado) */
.adf-thumb .adf-fav-btn::before {
  background-color: #f3eabb !important; /* dourado claro */
}

/* Hover normal (dourado mais forte) */
.adf-thumb .adf-fav-btn:hover::before {
  background-color: #e6d87f !important;
}

/* === ÍCONE FAVORITADO (vermelho) === */
.adf-thumb .adf-fav-btn.active::before {
  background-color: #C0392B !important; /* vermelho escuro */
  transition: background-color 0.25s ease;
}

/* Hover no favorito ativo (vermelho mais vivo) */
.adf-thumb .adf-fav-btn.active:hover::before {
  background-color: #E74C3C !important;
}

/* ===== FAVORITO — padroniza para usar máscara e permitir trocar a cor ===== */

/* 1) Base: sem fundo, sem borda, cor dourada no estado normal */
.adf-card--cover .adf-fav-btn,
.adf-thumb .adf-fav-btn{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: #f3eabb; /* dourado padrão */
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0;
  position: absolute; top: 10px; right: 10px;
  z-index: 60;
}

/* 2) Garante que qualquer <img> interno NÃO apareça (vamos desenhar via ::before) */
.adf-card--cover .adf-fav-btn img,
.adf-thumb .adf-fav-btn img{
  display: none !important;
}

/* 3) Desenha o ícone usando a imagem como MÁSCARA — a cor vem de currentColor */
.adf-card--cover .adf-fav-btn::before,
.adf-thumb .adf-fav-btn::before{
  content: "";
  width: 24px; height: 24px; display: block;
  background-color: currentColor !important;
  -webkit-mask: url('/wp-content/plugins/arquivo-da-fe/assets/images/favoritos.png') no-repeat center / contain;
          mask: url('/wp-content/plugins/arquivo-da-fe/assets/images/favoritos.png') no-repeat center / contain;
}

/* 4) Hover no estado normal (ainda dourado) */
.adf-card--cover .adf-fav-btn:hover,
.adf-thumb .adf-fav-btn:hover{
  color: #e6d87f;
}

/* 5) ===== ESTADO ATIVO (VERMELHO, SEM FUNDO) =====
      cobre: .active, aria-pressed="true", e contêiner com classe .favorited */
.adf-card--cover .adf-fav-btn.active::before,
.adf-thumb .adf-fav-btn.active::before,
.adf-card--cover .adf-fav-btn[aria-pressed="true"]::before,
.adf-thumb .adf-fav-btn[aria-pressed="true"]::before,
.favorited > .adf-fav-btn::before,
.favorited .adf-fav-btn::before{
  background-color: #C0392B !important; /* vermelho ativo */
}

/* Hover do ativo: vermelho um pouco mais vivo */
.adf-card--cover .adf-fav-btn.active:hover::before,
.adf-thumb .adf-fav-btn.active:hover::before,
.adf-card--cover .adf-fav-btn[aria-pressed="true"]:hover::before,
.adf-thumb .adf-fav-btn[aria-pressed="true"]:hover::before,
.favorited > .adf-fav-btn:hover::before,
.favorited .adf-fav-btn:hover::before{
  background-color: #E74C3C !important;
}

/* === Tabs no DESKTOP iguais ao MOBILE (sem fundo azul) === */
@media (min-width: 769px) {
  /* reset geral de hover/active vindos do tema */
  .adf-tabs button,
  .adf-tabs .active,
  .adf-tabs .is-active,
  .adf-tabs .current {
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
  }

  /* estado normal: sem sublinhado */
  .adf-tabs button { 
    border-bottom: 2px solid transparent;
  }

  /* estado ativo: igual ao mobile */
  .adf-tabs button.active {
    color: #fbeac6 !important;                  /* mesmo tom do mobile */
    border-bottom: 2px solid #cba731 !important;/* sublinhado dourado */
    background: transparent !important;
  }

  /* opcional: hover discreto, sem “pintar” o fundo */
  .adf-tabs button:hover,
  .adf-tabs button:focus {
    background: transparent !important;
    filter: brightness(1.05);
  }
}

/* 1) Define a razão via variável */
:root{ --adf-cover-ratio: 3 / 4.8; }   /* padrão (mobile e geral) */
.adf-card--cover{ aspect-ratio: var(--adf-cover-ratio); }

/* 2) No desktop, usa uma razão mais baixa */
@media (min-width: 769px){
  :root{ --adf-cover-ratio: 3 / 4.2; } /* ajuste fino aqui */
}

/* força exibir overlay quando o card tiver a classe .is-revealed */
.adf-card--cover.is-revealed .adf-overlay{
  transform: translateY(0);
}

/* 1) Padrão geral (fallback) */
:root { --adf-cover-ratio: 3 / 4.8; }

/* 2) Desktop: um pouco mais baixo (já tinha) */
@media (min-width: 769px){
  :root { --adf-cover-ratio: 3 / 4.2; }
}

/* 3) Mobile: MAIS baixo que o padrão */
@media (max-width: 768px){
  :root { --adf-cover-ratio: 3 / 4.1; } /* ajuste fino: 3/4.3, 3/4.0, etc. */
}

/* Aplicação única do ratio */
.adf-card--cover { aspect-ratio: var(--adf-cover-ratio); }

@media (max-width: 360px){
  .adf-card--cover { max-height: 340px; }
}

/* === Ajuste de altura no MOBILE === */
@media (max-width: 768px){

  /* 🔥 REMOVE a proporção fixa */
  .adf-card--cover{
    aspect-ratio: auto !important;
    height: auto !important;
    max-height: none;
    display: block;
  }

  /* container da imagem */
  .adf-card--cover .adf-cover{
    position: relative;
    width: 100%;
    height: auto;
  }

  /* imagem define o tamanho */
  .adf-card--cover .adf-cover__img{
    position: relative;   /* 🔥 MUITO IMPORTANTE (remove absolute) */
    width: 100%;
    height: auto;
    object-fit: contain;
    display: block;
  }
}
@media (max-width: 768px){
  .adf-categoria-nome{
    white-space: normal;          /* permite quebrar linha */
    overflow: visible;            /* remove corte */
    text-overflow: unset;

    display: -webkit-box;         /* limita linhas */
    -webkit-line-clamp: 2;        /* 🔥 até 2 linhas */
    -webkit-box-orient: vertical;

    line-height: 1.2;
    max-height: calc(1.2em * 2);  /* garante altura de 2 linhas */
  }
}
/* =========================================================
   MODAL (ADAPTADO PARA adf-libmodal)
   ========================================================= */
.adf-libmodal{
  display:none;
  position:fixed;
  inset:0;
  z-index:99999;
  overflow:auto;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(4px);
}
.adf-libmodal .adf-libmodal-content{
  background:#fefaf2;
  margin:50px auto;
  padding:0;
  border-radius:12px;
  width:90%;
  max-width:880px;
  box-shadow:0 20px 60px rgba(0,0,0,.25);
  position:relative;
  font-family:'Crimson Text', serif;
  opacity:0;
  transform:translateY(-20px);
  transition:.3s ease;
}
.adf-libmodal.open .adf-libmodal-content{
  opacity:1;
  transform:translateY(0);
}

.adf-close{
  position:absolute;
  top:20px;
  right:30px;
  font-size:28px;
  color:#351a0e;
  cursor:pointer;
  z-index:1;
}

.adf-libmodal-body.estilo-claro{
  display:flex;
  flex-direction:row;
  gap:40px;
  padding:40px;
  box-sizing:border-box;
}

.modal-coluna-esquerda{
  width:40%;
  padding:15px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:transparent;
  position:relative;
}

.modal-coluna-esquerda img{
  width:100%;
  height:auto;
  border-radius:8px;
  object-fit:contain;
  box-shadow:16px 12px 40px rgba(0,0,0,.45);
  transition:transform .3s ease, box-shadow .3s ease;
}

.modal-coluna-direita{
  width:60%;
  padding:25px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  margin-bottom:16px;
}

#modal-category{
  color:#572c22;
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.5px;
  border-left:4px solid #cba731;
  padding-left:10px;
  margin-bottom:14px;
}

#adf-libmodal h2{
  font:700 28px/1.2 'Crimson Text', serif;
  text-transform:uppercase;
  color:#351a0e;
  margin:0 0 20px;
}

#modal-desc{
  font-size:16px;
  color:#4d3d36;
  line-height:1.6;
  margin-bottom:30px;
  text-align:justify;
}

#modal-price{
  display:block;
  margin:0 auto 25px;
}
#modal-price .preco-wrapper{
  text-align:center;
  line-height:1.5;
}
#modal-price .preco-de-linha{
  font-size:16px;
  margin-bottom:5px;
  color:#999;
}
#modal-price .preco-de-label{
  font-size:14px;
  color:#aaa;
  margin-right:4px;
}
#modal-price .preco-de{
  text-decoration:line-through;
  color:#999;
  font-weight:500;
}
#modal-price .preco-por-linha{
  font-size:14px;
  color:#333;
}
#modal-price .preco-por-label{
  display:block;
  font-size:15px;
  color:#333;
  margin-bottom:3px;
}
#modal-price .preco-por{
  display:block;
  font-size:28px;
  font-weight:700;
  color:#c92c2c;
}

#modal-action{
  display:flex;
  justify-content:center;
  margin-top:auto;
}
#modal-action a,
#modal-action button{
  background:#cba731;
  color:#fff;
  font-size:16px;
  padding:14px 30px;
  border:0;
  text-transform:uppercase;
  font-weight:700;
  border-radius:0;
  cursor:pointer;
  transition:background .3s;
}
#modal-action a:hover,
#modal-action button:hover{
  background:#b8941e;
}

/* ===== MODAL DE REGISTRO (FINAL CORRETO) ===== */

#adf-modal-registrorg.adf-regmodal {
  position: fixed;
  inset: 0;
  z-index: 2147483600;
  display: block; /* impede que o flex bloqueie o scroll */
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
  overflow-y: auto; /* rola o modal */
  padding: 40px 16px;
  overscroll-behavior: contain;
}

/* Conteúdo central do modal */
#adf-modal-registrorg .adf-regmodal-content {
  background: #fefaf2;
  border-radius: 18px;
  width: min(640px, 92vw);
  margin: 60px auto;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  padding: 28px 24px 32px;
  position: relative;
  max-height: none; /* permite crescer naturalmente */
}

/* Corpo interno do modal */
#adf-modal-registrorg .adf-modal-body {
  padding: 0 !important;
}

/* Botão X */
#adf-modal-registrorg .adf-close {
  position: absolute;
  top: 14px;
  right: 20px;
  font-size: 28px;
  line-height: 1;
  color: #4a2f26;
  cursor: pointer;
  z-index: 100;
}

/* Travar o scroll da página abaixo */
html.adf-modal-open,
body.adf-modal-open {
  overflow: hidden !important;
  height: 100% !important;
}
/* =========================================================
   MODAL PREMIUM – MOBILE (EDITORIAL / CLÁSSICO)
   ========================================================= */
@media (max-width: 768px){

  /* Fundo: deixa CLARO que é modal */
  .adf-libmodal{
    background: rgba(30, 20, 12, 0.72);
    backdrop-filter: blur(3px);
  }

  /* Janela flutuante (não fullscreen) */
  .adf-libmodal .adf-libmodal-content{
    width: calc(100% - 28px);
    max-width: 520px;
    margin: 48px auto;
    border-radius: 18px;
    box-shadow: 0 28px 80px rgba(0,0,0,.45);
    overflow: hidden;
  }

  /* Corpo */
  .adf-libmodal-body.estilo-claro{
    flex-direction: column;
    gap: 0;
    padding: 0;
  }

  /* ================= IMAGEM ================= */
  .modal-coluna-esquerda{
    width: 100%;
    padding: 28px 24px 16px;
    background: #f3eee3;
    display: flex;
    justify-content: center;
  }

  .modal-coluna-esquerda img{
    max-width: 180px;          /* imagem menor */
    border-radius: 6px;
    box-shadow: 0 12px 30px rgba(0,0,0,.35);
  }

  /* ================= CONTEÚDO ================= */
  .modal-coluna-direita{
    width: 100%;
    padding: 22px 26px 28px;
  }

  /* Categoria — agora VISÍVEL e elegante */
  #modal-category{
    font-size: 13px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #6b4a2e;
    margin-bottom: 10px;
    border-left: 3px solid #cba731;
    padding-left: 10px;
  }

  #adf-libmodal h2{
    font-size: 23px;
    line-height: 1.25;
    margin-bottom: 14px;
    color: #2c150c;
    text-align: left;
  }

  #modal-desc{
    font-size: 15px;
    line-height: 1.6;
    color: #4a3a32;
    margin-bottom: 26px;
    text-align: left;
  }

  /* ================= PREÇO ================= */
  #modal-price{
    margin-bottom: 24px;
  }

  #modal-price .preco-por{
    font-size: 24px;
    color: #b32626;
  }

  /* ================= CTA ================= */
  #modal-action{
    display: flex;
    justify-content: center;
  }

  #modal-action a,
  #modal-action button{
    width: auto;                 /* NÃO full width */
    min-width: 220px;
    padding: 14px 28px;
    font-size: 14px;
    border-radius: 8px;
    letter-spacing: .08em;
    text-align: center;          /* texto centralizado */
    box-shadow: 0 8px 20px rgba(203,167,49,.45);
  }

  /* ================= BOTÃO FECHAR ================= */
  .adf-close{
    position: absolute;
    top: 14px;
    right: 16px;
    font-size: 24px;
    color: #3a1f14;
    background: none;
    width: auto;
    height: auto;
  }
}
/* =========================================================
   MODAL PREMIUM – MOBILE (REFINO FINAL)
   ========================================================= */
@media (max-width: 768px){

  /* 1️⃣ Mais respiro no topo do modal (X fora da imagem) */
  .adf-libmodal .adf-libmodal-content{
    margin: 72px auto 48px; /* mais espaço em cima */
  }

  /* 2️⃣ Área da imagem com mais respiro superior */
  .modal-coluna-esquerda{
    padding-top: 44px;   /* empurra a imagem para baixo */
    padding-bottom: 24px;
  }

  /* 3️⃣ Imagem com proporção do desktop (sem corte) */
  .modal-coluna-esquerda img{
    max-width: 180px;
    height: auto;
    object-fit: contain;     /* garante NÃO cortar */
    aspect-ratio: 3 / 4.2;  /* mesma lógica visual do desktop */
  }

  /* 4️⃣ Mais espaço entre imagem e categoria */
  .modal-coluna-direita{
    padding-top: 32px;  /* cria distância clara da imagem */
  }

  /* Categoria mais confortável visualmente */
  #modal-category{
    margin-bottom: 14px;
  }

  /* 5️⃣ Botão fechar sempre acima de tudo, fora da imagem */
  .adf-close{
    top: 18px;
    right: 18px;
    z-index: 100001;
  }
}

/* =========================================================
   REMOVE FUNDO DA IMAGEM – MODAL MOBILE
   ========================================================= */
@media (max-width: 768px){

  /* Remove qualquer fundo atrás da imagem */
  .modal-coluna-esquerda{
    background: transparent !important;
  }

  /* Garante que a imagem não receba filtros ou sombras extras */
  .modal-coluna-esquerda img{
    background: transparent !important;
    filter: none !important;
    opacity: 1 !important;
  }
}

/* =========================================
   OVERLAY (FUNDO ESCURECIDO + BLUR)
========================================= */
#adf-libmodal{
  position: fixed;
  inset: 0;
  background: rgba(20, 16, 12, 0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 99999;
  padding: 40px 20px;
}

/* modal ativo */
#adf-libmodal.active{
  display: flex;
}

/* =========================================
   CONTAINER PRINCIPAL
========================================= */
.adf-libmodal-content{
  position: relative;
  width: 100%;
  max-width: 980px;
  background: #fffdf8;
  border-radius: 26px;
  box-shadow:
    0 40px 80px rgba(0,0,0,.25),
    0 10px 30px rgba(0,0,0,.15);
  overflow: hidden;
  animation: adfModalEnter .35s ease;
}

@keyframes adfModalEnter{
  from{ opacity:0; transform: scale(.96) translateY(12px); }
  to{ opacity:1; transform: scale(1) translateY(0); }
}

/* =========================================
   BOTÃO FECHAR
========================================= */
.adf-libmodal .adf-close{
  position: absolute;
  top: 22px;
  right: 26px;
  font-size: 22px;
  color: #6b5f52;
  cursor: pointer;
  transition: transform .2s ease, color .2s ease;
  z-index: 10;
}
.adf-libmodal .adf-close:hover{
  transform: scale(1.1);
  color: #2c1e12;
}

/* =========================================
   BODY / GRID
========================================= */
.adf-libmodal-body{
  display: grid;
  grid-template-columns: 42% 58%;
  gap: 0;
  padding: 56px;
}

/* =========================================
   COLUNA ESQUERDA – IMAGEM
========================================= */
.modal-coluna-esquerda{
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-coluna-esquerda img{
  width: 100%;
  max-width: 360px;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border-radius: 16px;
  box-shadow:
    0 22px 45px rgba(0,0,0,.25),
    0 8px 18px rgba(0,0,0,.15);
  background: #ddd;
}

/* =========================================
   COLUNA DIREITA – CONTEÚDO
========================================= */
.modal-coluna-direita{
  padding-left: 10px;
  display: flex;
  flex-direction: column;
}

/* Categoria */
.modal-category{
  font-size: 12px;
  letter-spacing: .18em;
  font-weight: 600;
  color: #b18a2f;
  text-transform: uppercase;
  margin-bottom: 14px;
}

/* Título */
#modal-title{
  font-size: 30px;
  line-height: 1.25;
  color: #2b1d12;
  margin: 0 0 18px;
  font-weight: 700;
}

/* Descrição */
#modal-desc{
  font-size: 15.5px;
  line-height: 1.7;
  color: #5a5046;
  margin-bottom: 28px;
}
#modal-desc p{
  margin-bottom: 14px;
}

/* =========================================
   PREÇO
========================================= */
.modal-price{
  margin-bottom: 26px;
}

.modal-price del{
  display: block;
  font-size: 14px;
  color: #9a8f84;
  margin-bottom: 4px;
}

.modal-price .price-current{
  font-size: 30px;
  font-weight: 800;
  color: #c62d2d;
}

/* =========================================
   AÇÃO / BOTÕES
========================================= */
.modal-action{
  margin-top: auto;
}

.modal-action .btn,
.modal-action button,
.modal-action a{
  display: inline-block;
  padding: 16px 36px;
  border-radius: 14px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition:
    transform .22s ease,
    box-shadow .22s ease,
    background-color .22s ease;
}

/* CTA PRINCIPAL */
.modal-action .btn-comprar,
.modal-action .btn-assinar,
.modal-action .btn-acessar{
  background: linear-gradient(135deg, #d6b15a, #c7a24a);
  color: #fff;
  box-shadow: 0 14px 30px rgba(199,162,74,.45);
}
.modal-action .btn-comprar:hover,
.modal-action .btn-assinar:hover,
.modal-action .btn-acessar:hover{
  transform: scale(1.04);
  box-shadow: 0 18px 38px rgba(199,162,74,.55);
}

/* CTA DESABILITADO */
.modal-action .btn[disabled],
.modal-action .btn-disabled{
  background: #e6e1da;
  color: #8f867c;
  cursor: not-allowed;
  box-shadow: none;
}

/* =========================================
   RESPONSIVO
========================================= */
@media (max-width: 900px){
  .adf-libmodal-body{
    grid-template-columns: 1fr;
    padding: 36px 26px;
  }

  .modal-coluna-esquerda{
    margin-bottom: 28px;
  }

  .modal-coluna-esquerda img{
    max-width: 280px;
    margin: 0 auto;
  }

  #modal-title{
    font-size: 26px;
  }
}

.modal-coluna-esquerda img{
  width: 100%;
  max-width: 360px;
  aspect-ratio: 3 / 4;
  object-fit: cover;

  /* Moldura dourada direta */
  border: 2px solid #c7a24a;
  border-radius: 18px;

  box-shadow:
    0 18px 40px rgba(0,0,0,.28),
    0 6px 16px rgba(0,0,0,.18);

  background: #ddd;
}


.adf-libmodal-content:hover .modal-coluna-esquerda img{
  transform: translateY(-3px);
  box-shadow:
    0 26px 52px rgba(0,0,0,.28),
    0 10px 22px rgba(0,0,0,.18);
}

/* =========================================
   AJUSTE FINO — CATEGORIA NO MODAL (MOBILE)
========================================= */
@media (max-width: 768px){

  /* Cria respiro real entre imagem e conteúdo */
  .modal-coluna-direita{
    padding-top: 20px !important;
  }

  /* Categoria mais elegante e respirada */
  #modal-category{
    margin-top: 6px;
    margin-bottom: 16px;       /* afasta do título */
    padding-left: 12px !important;        /* dá mais peso à linha */
    font-size: 12px;           /* um pouco menor */
    letter-spacing: .16em;     /* mais editorial */
    border-left-width: 3px;
    color: #6a4a2c;
  }

  /* Título sobe um pouco e ganha foco */
  #adf-libmodal h2{
    margin-top: 0;
    margin-bottom: 14px !important;
  }
}

/* =========================================
   1) BOTÃO FECHAR – FORA DA IMAGEM
========================================= */
@media (max-width: 768px){
  .adf-libmodal .adf-close{
    top: 20px;          /* mais afastado do topo */
    right: 20px;
    z-index: 10002;
  }
}

/* =========================================
   2) EMPURRAR IMAGEM PARA BAIXO
========================================= */
@media (max-width: 768px){
  .modal-coluna-esquerda{
    padding-top: 38px !important;   /* antes estava ~28–44 */
    padding-bottom: 18px;
  }
}

/* =========================================
   3) MAIS MARGEM ESQUERDA NO CONTEÚDO
========================================= */
@media (max-width: 768px){
  .modal-coluna-direita{
    padding-left: 32px !important;   /* antes ~22–26 */
    padding-right: 28px !important;
    padding-top: 15px !important;
  }
}

