/* ===========================
   Avocado Tema Flux — Main CSS
   (componentes e seção de conteúdo)
   =========================== */

/* ---------- Tokens auxiliares do drawer (não mexem no resto do tema) ---------- */
:root{
  --drawer-mask: rgba(0,0,0,.42);
  --drawer-link-hover-light: rgba(0,0,0,.06);
  --drawer-link-hover-dark:  rgba(255,255,255,.08);
  --drawer-border-light: rgba(0,0,0,.12);
  --drawer-border-dark:  rgba(255,255,255,.08);
  --drawer-text-light:#0b0f12;
  --drawer-text-dark:#e7eef5;
  --drawer-bg-light:#ffffff;
  --drawer-bg-dark:#0b0f12;
}

/* ---------- Utilitários ---------- */
.flow > * + * { margin-top: 16px }
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.center { margin-left:auto; margin-right:auto }
.max-content { max-width: 75ch }
.alignwide { max-width: 1200px; margin-inline:auto }
.alignfull { width:100vw; margin-left:50%; transform:translateX(-50%) }

.intrinsic{content-visibility:auto;contain-intrinsic-size:1px 500px}
.no-js .lazy{opacity:1 !important}
.js .lazy{opacity:0;transition:opacity .2s ease}
.js .lazy.is-loaded{opacity:1}

/* ---------- Botões ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  border-radius:999px;padding:10px 16px;
  border:1px solid #1b2a35;text-decoration:none;cursor:pointer
}
.btn:focus-visible{outline:2px solid var(--av-accent);outline-offset:2px}
.btn--accent{background:linear-gradient(90deg,var(--av-accent),var(--av-accent2));color:#001018;border:0}
.btn--ghost{background:transparent;border:1px solid #23313c}
.btn--soft{background:color-mix(in srgb, var(--av-accent) 18%, transparent);border:0}

/* ---------- Grades ---------- */
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
@media (max-width: 900px){
  .grid-2,.grid-3{grid-template-columns:1fr}
}

/* Grades específicas usadas em home */
.grid-cards .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:900px){ .grid-cards .cards{grid-template-columns:1fr} }

/* Evitar sobreposição do último card sobre o botão "Ver todos os artigos" */
.grid-cards .cards { position: relative; z-index: 1; }
#latest .flow { position: relative; z-index: 2; margin-top: 16px; }
.grid-cards .cards .card a { display: inline-block; }

/* ---------- Links e cartões ---------- */
.card{transition: transform .18s ease, box-shadow .18s ease}
.card:hover{transform: translateY(-2px); box-shadow: var(--av-shadow-md)}
.card a:not(.btn){text-decoration:none}
.card a:not(.btn):hover{text-decoration:underline}

/* ---------- Tipografia do conteúdo ---------- */
.content, .page-content { max-width: 75ch }
.content h1, .page-content h1 { font-size:clamp(1.8rem,4vw,2.4rem); line-height:1.2; margin:1.2em 0 .5em }
.content h2, .page-content h2 { font-size:clamp(1.3rem,3vw,1.8rem); margin:1.4em 0 .6em }
.content h3, .page-content h3 { font-size:clamp(1.1rem,2.5vw,1.3rem); margin:1.2em 0 .6em }
.content p, .page-content p { margin:1em 0 }
.content ul, .page-content ul,
.content ol, .page-content ol { padding-left:1.2em; margin:1em 0; }
.content li + li, .page-content li + li { margin-top:.35em }
.content blockquote, .page-content blockquote {
  margin:1.2em 0; padding:1em; border-left:4px solid var(--av-accent);
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
}
.content code, .page-content code { padding:.15em .35em; border-radius:.3rem; background:rgba(255,255,255,.06) }
.content pre, .page-content pre {
  overflow:auto; padding:1em; border-radius:.6rem; border:1px solid #14222c;
  background:rgba(0,0,0,.35); font-size:.95em
}

/* ---------- Tabelas (responsivas) ---------- */
/* FIX: torna as tabelas roláveis no mobile para não “cortar” conteúdo */
.content table, .page-content table, .wp-block-table table{
  display:block;                 /* permite overflow interno */
  width:100%;
  max-width:100%;
  border-collapse:collapse;
  margin:1.2em 0;
  overflow-x:auto;               /* rolagem horizontal quando necessário */
  -webkit-overflow-scrolling:touch;
}
.content th, .page-content th, .content td, .page-content td {
  padding:.6em .7em; border:1px solid #14222c;
  word-break:break-word;         /* evita palavras gigantes estourando a célula */
}
.content thead th, .page-content thead th {
  background:color-mix(in srgb, var(--av-accent) 14%, transparent); text-align:left
}

/* ---------- Breadcrumbs ---------- */
.breadcrumbs{font-size:.95rem;color:var(--av-muted);margin:8px 0 16px}
.breadcrumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;margin:0;padding:0}
.breadcrumbs li{display:flex;align-items:center;gap:.4rem}
.breadcrumbs li a{color:inherit;text-decoration:none;opacity:.95}
.breadcrumbs li a:hover,.breadcrumbs li a:focus-visible{opacity:1;text-decoration:underline}
.breadcrumbs .sep{opacity:.6}

/* ---------- Formulários ---------- */
input, select, textarea {
  width:100%; padding:.65rem .8rem; border-radius:.6rem; border:1px solid #1b2a35;
  background:rgba(255,255,255,.02); color:var(--av-text)
}
input:focus, select:focus, textarea:focus { outline:2px solid var(--av-accent); outline-offset:2px }
label{display:block;margin:.6rem 0 .25rem}
button, input[type=submit]{cursor:pointer}

/* ---------- Paginação (WP) ---------- */
.nav-links, .pagination{display:flex;gap:8px;align-items:center;margin:24px 0}
.page-numbers{display:inline-flex;min-width:36px;justify-content:center;align-items:center;border-radius:.6rem;border:1px solid #1b2a35;padding:.4rem .6rem;text-decoration:none}
.page-numbers.current{background:color-mix(in srgb, var(--av-accent) 18%, transparent);border-color:transparent}

/* ---------- Avisos ---------- */
.notice{padding:12px 14px;border-radius:.6rem;border:1px solid #22323e;background:rgba(255,255,255,.02)}
.notice--success{border-color:rgba(0,255,170,.25)}
.notice--warning{border-color:rgba(255,200,0,.25)}
.notice--danger{border-color:rgba(255,0,90,.25)}

/* ---------- Seções dos padrões (pricing/FAQ/testimonials) ---------- */
.pricing{display:grid;gap:16px}
.pricing .plan{border:1px solid #14222c;border-radius:1rem;padding:20px;background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0))}
.pricing .plan--featured{outline:2px solid color-mix(in srgb, var(--av-accent) 55%, transparent)}
.pricing .price{font-size:clamp(1.6rem,4vw,2rem);font-weight:800;margin:.2em 0}

.faq .item{border-bottom:1px solid #14222c;padding:12px 0}
.faq .q{font-weight:700;cursor:pointer}
.faq .a{margin-top:8px;color:var(--av-muted)}

.testimonials{display:grid;gap:16px}
.testimonial{border:1px solid #14222c;border-radius:1rem;padding:16px;background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0))}
.testimonial .who{display:flex;align-items:center;gap:10px;margin-top:10px;font-size:.95rem;color:var(--av-muted)}

/* ---------- Author Box (final do post) ---------- */
.author-box{
  display:flex; gap:16px; align-items:flex-start;
  border:1px solid #14222c; border-radius:1rem; padding:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
}
.author-avatar{ border-radius:50% }
.author-avatar-wrap{ flex:0 0 auto; display:grid; place-items:center }
.author-avatar-wrap .author-avatar{ box-shadow:0 0 0 3px color-mix(in srgb, var(--av-accent) 45%, transparent) }
.author-meta{ flex:1 1 auto }
.author-bio{ color:var(--av-muted) }
.author-more{
  color:var(--av-accent); text-decoration:none; font-weight:700;
}
.author-more:hover{ text-decoration:underline }
@media (max-width:700px){
  .author-box{ flex-direction:row }
}

/* ---------- Rodapé ---------- */
.site-footer .menu{list-style:none;display:flex;flex-wrap:wrap;gap:16px;margin:0 0 10px 0;padding:0}
.site-footer a{text-decoration:none;opacity:.9}
.site-footer a:hover{text-decoration:underline;opacity:1}
.footer-cats{margin-top:8px}
.site-copy{margin-top:8px;color:var(--av-muted);font-size:.95rem}

/* ---------- Botão Voltar ao Topo ---------- */
.back-to-top{
  position:fixed;right:16px;bottom:20px;z-index:9999;
  width:44px;height:44px;border-radius:999px;border:0;
  background:#0ea5e9;color:#001018;font-weight:800;cursor:pointer;
  box-shadow:0 6px 20px rgb(0 0 0 / .25);opacity:0;pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
}
.back-to-top:hover{transform:translateY(-2px)}
.back-to-top.is-visible{opacity:1;pointer-events:auto}

/* ---------- FAB WhatsApp / Telegram ---------- */
.fab{
  position:fixed; right:16px; bottom:calc(env(safe-area-inset-bottom) + 88px);
  display:flex; flex-direction:column; gap:12px; z-index:9999;
}
.fab-btn{
  width:52px; height:52px; border-radius:999px; display:inline-flex;
  align-items:center; justify-content:center; border:0; cursor:pointer;
  box-shadow:0 10px 25px rgba(0,0,0,.25); text-decoration:none;
  transition:transform .15s ease, filter .15s ease;
}
.fab-btn:hover{ transform:translateY(-2px); filter:brightness(.98) }
.fab-btn svg{ width:26px; height:26px; fill:#fff; display:block }
.fab-wa{ background:#25D366 }   /* WhatsApp */
.fab-tg{ background:#2AABEE }   /* Telegram */
@media (max-width: 480px){
  .fab{ right:12px; gap:10px }
  .fab-btn{ width:50px; height:50px }
}

/* ---------- Depoimentos/relacionados ajustes ---------- */
.related-posts .card img{display:block;border-radius:.6rem}
.related-posts .card-title{margin-top:8px}

/* ---------- Impressão ---------- */
@media print{
  .nav, .site-footer, .toggles, .skip-link, .back-to-top, .fab { display:none !important }
  .site-content{ padding:0 }
  a{ text-decoration:underline }
}

/* =======================================================
   Mobile Drawer (menu hambúrguer) — sem fantasmas/fiapos
   ======================================================= */

/* Cores por tema */
[data-theme="light"] .drawer{
  background:var(--drawer-bg-light,#fff);
  color:var(--drawer-text-light,#0b0f12);
  border-right:1px solid var(--drawer-border-light,rgba(0,0,0,.12));
}
[data-theme="dark"] .drawer{
  background:var(--drawer-bg-dark,#0b0f12);
  color:var(--drawer-text-dark,#e7eef5);
  border-right:1px solid var(--drawer-border-dark,rgba(255,255,255,.08));
}

/* Drawer: fechado = invisível e sem interações */
.drawer{
  position:fixed; inset:0 auto 0 0; width:82vw; max-width:340px; height:100dvh;
  transform:translateX(-120%); /* bem fora da tela */
  visibility:hidden; pointer-events:none; box-shadow:none;
  transition:transform .28s ease, visibility 0s linear .28s;
  z-index:9999; display:flex; flex-direction:column;
  will-change:transform;
}
.drawer.open{
  transform:translateX(0);
  visibility:visible; pointer-events:auto; box-shadow:0 10px 40px rgba(0,0,0,.35);
  transition:transform .28s ease, visibility 0s;
}

.drawer-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px; border-bottom:1px solid rgba(255,255,255,.08);
}
[data-theme="light"] .drawer-head{ border-bottom-color: rgba(0,0,0,.12); }

.drawer-title{ font-weight:800; letter-spacing:.2px }
.drawer-close{
  background:transparent; color:inherit;
  border:1.5px solid currentColor; border-radius:999px;
  padding:.3rem .55rem; line-height:1; opacity:.92;
}
.drawer-close:hover{ opacity:1 }

/* Navegação e links */
.drawer-nav{ padding:6px 8px 16px 8px; overflow:auto }
.drawer-menu{ list-style:none; margin:0; padding:0 }
.drawer-menu > li > a{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px; padding:12px 14px; border-radius:12px;
  color:inherit; text-decoration:none; font-weight:600;
}
[data-theme="light"] .drawer-menu > li > a:hover{ background:rgba(0,0,0,.06) }
[data-theme="dark"]  .drawer-menu > li > a:hover{ background:rgba(255,255,255,.08) }

/* Submenus: botão grande e visível */
.drawer-menu li.menu-item-has-children{ position:relative }
.drawer-menu li .submenu-toggle{
  margin-left:8px; width:34px; height:34px;
  display:inline-flex; align-items:center; justify-content:center;
  border:1.5px solid currentColor; border-radius:999px;
  background:rgba(255,255,255,.06); color:inherit; cursor:pointer;
  transition:background .15s ease, transform .15s ease, opacity .15s ease;
  opacity:.95;
}
[data-theme="light"] .drawer-menu li .submenu-toggle{ background:rgba(0,0,0,.05) }
.drawer-menu li .submenu-toggle:hover{ opacity:1; transform:translateY(-1px) }
.drawer-menu li .submenu-toggle .chev{ font-size:18px; line-height:1 }
.drawer-menu li .sub-menu{
  display:none; list-style:none; margin:6px 0 0 0; padding-left:12px;
  border-left:2px solid color-mix(in srgb, currentColor 35%, transparent);
}
.drawer-menu li.open > .sub-menu{ display:block }

/* Overlay com fade real (sem usar [hidden]) */
.drawer-mask{
  position:fixed; inset:0; background:rgba(0,0,0,.42);
  z-index:9998; opacity:0; visibility:hidden;
  transition:opacity .18s ease, visibility 0s linear .18s;
}
.drawer-mask.is-visible{
  opacity:1; visibility:visible; transition:opacity .18s ease, visibility 0s;
}

/* Travar scroll quando o drawer está aberto */
.no-scroll{ overflow:hidden }

/* Desktop x Mobile */
@media (max-width: 900px){
  .nav--desktop{ display:none }
  .nav-toggle{ display:inline-flex }
}
@media (min-width: 901px){
  .drawer, .drawer-mask{ display:none }
}

/* Toque confortável */
@media (max-width: 480px){
  .drawer-menu > li > a{ padding:14px 16px }
  .drawer-head{ padding:16px }
}

/* =======================
   FIX — TOC em páginas (mobile)
   - remove TOC no mobile
   - força layout 1 coluna
   - evita qualquer sobra lateral
   ======================= */

/* Páginas com TOC em 2 colunas (desktop) — mantém como está */
.page-with-toc,
.page-toc-layout{
  display:grid;
  grid-template-columns: minmax(280px, 320px) 1fr;
  gap:24px;
}

/* Cartão do TOC (desktop) — ok */
.page-with-toc .toc,
.page-toc-layout .toc{
  border:1px solid rgba(127,150,169,.25);
  border-radius:12px;
  padding:14px 16px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
}

/* MOBILE: esconde TOC e força uma coluna */
@media (max-width: 1024px){
  .page-with-toc,
  .page-toc-layout{
    display:block !important;            /* 1 coluna */
  }
  .page-with-toc .toc,
  .page-toc-layout .toc,
  aside.toc{
    display:none !important;             /* TOC some no mobile */
  }
}

/* Segurança extra: nada de “duas telas” por overflow horizontal */
html, body{ overflow-x:hidden }

/* ---------- Cinto de segurança para listas de posts ---------- */
/* FIX: se algum template travar colunas via style inline, no mobile vira 1 coluna */
@media (max-width:900px){
  .cards.grid{ grid-template-columns:1fr !important; } /* FIX */
}
/* ===== FIX: vídeos (YouTube/Vimeo) responsivos no mobile ===== */
:where(.content, .page-content) iframe[src*="youtube.com"],
:where(.content, .page-content) iframe[src*="youtu.be"],
:where(.content, .page-content) iframe[src*="vimeo.com"]{
  display:block;
  width:100% !important;
  height:auto !important;
  aspect-ratio:16 / 9;           /* calcula a altura automaticamente */
  max-width:100%;
  border:0;
}

/* Se o plugin colocar o iframe dentro de wrappers com altura fixa */
:where(.content, .page-content) .wp-block-embed,
:where(.content, .page-content) .wp-block-embed__wrapper,
:where(.content, .page-content) [class*="embed"],
:where(.content, .page-content) [class*="video"]{
  max-width:100%;
}

/* Cinturão de segurança: se algum wrapper tiver height travado no mobile */
@media (max-width: 900px){
  :where(.content, .page-content) .wp-block-embed,
  :where(.content, .page-content) [class*="embed"],
  :where(.content, .page-content) [class*="video"]{
    height:auto !important;
    overflow:visible;            /* evita corte do player */
  }
}
/* ========================================
   MELHORIAS FRONT-PAGE (Avocado Flux)
   ======================================== */

/* ---------- Categorias em Destaque ---------- */
.avflux-categories .grid-4 { gap: 20px }

.cat-card { 
  position: relative; 
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease;
}

.cat-card:hover { 
  transform: translateY(-4px);
  box-shadow: var(--av-shadow-md);
}

.cat-card .cat-thumb {
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: .6rem;
  transition: transform .35s ease;
  display: block;
}

.cat-card:hover .cat-thumb { 
  transform: scale(1.08);
}

.cat-card .card-title { 
  margin-top: 12px;
  font-size: 1.15rem;
}

.cat-card .card-meta {
  margin-top: 6px;
  font-size: .85rem;
}

/* ---------- Seção Visual (Vídeos/Destaque) ---------- */
.avflux-visual .grid-4 { gap: 16px }

.visual-card {
  position: relative;
  overflow: hidden;
  border-radius: var(--av-radius-lg);
  min-height: 220px;
  padding: 0 !important;
}

.visual-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s ease, filter .35s ease;
}

.visual-card:hover img {
  transform: scale(1.1);
  filter: brightness(.85);
}

.visual-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    0deg,
    rgba(0,0,0,.85) 0%,
    rgba(0,0,0,.35) 50%,
    transparent 100%
  );
  display: flex;
  align-items: flex-end;
  padding: 16px;
  z-index: 2;
  pointer-events: none;
}

.visual-overlay .card-title {
  color: #fff;
  margin: 0;
  font-size: 1rem;
  line-height: 1.3;
  text-shadow: 0 2px 8px rgba(0,0,0,.5);
}

/* ---------- Grid 4 colunas (responsivo) ---------- */
.grid-4 { 
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

@media (max-width: 1100px) { 
  .grid-4 { grid-template-columns: repeat(2, 1fr); } 
}

@media (max-width: 600px) { 
  .grid-4 { grid-template-columns: 1fr; }
  .cat-card .cat-thumb { height: 160px; }
  .visual-card { min-height: 180px; }
}

/* ---------- Espaçamento entre seções ---------- */
.avflux-categories,
.avflux-visual {
  scroll-margin-top: calc(var(--header-h) + 24px);
}

/* ---------- Performance: content-visibility ---------- */
.avflux-categories .cat-card,
.avflux-visual .visual-card {
  content-visibility: auto;
  contain-intrinsic-size: 1px 280px;
}
/* ========================================
   SISTEMA DE BADGES (Avocado Flux)
   ======================================== */

/* Container de badges (sobre a imagem) */
.card-thumb-wrap {
  position: relative;
  overflow: hidden;
  border-radius: .6rem;
}

.card-badges {
  position: absolute;
  top: 10px;
  left: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  z-index: 3;
}

/* Badges overlay (cards visuais) */
.card-badges--overlay {
  top: 12px;
  left: 12px;
}

/* Badge base */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .3px;
  text-transform: uppercase;
  line-height: 1.2;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, .15);
  transition: transform .2s ease, box-shadow .2s ease;
}

.badge:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, .25);
}

/* Badge: Novo */
.badge--new {
  background: linear-gradient(135deg, #10b981, #059669);
  color: #fff;
}

/* Badge: Popular */
.badge--popular {
  background: linear-gradient(135deg, #f59e0b, #d97706);
  color: #fff;
}

/* Badge: Destaque */
.badge--featured {
  background: linear-gradient(135deg, #8b5cf6, #7c3aed);
  color: #fff;
}

/* Badge: Atualizado */
.badge--updated {
  background: linear-gradient(135deg, #3b82f6, #2563eb);
  color: #fff;
}

/* Badge: Vídeo */
.badge--video {
  background: linear-gradient(135deg, #ef4444, #dc2626);
  color: #fff;
  font-size: 1rem;
  padding: 4px 8px;
}

/* Modo claro: ajusta contraste */
html[data-theme="light"] .badge {
  box-shadow: 0 2px 8px rgba(0, 0, 0, .2);
}

html[data-theme="light"] .badge:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, .3);
}

/* Categoria inline (nos cards) */
.cat-inline {
  color: var(--av-accent);
  font-weight: 600;
  font-size: .85rem;
}

/* Mobile: badges menores */
@media (max-width: 600px) {
  .badge {
    font-size: .7rem;
    padding: 3px 8px;
  }
  
  .card-badges {
    top: 8px;
    left: 8px;
    gap: 4px;
  }
}

/* Performance: content-visibility */
.badge {
  content-visibility: auto;
}
/* ========================================
   SIDEBAR DINÂMICA (Avocado Flux)
   ======================================== */

/* Layout: Conteúdo + Sidebar (70/30) */
.single-with-sidebar,
.archive-with-sidebar {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 40px;
  align-items: start;
}

/* Sticky sidebar (não sai da tela ao rolar) */
.sidebar {
  position: sticky;
  top: calc(var(--header-h) + 24px);
  max-height: calc(100vh - var(--header-h) - 48px);
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
  scrollbar-color: var(--av-accent) transparent;
}

.sidebar::-webkit-scrollbar {
  width: 6px;
}

.sidebar::-webkit-scrollbar-track {
  background: transparent;
}

.sidebar::-webkit-scrollbar-thumb {
  background: var(--av-accent);
  border-radius: 999px;
}

/* Widgets */
.widget {
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  border: 1px solid #14222c;
  border-radius: var(--av-radius-lg);
  padding: 20px;
  margin-bottom: 24px;
}

.widget:last-child {
  margin-bottom: 0;
}

.widget-title {
  margin: 0 0 16px 0;
  font-size: 1.1rem;
  color: var(--av-text);
  border-bottom: 2px solid var(--av-accent);
  padding-bottom: 8px;
}

/* Widget: Lista de posts */
.widget-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.widget-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
}

.widget-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.widget-thumb {
  flex: 0 0 60px;
  height: 60px;
  border-radius: .5rem;
  overflow: hidden;
}

.widget-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s ease;
}

.widget-thumb:hover img {
  transform: scale(1.1);
}

.widget-content {
  flex: 1 1 auto;
  min-width: 0;
}

.widget-link {
  display: block;
  color: var(--av-text);
  text-decoration: none;
  font-weight: 600;
  font-size: .95rem;
  line-height: 1.3;
  margin-bottom: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.widget-link:hover {
  color: var(--av-accent);
  text-decoration: underline;
}

.widget-meta {
  font-size: .8rem;
  color: var(--av-muted);
}

/* Widget: Categorias */
.widget-categories li {
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
}

.widget-categories li:last-child {
  border-bottom: none;
}

.widget-categories a {
  color: var(--av-text);
  text-decoration: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: color .2s ease;
}

.widget-categories a:hover {
  color: var(--av-accent);
}

.cat-count {
  color: var(--av-muted);
  font-size: .85rem;
}

/* Widget: Busca */
.widget-searchform {
  display: flex;
  gap: 8px;
}

.widget-search-input {
  flex: 1;
  padding: 10px 12px;
  border-radius: .6rem;
  border: 1px solid #1b2a35;
  background: rgba(255,255,255,.02);
  color: var(--av-text);
}

.widget-search-btn {
  white-space: nowrap;
  padding: 10px 16px;
}

/* Mobile: sidebar vai para baixo */
@media (max-width: 1024px) {
  .single-with-sidebar,
  .archive-with-sidebar {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  
  .sidebar {
    position: static;
    max-height: none;
    overflow: visible;
  }
}

/* Tablet: 2 colunas nos arquivos */
@media (max-width: 900px) and (min-width:601px) {
.archive-main .grid-2 {
grid-template-columns: 1fr;
}
}
/* Mobile: 1 coluna */
@media (max-width: 600px) {
.single-with-sidebar,
.archive-with-sidebar {
gap: 24px;
}
.widget {
padding: 16px;
}
.widget-thumb {
flex: 0 0 50px;
height: 50px;
}
}
/* Modo claro */
html[data-theme="light"] .widget {
border-color: #e6eef7;
}
html[data-theme="light"] .widget-item {
border-bottom-color: rgba(0,0,0,.08);
}
html[data-theme="light"] .widget-categories li {
border-bottom-color: rgba(0,0,0,.08);
}
/* ========================================
   HOME: LAYOUT COM SIDEBAR
   ======================================== */

.home-with-sidebar {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 40px;
  align-items: start;
}

.home-main {
  min-width: 0; /* evita overflow */
}

.home-sidebar {
  position: sticky;
  top: calc(var(--header-h) + 24px);
  max-height: calc(100vh - var(--header-h) - 48px);
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
  scrollbar-color: var(--av-accent) transparent;
}

.home-sidebar::-webkit-scrollbar {
  width: 6px;
}

.home-sidebar::-webkit-scrollbar-track {
  background: transparent;
}

.home-sidebar::-webkit-scrollbar-thumb {
  background: var(--av-accent);
  border-radius: 999px;
}

/* Mobile: sidebar embaixo */
@media (max-width: 1024px) {
  .home-with-sidebar {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  
  .home-sidebar {
    position: static;
    max-height: none;
    overflow: visible;
  }
}

/* Tablet: ajusta espaçamento */
@media (max-width: 900px) {
  .home-with-sidebar {
    gap: 24px;
  }
}
