/* ============================================================================
   BLOG MGP — estilos das páginas de conteúdo (usa main.css como base)
   ========================================================================== */
.bloghero { background: linear-gradient(160deg,#0F1F30,#1C3553); color:#fff; padding: 140px 0 60px; position:relative; overflow:hidden; }
.bloghero::before { content:''; position:absolute; inset:0; opacity:.5; background: radial-gradient(700px 400px at 85% 10%, rgba(200,169,110,.22), transparent 60%); }
.bloghero .container { position:relative; z-index:2; }
.breadcrumb { display:flex; gap:8px; align-items:center; font-size:.84rem; color:#9FB0C2; margin-bottom: 22px; flex-wrap:wrap; }
.breadcrumb a { color:#9FB0C2; transition: var(--t-fast); } .breadcrumb a:hover { color: var(--accent-light); }
.breadcrumb span { color: var(--accent-light); }
.bloghero__cat { display:inline-block; background: rgba(200,169,110,.18); border:1px solid rgba(200,169,110,.4); color: var(--accent-light); padding: 6px 14px; border-radius: var(--radius-full); font-size:.78rem; font-weight:700; margin-bottom: 18px; }
.bloghero h1 { font-size: clamp(1.9rem,4.4vw,3rem); max-width: 860px; line-height:1.1; }
.bloghero__meta { margin-top: 20px; display:flex; gap: 20px; flex-wrap:wrap; color:#B9C6D4; font-size:.9rem; }
.bloghero__meta span { display:flex; align-items:center; gap:7px; }
.bloghero__meta svg { width:16px; height:16px; color: var(--accent); }

.article { padding: 64px 0 80px; }
.article__wrap { max-width: 760px; margin-inline:auto; }
.article__lead { font-size: 1.22rem; color: var(--primary); font-weight: 500; line-height:1.6; margin-bottom: 34px; padding-bottom: 30px; border-bottom: 2px solid var(--border); }
.prose p { color: var(--text-medium); font-size: 1.06rem; line-height: 1.85; margin-bottom: 22px; }
.prose h2 { font-size: 1.7rem; color: var(--primary); margin: 44px 0 16px; }
.prose h3 { font-size: 1.28rem; color: var(--primary); margin: 32px 0 12px; }
.prose ul, .prose ol { margin: 0 0 22px 0; padding-left: 0; }
.prose li { position:relative; padding-left: 32px; margin-bottom: 12px; color: var(--text-medium); font-size: 1.04rem; line-height:1.7; }
.prose ul li::before { content:''; position:absolute; left:0; top:9px; width:18px; height:18px; background: var(--accent); -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") center/contain no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") center/contain no-repeat; }
.prose ol { counter-reset: li; }
.prose ol li { counter-increment: li; }
.prose ol li::before { content: counter(li); position:absolute; left:0; top:2px; width:22px; height:22px; background: var(--primary); color:#fff; border-radius:50%; font-size:.78rem; font-weight:700; display:flex; align-items:center; justify-content:center; font-family: var(--font-body); }
.prose strong { color: var(--text); }
.prose a { color: var(--accent-dark); font-weight:600; text-decoration: underline; text-underline-offset: 3px; }

.callout { background: linear-gradient(135deg,#f3eee2,#faf7f0); border:1px solid var(--border-dark); border-left: 4px solid var(--accent); border-radius: var(--radius-md); padding: 22px 26px; margin: 30px 0; }
.callout strong { color: var(--primary); display:block; margin-bottom: 6px; font-family: var(--font-display); font-size: 1.1rem; }
.callout p { margin:0; font-size: 1rem; }

.tip-grid { display:grid; grid-template-columns: repeat(2,1fr); gap: 16px; margin: 28px 0; }
.tip { background:#fff; border:1px solid var(--border); border-radius: var(--radius-md); padding: 22px; box-shadow: var(--shadow-xs); }
.tip svg { width:30px; height:30px; color: var(--accent-dark); margin-bottom: 12px; }
.tip h4 { color: var(--primary); font-size: 1.05rem; margin-bottom: 6px; }
.tip p { font-size:.94rem; margin:0; }

.article-cta { margin: 50px 0 10px; background: linear-gradient(135deg,var(--primary),var(--primary-dark)); border-radius: var(--radius-lg); padding: 40px; text-align:center; color:#fff; position:relative; overflow:hidden; }
.article-cta::before { content:''; position:absolute; inset:0; opacity:.5; background: radial-gradient(500px 300px at 80% 20%, rgba(200,169,110,.25), transparent 60%); }
.article-cta > * { position:relative; z-index:2; }
.article-cta h3 { font-size:1.6rem; color:#fff; margin-bottom: 10px; }
.article-cta p { color:#C7D3E0; margin-bottom: 24px; }

.related { background: var(--bg); padding: 60px 0 80px; }
.related h2 { text-align:center; color: var(--primary); font-size:1.8rem; margin-bottom: 36px; }

/* blog index */
.blogindex { padding: 56px 0 80px; }
.blogindex .blog-grid { margin-top: 10px; }
.feat-post { display:grid; grid-template-columns: 1.1fr 1fr; gap: 0; background:#fff; border-radius: var(--radius-xl); overflow:hidden; box-shadow: var(--shadow-md); border:1px solid var(--border); margin-bottom: 48px; }
.feat-post__media { position:relative; min-height: 320px; display:flex; align-items:flex-end; padding: 24px; color:#fff; }
.feat-post__pat { position:absolute; inset:0; opacity:.16; background-image: linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.5) 1px,transparent 1px); background-size: 28px 28px; }
.feat-post__cat { position:relative; z-index:2; background: rgba(255,255,255,.16); backdrop-filter: blur(4px); padding: 6px 14px; border-radius: var(--radius-full); font-size:.76rem; font-weight:700; }
.feat-post__body { padding: 40px; display:flex; flex-direction:column; justify-content:center; }
.feat-post__body .post__meta { font-size:.84rem; color: var(--text-light); margin-bottom: 12px; }
.feat-post__body h2 { font-size: 1.9rem; color: var(--primary); line-height:1.18; }
.feat-post__body p { color: var(--text-medium); margin: 16px 0 24px; font-size:1.05rem; }

@media (max-width: 768px) {
  .tip-grid { grid-template-columns: 1fr; }
  .feat-post { grid-template-columns: 1fr; }
  .feat-post__media { min-height: 200px; }
  .feat-post__body { padding: 28px; }
  .article-cta { padding: 30px 24px; }
}
