/* ============================================================
   INTERFALA — Blog CSS
   Estilos do Blog. Carregar APÓS variables.css e components.css.
   ============================================================ */

/* ============================================================
   BASE RESET DO TEMA
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:140px}
body{
  font-family:var(--font-body,'Inter Tight',system-ui,sans-serif);
  font-size:16px;line-height:1.6;
  color:var(--color-gray-900,#1a1130);
  background:#fff;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
h1,h2,h3,h4,h5{
  font-family:var(--font-display,'Sora',system-ui,sans-serif);
  letter-spacing:-0.03em;line-height:1.15;
  color:var(--color-gray-900,#1a1130);
}
p{color:var(--color-gray-700,#4a4365);line-height:1.7}
.container{max-width:1180px;margin:0 auto;padding:0 24px}

/* Utilitários compartilhados */
.section-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(113,48,240,0.08);border:1px solid rgba(113,48,240,0.15);
  color:var(--color-purple,#7130f0);
  font-family:var(--font-display,'Sora',system-ui,sans-serif);
  font-size:13px;font-weight:600;padding:6px 14px;border-radius:99px;
  letter-spacing:-0.01em;margin-bottom:14px;
}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display,'Sora',system-ui,sans-serif);
  font-weight:600;font-size:15px;border-radius:10px;
  padding:14px 28px;transition:all 0.2s;letter-spacing:-0.01em;
  white-space:nowrap;text-decoration:none;
}
.btn-primary{background:var(--color-purple,#7130f0);color:#fff;box-shadow:0 10px 40px rgba(113,48,240,0.35)}
.btn-primary:hover{background:#5f24d6;transform:translateY(-3px)}
.btn-ghost{background:transparent;color:var(--color-purple,#7130f0);border:1.5px solid rgba(113,48,240,0.3)}
.btn-ghost:hover{background:rgba(113,48,240,0.06);transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--color-purple,#7130f0)}
.btn-white:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(255,255,255,0.25)}
.btn-outline-white{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,0.4)}
.btn-outline-white:hover{background:rgba(255,255,255,0.08);transform:translateY(-2px)}
.btn-arrow{transition:transform 0.2s;display:inline-block}
.btn:hover .btn-arrow{transform:translateX(4px)}

/* Animação fade-up */
.fade-up{opacity:0;transform:translateY(20px);transition:opacity 0.7s cubic-bezier(0.16,1,0.3,1),transform 0.7s cubic-bezier(0.16,1,0.3,1)}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up.d1{transition-delay:0.05s}.fade-up.d2{transition-delay:0.1s}
.fade-up.d3{transition-delay:0.15s}.fade-up.d4{transition-delay:0.2s}
.fade-up.d5{transition-delay:0.25s}.fade-up.d6{transition-delay:0.3s}

/* ============================================================
   1. READING PROGRESS BAR
   ============================================================ */
.reading-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:300;background:transparent;pointer-events:none}
.reading-progress-bar{
  height:100%;width:0%;
  background:linear-gradient(90deg,var(--color-purple),var(--color-cyan));
  transition:width 80ms linear;
  box-shadow:0 0 14px rgba(0,255,210,0.45);
}

/* ============================================================
   2. BLOG HERO
   ============================================================ */
.blog-hero{
  position:relative;background:var(--color-lavender);
  padding:96px 0 80px;overflow:hidden;text-align:center;
  border-bottom:1px solid rgba(113,48,240,0.06);
}
.blog-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(113,48,240,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(113,48,240,0.05) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(0,0,0,1) 30%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(0,0,0,1) 30%,transparent 100%);
}
.blog-hero::after{
  content:'';position:absolute;top:-220px;left:50%;transform:translateX(-50%);
  width:900px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(174,98,255,0.18) 0%,transparent 60%);
  pointer-events:none;
}
.blog-hero-inner{position:relative;z-index:1;max-width:820px;margin:0 auto;padding:0 24px}
.blog-hero h1{font-size:clamp(2.4rem,5vw,3.8rem);font-weight:800;line-height:1.05;letter-spacing:-0.04em;margin:14px 0 18px}
.blog-hero h1 .grad{
  background:linear-gradient(135deg,var(--color-purple) 0%,var(--color-purple-light) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  position:relative;display:inline-block;
}
.blog-hero h1 .grad::after{
  content:'';position:absolute;left:0;right:0;bottom:-6px;
  height:5px;border-radius:99px;background:var(--color-cyan);opacity:0.55;transform:skew(-3deg);
}
.blog-hero-sub{font-size:19px;color:var(--color-gray-500);line-height:1.6;max-width:600px;margin:0 auto 36px;text-wrap:pretty}

/* Search bar */
.blog-search{max-width:560px;margin:0 auto;position:relative}
.blog-search input{
  width:100%;font-family:var(--font-body);font-size:16px;color:var(--color-gray-900);
  padding:18px 22px 18px 56px;background:#fff;
  border:1.5px solid var(--color-gray-300);border-radius:99px;
  box-shadow:0 8px 32px rgba(16,10,60,0.06);
  transition:border-color .2s var(--ease-out),box-shadow .2s var(--ease-out),transform .2s var(--ease-out);
  outline:none;
}
.blog-search input::placeholder{color:var(--color-gray-500)}
.blog-search input:focus{
  border-color:var(--color-purple);
  box-shadow:0 12px 40px rgba(113,48,240,0.18),0 0 0 4px rgba(113,48,240,0.08);
  transform:translateY(-1px);
}
.blog-search-icon{position:absolute;left:22px;top:50%;transform:translateY(-50%);color:var(--color-gray-500);width:20px;height:20px;pointer-events:none}
.blog-search button{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  background:var(--color-purple);color:#fff;
  font-family:var(--font-display);font-weight:600;font-size:14px;
  padding:11px 22px;border-radius:99px;
  transition:background .2s,transform .2s;letter-spacing:-0.01em;
}
.blog-search button:hover{background:#5f24d6;transform:translateY(-50%) scale(1.03)}

/* ============================================================
   3. FEATURED POST
   ============================================================ */
.featured-post-section{padding:72px 0 24px;background:#fff}
.featured-post{
  display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center;
  background:#fff;border:1px solid var(--color-gray-300);
  border-radius:var(--radius-2xl);padding:28px;position:relative;
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out);overflow:hidden;
}
.featured-post::before{
  content:'EM DESTAQUE';position:absolute;top:48px;left:48px;z-index:2;
  font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:0.12em;
  background:var(--color-ink);color:var(--color-cyan);padding:6px 12px;border-radius:99px;
}
.featured-post:hover{transform:translateY(-4px);box-shadow:var(--shadow-lifted);border-color:rgba(113,48,240,0.18)}
.featured-post-img{position:relative;border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:16/10}
.featured-post-img .cover-art, .featured-post-img img{transition:transform .6s var(--ease-out)}
.featured-post:hover .featured-post-img .cover-art,
.featured-post:hover .featured-post-img img{transform:scale(1.04)}
.featured-post-body{padding:8px 16px 8px 0;display:flex;flex-direction:column;gap:18px}
.featured-post-body .post-cat{align-self:flex-start}
.featured-post-body h2{font-family:var(--font-display);font-size:clamp(1.6rem,2.6vw,2.1rem);font-weight:800;line-height:1.15;letter-spacing:-0.03em;color:var(--color-gray-900);text-wrap:balance}
.featured-post-body h2 a{color:inherit;background-image:linear-gradient(var(--color-purple),var(--color-purple));background-size:0% 2px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .35s var(--ease-out)}
.featured-post-body h2 a:hover{background-size:100% 2px}
.featured-post-body .excerpt{font-size:16px;color:var(--color-gray-500);line-height:1.7;text-wrap:pretty}
.featured-post-body .post-meta{margin-top:auto}
.featured-post-cta{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;margin-top:8px}

/* ============================================================
   4. CATEGORY FILTER PILLS
   ============================================================ */
.cat-filter-wrap{
  background:#fff;border-bottom:1px solid var(--color-gray-300);
  position:sticky;top:var(--header-h,64px);z-index:50;
  backdrop-filter:blur(8px);background:rgba(255,255,255,0.92);
}
.cat-filter{
  display:flex;align-items:center;gap:8px;padding:14px 0;
  overflow-x:auto;scrollbar-width:none;scroll-snap-type:x mandatory;
}
.cat-filter::-webkit-scrollbar{display:none}
.cat-pill{
  flex-shrink:0;scroll-snap-align:start;
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-display);font-size:14px;font-weight:600;letter-spacing:-0.01em;
  color:var(--color-gray-700);background:var(--color-gray-100);
  border:1px solid transparent;padding:9px 16px;border-radius:99px;
  cursor:pointer;text-decoration:none;transition:all .2s var(--ease-out);white-space:nowrap;
}
.cat-pill:hover{background:#ece6fa;color:var(--color-purple)}
.cat-pill.active{background:var(--color-purple);color:#fff;box-shadow:0 8px 22px rgba(113,48,240,0.25)}
.cat-pill .pill-emoji{font-size:14px;line-height:1}

/* ============================================================
   5. POSTS GRID + POST CARD
   ============================================================ */
.posts-grid-section{padding:56px 0 80px;background:#fff}
.posts-grid-head{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:36px;flex-wrap:wrap}
.posts-grid-head h2{font-family:var(--font-display);font-size:clamp(1.6rem,2.4vw,2rem);font-weight:800;letter-spacing:-0.03em}
.posts-grid-head .count{font-size:14px;color:var(--color-gray-500)}
.posts-grid-head select{
  font-family:var(--font-body);font-size:14px;color:var(--color-gray-700);
  background:#fff;border:1px solid var(--color-gray-300);
  padding:9px 36px 9px 14px;border-radius:99px;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238b85a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center;cursor:pointer;
}
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.post-card{
  background:#fff;border:1px solid var(--color-gray-300);
  border-radius:var(--radius-xl);overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out),border-color .35s var(--ease-out);
  position:relative;
}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lifted);border-color:rgba(113,48,240,0.18)}
.post-card-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--color-gray-100)}
.post-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .55s var(--ease-out)}
.post-card-img .cover-art{transition:transform .55s var(--ease-out)}
.post-card:hover .post-card-img img,
.post-card:hover .post-card-img .cover-art{transform:scale(1.05)}
.post-card-img .post-cat{position:absolute;top:14px;left:14px;z-index:2}
.post-card-body{padding:22px 24px 20px;display:flex;flex-direction:column;gap:12px;flex:1}
.post-card-body h3{
  font-family:var(--font-display);font-size:19px;font-weight:700;line-height:1.3;letter-spacing:-0.02em;
  color:var(--color-gray-900);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-wrap:balance;
}
.post-card-body h3 a{color:inherit}
.post-card-body h3 a:hover{color:var(--color-purple)}
.post-card-body .excerpt{
  font-size:14px;color:var(--color-gray-500);line-height:1.6;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-wrap:pretty;
}
.post-card .post-meta{margin-top:auto;padding-top:14px;border-top:1px solid var(--color-gray-100)}
.post-card-link-overlay{position:absolute;inset:0;z-index:1}

/* ============================================================
   6. POST META
   ============================================================ */
.post-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;color:var(--color-gray-500)}
.post-meta .author{display:inline-flex;align-items:center;gap:8px;color:var(--color-gray-700);font-weight:500}
.post-meta .author .avatar{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--color-purple),var(--color-purple-light));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:11px;font-weight:700;flex-shrink:0;
}
.post-meta .author .avatar.lg{width:40px;height:40px;font-size:14px}
.post-meta .sep{color:var(--color-gray-300)}
.post-meta .read-time{display:inline-flex;align-items:center;gap:4px}
.post-meta .read-time svg{width:13px;height:13px}

/* Category badge */
.post-cat{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
  padding:5px 10px;border-radius:99px;background:#fff;color:var(--color-purple);
  border:1px solid rgba(113,48,240,0.2);text-decoration:none;transition:all .2s;
}
.post-cat:hover{background:var(--color-purple);color:#fff;border-color:transparent}
.post-cat.cat-tutoriais{color:#5f24d6;border-color:rgba(95,36,214,0.25)}
.post-cat.cat-estrategia{color:#0099a0;border-color:rgba(0,204,170,0.35);background:rgba(0,255,210,0.08)}
.post-cat.cat-cases{color:#b2511f;border-color:rgba(240,148,51,0.35);background:rgba(240,148,51,0.08)}
.post-cat.cat-novidades{color:#aa39c8;border-color:rgba(221,140,245,0.45);background:rgba(221,140,245,0.1)}
.post-cat.cat-tendencias{color:#3a4ad9;border-color:rgba(59,130,246,0.3);background:rgba(59,130,246,0.08)}

/* ============================================================
   7. PAGINATION
   ============================================================ */
.pagination,
.nav-links{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;margin-top:56px}
.pagination a, .pagination span,
.nav-links a, .nav-links span{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;height:42px;padding:0 14px;
  font-family:var(--font-display);font-size:14px;font-weight:600;
  border-radius:10px;color:var(--color-gray-700);
  background:#fff;border:1px solid var(--color-gray-300);
  transition:all .2s;text-decoration:none;
}
.pagination a:hover,
.nav-links a:hover{color:var(--color-purple);border-color:var(--color-purple);background:rgba(113,48,240,0.05)}
.pagination .current, .nav-links .current,
.pagination span.current{background:var(--color-purple);color:#fff;border-color:transparent;box-shadow:0 6px 18px rgba(113,48,240,0.3)}
.pagination .dots, .nav-links .dots{background:none;border:none;color:var(--color-gray-500)}
.pagination .prev, .pagination .next,
.nav-links .prev, .nav-links .next{padding:0 18px}

/* ============================================================
   8. NEWSLETTER CTA
   ============================================================ */
.newsletter-cta{
  background:var(--color-ink);color:#fff;
  padding:96px 0;position:relative;overflow:hidden;
  border-top:1px solid rgba(255,255,255,0.06);
}
.newsletter-cta::before{
  content:'';position:absolute;top:-200px;left:-100px;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(113,48,240,0.4) 0%,transparent 60%);pointer-events:none;
}
.newsletter-cta::after{
  content:'';position:absolute;bottom:-200px;right:-100px;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,255,210,0.18) 0%,transparent 60%);pointer-events:none;
}
.newsletter-inner{position:relative;z-index:1;max-width:620px;margin:0 auto;padding:0 24px;text-align:center}
.newsletter-inner .section-badge{background:rgba(0,255,210,0.08);border-color:rgba(0,255,210,0.18);color:var(--color-cyan)}
.newsletter-inner h2{color:#fff;font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:800;letter-spacing:-0.03em;line-height:1.1;margin:14px 0 14px;text-wrap:balance}
.newsletter-inner p{color:rgba(255,255,255,0.65);font-size:17px;line-height:1.6;margin-bottom:32px;text-wrap:pretty}
.newsletter-form{
  display:flex;gap:8px;background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.12);padding:6px;border-radius:99px;
  max-width:480px;margin:0 auto 16px;transition:border-color .2s,background .2s;
}
.newsletter-form:focus-within{border-color:rgba(0,255,210,0.4);background:rgba(255,255,255,0.07)}
.newsletter-form input{flex:1;background:transparent;border:none;outline:none;font-family:var(--font-body);font-size:15px;color:#fff;padding:0 18px}
.newsletter-form input::placeholder{color:rgba(255,255,255,0.4)}
.newsletter-form button{
  background:var(--color-cyan);color:var(--color-ink);
  font-family:var(--font-display);font-weight:700;font-size:14px;
  padding:13px 24px;border-radius:99px;transition:transform .2s,box-shadow .2s;letter-spacing:-0.01em;
}
.newsletter-form button:hover{transform:scale(1.03);box-shadow:0 8px 24px rgba(0,255,210,0.4)}
.newsletter-fineprint{font-size:13px;color:rgba(255,255,255,0.4);display:inline-flex;align-items:center;gap:6px}

/* ============================================================
   9. POST INDIVIDUAL — Breadcrumb, Hero, Featured image
   ============================================================ */
.breadcrumb{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;color:var(--color-gray-500);margin-bottom:24px}
.breadcrumb a{color:var(--color-gray-500);transition:color .15s}
.breadcrumb a:hover{color:var(--color-purple)}
.breadcrumb .sep{color:var(--color-gray-300)}
.breadcrumb .current{color:var(--color-gray-900);font-weight:500}

.article-hero{background:linear-gradient(180deg,var(--color-lavender) 0%,#fff 100%);padding:64px 0 48px;position:relative;overflow:hidden}
.article-hero::before{
  content:'';position:absolute;top:-300px;left:50%;transform:translateX(-50%);
  width:1100px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(174,98,255,0.12) 0%,transparent 65%);pointer-events:none;
}
.article-hero-inner{position:relative;z-index:1;max-width:820px;margin:0 auto;padding:0 24px}
.article-hero h1{font-size:clamp(2rem,4.2vw,3.2rem);font-weight:800;line-height:1.1;letter-spacing:-0.035em;margin:18px 0 18px;text-wrap:balance}
.article-dek{font-size:20px;line-height:1.55;color:var(--color-gray-700);margin-bottom:32px;font-weight:400;text-wrap:pretty}
.article-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:20px 0;border-top:1px solid rgba(113,48,240,0.1);border-bottom:1px solid rgba(113,48,240,0.1)}
.article-meta-author{display:flex;align-items:center;gap:12px}
.article-meta-author .name{font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--color-gray-900);letter-spacing:-0.01em}
.article-meta-author .role{font-size:12px;color:var(--color-gray-500)}
.article-meta-info{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:13px;color:var(--color-gray-500);margin-left:auto}
.article-meta-info .info-item{display:inline-flex;align-items:center;gap:6px}
.article-meta-info svg{width:14px;height:14px}
.article-meta-share{display:flex;align-items:center;gap:6px;margin-left:auto}
.share-btn{
  width:36px;height:36px;border-radius:10px;background:#fff;
  border:1px solid var(--color-gray-300);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--color-gray-700);transition:all .2s;cursor:pointer;text-decoration:none;
}
.share-btn:hover{background:var(--color-purple);color:#fff;border-color:transparent;transform:translateY(-2px)}
.share-btn svg{width:15px;height:15px}
.share-btn.copied{background:var(--color-cyan);color:var(--color-ink);border-color:transparent}

.article-featured-img{max-width:1100px;margin:0 auto;padding:0 24px}
.article-featured-img-inner{border-radius:var(--radius-2xl);overflow:hidden;aspect-ratio:16/9;box-shadow:0 30px 80px rgba(16,10,60,0.15)}
.article-featured-img-inner img{width:100%;height:100%;object-fit:cover}

/* ============================================================
   10. ARTICLE LAYOUT (TOC + content + share)
   ============================================================ */
.article-layout{
  display:grid;grid-template-columns:240px minmax(0,720px) 60px;
  gap:64px;max-width:1180px;margin:0 auto;padding:80px 24px 96px;position:relative;
}
.article-toc{
  position:sticky;top:calc(var(--header-h,64px) + 24px);
  align-self:start;max-height:calc(100vh - 120px);overflow-y:auto;padding-right:8px;
}
.article-toc h4{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--color-gray-500);margin-bottom:16px}
.article-toc ul{display:flex;flex-direction:column;gap:2px}
.article-toc li a{
  display:block;padding:8px 12px 8px 14px;font-size:13px;line-height:1.4;
  color:var(--color-gray-700);border-left:2px solid var(--color-gray-300);
  margin-left:-2px;transition:all .2s;text-decoration:none;
}
.article-toc li a:hover{color:var(--color-purple);border-left-color:rgba(113,48,240,0.4)}
.article-toc li a.active{color:var(--color-purple);font-weight:600;border-left-color:var(--color-purple);background:rgba(113,48,240,0.04)}
.article-share-sticky{
  position:sticky;top:calc(var(--header-h,64px) + 24px);
  align-self:start;display:flex;flex-direction:column;gap:8px;align-items:center;
}
.article-share-sticky .label{
  font-family:var(--font-display);font-size:10px;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--color-gray-500);
  writing-mode:vertical-rl;transform:rotate(180deg);margin-bottom:8px;
}

/* ============================================================
   11. ENTRY-CONTENT (the_content / Gutenberg)
   ============================================================ */
.entry-content{font-family:var(--font-body);font-size:18px;line-height:1.8;color:var(--color-gray-700)}
.entry-content > * + *{margin-top:24px}
.entry-content p{color:var(--color-gray-700);text-wrap:pretty}

/* Headings */
.entry-content h2{
  font-family:var(--font-display);font-size:30px;font-weight:700;line-height:1.2;letter-spacing:-0.03em;
  color:var(--color-gray-900);margin-top:56px;margin-bottom:18px;
  scroll-margin-top:100px;position:relative;text-wrap:balance;
}
.entry-content h2::before{
  content:'';position:absolute;left:-20px;top:14px;width:6px;height:20px;
  background:linear-gradient(180deg,var(--color-purple),var(--color-purple-light));border-radius:99px;
}
.entry-content h3{font-family:var(--font-display);font-size:22px;font-weight:700;line-height:1.25;letter-spacing:-0.02em;color:var(--color-gray-900);margin-top:40px;margin-bottom:14px}
.entry-content h4{font-family:var(--font-display);font-size:18px;font-weight:700;line-height:1.3;letter-spacing:-0.02em;color:var(--color-gray-900);margin-top:32px;margin-bottom:12px}

/* Links */
.entry-content a{color:var(--color-purple);text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:3px;transition:text-decoration-thickness .15s,color .15s}
.entry-content a:hover{text-decoration-thickness:3px;color:#5f24d6}
.entry-content strong{color:var(--color-gray-900);font-weight:700}
.entry-content em{font-style:italic}

/* Lists */
.entry-content ul,.entry-content ol{padding-left:8px}
.entry-content ul li,.entry-content ol li{position:relative;padding-left:28px;margin-bottom:10px;line-height:1.7}
.entry-content ul li::before{content:'';position:absolute;left:4px;top:14px;width:8px;height:8px;border-radius:50%;background:var(--color-purple)}
.entry-content ol{counter-reset:olcount}
.entry-content ol li{counter-increment:olcount}
.entry-content ol li::before{
  content:counter(olcount);position:absolute;left:0;top:2px;
  width:22px;height:22px;border-radius:50%;
  background:rgba(113,48,240,0.1);color:var(--color-purple);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:11px;font-weight:700;
}
.entry-content li > ul,.entry-content li > ol{margin-top:10px;margin-bottom:10px}

/* Blockquote */
.entry-content blockquote,
.entry-content .wp-block-quote{
  position:relative;padding:28px 32px 28px 56px;margin:36px 0;
  background:var(--color-lavender);border-left:4px solid var(--color-purple);
  border-radius:0 var(--radius-lg) var(--radius-lg) 0;
  font-family:var(--font-display);font-size:20px;font-weight:500;line-height:1.5;
  color:var(--color-gray-900);font-style:italic;text-wrap:balance;
}
.entry-content blockquote::before,
.entry-content .wp-block-quote::before{
  content:'"';position:absolute;left:20px;top:0;
  font-family:'Sora',serif;font-size:60px;font-weight:800;font-style:normal;
  color:var(--color-purple);opacity:0.4;line-height:1;
}
.entry-content blockquote cite,
.entry-content .wp-block-quote cite{display:block;margin-top:14px;font-family:var(--font-body);font-size:14px;font-style:normal;font-weight:600;color:var(--color-gray-500)}
.entry-content blockquote cite::before,
.entry-content .wp-block-quote cite::before{content:'— '}

/* Pull quote */
.entry-content .wp-block-pullquote{padding:48px 0;margin:48px 0;text-align:center;border-top:2px solid rgba(113,48,240,0.15);border-bottom:2px solid rgba(113,48,240,0.15);background:none}
.entry-content .wp-block-pullquote p{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1.3;color:var(--color-gray-900);letter-spacing:-0.02em;text-wrap:balance}
.entry-content .wp-block-pullquote blockquote::before{display:none}

/* Images */
.entry-content img,
.entry-content .wp-block-image img{width:100%;height:auto;border-radius:var(--radius-xl);box-shadow:0 16px 48px rgba(16,10,60,0.1);margin:8px 0}
.entry-content figure,.entry-content .wp-block-image{margin:36px 0}
.entry-content figcaption,.wp-caption-text{font-size:13px;color:var(--color-gray-500);text-align:center;font-style:italic;margin-top:12px;line-height:1.5}

/* Alinhamentos WP */
.alignleft{float:left;margin:0 24px 16px 0}
.alignright{float:right;margin:0 0 16px 24px}
.aligncenter{display:block;margin:0 auto}
.alignwide{max-width:1000px;margin-left:auto;margin-right:auto}
.alignfull{width:100vw;max-width:100vw;margin-left:calc(-50vw + 50%)}

/* Code */
.entry-content pre,
.entry-content .wp-block-code{
  background:var(--color-ink);color:#e8e3f8;padding:24px 28px;border-radius:var(--radius-xl);
  overflow-x:auto;font-family:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace;
  font-size:14px;line-height:1.7;margin:32px 0;position:relative;
  box-shadow:0 16px 48px rgba(16,10,60,0.15);
}
.entry-content pre::before{
  content:'';position:absolute;top:14px;left:18px;width:10px;height:10px;border-radius:50%;
  background:#ff5f57;box-shadow:18px 0 0 #ffbd2e,36px 0 0 #28c840;
}
.entry-content pre code{background:none;padding:0;color:inherit;font-size:inherit;display:block;margin-top:24px}
.entry-content code{
  background:var(--color-gray-100);color:#5f24d6;
  font-family:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace;
  font-size:0.88em;padding:2px 8px;border-radius:6px;border:1px solid rgba(113,48,240,0.1);
}

/* Tables */
.entry-content table,
.entry-content .wp-block-table table{
  width:100%;border-collapse:separate;border-spacing:0;margin:32px 0;font-size:15px;
  border:1px solid var(--color-gray-300);border-radius:var(--radius-xl);overflow:hidden;
}
.entry-content thead{background:var(--color-gray-100)}
.entry-content th{font-family:var(--font-display);font-size:13px;font-weight:700;text-align:left;color:var(--color-gray-900);padding:14px 18px;border-bottom:1px solid var(--color-gray-300);text-transform:uppercase;letter-spacing:0.05em}
.entry-content td{padding:14px 18px;border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-700)}
.entry-content tbody tr:last-child td{border-bottom:none}
.entry-content tbody tr{transition:background .15s}
.entry-content tbody tr:hover{background:rgba(113,48,240,0.03)}

/* HR */
.entry-content hr{border:none;margin:48px 0;height:1px;background:none;display:flex;align-items:center;justify-content:center;position:relative}
.entry-content hr::before{content:'• • •';color:var(--color-gray-300);font-size:18px;letter-spacing:0.6em}

/* WP block button */
.entry-content .wp-block-button{margin:32px 0}
.entry-content .wp-block-button .wp-block-button__link{
  display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);
  font-weight:600;font-size:15px;color:#fff !important;background:var(--color-purple);
  padding:14px 28px;border-radius:10px;box-shadow:0 10px 30px rgba(113,48,240,0.3);
  transition:all .2s;text-decoration:none;
}
.entry-content .wp-block-button .wp-block-button__link:hover{background:#5f24d6;transform:translateY(-2px)}

/* Embed responsivo */
.entry-content .wp-block-embed{margin:32px 0}
.entry-content .wp-block-embed__wrapper{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:var(--radius-xl)}
.entry-content .wp-block-embed__wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%}

/* ============================================================
   12. CALLOUTS
   ============================================================ */
.callout{position:relative;padding:20px 24px 20px 60px;margin:32px 0;border-radius:var(--radius-lg);border-left:4px solid;font-size:16px;line-height:1.7}
.callout::before{position:absolute;left:18px;top:18px;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-family:var(--font-display);font-weight:700}
.callout > *:first-child{margin-top:0}
.callout > *:last-child{margin-bottom:0}
.callout strong{display:block;margin-bottom:4px;font-family:var(--font-display);font-size:14px;letter-spacing:-0.01em;color:var(--color-gray-900)}
.callout-info{background:rgba(0,255,210,0.07);border-left-color:var(--color-cyan-dark)}
.callout-info::before{content:'i';background:var(--color-cyan-dark);color:#fff;font-style:italic}
.callout-tip{background:rgba(113,48,240,0.06);border-left-color:var(--color-purple)}
.callout-tip::before{content:'💡';background:rgba(113,48,240,0.12)}
.callout-warning{background:rgba(245,158,11,0.08);border-left-color:#f59e0b}
.callout-warning::before{content:'!';background:#f59e0b;color:#fff}

/* ============================================================
   13. AUTHOR CARD
   ============================================================ */
.author-card{
  max-width:720px;margin:64px auto 0;background:#fff;
  border:1px solid var(--color-gray-300);border-radius:var(--radius-xl);
  padding:28px 32px;display:flex;gap:20px;align-items:flex-start;
}
.author-card .avatar-lg{
  width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg,var(--color-purple),var(--color-purple-light));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:22px;font-weight:700;
  flex-shrink:0;box-shadow:0 8px 24px rgba(113,48,240,0.25);
}
.author-card .author-info{flex:1}
.author-card .author-label{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--color-gray-500);margin-bottom:6px}
.author-card h4{font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:-0.02em;margin-bottom:8px}
.author-card p{font-size:15px;color:var(--color-gray-500);line-height:1.6;margin-bottom:14px;text-wrap:pretty}
.author-card .author-socials{display:flex;gap:8px}
.author-card .author-socials a{width:32px;height:32px;border-radius:8px;background:var(--color-gray-100);display:inline-flex;align-items:center;justify-content:center;color:var(--color-gray-700);transition:all .2s}
.author-card .author-socials a:hover{background:var(--color-purple);color:#fff}
.author-card .author-socials svg{width:14px;height:14px}

/* ============================================================
   14. CONTEXTUAL CTA
   ============================================================ */
.contextual-cta{
  max-width:720px;margin:48px auto 0;
  background:linear-gradient(135deg,#4d387d 0%,var(--color-purple) 50%,#a64eff 100%);
  border-radius:var(--radius-2xl);padding:48px;color:#fff;
  position:relative;overflow:hidden;box-shadow:0 24px 64px rgba(113,48,240,0.3);
}
.contextual-cta::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(0,255,210,0.2) 0%,transparent 60%);pointer-events:none}
.contextual-cta::after{content:'';position:absolute;bottom:-80px;left:-80px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(174,98,255,0.3) 0%,transparent 60%);pointer-events:none}
.contextual-cta-inner{position:relative;z-index:1}
.contextual-cta .label{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--color-cyan);margin-bottom:10px}
.contextual-cta h3{font-family:var(--font-display);font-size:28px;font-weight:800;line-height:1.2;letter-spacing:-0.02em;color:#fff;margin-bottom:14px;text-wrap:balance}
.contextual-cta p{color:rgba(255,255,255,0.8);font-size:16px;line-height:1.6;margin-bottom:24px;text-wrap:pretty}
.contextual-cta-actions{display:flex;gap:12px;flex-wrap:wrap}

/* ============================================================
   15. RELATED POSTS
   ============================================================ */
.related-posts{padding:80px 0;background:var(--color-lavender);border-top:1px solid rgba(113,48,240,0.06)}
.related-posts-head{display:flex;align-items:end;justify-content:space-between;max-width:1180px;margin:0 auto 36px;padding:0 24px;flex-wrap:wrap;gap:16px}
.related-posts-head h2{font-family:var(--font-display);font-size:clamp(1.6rem,2.4vw,2rem);font-weight:800;letter-spacing:-0.03em}
.related-posts-head a{font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--color-purple);display:inline-flex;align-items:center;gap:4px}
.related-posts-head a:hover{gap:8px;transition:gap .2s}
.related-posts .posts-grid{max-width:1180px;margin:0 auto;padding:0 24px}

/* ============================================================
   16. CATEGORY HERO
   ============================================================ */
.category-hero{background:var(--color-lavender);padding:72px 0 64px;position:relative;overflow:hidden;border-bottom:1px solid rgba(113,48,240,0.06)}
.category-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(113,48,240,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(113,48,240,0.05) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(0,0,0,1) 30%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(0,0,0,1) 30%,transparent 100%);
}
.category-hero-inner{position:relative;z-index:1;max-width:820px;margin:0 auto;padding:0 24px}
.category-icon-large{width:72px;height:72px;border-radius:20px;background:linear-gradient(135deg,var(--color-purple),var(--color-purple-light));display:flex;align-items:center;justify-content:center;font-size:32px;margin-bottom:20px;box-shadow:0 16px 40px rgba(113,48,240,0.3)}
.category-hero h1{font-size:clamp(2.2rem,4.5vw,3.4rem);font-weight:800;line-height:1.05;letter-spacing:-0.04em;margin-bottom:18px}
.category-hero-desc{font-size:18px;color:var(--color-gray-500);line-height:1.6;max-width:600px;margin-bottom:20px;text-wrap:pretty}
.category-hero-count{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--color-purple);background:rgba(113,48,240,0.08);padding:6px 14px;border-radius:99px;border:1px solid rgba(113,48,240,0.15)}

/* ============================================================
   17. COVER ART (placeholders)
   ============================================================ */
.cover-art{position:absolute;inset:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);color:#fff}
.cover-art svg{position:absolute;inset:0;width:100%;height:100%}
.cover-art .cover-label{position:relative;z-index:2;font-size:14px;font-weight:700;letter-spacing:-0.01em;background:rgba(255,255,255,0.15);backdrop-filter:blur(8px);padding:6px 14px;border-radius:99px;border:1px solid rgba(255,255,255,0.25)}
.cover-art.theme-purple{background:linear-gradient(135deg,#4d387d 0%,#7130f0 50%,#ae62ff 100%)}
.cover-art.theme-cyan{background:linear-gradient(135deg,#0d2b4e 0%,#0c8aa8 50%,#00ffd2 120%)}
.cover-art.theme-ink{background:linear-gradient(135deg,#0a0613 0%,#1a1130 50%,#4d387d 100%)}
.cover-art.theme-orange{background:linear-gradient(135deg,#7c2d12 0%,#dc6720 50%,#fbbf24 110%)}
.cover-art.theme-pink{background:linear-gradient(135deg,#7e1f8a 0%,#dd8cf5 60%,#fce7ff 110%)}
.cover-art.theme-mint{background:linear-gradient(135deg,#064e3b 0%,#10b981 50%,#a7f3d0 110%)}

/* ============================================================
   18. TOC MOBILE TOGGLE
   ============================================================ */
.article-toc-toggle{display:none}

/* ============================================================
   19. RESPONSIVE
   ============================================================ */
@media (max-width: 1100px){
  .article-layout{grid-template-columns:200px minmax(0,1fr);gap:48px}
  .article-share-sticky{display:none}
}
@media (max-width: 900px){
  .featured-post{grid-template-columns:1fr;gap:24px;padding:20px}
  .featured-post-img{aspect-ratio:16/9}
  .featured-post::before{top:32px;left:32px}
  .featured-post-body{padding:0 8px 8px}
  .posts-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .article-layout{grid-template-columns:1fr;gap:0;padding:48px 24px 72px}
  .article-toc{
    position:static;background:var(--color-lavender);border-radius:var(--radius-lg);
    padding:16px 20px;margin-bottom:32px;max-height:none;
  }
  .article-toc.collapsed ul{display:none}
  .article-toc-toggle{
    display:flex;align-items:center;justify-content:space-between;width:100%;
    font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--color-gray-900);
    background:none;padding:0;cursor:pointer;
  }
  .article-toc-toggle svg{transition:transform .2s}
  .article-toc.collapsed .article-toc-toggle svg{transform:rotate(-90deg)}
  .article-toc h4{display:none}
}
@media (max-width: 700px){
  .blog-hero{padding:64px 0 56px}
  .blog-hero-sub{font-size:16px}
  .blog-search input{padding:16px 18px 16px 48px;font-size:15px}
  .blog-search-icon{left:18px}
  .blog-search button{padding:9px 16px;font-size:13px}
  .featured-post-section{padding:48px 0 16px}
  .featured-post::before{top:24px;left:24px}
  .posts-grid{grid-template-columns:1fr}
  .posts-grid-section{padding:40px 0 64px}
  .newsletter-form{flex-direction:column;border-radius:var(--radius-xl);padding:8px}
  .newsletter-form input{padding:12px 18px}
  .newsletter-form button{width:100%}
  .article-hero{padding:48px 0 36px}
  .article-dek{font-size:17px}
  .article-meta{flex-direction:column;align-items:flex-start;gap:14px}
  .article-meta-info{margin-left:0}
  .article-meta-share{margin-left:0}
  .entry-content{font-size:16px;line-height:1.7}
  .entry-content h2{font-size:24px;margin-top:40px}
  .entry-content h2::before{display:none}
  .entry-content h3{font-size:19px}
  .entry-content blockquote{padding:24px 20px 24px 44px;font-size:17px}
  .entry-content blockquote::before{left:14px;font-size:48px}
  .contextual-cta{padding:32px 24px}
  .contextual-cta h3{font-size:22px}
  .author-card{flex-direction:column;text-align:center;padding:24px}
  .author-card .author-socials{justify-content:center}
  .related-posts-head{flex-direction:column;align-items:flex-start}
  .pagination .prev .label,.pagination .next .label{display:none}
}
@media (prefers-reduced-motion: reduce){
  .reading-progress-bar,.featured-post,.post-card,.post-card-img .cover-art{transition:none !important}
}

/* ============================================================
   20. HEADER MOBILE — mostrar toggle em telas pequenas
   ============================================================ */
@media (max-width: 768px){
  .if-nav{display:none}
  .if-btn-login{display:none}
  #menu-toggle{display:flex}
}
