/*
Theme Name:  FanWay Child
Template:    astra
Version:     1.0
Description: Child theme FanWay — loja K-pop
*/

/* ── FONTES ─────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@600;700;800&family=Inter:wght@400;500;600&display=swap');

:root {
  --roxo:    #7B2CBF;
  --rosa:    #FF4D8D;
  --roxo-lt: #9D4EDD;
  --lilas:   #CDB4DB;
  --borda:   #EBEBEB;
  --texto:   #1A1A1A;
  --texto2:  #666666;
  --bg-alt:  #F8F8F8;
  --grad:    linear-gradient(135deg,#7B2CBF,#FF4D8D);
}

body { font-family:'Inter',sans-serif; color:var(--texto); background:#fff; }

h1,h2,h3,h4,h5,h6 { font-family:'Poppins',sans-serif; font-weight:700; }

a            { color:var(--roxo); }
a:hover      { color:var(--rosa); }

/* ── BOTÕES ─────────────────────────────────────── */
.btn-fw,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
input[type="submit"] {
  background: var(--grad) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 6px !important;
  font-family: 'Inter',sans-serif !important;
  font-weight: 600 !important;
  padding: .7rem 1.6rem !important;
  transition: opacity .2s, transform .2s !important;
  cursor: pointer;
}
.btn-fw:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover { opacity:.9 !important; transform:translateY(-2px) !important; color:#fff !important; }

.btn-fw-ghost {
  background: transparent;
  color: var(--roxo);
  border: 1.5px solid var(--roxo);
  border-radius: 6px;
  font-family: 'Inter',sans-serif;
  font-weight: 600;
  padding: .7rem 1.6rem;
  text-decoration: none;
  display: inline-block;
  transition: background .2s;
}
.btn-fw-ghost:hover { background:rgba(123,44,191,.06); color:var(--roxo); }

/* ── LOGO ───────────────────────────────────────── */
.site-title a, .ast-site-name-wrap a {
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-family: 'Poppins',sans-serif !important;
  font-weight: 800 !important;
}

/* ── RESET BODY ─────────────────────────────────── */
.fw-homepage { margin: 0 !important; padding: 0 !important; background: #fff !important; }

/* ── HEADER PRÓPRIO ─────────────────────────────── */
.fw-header {
  background: #fff;
  border-bottom: 1px solid var(--borda);
  position: sticky;
  top: 0;
  z-index: 999;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.fw-header-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.fw-logo {
  font-family: 'Poppins', sans-serif;
  font-weight: 800;
  font-size: 1.4rem;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-decoration: none;
  white-space: nowrap;
  padding: .8rem 0;
  flex-shrink: 0;
}
.fw-header .fw-cat-nav {
  border-bottom: none;
  padding: 0;
  flex: 1;
}
.fw-header-actions { margin-left: auto; flex-shrink: 0; }
.fw-cart-ico {
  position: relative;
  font-size: 1.3rem;
  text-decoration: none;
  padding: .4rem;
  display: inline-block;
}
.fw-cart-count {
  position: absolute;
  top: -4px; right: -4px;
  background: var(--rosa);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  border-radius: 50%;
  width: 18px; height: 18px;
  display: flex; align-items: center; justify-content: center;
}

/* ── FOOTER ─────────────────────────────────────── */
.fw-footer { background: var(--texto); color: #fff; padding: 3rem 2rem; margin-top: 3rem; }
.fw-footer-inner { max-width: 1200px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: 1.5rem; text-align: center; }
.fw-footer .fw-logo { -webkit-text-fill-color: transparent; }
.fw-footer-brand p { color: #aaa; font-size: .85rem; margin-top: .3rem; }
.fw-footer-links { display: flex; gap: 1.5rem; flex-wrap: wrap; justify-content: center; }
.fw-footer-links a { color: #ccc; text-decoration: none; font-size: .84rem; }
.fw-footer-links a:hover { color: #fff; }
.fw-footer-copy { color: #666; font-size: .75rem; }

/* ── TOPBAR ─────────────────────────────────────── */
.fw-topbar {
  background: var(--roxo);
  color: #fff;
  text-align: center;
  padding: .45rem 1rem;
  font-size: .76rem;
  font-weight: 500;
}

/* ── CATEGORY NAV ───────────────────────────────── */
.fw-cat-nav {
  background: #fff;
  border-bottom: 1px solid var(--borda);
  padding: 0 2rem;
  display: flex;
  overflow-x: auto;
  scrollbar-width: none;
}
.fw-cat-nav::-webkit-scrollbar { display:none; }
.fw-cat-nav a {
  padding: .85rem 1.1rem;
  font-size: .84rem;
  font-weight: 500;
  color: var(--texto2);
  text-decoration: none;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color .2s, border-color .2s;
}
.fw-cat-nav a:hover,
.fw-cat-nav a.ativo { color:var(--roxo); border-bottom-color:var(--roxo); font-weight:600; }

/* ── HERO ───────────────────────────────────────── */
.fw-hero {
  background: linear-gradient(130deg,#F0E8FF 0%,#FFF0F7 55%,#F8F8F8 100%);
  padding: 4rem 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5rem;
}
.fw-hero-txt { max-width: 460px; }
.fw-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  background: rgba(123,44,191,.1);
  border: 1px solid rgba(123,44,191,.22);
  color: var(--roxo);
  padding: .35rem .9rem;
  border-radius: 2rem;
  font-size: .74rem;
  font-weight: 600;
  margin-bottom: 1.2rem;
}
.fw-hero-titulo {
  font-size: clamp(2rem,4vw,3rem);
  line-height: 1.12;
  letter-spacing: -.025em;
  margin-bottom: .9rem;
}
.fw-hero-titulo span { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.fw-hero-sub { color:var(--texto2); font-size:.94rem; line-height:1.7; margin-bottom:1.8rem; }
.fw-hero-ctas { display:flex; gap:.75rem; flex-wrap:wrap; }
.fw-hero-foto { width:360px; height:360px; border-radius:1.5rem; overflow:hidden; box-shadow:0 30px 80px rgba(123,44,191,.18); flex-shrink:0; }
.fw-hero-foto img { width:100%; height:100%; object-fit:cover; }

/* ── SEÇÕES ─────────────────────────────────────── */
.fw-section { max-width:1200px; margin:0 auto; padding:3rem 2rem; }
.fw-sec-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:1.6rem; }
.fw-sec-titulo { font-size:1.3rem; }
.fw-ver-todos { color:var(--roxo); font-size:.83rem; font-weight:600; text-decoration:none; }
.fw-ver-todos:hover { text-decoration:underline; color:var(--roxo); }

/* ── FANDOMS ─────────────────────────────────────── */
.fw-fandoms { display:flex; gap:1rem; overflow-x:auto; scrollbar-width:none; padding-bottom:.4rem; }
.fw-fandoms::-webkit-scrollbar { display:none; }
.fw-fandom { display:flex; flex-direction:column; align-items:center; gap:.5rem; text-decoration:none; flex-shrink:0; }
.fw-fandom-ico { width:68px; height:68px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.7rem; border:2.5px solid transparent; transition:transform .2s,border-color .2s; }
.fw-fandom:hover .fw-fandom-ico { transform:scale(1.1); border-color:var(--roxo); }
.fw-fandom-nome { font-size:.73rem; font-weight:600; color:var(--texto); }

/* ── PRODUTOS WOOCOMMERCE ───────────────────────── */
.fw-section .woocommerce ul.products li.product {
  border:1px solid var(--borda);
  border-radius:10px;
  overflow:hidden;
  background:#fff;
  transition:box-shadow .25s,transform .25s;
}
.fw-section .woocommerce ul.products li.product:hover {
  box-shadow:0 10px 36px rgba(0,0,0,.1);
  transform:translateY(-4px);
}
.fw-section .woocommerce ul.products li.product a img { border-radius:0; transition:transform .35s; }
.fw-section .woocommerce ul.products li.product:hover img { transform:scale(1.04); }
.fw-section .woocommerce ul.products li.product .woocommerce-loop-product__title { font-family:'Poppins',sans-serif; font-size:.88rem; font-weight:600; }
.woocommerce span.onsale { background:var(--rosa) !important; border-radius:6px !important; }
.woocommerce .price { color:var(--texto) !important; font-weight:700 !important; }
.woocommerce .price del { color:#bbb !important; font-weight:400 !important; }

/* ── BANNER PROMO ───────────────────────────────── */
.fw-banner {
  margin:0 2rem 3rem;
  max-width:1160px;
  margin-left:auto; margin-right:auto;
  background:var(--grad);
  border-radius:1rem;
  padding:2.5rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:2rem;
  color:#fff;
}
.fw-banner h3 { font-size:clamp(1.2rem,2.8vw,1.8rem); margin-bottom:.4rem; }
.fw-banner p  { opacity:.85; font-size:.88rem; }
.btn-banner   { background:#fff; color:var(--roxo); padding:.75rem 1.8rem; border-radius:.45rem; font-weight:700; font-size:.88rem; text-decoration:none; white-space:nowrap; }
.btn-banner:hover { opacity:.9; color:var(--roxo); }

/* ── TRUST BAR ──────────────────────────────────── */
.fw-trust {
  background:var(--bg-alt);
  border-top:1px solid var(--borda);
  border-bottom:1px solid var(--borda);
  padding:2rem;
  display:flex;
  justify-content:center;
  gap:3.5rem;
  flex-wrap:wrap;
}
.fw-trust-item { display:flex; align-items:center; gap:.75rem; }
.fw-trust-ico  { font-size:1.8rem; }
.fw-trust-txt strong { display:block; font-size:.86rem; font-weight:700; }
.fw-trust-txt span   { font-size:.76rem; color:var(--texto2); }

/* ── PÁGINA GENÉRICA (Sobre, Contato, etc) ───────── */
.fw-page-wrap { max-width: 780px; margin: 0 auto; padding: 3.5rem 2rem 4rem; }
.fw-page-titulo {
  font-size: clamp(1.6rem,3vw,2.2rem);
  margin-bottom: 1.8rem;
  padding-bottom: 1rem;
  border-bottom: 2px solid var(--borda);
}
.fw-page-content { font-size: .97rem; line-height: 1.85; color: var(--texto); }
.fw-page-content h2 { font-size:1.3rem; margin:2rem 0 .7rem; color:var(--roxo); }
.fw-page-content p  { margin-bottom:1rem; }
.fw-page-content ul { padding-left:1.6rem; margin-bottom:1rem; }
.fw-page-content li { margin-bottom:.4rem; line-height:1.7; }
.fw-page-content a  { color:var(--roxo); }

/* ── BLOG — HEADER ───────────────────────────────── */
.fw-blog-header {
  background: linear-gradient(130deg,#F0E8FF 0%,#FFF0F7 60%,#F8F8F8 100%);
  padding: 3.5rem 2rem 3rem;
  text-align: center;
  border-bottom: 1px solid var(--borda);
}
.fw-blog-header-inner { max-width: 700px; margin: 0 auto; }
.fw-blog-header h1 { font-size: clamp(1.6rem,3vw,2.2rem); margin-bottom: .6rem; }
.fw-blog-header p  { color: var(--texto2); font-size: .95rem; }

/* ── BLOG — CONTAINER ────────────────────────────── */
.fw-blog-container { max-width: 1200px; margin: 0 auto; padding: 3rem 2rem; }

/* ── BLOG — GRID ─────────────────────────────────── */
.fw-blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px,1fr));
  gap: 2rem;
}
.fw-blog-grid--3 { grid-template-columns: repeat(auto-fill, minmax(260px,1fr)); }

/* ── BLOG — CARD ─────────────────────────────────── */
.fw-blog-card {
  border: 1px solid var(--borda);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
  transition: box-shadow .25s, transform .25s;
  display: flex;
  flex-direction: column;
}
.fw-blog-card:hover { box-shadow: 0 10px 36px rgba(0,0,0,.09); transform: translateY(-3px); }
.fw-blog-thumb {
  display: block;
  aspect-ratio: 16/9;
  overflow: hidden;
  position: relative;
  background: var(--bg-alt);
}
.fw-blog-thumb img { width:100%; height:100%; object-fit:cover; transition: transform .35s; }
.fw-blog-card:hover .fw-blog-thumb img { transform: scale(1.04); }
.fw-blog-cat-badge {
  position: absolute; top: .75rem; left: .75rem;
  background: var(--grad); color: #fff;
  font-size: .68rem; font-weight: 700;
  padding: .25rem .65rem; border-radius: 2rem;
}
.fw-blog-card-body { padding: 1.3rem; flex: 1; display: flex; flex-direction: column; }
.fw-blog-meta { font-size: .74rem; color: var(--texto2); margin-bottom: .5rem; }
.fw-blog-card-body h2 { font-size: 1rem; margin-bottom: .5rem; line-height: 1.45; }
.fw-blog-card-body h2 a { color: var(--texto); text-decoration: none; }
.fw-blog-card-body h2 a:hover { color: var(--roxo); }
.fw-blog-card-body h3 { font-size: .92rem; margin-bottom: .4rem; line-height: 1.4; }
.fw-blog-card-body h3 a { color: var(--texto); text-decoration: none; }
.fw-blog-card-body h3 a:hover { color: var(--roxo); }
.fw-blog-excerpt { font-size: .84rem; color: var(--texto2); line-height: 1.6; flex: 1; margin-bottom: 1rem; }
.fw-blog-leia { font-size: .82rem; font-weight: 600; color: var(--roxo); text-decoration: none; margin-top: auto; }
.fw-blog-leia:hover { text-decoration: underline; color: var(--roxo); }
.fw-blog-pagination { margin-top: 3rem; display: flex; justify-content: center; }
.fw-blog-pagination .page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 6px; margin: 0 3px;
  border: 1px solid var(--borda); color: var(--texto); text-decoration: none;
  font-size: .85rem; font-weight: 500; transition: background .2s;
}
.fw-blog-pagination .page-numbers.current,
.fw-blog-pagination .page-numbers:hover { background: var(--roxo); color: #fff; border-color: var(--roxo); }
.fw-blog-empty { text-align: center; color: var(--texto2); padding: 4rem 0; font-size: .95rem; }

/* ── BARRA DE PROGRESSO ──────────────────────────── */
.fw-reading-progress {
  position: fixed; top: 0; left: 0; z-index: 9999;
  height: 3px; width: 0;
  background: var(--grad);
  transition: width .1s linear;
}

/* ── ARTIGO — HEADER ─────────────────────────────── */
.fw-article-header {
  background: linear-gradient(130deg,#F0E8FF 0%,#FFF0F7 60%,#F8F8F8 100%);
  padding: 3rem 2rem 2.5rem;
  border-bottom: 1px solid var(--borda);
}
.fw-article-header-inner { max-width: 780px; margin: 0 auto; }
.fw-breadcrumb { font-size: .76rem; color: var(--texto2); margin-bottom: 1rem; display: flex; gap: .4rem; flex-wrap: wrap; }
.fw-breadcrumb a { color: var(--texto2); text-decoration: none; }
.fw-breadcrumb a:hover { color: var(--roxo); }
.fw-blog-cat-tag {
  display: inline-block;
  background: rgba(123,44,191,.1);
  color: var(--roxo);
  font-size: .72rem; font-weight: 700;
  padding: .25rem .75rem; border-radius: 2rem;
  margin-bottom: .9rem;
}
.fw-article-titulo {
  font-size: clamp(1.5rem, 3.5vw, 2.2rem);
  line-height: 1.2;
  letter-spacing: -.02em;
  margin-bottom: .75rem;
}
.fw-article-lead {
  font-size: 1.08rem; color: var(--texto2); line-height: 1.7;
  margin: .75rem 0 1rem; font-style: italic;
}
.fw-article-meta {
  display: flex; flex-wrap: wrap; gap: .4rem .8rem;
  font-size: .78rem; color: var(--texto2); align-items: center;
}
.fw-meta-item { display: flex; align-items: center; gap: .3rem; }
.fw-meta-item a { color: var(--texto2); text-decoration: none; }
.fw-meta-item a:hover { color: var(--roxo); }
.fw-meta-sep { color: var(--borda); }

/* ── ARTIGO — IMAGEM DESTAQUE ────────────────────── */
.fw-article-hero-img {
  max-width: 1000px; margin: 2rem auto; padding: 0 2rem;
}
.fw-article-hero-img img {
  width: 100%; border-radius: 14px;
  aspect-ratio: 16/7; object-fit: cover;
  box-shadow: 0 12px 40px rgba(123,44,191,.15);
  display: block;
}

/* ── ARTIGO — LAYOUT ─────────────────────────────── */
.fw-article-wrap {
  max-width: 1140px; margin: 0 auto; padding: 2.5rem 2rem;
  display: grid; grid-template-columns: 1fr 300px; gap: 4rem; align-items: start;
}

/* ── ARTIGO — CONTEÚDO TIPOGRAFIA ────────────────── */
.fw-article-content {
  font-size: 1rem; line-height: 1.9; color: var(--texto);
  min-width: 0;
}

/* Primeiro parágrafo maior */
.fw-article-content .fw-lead-p {
  font-size: 1.12rem; line-height: 1.75;
  color: #333; font-weight: 500; margin-bottom: 1.5rem;
}

/* Parágrafos */
.fw-article-content p { margin-bottom: 1.2rem; }

/* H2 — seções principais */
.fw-article-content h2 {
  font-size: 1.4rem; font-weight: 700;
  margin: 2.8rem 0 1rem;
  color: var(--texto);
  padding: .7rem 1rem .7rem 1.2rem;
  background: linear-gradient(to right, rgba(123,44,191,.06), transparent);
  border-left: 4px solid var(--roxo);
  border-radius: 0 8px 8px 0;
  line-height: 1.3;
}

/* H3 — subseções */
.fw-article-content h3 {
  font-size: 1.1rem; font-weight: 700;
  margin: 2rem 0 .6rem;
  color: var(--roxo);
  display: flex; align-items: center; gap: .5rem;
}
.fw-article-content h3::before {
  content: '';
  display: inline-block; width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--grad);
  flex-shrink: 0;
}

/* Strong */
.fw-article-content strong { color: var(--texto); font-weight: 700; }

/* Links */
.fw-article-content a { color: var(--roxo); text-decoration: underline; text-underline-offset: 2px; }
.fw-article-content a:hover { color: var(--rosa); }

/* Listas não-ordenadas */
.fw-article-content ul {
  padding-left: 0; margin-bottom: 1.3rem; list-style: none;
}
.fw-article-content ul li {
  padding: .3rem 0 .3rem 1.6rem; position: relative; line-height: 1.7;
}
.fw-article-content ul li::before {
  content: ''; position: absolute; left: 0; top: .7rem;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--grad);
}

/* Listas ordenadas */
.fw-article-content ol {
  padding-left: 1.8rem; margin-bottom: 1.3rem; counter-reset: fw-ol;
  list-style: none;
}
.fw-article-content ol li {
  padding: .3rem 0 .3rem .5rem; line-height: 1.7;
  counter-increment: fw-ol; position: relative;
}
.fw-article-content ol li::before {
  content: counter(fw-ol);
  position: absolute; left: -1.8rem;
  background: var(--grad); color: #fff;
  width: 22px; height: 22px; border-radius: 50%;
  font-size: .72rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  top: .45rem;
}

/* Blockquote */
.fw-article-content blockquote {
  margin: 2rem 0;
  padding: 1.2rem 1.5rem 1.2rem 1.8rem;
  background: linear-gradient(135deg, #F0E8FF 0%, #FFF0F7 100%);
  border-left: 5px solid var(--roxo);
  border-radius: 0 12px 12px 0;
  font-size: 1.05rem; font-style: italic;
  color: var(--texto); line-height: 1.7;
  position: relative;
}
.fw-article-content blockquote::before {
  content: '"';
  font-size: 3rem; line-height: 1; color: var(--lilas);
  position: absolute; top: -.2rem; left: .8rem;
  font-family: Georgia, serif;
}

/* Imagens dentro do conteúdo */
.fw-article-content img {
  width: 100%; height: auto; border-radius: 10px;
  margin: 1.5rem 0;
  box-shadow: 0 4px 20px rgba(0,0,0,.08);
}
.fw-article-content figure { margin: 1.5rem 0; }
.fw-article-content figcaption {
  text-align: center; font-size: .78rem;
  color: var(--texto2); margin-top: .4rem; font-style: italic;
}

/* Tabelas */
.fw-article-content table {
  width: 100%; border-collapse: collapse;
  margin: 1.5rem 0; font-size: .9rem;
  border-radius: 8px; overflow: hidden;
}
.fw-article-content th {
  background: var(--roxo); color: #fff;
  padding: .7rem 1rem; text-align: left; font-weight: 600;
}
.fw-article-content td {
  padding: .65rem 1rem; border-bottom: 1px solid var(--borda);
}
.fw-article-content tr:nth-child(even) td { background: rgba(123,44,191,.03); }

/* Leia também */
.fw-leia-tambem {
  background: var(--bg-alt); border-left: 4px solid var(--roxo);
  border-radius: 0 10px 10px 0; padding: 1rem 1.4rem;
  margin: 2rem 0;
}
.fw-leia-tambem p { margin: 0 0 .5rem; font-weight: 600; font-size: .9rem; color: var(--texto); }
.fw-leia-tambem ul { list-style: none; padding: 0; margin: 0; }
.fw-leia-tambem ul li { margin-bottom: .35rem; font-size: .88rem; }
.fw-leia-tambem ul li::before { content: '→ '; color: var(--rosa); font-weight: 700; }
.fw-leia-tambem a { color: var(--roxo); text-decoration: none; }
.fw-leia-tambem a:hover { color: var(--rosa); text-decoration: underline; }

/* FAQ items */
.fw-article-content .fw-faq { margin-top: 2.5rem; }
.fw-article-content .fw-faq-item {
  border: 1px solid var(--borda); border-radius: 10px;
  margin-bottom: .7rem; overflow: hidden;
  transition: border-color .2s;
}
.fw-article-content .fw-faq-item:hover { border-color: var(--lilas); }
.fw-article-content .fw-faq-item strong {
  display: block; padding: 1rem 1.2rem;
  color: var(--texto); font-weight: 600; font-size: .95rem;
  cursor: pointer; background: #fafafa;
}
.fw-article-content .fw-faq-item div {
  padding: 0 1.2rem 1rem; font-size: .9rem; line-height: 1.7;
}

/* ── ARTIGO — SIDEBAR ────────────────────────────── */
.fw-article-sidebar { position: sticky; top: 76px; display: flex; flex-direction: column; gap: 1.2rem; }

.fw-toc {
  background: #fff; border: 1px solid var(--borda);
  border-radius: 12px; padding: 1.2rem;
}
.fw-toc-title { font-family:'Poppins',sans-serif; font-weight:700; font-size:.9rem; margin-bottom:.8rem; }
.fw-toc-list { list-style: none; padding: 0; margin: 0; counter-reset: toc-cnt; }
.fw-toc-list li { counter-increment: toc-cnt; margin-bottom: .4rem; }
.fw-toc-list a {
  font-size: .82rem; color: var(--texto2); text-decoration: none;
  display: flex; gap: .5rem; align-items: flex-start; line-height: 1.4;
  padding: .25rem .4rem; border-radius: 5px; transition: background .15s;
}
.fw-toc-list a::before {
  content: counter(toc-cnt);
  background: var(--grad); color: #fff;
  width: 18px; height: 18px; border-radius: 50%;
  font-size: .65rem; font-weight: 700; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; margin-top: .1rem;
}
.fw-toc-list a:hover { background: rgba(123,44,191,.06); color: var(--roxo); }

.fw-sidebar-cta {
  background: linear-gradient(135deg,#F0E8FF,#FFF0F7);
  border: 1px solid rgba(123,44,191,.15);
  border-radius: 12px; padding: 1.4rem; text-align: center;
}
.fw-sidebar-cta-title { font-family:'Poppins',sans-serif; font-weight:700; font-size:.9rem; margin-bottom:.4rem; }
.fw-sidebar-cta p:not(.fw-sidebar-cta-title) { font-size:.81rem; color:var(--texto2); margin-bottom:.9rem; line-height:1.5; }
.fw-sidebar-cta ul { padding:0; margin:0 0 .9rem; list-style:none; }
.fw-sidebar-cta ul li::before { display:none; }

.fw-sidebar-fandoms { background:#fff; border:1px solid var(--borda); border-radius:12px; padding:1.2rem; }
.fw-sidebar-fandom-link {
  display: block; padding: .42rem .7rem; border-radius: 6px;
  color: var(--texto); font-size: .82rem; font-weight: 500;
  text-decoration: none; transition: background .15s;
}
.fw-sidebar-fandom-link:hover { background: rgba(123,44,191,.07); color: var(--roxo); }

.fw-sidebar-share { background:#fff; border:1px solid var(--borda); border-radius:12px; padding:1.2rem; }
.fw-share-btns { display: flex; gap: .6rem; margin-top: .6rem; }
.fw-share-btn {
  flex: 1; padding: .5rem; border-radius: 7px;
  font-size: .78rem; font-weight: 700; text-align: center;
  text-decoration: none; transition: opacity .2s;
}
.fw-share-btn:hover { opacity: .85; }
.fw-share-wa { background: #25D366; color: #fff; }
.fw-share-tw { background: #1DA1F2; color: #fff; }

/* ── ARTIGOS RELACIONADOS ────────────────────────── */
.fw-related { border-top: 1px solid var(--borda); background: var(--bg-alt); }

/* ── RESPONSIVE ─────────────────────────────────── */
@media(max-width:768px){
  .fw-hero        { flex-direction:column-reverse; padding:2.5rem 1.2rem; gap:2rem; }
  .fw-hero-foto   { width:100%; height:240px; border-radius:1rem; }
  .fw-banner      { flex-direction:column; text-align:center; margin:0 1rem 2rem; }
  .fw-trust       { gap:1.5rem; }
  .fw-cat-nav     { padding:0 1rem; }
  .fw-section     { padding:2rem 1rem; }
  .fw-header-inner{ padding:0 1rem; gap:.75rem; }
  .fw-header .fw-cat-nav { display:none; }
  .fw-article-wrap { grid-template-columns:1fr; gap:2rem; }
  .fw-article-sidebar { position:static; }
  .fw-blog-grid   { grid-template-columns:1fr; }
  .fw-article-content h2 { font-size:1.2rem; }
  .fw-reading-progress { height:2px; }
}
