/*
Theme Name:   Hello Elementor JPGomes
Theme URI:    https://jpgomes.com.br/
Description:  Tema filho do Hello Elementor para JPGomes Advocacia. Inclui template de blog dinamico, header/footer customizados, suporte a Areas de Atuacao, compliance OAB (Provimento 205/2021) e design system proprietario.
Author:       JPGomes Advocacia
Author URI:   https://jpgomes.com.br/
Template:     hello-elementor
Version:      1.0.4
Text Domain:  jpgomes-child
*/

/* ============================================================
   DESIGN SYSTEM JPGOMES — Variaveis globais
   ============================================================ */
:root{
  --c-navy:#0a2540;
  --c-navy-dark:#061829;
  --c-navy-light:#0f3a66;
  --c-gold:#c9a961;
  --c-gold-dark:#a88a47;
  --c-gold-light:#dcc285;
  --c-cream:#f8f5ec;
  --c-wpp:#25d366;
  --c-wpp-dark:#1eb955;

  --c-white:#ffffff;
  --c-bg:#fafbfc;
  --c-text:#3a4556;
  --c-text-light:#6b7280;
  --c-border:#e5e7eb;
  --c-border-light:#f0f2f5;

  --shadow-sm:0 1px 3px rgba(10,37,64,.08);
  --shadow-md:0 4px 16px rgba(10,37,64,.10);
  --shadow-lg:0 12px 32px rgba(10,37,64,.14);
  --shadow-gold:0 6px 20px rgba(201,169,97,.25);

  --radius:12px;
  --radius-lg:20px;
  --radius-pill:99px;
  --max:1200px;

  --font-serif:'Playfair Display', Georgia, 'Times New Roman', serif;
  --font-sans:-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
}

/* ============================================================
   RESET E BASE
   ============================================================ */
body.jpg-blog-body{
  margin:0; padding:0;
  font-family:var(--font-sans);
  font-size:16px; line-height:1.6;
  color:var(--c-text); background:var(--c-white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.jpg-blog-body *,
body.jpg-blog-body *::before,
body.jpg-blog-body *::after{ box-sizing:border-box; }
body.jpg-blog-body img,
body.jpg-blog-body svg{ max-width:100%; height:auto; display:block; }
body.jpg-blog-body a{
  color:var(--c-navy); text-decoration:none;
  transition:color .2s, opacity .2s;
}
body.jpg-blog-body a:hover,
body.jpg-blog-body a:focus{
  color:var(--c-gold-dark); text-decoration:underline;
}
body.jpg-blog-body :focus-visible{
  outline:3px solid var(--c-gold); outline-offset:3px;
  border-radius:4px; box-shadow:0 0 0 6px rgba(201,169,97,.25);
}

/* Skip link acessibilidade */
.jpg-skip,
.jpg-skip-link{
  position:absolute; left:-9999px; top:0;
  background:var(--c-navy); color:#fff;
  padding:12px 20px; z-index:9999;
  text-decoration:none; font-weight:600;
}
.jpg-skip:focus,
.jpg-skip-link:focus{ left:0; }

.screen-reader-text{
  border:0; clip:rect(1px,1px,1px,1px);
  -webkit-clip-path:inset(50%); clip-path:inset(50%);
  height:1px; margin:-1px; overflow:hidden;
  padding:0; position:absolute; width:1px; word-wrap:normal!important;
}
.screen-reader-text:focus{
  background-color:#f1f1f1; border-radius:3px;
  box-shadow:0 0 2px 2px rgba(0,0,0,.6);
  clip:auto!important; -webkit-clip-path:none; clip-path:none;
  color:var(--c-navy); display:block;
  font-size:14px; font-weight:700; height:auto;
  left:5px; line-height:normal; padding:15px 23px 14px;
  text-decoration:none; top:5px; width:auto; z-index:100000;
}

/* ============================================================
   CONTAINER
   ============================================================ */
.jpg-container{
  max-width:var(--max); margin:0 auto; padding:0 24px;
}
.jpg-blog .container{
  max-width:var(--max); margin:0 auto; padding:0 24px;
}
.jpg-blog .visually-hidden{
  position:absolute; width:1px; height:1px;
  padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ============================================================
   HEADER GLOBAL
   ============================================================ */
.jpg-site-header,
.jpg-header{
  position:sticky; top:0;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid var(--c-border);
  z-index:100;
}

.jpg-header .jpg-header-inner,
.jpg-header-inner{
  max-width:var(--max);
  margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px; gap:24px;
}

/* LOGO HEADER */
.jpg-header-logo{
  flex-shrink:0;
}
.jpg-header-logo a{
  display:inline-block;
  line-height:0;
  text-decoration:none;
}
.jpg-header-logo img,
.jpg-logo-img,
.jpg-custom-logo img,
.jpg-site-branding img{
  height:56px;
  width:auto;
  max-width:240px;
  object-fit:contain;
  display:block;
  background:transparent !important;
  mix-blend-mode:multiply;
}

.jpg-site-branding{
  display:flex; align-items:center; gap:12px;
  flex-shrink:0;
}
.jpg-custom-logo a,
.jpg-custom-logo{ display:block; }
.jpg-site-title-link{ text-decoration:none; }
.jpg-site-title-link:hover{ text-decoration:none; }
.jpg-site-title{
  margin:0; padding:0;
  font-family:var(--font-serif);
  font-weight:700; line-height:1; color:var(--c-navy);
  display:flex; align-items:baseline; gap:6px;
}
.jpg-site-title__main{ font-size:28px; }
.jpg-site-title__sub{
  font-size:13px; font-weight:500;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--c-gold);
}
.jpg-site-description{ display:none; }

/* NAVEGACAO PRINCIPAL */
.jpg-main-navigation,
.jpg-nav{ flex:1; }

.jpg-menu,
.jpg-nav .jpg-menu{
  display:flex; align-items:center; gap:28px;
  list-style:none; margin:0; padding:0;
  justify-content:center;
}
.jpg-menu li,
.jpg-nav .jpg-menu li{ list-style:none; position:relative; }

.jpg-menu a,
.jpg-nav .jpg-menu a{
  color:var(--c-navy); font-weight:500; font-size:15px;
  text-decoration:none; padding:8px 0;
  transition:color .2s;
}
.jpg-menu a:hover,
.jpg-nav .jpg-menu a:hover{
  color:var(--c-gold-dark); text-decoration:none;
}
.jpg-menu .current-menu-item > a,
.jpg-menu .current_page_item > a,
.jpg-menu .jpg-menu-active{
  color:var(--c-gold-dark); font-weight:700;
  border-bottom:2px solid var(--c-gold);
}

/* SUBMENU */
.jpg-menu .sub-menu,
.jpg-menu ul.children,
.jpg-nav .sub-menu{
  position:absolute; top:100%; left:-16px;
  background:#fff; min-width:240px;
  box-shadow:var(--shadow-md);
  border:1px solid var(--c-border);
  border-radius:var(--radius);
  padding:8px 0; margin:0;
  list-style:none;
  opacity:0; visibility:hidden;
  transform:translateY(8px);
  transition:all .25s;
  z-index:50;
}
.jpg-menu li:hover > .sub-menu,
.jpg-menu li:hover > ul.children,
.jpg-menu li:focus-within > .sub-menu,
.jpg-menu li:focus-within > ul.children,
.jpg-nav .menu-item-has-children:hover > .sub-menu,
.jpg-nav .menu-item-has-children:focus-within > .sub-menu{
  opacity:1; visibility:visible; transform:translateY(0);
}
.jpg-menu .sub-menu li,
.jpg-menu ul.children li,
.jpg-nav .sub-menu li{ display:block; }

.jpg-menu .sub-menu a,
.jpg-menu ul.children a,
.jpg-nav .sub-menu a{
  display:block; padding:10px 18px;
  border-bottom:0; font-size:14px;
}
.jpg-menu .sub-menu a:hover,
.jpg-menu ul.children a:hover,
.jpg-nav .sub-menu a:hover{
  background:var(--c-bg); color:var(--c-gold-dark);
}

/* CTA HEADER */
.jpg-header-cta{ flex-shrink:0; }
.jpg-btn-sm{
  padding:10px 18px; font-size:14px;
  min-height:auto;
}

/* HAMBURGUER */
.jpg-menu-toggle,
.jpg-hamburger{
  display:none; background:none; border:0; cursor:pointer;
  padding:8px; color:var(--c-navy);
  flex-direction:column; gap:5px;
  width:40px; height:40px;
  align-items:center; justify-content:center;
}
.jpg-menu-toggle__icon{
  display:inline-block; width:24px; height:18px; position:relative;
}
.jpg-menu-toggle__bar,
.jpg-hamburger-bar{
  display:block; width:24px; height:2px;
  background:var(--c-navy); border-radius:2px;
  transition:all .25s;
}
.jpg-menu-toggle__bar{
  position:absolute; left:0;
}
.jpg-menu-toggle__bar:nth-child(1){ top:0; }
.jpg-menu-toggle__bar:nth-child(2){ top:50%; transform:translateY(-50%); }
.jpg-menu-toggle__bar:nth-child(3){ bottom:0; }
.jpg-menu-toggle[aria-expanded="true"] .jpg-menu-toggle__bar:nth-child(1){
  top:50%; transform:translateY(-50%) rotate(45deg);
}
.jpg-menu-toggle[aria-expanded="true"] .jpg-menu-toggle__bar:nth-child(2){
  opacity:0;
}
.jpg-menu-toggle[aria-expanded="true"] .jpg-menu-toggle__bar:nth-child(3){
  bottom:50%; transform:translateY(50%) rotate(-45deg);
}
.jpg-menu-toggle__label{
  font-size:14px; font-weight:600; color:var(--c-navy);
}

/* ============================================================
   BOTOES
   ============================================================ */
.jpg-blog .jpg-btn,
.jpg-blog .btn,
body.jpg-blog-body .jpg-btn,
body.jpg-blog-body .btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px; padding:14px 28px;
  border-radius:var(--radius);
  font-weight:600; font-size:16px;
  border:2px solid transparent; cursor:pointer;
  transition:all .25s; text-decoration:none;
  line-height:1.2; min-height:48px;
  font-family:var(--font-sans);
}

.jpg-blog .btn-primary,
.jpg-blog .jpg-btn-wpp,
body.jpg-blog-body .btn-primary,
body.jpg-blog-body .jpg-btn-wpp{
  background:var(--c-wpp); color:#fff;
}
.jpg-blog .btn-primary:hover,
.jpg-blog .jpg-btn-wpp:hover,
body.jpg-blog-body .btn-primary:hover,
body.jpg-blog-body .jpg-btn-wpp:hover{
  background:var(--c-wpp-dark); color:#fff;
  text-decoration:none; transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}

.jpg-blog .jpg-btn-gold,
body.jpg-blog-body .jpg-btn-gold{
  background:var(--c-gold); color:var(--c-navy);
}
.jpg-blog .jpg-btn-gold:hover,
body.jpg-blog-body .jpg-btn-gold:hover{
  background:var(--c-gold-dark); color:var(--c-navy);
  text-decoration:none; transform:translateY(-2px);
  box-shadow:var(--shadow-gold);
}

.jpg-blog .jpg-btn-navy,
body.jpg-blog-body .jpg-btn-navy{
  background:var(--c-navy); color:#fff;
}
.jpg-blog .jpg-btn-navy:hover,
body.jpg-blog-body .jpg-btn-navy:hover{
  background:var(--c-navy-dark); color:#fff;
  text-decoration:none; transform:translateY(-2px);
}

.jpg-blog .btn-light,
.jpg-blog .jpg-btn-light,
body.jpg-blog-body .btn-light,
body.jpg-blog-body .jpg-btn-light{
  background:#fff; color:var(--c-navy);
}
.jpg-blog .btn-light:hover,
.jpg-blog .jpg-btn-light:hover,
body.jpg-blog-body .btn-light:hover,
body.jpg-blog-body .jpg-btn-light:hover{
  background:var(--c-gold); color:var(--c-navy);
  text-decoration:none;
}

.jpg-blog .jpg-btn-outline,
body.jpg-blog-body .jpg-btn-outline{
  background:transparent; color:var(--c-navy);
  border-color:var(--c-navy);
}
.jpg-blog .jpg-btn-outline:hover,
body.jpg-blog-body .jpg-btn-outline:hover{
  background:var(--c-navy); color:#fff;
  text-decoration:none;
}

/* ============================================================
   HERO BLOG
   ============================================================ */
.jpg-hero{
  background:linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-light) 50%, #0f4a8a 100%);
  color:#fff; padding:90px 24px 110px;
  position:relative; overflow:hidden;
}
.jpg-hero::before{
  content:""; position:absolute; top:-50%; right:-10%;
  width:600px; height:600px;
  background:radial-gradient(circle, rgba(201,169,97,.18) 0%, transparent 70%);
  pointer-events:none;
}
.jpg-hero-grid{
  max-width:var(--max); margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:60px;
  align-items:center; position:relative; z-index:1;
}
.jpg-hero-tag{
  display:inline-block; background:rgba(201,169,97,.18);
  color:var(--c-gold); padding:6px 14px;
  border-radius:var(--radius-pill);
  font-size:13px; font-weight:600; letter-spacing:.5px;
  margin-bottom:20px; border:1px solid rgba(201,169,97,.4);
}
.jpg-hero h1{
  font-family:var(--font-serif);
  font-size:clamp(32px, 4.5vw, 52px);
  font-weight:700; line-height:1.15;
  margin-bottom:18px; letter-spacing:-.5px; color:#fff;
}
.jpg-hero h1 strong{
  color:var(--c-gold); font-weight:700;
}
.jpg-hero .subtitle{
  font-size:clamp(16px, 2vw, 19px); line-height:1.6;
  color:#d8e2ee; margin-bottom:32px; max-width:580px;
}
.jpg-hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }

.jpg-hero-card{
  background:#fff; border-radius:var(--radius-lg);
  padding:32px; box-shadow:var(--shadow-lg);
  max-width:380px; width:100%; color:var(--c-text);
}
.jpg-hero-card h3{
  color:var(--c-navy); font-size:18px; margin-bottom:18px;
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-serif);
}
.jpg-hero-card h3 svg{
  width:24px; height:24px; color:var(--c-gold); flex-shrink:0;
}
.jpg-hero-card ul{ list-style:none; padding:0; margin:0; }
.jpg-hero-card li{
  display:flex; align-items:flex-start; gap:10px;
  padding:10px 0; font-size:15px;
  border-bottom:1px solid var(--c-border-light);
}
.jpg-hero-card li:last-child{ border:0; }
.jpg-hero-card li::before{
  content:""; width:18px; height:18px;
  flex-shrink:0; margin-top:2px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23c9a961'><path d='M9 16.17 4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/></svg>");
  background-size:contain; background-repeat:no-repeat;
}
.jpg-hero-card li a{
  color:var(--c-text); text-decoration:none; flex:1;
}
.jpg-hero-card li a:hover{
  color:var(--c-gold-dark); text-decoration:none;
}
.jpg-cat-count{
  font-size:12px; color:var(--c-text-light); font-weight:600;
}

/* ============================================================
   STATS
   ============================================================ */
.jpg-stats{
  background:var(--c-navy); color:#fff;
  padding:50px 24px;
}
.jpg-stats-grid{
  max-width:var(--max); margin:0 auto;
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:30px; text-align:center;
}
.jpg-stat-num{
  font-family:var(--font-serif);
  font-size:clamp(28px, 4vw, 44px); font-weight:700;
  color:var(--c-gold); line-height:1;
  margin-bottom:8px; letter-spacing:-.5px;
}
.jpg-stat-label{
  font-size:13px; color:#b8c5d6;
  font-weight:600; letter-spacing:.5px;
  text-transform:uppercase;
}

/* ============================================================
   FILTROS DE CATEGORIA
   ============================================================ */
.jpg-filters{
  max-width:var(--max); margin:0 auto 40px;
  padding:0 24px;
  display:flex; flex-wrap:wrap; gap:10px;
  justify-content:center;
}
.jpg-filter{
  padding:8px 18px; border-radius:var(--radius-pill);
  background:#fff; border:1.5px solid var(--c-border);
  color:var(--c-text); font-size:14px; font-weight:600;
  text-decoration:none; transition:all .2s;
}
.jpg-filter:hover{
  border-color:var(--c-gold); color:var(--c-gold-dark);
  text-decoration:none;
}
.jpg-filter.active{
  background:var(--c-navy); color:#fff;
  border-color:var(--c-navy);
}

/* ============================================================
   GRID DE POSTS
   ============================================================ */
.jpg-posts-section{
  background:var(--c-bg); padding:80px 24px;
}
.jpg-section-head{
  text-align:center; max-width:760px;
  margin:0 auto 56px;
}
.jpg-section-tag{
  display:inline-block; color:var(--c-gold-dark);
  font-size:13px; font-weight:700;
  letter-spacing:1.5px; text-transform:uppercase;
  margin-bottom:14px;
}
.jpg-section-title{
  font-family:var(--font-serif);
  font-size:clamp(28px, 3.5vw, 40px); color:var(--c-navy);
  font-weight:700; line-height:1.2;
  margin-bottom:18px; letter-spacing:-.5px;
}
.jpg-section-sub{
  font-size:18px; color:var(--c-text-light);
  max-width:680px; line-height:1.6; margin:0 auto;
}
.jpg-posts-grid{
  max-width:var(--max); margin:0 auto;
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:28px;
}
.jpg-post-card{
  background:#fff; border:1px solid var(--c-border);
  border-radius:var(--radius-lg); overflow:hidden;
  transition:all .3s; display:flex; flex-direction:column;
  text-decoration:none; color:inherit;
}
.jpg-post-card:hover{
  transform:translateY(-6px); box-shadow:var(--shadow-lg);
  border-color:transparent; text-decoration:none; color:inherit;
}
.jpg-post-thumb{
  aspect-ratio:16/9;
  background:linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-light) 100%);
  position:relative; display:flex; align-items:center;
  justify-content:center; overflow:hidden;
}
.jpg-post-thumb img{
  width:100%; height:100%; object-fit:cover;
}
.jpg-post-thumb::before{
  content:""; position:absolute;
  width:200px; height:200px;
  background:radial-gradient(circle, rgba(201,169,97,.25) 0%, transparent 70%);
  top:-60px; right:-60px; z-index:1;
}
.jpg-post-thumb-fallback{
  width:80px; height:80px; color:rgba(255,255,255,.85);
  position:relative; z-index:1;
}
.jpg-post-badge{
  position:absolute; top:14px; left:14px;
  background:var(--c-gold); color:var(--c-navy);
  padding:5px 12px; border-radius:var(--radius-pill);
  font-size:11px; font-weight:700; letter-spacing:.6px;
  text-transform:uppercase; z-index:2;
  box-shadow:0 2px 8px rgba(0,0,0,.2);
}
.jpg-post-body{
  padding:24px 24px 26px;
  display:flex; flex-direction:column; flex:1;
}
.jpg-post-card h3{
  font-family:var(--font-serif);
  color:var(--c-navy); font-size:20px;
  font-weight:700; line-height:1.3;
  margin:0 0 12px; letter-spacing:-.2px;
}
.jpg-post-card p{
  font-size:15px; color:var(--c-text-light);
  line-height:1.6; margin:0 0 18px; flex:1;
}
.jpg-post-meta{
  display:flex; align-items:center; gap:14px;
  font-size:13px; color:var(--c-text-light);
  margin-bottom:14px; padding-top:14px;
  border-top:1px solid var(--c-border-light);
  flex-wrap:wrap;
}
.jpg-post-meta span{
  display:flex; align-items:center; gap:5px;
}
.jpg-post-meta svg{
  width:14px; height:14px;
  color:var(--c-gold-dark); flex-shrink:0;
}
.jpg-post-link{
  color:var(--c-gold-dark); font-weight:600; font-size:14px;
  display:inline-flex; align-items:center; gap:6px;
  transition:gap .2s;
}
.jpg-post-card:hover .jpg-post-link{
  gap:10px; color:var(--c-navy);
}

/* ============================================================
   PAGINACAO
   ============================================================ */
.jpg-pagination{
  max-width:var(--max); margin:60px auto 0;
  padding:0 24px; display:flex;
  justify-content:center; gap:8px; flex-wrap:wrap;
}
.jpg-pagination .page-numbers{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:42px; height:42px; padding:0 14px;
  border-radius:8px; background:#fff;
  border:1.5px solid var(--c-border);
  color:var(--c-text); font-weight:600; font-size:14px;
  text-decoration:none; transition:all .2s;
}
.jpg-pagination .page-numbers:hover{
  border-color:var(--c-gold); color:var(--c-gold-dark);
  text-decoration:none;
}
.jpg-pagination .page-numbers.current{
  background:var(--c-navy); color:#fff;
  border-color:var(--c-navy);
}
.jpg-pagination .dots{
  border:0; background:transparent;
}

/* ============================================================
   ESTADO VAZIO
   ============================================================ */
.jpg-no-posts{
  max-width:600px; margin:0 auto;
  text-align:center; padding:60px 24px;
  color:var(--c-text-light);
}
.jpg-no-posts h3{
  font-family:var(--font-serif);
  color:var(--c-navy); font-size:24px;
  margin-bottom:12px;
}

/* ============================================================
   CTA FINAL
   ============================================================ */
.jpg-cta{
  background:linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-light) 100%);
  color:#fff; text-align:center; padding:90px 24px;
  position:relative; overflow:hidden;
}
.jpg-cta::before{
  content:""; position:absolute;
  bottom:-30%; left:-10%; width:500px; height:500px;
  background:radial-gradient(circle, rgba(201,169,97,.15) 0%, transparent 70%);
  pointer-events:none;
}
.jpg-cta > *{ position:relative; z-index:1; }
.jpg-cta h2{
  font-family:var(--font-serif);
  font-size:clamp(28px, 3.5vw, 42px); font-weight:700;
  margin-bottom:8px; line-height:1.2; color:#fff;
}
.jpg-cta-lead{
  font-size:20px; color:var(--c-gold);
  font-weight:600; margin-bottom:16px;
}
.jpg-cta p{
  font-size:18px; color:#d8e2ee; max-width:640px;
  margin:0 auto 36px; line-height:1.6;
}
.jpg-cta-buttons{
  display:flex; gap:14px; justify-content:center;
  flex-wrap:wrap; margin-bottom:32px;
}

/* ============================================================
   SINGLE POST — HERO
   ============================================================ */
.jpg-post-hero{
  background:linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-light) 50%, #0f4a8a 100%);
  color:#fff; padding:60px 24px 0;
  position:relative; overflow:hidden;
}
.jpg-post-hero::before{
  content:""; position:absolute; top:-30%; right:-10%;
  width:500px; height:500px;
  background:radial-gradient(circle, rgba(201,169,97,.12) 0%, transparent 70%);
  pointer-events:none;
}
.jpg-post-hero-inner{
  max-width:880px; margin:0 auto;
  position:relative; z-index:1;
  padding-bottom:50px;
}
.jpg-breadcrumbs{
  display:flex; flex-wrap:wrap; align-items:center; gap:8px;
  font-size:13px; color:#b8c5d6; margin-bottom:24px;
}
.jpg-breadcrumbs a{
  color:#d8e2ee; text-decoration:none;
}
.jpg-breadcrumbs a:hover{
  color:var(--c-gold); text-decoration:none;
}
.jpg-breadcrumbs span[aria-hidden]{ color:#6b7d96; }
.jpg-breadcrumb-current{ color:#fff; font-weight:500; }

.jpg-post-hero-badge{
  display:inline-block; background:var(--c-gold);
  color:var(--c-navy); padding:6px 14px;
  border-radius:var(--radius-pill);
  font-size:12px; font-weight:700; letter-spacing:.6px;
  text-transform:uppercase; margin-bottom:20px;
  text-decoration:none; transition:transform .2s;
}
.jpg-post-hero-badge:hover{
  transform:translateY(-2px); color:var(--c-navy);
  text-decoration:none;
}
.jpg-post-hero-title{
  font-family:var(--font-serif);
  font-size:clamp(28px, 4vw, 46px); font-weight:700;
  line-height:1.2; margin-bottom:20px;
  letter-spacing:-.5px; color:#fff;
}
.jpg-post-hero-meta{
  display:flex; gap:24px; flex-wrap:wrap;
  font-size:14px; color:#b8c5d6;
}
.jpg-post-hero-meta span{
  display:flex; align-items:center; gap:6px;
}
.jpg-post-hero-meta svg{
  width:16px; height:16px;
  color:var(--c-gold); flex-shrink:0;
}
.jpg-post-hero-image{
  max-width:1100px; margin:0 auto;
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  overflow:hidden;
  box-shadow:0 -10px 40px rgba(0,0,0,.2);
  position:relative; z-index:1;
}
.jpg-post-hero-image img{
  width:100%; height:auto; display:block;
  aspect-ratio:21/9; object-fit:cover;
}

/* ============================================================
   SINGLE POST — CONTEUDO
   ============================================================ */
.jpg-post-content{
  max-width:760px; margin:60px auto 0;
  padding:0 24px; position:relative;
}
.jpg-post-body{
  font-size:18px; line-height:1.75;
  color:var(--c-text);
}
.jpg-post-body > *:first-child{ margin-top:0; }
.jpg-post-body p{
  margin:0 0 22px; color:var(--c-text);
}
.jpg-post-body h2{
  font-family:var(--font-serif);
  font-size:clamp(24px, 3vw, 32px); color:var(--c-navy);
  font-weight:700; line-height:1.25;
  margin:48px 0 18px; letter-spacing:-.3px;
  padding-top:12px; border-top:3px solid var(--c-gold);
  display:inline-block;
}
.jpg-post-body h3{
  font-family:var(--font-serif);
  font-size:clamp(20px, 2.5vw, 24px); color:var(--c-navy);
  font-weight:700; line-height:1.3;
  margin:36px 0 14px;
}
.jpg-post-body h4{
  font-size:18px; color:var(--c-navy);
  font-weight:700; margin:28px 0 12px;
}
.jpg-post-body ul,
.jpg-post-body ol{
  margin:0 0 22px; padding-left:24px;
}
.jpg-post-body li{
  margin-bottom:10px; line-height:1.7;
}
.jpg-post-body ul li::marker{ color:var(--c-gold); }
.jpg-post-body ol li::marker{
  color:var(--c-navy); font-weight:700;
}
.jpg-post-body blockquote{
  margin:32px 0; padding:20px 28px;
  background:var(--c-bg);
  border-left:4px solid var(--c-gold);
  border-radius:0 var(--radius) var(--radius) 0;
  font-style:italic; color:var(--c-text);
}
.jpg-post-body blockquote p:last-child{ margin-bottom:0; }
.jpg-post-body strong{ color:var(--c-navy); font-weight:700; }
.jpg-post-body a{
  color:var(--c-gold-dark); text-decoration:underline;
  text-decoration-color:rgba(201,169,97,.4);
  text-underline-offset:3px; transition:all .2s;
}
.jpg-post-body a:hover{
  color:var(--c-navy);
  text-decoration-color:var(--c-navy);
}
.jpg-post-body img{
  border-radius:var(--radius); margin:28px auto;
  box-shadow:var(--shadow-md);
}
.jpg-post-body code{
  background:var(--c-border-light); padding:2px 8px;
  border-radius:4px; font-size:.9em; color:var(--c-navy);
  font-family:'SF Mono', Monaco, Menlo, monospace;
}
.jpg-post-body table{
  width:100%; border-collapse:collapse;
  margin:28px 0; border-radius:var(--radius);
  overflow:hidden; box-shadow:var(--shadow-sm);
  font-size:15px;
}
.jpg-post-body table th{
  background:var(--c-navy); color:#fff;
  padding:14px 16px; text-align:left; font-weight:700;
}
.jpg-post-body table td{
  padding:12px 16px;
  border-bottom:1px solid var(--c-border);
}
.jpg-post-body table tr:last-child td{ border-bottom:0; }
.jpg-post-body table tr:nth-child(even){ background:var(--c-bg); }
.jpg-post-body hr{
  border:0; height:1px;
  background:var(--c-border); margin:36px 0;
}

/* ============================================================
   SINGLE POST — SHARE BAR LATERAL
   ============================================================ */
.jpg-share-bar{
  position:fixed; left:24px; top:50%;
  transform:translateY(-50%); z-index:50;
  display:flex; flex-direction:column; gap:10px;
  background:#fff; padding:14px 10px;
  border-radius:var(--radius);
  box-shadow:var(--shadow-md);
  border:1px solid var(--c-border);
}
.jpg-share-label{
  font-size:10px; font-weight:700;
  color:var(--c-text-light);
  letter-spacing:1px; text-transform:uppercase;
  text-align:center; margin-bottom:4px;
}
.jpg-share-bar a,
.jpg-share-bar button{
  width:38px; height:38px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  border:0; cursor:pointer; transition:all .2s;
  text-decoration:none;
}
.jpg-share-bar svg{ width:18px; height:18px; }
.jpg-share-wpp{ background:var(--c-wpp); color:#fff; }
.jpg-share-wpp:hover{
  background:var(--c-wpp-dark); transform:scale(1.1);
  text-decoration:none;
}
.jpg-share-li{ background:#0a66c2; color:#fff; }
.jpg-share-li:hover{
  background:#084d92; transform:scale(1.1);
  text-decoration:none;
}
.jpg-share-fb{ background:#1877f2; color:#fff; }
.jpg-share-fb:hover{
  background:#0d5cbd; transform:scale(1.1);
  text-decoration:none;
}
.jpg-share-copy{
  background:var(--c-border-light); color:var(--c-navy);
  position:relative;
}
.jpg-share-copy:hover{
  background:var(--c-gold); transform:scale(1.1);
}
.jpg-share-copy.copied::after{
  content:"Copiado!"; position:absolute; left:50px;
  background:var(--c-navy); color:#fff;
  padding:6px 12px; border-radius:6px;
  font-size:12px; white-space:nowrap;
  animation:jpgFadeOut 2s forwards;
}
@keyframes jpgFadeOut{
  0%, 70%{ opacity:1; }
  100%{ opacity:0; }
}

/* ============================================================
   SINGLE POST — TAGS
   ============================================================ */
.jpg-post-tags{
  max-width:760px; margin:40px auto 0;
  padding:24px 24px 0;
  border-top:1px solid var(--c-border);
  display:flex; flex-wrap:wrap; gap:10px;
  align-items:center;
}
.jpg-tags-label{
  font-size:14px; color:var(--c-text-light); font-weight:600;
}
.jpg-tag{
  display:inline-block; padding:5px 12px;
  background:var(--c-bg);
  border:1px solid var(--c-border);
  border-radius:var(--radius-pill);
  font-size:13px; color:var(--c-text);
  text-decoration:none; transition:all .2s;
}
.jpg-tag:hover{
  background:var(--c-navy); color:#fff;
  border-color:var(--c-navy); text-decoration:none;
}

/* ============================================================
   SINGLE POST — CTA WHATSAPP DESTACADO
   ============================================================ */
.jpg-post-cta{
  max-width:880px; margin:60px auto;
  padding:0 24px;
}
.jpg-post-cta-inner{
  background:linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-light) 100%);
  color:#fff; padding:40px 36px;
  border-radius:var(--radius-lg);
  display:grid; grid-template-columns:auto 1fr auto;
  gap:28px; align-items:center;
  box-shadow:var(--shadow-lg);
  position:relative; overflow:hidden;
}
.jpg-post-cta-inner::before{
  content:""; position:absolute;
  top:-50%; right:-10%;
  width:300px; height:300px;
  background:radial-gradient(circle, rgba(201,169,97,.2) 0%, transparent 70%);
  pointer-events:none;
}
.jpg-post-cta-icon{
  width:64px; height:64px; border-radius:50%;
  background:var(--c-wpp); display:flex;
  align-items:center; justify-content:center;
  flex-shrink:0; position:relative; z-index:1;
}
.jpg-post-cta-icon svg{
  width:32px; height:32px; color:#fff;
}
.jpg-post-cta-text{ position:relative; z-index:1; }
.jpg-post-cta-text h3{
  font-family:var(--font-serif);
  color:#fff; font-size:22px; font-weight:700;
  margin:0 0 6px; line-height:1.3;
}
.jpg-post-cta-text p{
  color:#d8e2ee; font-size:15px;
  line-height:1.5; margin:0;
}
.jpg-post-cta .btn,
.jpg-post-cta .jpg-btn{
  position:relative; z-index:1; flex-shrink:0;
}

/* ============================================================
   POSTS RELACIONADOS
   ============================================================ */
.jpg-related{ padding-top:40px; }

/* ============================================================
   AREAS DE ATUACAO — Pagina indice
   ============================================================ */
.jpg-areas-section{
  padding:80px 24px; background:#fff;
}
.jpg-areas-grid{
  max-width:var(--max); margin:0 auto;
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:28px;
}
.jpg-area-card{
  background:#fff; border:1.5px solid var(--c-border);
  border-radius:var(--radius-lg); padding:32px 28px;
  transition:all .3s; display:flex; flex-direction:column;
  text-decoration:none; color:inherit;
  position:relative; overflow:hidden;
}
.jpg-area-card::before{
  content:""; position:absolute;
  top:0; left:0; right:0; height:4px;
  background:var(--c-gold);
  transform:scaleX(0); transform-origin:left;
  transition:transform .3s;
}
.jpg-area-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
  border-color:transparent;
  text-decoration:none; color:inherit;
}
.jpg-area-card:hover::before{ transform:scaleX(1); }

.jpg-area-icon{
  width:56px; height:56px; border-radius:14px;
  background:var(--c-cream);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:20px; color:var(--c-gold-dark);
  transition:all .3s;
}
.jpg-area-card:hover .jpg-area-icon{
  background:var(--c-gold); color:var(--c-navy);
}
.jpg-area-icon svg{
  width:28px; height:28px;
}
.jpg-area-card h3{
  font-family:var(--font-serif);
  font-size:22px; color:var(--c-navy);
  font-weight:700; line-height:1.3;
  margin:0 0 12px;
}
.jpg-area-card p{
  font-size:15px; color:var(--c-text-light);
  line-height:1.6; margin:0 0 20px; flex:1;
}
.jpg-area-card-link{
  color:var(--c-gold-dark); font-weight:600;
  font-size:14px; display:inline-flex;
  align-items:center; gap:6px; transition:gap .2s;
}
.jpg-area-card:hover .jpg-area-card-link{
  gap:10px; color:var(--c-navy);
}

/* ============================================================
   AREAS DE ATUACAO — Pagina individual
   ============================================================ */
.jpg-area-hero{
  background:linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-light) 100%);
  color:#fff; padding:80px 24px 100px;
  position:relative; overflow:hidden;
}
.jpg-area-hero::before{
  content:""; position:absolute;
  bottom:-30%; right:-10%;
  width:500px; height:500px;
  background:radial-gradient(circle, rgba(201,169,97,.15) 0%, transparent 70%);
  pointer-events:none;
}
.jpg-area-hero-inner{
  max-width:880px; margin:0 auto;
  position:relative; z-index:1; text-align:center;
}
.jpg-area-hero-icon{
  width:80px; height:80px; border-radius:20px;
  background:rgba(201,169,97,.18);
  display:inline-flex; align-items:center; justify-content:center;
  margin-bottom:24px; color:var(--c-gold);
  border:1px solid rgba(201,169,97,.4);
}
.jpg-area-hero-icon svg{
  width:40px; height:40px;
}
.jpg-area-hero h1{
  font-family:var(--font-serif);
  font-size:clamp(32px, 4.5vw, 48px); font-weight:700;
  line-height:1.2; margin-bottom:18px;
  letter-spacing:-.5px; color:#fff;
}
.jpg-area-hero p{
  font-size:clamp(16px, 2vw, 19px); line-height:1.6;
  color:#d8e2ee; max-width:680px; margin:0 auto;
}

.jpg-area-services{
  max-width:880px; margin:60px auto;
  padding:0 24px;
}
.jpg-area-services h2{
  font-family:var(--font-serif);
  font-size:clamp(24px, 3vw, 32px); color:var(--c-navy);
  font-weight:700; line-height:1.25; margin:0 0 24px;
  text-align:center;
}
.jpg-area-services-grid{
  display:grid; grid-template-columns:repeat(2, 1fr);
  gap:16px; margin-top:32px;
}
.jpg-area-service-item{
  display:flex; align-items:flex-start; gap:14px;
  padding:18px 20px; background:var(--c-bg);
  border-radius:var(--radius);
  border-left:3px solid var(--c-gold);
  transition:all .2s;
}
.jpg-area-service-item:hover{
  background:#fff; box-shadow:var(--shadow-sm);
  transform:translateX(4px);
}
.jpg-area-service-icon{
  width:24px; height:24px; flex-shrink:0;
  color:var(--c-gold-dark);
}
.jpg-area-service-text{
  font-size:15px; color:var(--c-text); line-height:1.5;
}
.jpg-area-service-text strong{ color:var(--c-navy); }

/* ============================================================
   FOOTER
   ============================================================ */
.jpg-site-footer,
.jpg-footer{
  background:var(--c-navy-dark); color:#cbd5e0;
  padding:60px 24px 24px; font-size:14px;
}

.jpg-footer-inner{
  max-width:var(--max);
  margin:0 auto 40px;
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:40px;
  padding:0 24px;
}

.jpg-foot-grid{
  max-width:var(--max); margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:40px; margin-bottom:40px;
}
.jpg-foot-grid h5,
.jpg-footer-col h3,
.jpg-footer-title{
  font-family:var(--font-serif);
  color:#fff; font-size:16px; margin:0 0 18px;
  font-weight:700; letter-spacing:.3px;
}
.jpg-foot-grid ul,
.jpg-footer-col ul,
.jpg-footer-list,
.jpg-footer-contact-list{
  list-style:none; margin:0; padding:0;
}
.jpg-foot-grid li,
.jpg-footer-col li,
.jpg-footer-list li,
.jpg-footer-contact-list li{
  padding:6px 0; list-style:none;
  line-height:1.6; color:#cbd5e0;
}

.jpg-foot-grid a,
.jpg-footer a,
.jpg-footer-inner a,
.jpg-footer-col a,
.jpg-footer-list a,
.jpg-footer-contact-list a{
  color:#cbd5e0 !important;
  text-decoration:none;
  transition:color .2s;
}
.jpg-foot-grid a:hover,
.jpg-footer a:hover,
.jpg-footer-inner a:hover,
.jpg-footer-col a:hover,
.jpg-footer-list a:hover,
.jpg-footer-contact-list a:hover{
  color:var(--c-gold) !important;
  text-decoration:none;
}

.jpg-footer-contact-list li{
  display:flex; align-items:flex-start;
  gap:10px; padding:8px 0; color:#cbd5e0;
}
.jpg-footer-contact-list li svg{
  color:var(--c-gold); flex-shrink:0; margin-top:3px;
}
.jpg-footer-address span{ color:#cbd5e0; }

/* ============================================================
   FOOTER BRAND — Logo Tipografico Premium
   ============================================================ */
.jpg-footer-brand-link{
  display:inline-block;
  text-decoration:none !important;
  margin-bottom:20px;
  transition:transform .25s;
}
.jpg-footer-brand-link:hover{
  transform:translateY(-2px);
  text-decoration:none !important;
}
.jpg-footer-brand-logo{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:6px;
  padding:4px 0;
}
.jpg-footer-brand-name{
  font-family:var(--font-serif), 'Playfair Display', Georgia, serif;
  font-size:32px;
  font-weight:700;
  color:#ffffff;
  line-height:1;
  letter-spacing:-.5px;
  transition:color .25s;
}
.jpg-footer-brand-link:hover .jpg-footer-brand-name{
  color:var(--c-gold);
}
.jpg-footer-brand-divider{
  display:block;
  width:60px;
  height:2px;
  background:var(--c-gold);
  margin:2px 0;
  transition:width .3s;
}
.jpg-footer-brand-link:hover .jpg-footer-brand-divider{
  width:100px;
}
.jpg-footer-brand-sub{
  font-family:var(--font-sans);
  font-size:11px;
  font-weight:600;
  color:var(--c-gold);
  letter-spacing:6px;
  text-transform:uppercase;
  line-height:1;
}

.jpg-foot-about p{
  line-height:1.6; margin:0 0 16px; color:#a3b1c4;
}
.jpg-foot-tagline,
.jpg-footer-tagline{
  font-style:italic;
  color:var(--c-gold) !important;
  margin-bottom:20px;
  line-height:1.5;
}
.jpg-foot-oab{
  font-size:13px; color:#a3b1c4;
  padding:12px 0; border-top:1px solid rgba(255,255,255,.08);
  margin-top:16px;
}
.jpg-foot-oab strong{ color:#fff; }

.jpg-footer-credentials{
  padding-top:16px;
  border-top:1px solid rgba(255,255,255,.08);
  margin-top:16px;
}
.jpg-footer-oab{
  display:flex; align-items:center; gap:8px;
  flex-wrap:wrap; font-size:13px;
  color:#a3b1c4; margin-bottom:8px;
}
.jpg-footer-oab svg{
  color:var(--c-gold); flex-shrink:0;
}
.jpg-footer-oab strong{
  color:#fff; font-weight:700;
}
.jpg-footer-cnpj small{
  font-size:12px; color:#7d8a9c;
}

.jpg-foot-social,
.jpg-footer-social{
  display:flex; align-items:center; gap:10px; margin-top:16px;
}
.jpg-footer-social-label{
  font-size:13px; color:#a3b1c4; font-weight:600;
}
.jpg-foot-social a,
.jpg-social-icon{
  width:38px; height:38px;
  background:rgba(255,255,255,.08);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:#fff !important; transition:all .2s;
}
.jpg-foot-social a:hover,
.jpg-social-icon:hover{
  background:var(--c-gold); color:var(--c-navy) !important;
  transform:translateY(-2px);
}

.jpg-foot-bottom{
  max-width:var(--max); margin:0 auto;
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex; justify-content:space-between;
  flex-wrap:wrap; gap:14px;
  font-size:13px; color:#9ca8bd;
}

.jpg-footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:24px; margin-top:24px;
}
.jpg-footer-bottom-inner{
  max-width:var(--max); margin:0 auto;
  padding:0 24px;
}

.jpg-foot-disclaimer,
.jpg-footer-disclaimer{
  max-width:var(--max); margin:0 auto;
  font-size:12px; color:#7d8a9c; line-height:1.6;
  text-align:center; margin-bottom:16px;
}
.jpg-foot-disclaimer strong,
.jpg-footer-disclaimer strong{ color:#a3b1c4; }

.jpg-footer-copyright{
  text-align:center;
  font-size:13px; color:#9ca8bd;
}
.jpg-footer-copyright strong{ color:#fff; }
.jpg-footer-copyright-sep{
  margin:0 8px; color:var(--c-gold);
}

/* ============================================================
   WHATSAPP FLUTUANTE (SEM ANIMACAO PULSANTE - OAB COMPLIANT)
   ============================================================ */
.jpg-wpp-float{
  position:fixed; bottom:24px; right:24px;
  width:60px; height:60px;
  background:var(--c-wpp); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 20px rgba(37,211,102,.35);
  z-index:99; transition:transform .25s, box-shadow .25s;
  text-decoration:none;
}
.jpg-wpp-float:hover{
  transform:scale(1.08);
  box-shadow:0 8px 28px rgba(37,211,102,.5);
  text-decoration:none;
}
.jpg-wpp-float svg{
  width:32px; height:32px; color:#fff;
}

/* ============================================================
   BOTAO VOLTAR AO TOPO
   ============================================================ */
.jpg-back-top,
.jpg-back-to-top{
  position:fixed; bottom:96px; right:24px;
  width:44px; height:44px; border-radius:50%;
  background:#fff; border:1.5px solid var(--c-border);
  color:var(--c-navy); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-md); z-index:98;
  opacity:0; visibility:hidden; transform:translateY(10px);
  transition:all .25s;
}
.jpg-back-top.visible,
.jpg-back-to-top.is-visible{
  opacity:1; visibility:visible; transform:translateY(0);
}
.jpg-back-top:hover,
.jpg-back-to-top:hover{
  background:var(--c-navy); color:#fff;
  border-color:var(--c-navy); transform:translateY(-2px);
}

/* ============================================================
   HEADER BRAND — Logo Tipografico Premium
   ============================================================ */
.jpg-header-brand-link{
  display:inline-flex;
  align-items:center;
  text-decoration:none !important;
  transition:transform .25s;
  padding:4px 0;
}
.jpg-header-brand-link:hover{
  transform:translateY(-1px);
  text-decoration:none !important;
}

.jpg-header-brand-logo{
  display:flex;
  align-items:center;
  gap:14px;
}

.jpg-header-brand-name{
  font-family:var(--font-serif), 'Playfair Display', Georgia, serif;
  font-size:26px;
  font-weight:700;
  color:var(--c-navy);
  line-height:1;
  letter-spacing:-.5px;
  transition:color .25s;
}

.jpg-header-brand-link:hover .jpg-header-brand-name{
  color:var(--c-gold-dark);
}

.jpg-header-brand-divider{
  display:block;
  width:2px;
  height:28px;
  background:var(--c-gold);
  transition:height .3s;
}

.jpg-header-brand-link:hover .jpg-header-brand-divider{
  height:34px;
}

.jpg-header-brand-sub{
  font-family:var(--font-sans);
  font-size:10px;
  font-weight:600;
  color:var(--c-gold-dark);
  letter-spacing:5px;
  text-transform:uppercase;
  line-height:1;
}

/* ============================================================
   PATCH — FIX ESPECIFICIDADE BRAND TIPOGRAFICO
   Forca aplicacao sobre Hello Elementor + Elementor Kit
   ============================================================ */
.jpg-header .jpg-header-brand-link{
  display:inline-flex !important;
  align-items:center !important;
  text-decoration:none !important;
  gap:0 !important;
  padding:4px 0 !important;
  transition:transform .25s !important;
}

.jpg-header .jpg-header-brand-link:hover{
  transform:translateY(-1px) !important;
}

.jpg-header .jpg-header-brand-logo{
  display:flex !important;
  align-items:center !important;
  gap:14px !important;
  flex-direction:row !important;
}

.jpg-header span.jpg-header-brand-name{
  font-family:'Playfair Display', Georgia, 'Times New Roman', serif !important;
  font-size:26px !important;
  font-weight:700 !important;
  color:#0a2540 !important;
  line-height:1 !important;
  letter-spacing:-.5px !important;
  display:inline-block !important;
  transition:color .25s !important;
}

.jpg-header .jpg-header-brand-link:hover span.jpg-header-brand-name{
  color:#a88a47 !important;
}

.jpg-header span.jpg-header-brand-divider{
  display:inline-block !important;
  width:2px !important;
  height:28px !important;
  background:#c9a961 !important;
  flex-shrink:0 !important;
  transition:height .3s !important;
}

.jpg-header .jpg-header-brand-link:hover span.jpg-header-brand-divider{
  height:34px !important;
}

.jpg-header span.jpg-header-brand-sub{
  font-family:'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
  font-size:10px !important;
  font-weight:600 !important;
  color:#a88a47 !important;
  letter-spacing:5px !important;
  text-transform:uppercase !important;
  line-height:1 !important;
  display:inline-block !important;
}

/* FOOTER BRAND — Force */
.jpg-footer .jpg-footer-brand-name{
  font-family:'Playfair Display', Georgia, serif !important;
  font-size:32px !important;
  font-weight:700 !important;
  color:#ffffff !important;
  line-height:1.1 !important;
  letter-spacing:-.5px !important;
  display:block !important;
  margin:0 0 12px 0 !important;
}

.jpg-footer .jpg-footer-brand-divider{
  display:block !important;
  width:60px !important;
  height:2px !important;
  background:#c9a961 !important;
  margin:12px 0 !important;
  border:none !important;
}

.jpg-footer .jpg-footer-brand-sub{
  font-family:'Inter', -apple-system, sans-serif !important;
  font-size:11px !important;
  font-weight:600 !important;
  color:#dcc285 !important;
  letter-spacing:6px !important;
  text-transform:uppercase !important;
  line-height:1 !important;
  display:block !important;
  margin:0 0 16px 0 !important;
}

/* ============================================================
   BLOG PAGE TEMPLATE (page-blog.php) — V2.4
   ============================================================ */

/* BLOG HERO */
.jpg-blog-hero{
  position:relative;
  padding:80px 0 64px;
  background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-light) 50%,#0f4a8a 100%);
  overflow:hidden;
}

.jpg-blog-hero-bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 30%,rgba(201,169,97,.1) 0%,transparent 50%),
    radial-gradient(circle at 80% 70%,rgba(201,169,97,.06) 0%,transparent 50%);
  pointer-events:none;
}

.jpg-blog-hero-grid{
  max-width:var(--max);
  margin:0 auto;
  padding:0 24px;
  display:grid;
  grid-template-columns:1fr 380px;
  gap:60px;
  align-items:center;
  position:relative;
  z-index:1;
}

.jpg-blog-hero-text{
  color:#fff;
}

.jpg-blog-hero .jpg-hero-tag{
  display:inline-block;
  background:rgba(201,169,97,.15);
  color:var(--c-gold);
  padding:6px 14px;
  border-radius:var(--radius-pill);
  font-size:13px;
  font-weight:600;
  letter-spacing:.5px;
  margin-bottom:20px;
  border:1px solid rgba(201,169,97,.35);
}

.jpg-blog-hero-title{
  font-family:var(--font-serif);
  font-size:clamp(32px,4.5vw,52px);
  font-weight:700;
  line-height:1.12;
  margin:0 0 18px;
  letter-spacing:-.5px;
  color:#fff;
}

.jpg-hero-title-accent{
  color:var(--c-gold);
}

.jpg-blog-hero-sub{
  font-size:clamp(16px,2vw,19px);
  line-height:1.65;
  color:#d8e2ee;
  margin:0 0 32px;
  max-width:560px;
}

.jpg-blog-hero-cta{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

/* BLOG HERO — Card Expertise */
.jpg-blog-hero-aside{
  display:flex;
  align-items:center;
  justify-content:flex-end;
}

.jpg-expertise-card{
  background:#fff;
  border-radius:var(--radius-lg);
  padding:32px 28px;
  box-shadow:var(--shadow-lg);
  width:100%;
  max-width:380px;
  color:var(--c-text);
  overflow:hidden;
}

.jpg-expertise-head{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:14px;
  margin-bottom:24px;
  padding-bottom:20px;
  border-bottom:2px solid var(--c-gold);
}

.jpg-expertise-badge{
  background:var(--c-cream);
  color:var(--c-gold-dark);
  padding:5px 14px;
  border-radius:var(--radius-pill);
  font-size:11px;
  font-weight:700;
  letter-spacing:.8px;
  text-transform:uppercase;
  white-space:nowrap;
  order:-1;
}

.jpg-expertise-head h3{
  font-family:var(--font-serif);
  color:var(--c-navy);
  font-size:22px;
  font-weight:700;
  margin:0;
  line-height:1.25;
}

.jpg-expertise-list{
  list-style:none;
  margin:0;
  padding:0;
}

.jpg-expertise-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  border-bottom:1px solid #f0f0f0;
  transition:all .2s;
  text-decoration:none;
  color:inherit;
  gap:12px;
}

.jpg-expertise-item:last-child{
  border-bottom:0;
}

a.jpg-expertise-item:hover{
  padding-left:8px;
}

.jpg-expertise-name{
  font-size:15px;
  font-weight:500;
  color:var(--c-text);
  transition:color .2s;
  flex:1;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

a.jpg-expertise-item:hover .jpg-expertise-name{
  color:var(--c-gold-dark);
}

.jpg-expertise-arrow{
  font-size:14px;
  color:#ccc;
  transition:transform .2s, color .2s;
  flex-shrink:0;
}

a.jpg-expertise-item:hover .jpg-expertise-arrow{
  transform:translateX(4px);
  color:var(--c-gold-dark);
}

.jpg-expertise-icon{
  display:none;
}

/* ============================================================
   BLOG STATS BAR — 4 blocos uniformes (sem OAB)
   ============================================================ */
.jpg-blog-stats{
  background:var(--c-navy-dark);
  color:#fff;
  padding:44px 24px;
}

.jpg-blog-stats .jpg-stats-grid{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:30px;
  text-align:center;
}

.jpg-stat-block{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
}

.jpg-stat-number{
  font-family:var(--font-serif);
  font-size:clamp(32px,4vw,48px);
  font-weight:700;
  color:var(--c-gold);
  line-height:1;
  letter-spacing:-.5px;
}

.jpg-stat-block .jpg-stat-label{
  font-size:13px;
  color:#b8c5d6;
  font-weight:600;
  letter-spacing:.5px;
  text-transform:uppercase;
}

/* ============================================================
   PILLS — Filtros de Categoria
   ============================================================ */
.jpg-blog-section .jpg-filters{
  max-width:var(--max);
  margin:0 auto 40px;
  padding:0 24px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
}

.jpg-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:9px 20px;
  border-radius:var(--radius-pill);
  background:#fff;
  border:1.5px solid var(--c-border);
  color:var(--c-text);
  font-family:var(--font-sans);
  font-size:14px;
  font-weight:600;
  text-decoration:none;
  transition:all .2s;
  cursor:pointer;
}

.jpg-pill:hover{
  border-color:var(--c-gold);
  color:var(--c-gold-dark);
  text-decoration:none;
}

.jpg-pill.active,
.jpg-pill.is-active{
  background:var(--c-navy);
  color:#fff;
  border-color:var(--c-navy);
}

.jpg-pill.active:hover,
.jpg-pill.is-active:hover{
  background:var(--c-gold);
  color:var(--c-navy);
  border-color:var(--c-gold);
}

.jpg-pill-count{
  font-size:12px;
  opacity:.7;
  font-weight:500;
}

.jpg-pill.active .jpg-pill-count,
.jpg-pill.is-active .jpg-pill-count{
  opacity:.85;
}

/* ============================================================
   POST CARDS — Ajustes para wrapper <a>
   ============================================================ */
a.jpg-post-card{
  text-decoration:none;
  color:inherit;
}

a.jpg-post-card:hover{
  text-decoration:none;
  color:inherit;
}

.jpg-post-card .jpg-post-title{
  font-family:var(--font-serif);
  color:var(--c-navy);
  font-size:20px;
  font-weight:700;
  line-height:1.3;
  margin:0 0 12px;
  letter-spacing:-.2px;
}

.jpg-post-card:hover .jpg-post-title{
  color:var(--c-gold-dark);
}

.jpg-post-card .jpg-post-excerpt{
  font-size:15px;
  color:var(--c-text-light);
  line-height:1.6;
  margin:0 0 18px;
  flex:1;
}

.jpg-post-card .jpg-meta-item{
  display:inline-flex;
  align-items:center;
  gap:5px;
}

.jpg-post-card .jpg-meta-item svg{
  width:14px;
  height:14px;
  color:var(--c-gold-dark);
  flex-shrink:0;
}

/* POST CARD — V2.7 classes */
.jpg-post-card-link{
  display:flex;
  flex-direction:column;
  height:100%;
  text-decoration:none;
  color:inherit;
}

.jpg-post-card-image-wrap{
  position:relative;
  aspect-ratio:16/9;
  overflow:hidden;
  background:#0a1f3d;
}

.jpg-post-card-image{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .5s cubic-bezier(0.4,0,0.2,1);
}

.jpg-post-card:hover .jpg-post-card-image{
  transform:scale(1.05);
}

.jpg-post-card-image-placeholder{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,#0a1f3d 0%,#0f2a52 100%);
}

.jpg-placeholder-text{
  font-family:var(--font-serif);
  font-size:48px;
  font-weight:700;
  color:rgba(196,162,99,0.4);
  letter-spacing:0.05em;
}

.jpg-post-card-body{
  padding:24px;
  flex:1;
  display:flex;
  flex-direction:column;
}

.jpg-post-card-category{
  display:inline-block;
  font-family:var(--font-sans);
  font-size:11px;
  font-weight:600;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--c-gold);
  margin-bottom:12px;
}

.jpg-post-card-title{
  font-family:var(--font-serif);
  font-size:20px;
  font-weight:700;
  line-height:1.3;
  color:var(--c-navy);
  margin:0 0 12px;
  letter-spacing:-0.01em;
  transition:color .25s ease;
}

.jpg-post-card:hover .jpg-post-card-title{
  color:var(--c-gold);
}

.jpg-post-card-excerpt{
  font-family:var(--font-sans);
  font-size:14px;
  line-height:1.6;
  color:#555;
  margin:0 0 20px;
  flex:1;
}

.jpg-post-card-meta{
  display:flex;
  align-items:center;
  gap:8px;
  padding-top:16px;
  border-top:1px solid #f0f0f0;
  font-family:var(--font-sans);
  font-size:12px;
  color:#888;
}

.jpg-post-card-meta svg{
  vertical-align:middle;
  margin-right:4px;
  opacity:0.6;
}

.jpg-meta-date,
.jpg-meta-reading{
  display:inline-flex;
  align-items:center;
}

.jpg-meta-separator{
  color:#ccc;
}

/* ============================================================
   EMPTY STATE
   ============================================================ */
.jpg-empty-state{
  grid-column:1 / -1;
  max-width:500px;
  margin:0 auto;
  text-align:center;
  padding:60px 24px;
  color:var(--c-text-light);
}

.jpg-empty-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 20px;
}

.jpg-empty-icon svg{
  width:64px;
  height:64px;
  color:var(--c-border);
}

.jpg-empty-state h3{
  font-family:var(--font-serif);
  color:var(--c-navy);
  font-size:22px;
  font-weight:700;
  margin:0 0 10px;
}

.jpg-empty-state p{
  font-size:15px;
  color:var(--c-text-light);
  line-height:1.6;
  margin:0 0 24px;
}

.jpg-blog-empty{
  grid-column:1 / -1;
  text-align:center;
  padding:80px 20px;
  font-family:var(--font-sans);
}

.jpg-blog-empty p{
  font-size:16px;
  color:#666;
  margin:0 0 20px;
}

.jpg-btn-reset{
  padding:12px 28px;
  font-family:var(--font-sans);
  font-size:13px;
  font-weight:500;
  letter-spacing:0.05em;
  color:#fff;
  background:var(--c-navy);
  border:none;
  border-radius:6px;
  cursor:pointer;
  transition:background 0.25s ease;
}

.jpg-btn-reset:hover{
  background:var(--c-gold);
}

/* ============================================================
   CTA SECTION — Chamada final do blog
   ============================================================ */
.jpg-cta-section{
  background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-light) 100%);
  color:#fff;
  padding:90px 24px;
  position:relative;
  overflow:hidden;
}

.jpg-cta-section::before{
  content:"";
  position:absolute;
  bottom:-30%;
  left:-10%;
  width:500px;
  height:500px;
  background:radial-gradient(circle,rgba(201,169,97,.15) 0%,transparent 70%);
  pointer-events:none;
}

.jpg-cta-box{
  max-width:720px;
  margin:0 auto;
  text-align:center;
  position:relative;
  z-index:1;
}

.jpg-cta-tag{
  display:inline-block;
  color:var(--c-gold);
  font-size:13px;
  font-weight:700;
  letter-spacing:1.5px;
  text-transform:uppercase;
  margin-bottom:16px;
}

.jpg-cta-title{
  font-family:var(--font-serif);
  font-size:clamp(28px,3.5vw,42px);
  font-weight:700;
  line-height:1.2;
  margin:0 0 16px;
  color:#fff;
}

.jpg-cta-sub{
  font-size:18px;
  color:#d8e2ee;
  line-height:1.65;
  margin:0 0 36px;
  max-width:600px;
  margin-left:auto;
  margin-right:auto;
}

.jpg-cta-content{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.jpg-cta-actions{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
}

/* Blog CTA alternativo */
.jpg-blog-cta{
  padding:80px 0;
  background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-navy-light) 100%);
  text-align:center;
}

.jpg-blog-cta-inner{
  max-width:680px;
  margin:0 auto;
  padding:0 24px;
}

.jpg-blog-cta-title{
  font-family:var(--font-serif);
  font-size:clamp(28px,3.5vw,36px);
  font-weight:700;
  color:#fff;
  line-height:1.2;
  margin:0 0 16px;
  letter-spacing:-0.01em;
}

.jpg-blog-cta-text{
  font-family:var(--font-sans);
  font-size:16px;
  line-height:1.7;
  color:rgba(255,255,255,0.85);
  margin:0 0 32px;
  font-weight:300;
}

.jpg-blog-cta-button{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:16px 36px;
  font-family:var(--font-sans);
  font-size:15px;
  font-weight:500;
  letter-spacing:0.05em;
  color:var(--c-navy);
  background:var(--c-gold);
  border-radius:6px;
  text-decoration:none;
  transition:all 0.3s ease;
}

.jpg-blog-cta-button:hover{
  background:#fff;
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(196,162,99,0.3);
}

.jpg-blog-cta-button svg{
  transition:transform 0.3s ease;
}

.jpg-blog-cta-button:hover svg{
  transform:translateX(4px);
}

/* ============================================================
   BOTOES — ghost, ghost-light, gold-outline
   ============================================================ */

/* Ghost */
.jpg-btn-ghost,
body.jpg-blog-body .jpg-btn-ghost{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 28px;
  border-radius:var(--radius);
  font-weight:600;
  font-size:16px;
  cursor:pointer;
  transition:all .25s;
  text-decoration:none;
  line-height:1.2;
  min-height:48px;
  font-family:var(--font-sans);
  background:transparent;
  color:var(--c-navy);
  border:2px solid var(--c-navy);
}

.jpg-btn-ghost:hover,
body.jpg-blog-body .jpg-btn-ghost:hover{
  background:var(--c-navy);
  color:#fff;
  text-decoration:none;
  transform:translateY(-2px);
}

/* Ghost Light (para fundos escuros) */
.jpg-btn-ghost-light,
body.jpg-blog-body .jpg-btn-ghost-light,
body .jpg-btn-ghost-light,
a.jpg-btn-ghost-light{
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 28px;
  border-radius:var(--radius);
  font-weight:600;
  font-size:16px;
  cursor:pointer;
  transition:all .25s;
  text-decoration:none;
  line-height:1.2;
  min-height:48px;
  font-family:var(--font-sans);
  background:transparent;
  color:#ffffff !important;
  border:2px solid #ffffff !important;
}

.jpg-btn-ghost-light:hover,
body.jpg-blog-body .jpg-btn-ghost-light:hover,
body .jpg-btn-ghost-light:hover,
a.jpg-btn-ghost-light:hover{
  background:#ffffff !important;
  color:var(--c-navy) !important;
  border-color:#ffffff !important;
  text-decoration:none;
  transform:translateY(-2px);
  box-shadow:0 4px 20px rgba(255,255,255,.2);
}

/* Gold Outline (para fundos escuros) */
.jpg-btn-gold-outline,
body.jpg-blog-body .jpg-btn-gold-outline{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 28px;
  border-radius:var(--radius);
  font-weight:600;
  font-size:16px;
  cursor:pointer;
  transition:all .25s;
  text-decoration:none;
  line-height:1.2;
  min-height:48px;
  font-family:var(--font-sans);
  background:transparent;
  color:var(--c-gold);
  border:2px solid var(--c-gold);
}

.jpg-btn-gold-outline:hover,
body.jpg-blog-body .jpg-btn-gold-outline:hover{
  background:var(--c-gold);
  color:var(--c-navy);
  text-decoration:none;
  transform:translateY(-2px);
  box-shadow:var(--shadow-gold);
}

/* btn-sm variante */
.jpg-btn-ghost.jpg-btn-sm,
.jpg-btn-ghost-light.jpg-btn-sm,
.jpg-btn-gold-outline.jpg-btn-sm{
  padding:10px 18px;
  font-size:14px;
  min-height:auto;
}

/* SVGs dentro de botoes */
.jpg-btn-ghost svg,
.jpg-btn-ghost-light svg,
.jpg-btn-gold-outline svg,
.jpg-btn-wpp svg,
.jpg-btn-gold svg,
.jpg-btn-navy svg{
  width:18px;
  height:18px;
  flex-shrink:0;
}

/* Fix botao ghost no CTA section */
.jpg-cta-section .jpg-btn-ghost,
.jpg-cta-section a.jpg-btn-ghost,
.jpg-cta-box .jpg-btn-ghost,
body.jpg-blog-body .jpg-cta-section .jpg-btn-ghost{
  background:transparent !important;
  color:#ffffff !important;
  border:2px solid #ffffff !important;
}

.jpg-cta-section .jpg-btn-ghost:hover,
.jpg-cta-section a.jpg-btn-ghost:hover,
.jpg-cta-box .jpg-btn-ghost:hover,
body.jpg-blog-body .jpg-cta-section .jpg-btn-ghost:hover{
  background:#ffffff !important;
  color:var(--c-navy) !important;
  border-color:#ffffff !important;
  transform:translateY(-2px);
  box-shadow:0 4px 20px rgba(255,255,255,.2);
}

/* CTA actions gold-outline */
.jpg-cta-actions .jpg-btn-gold-outline{
  color:var(--c-gold);
  border-color:var(--c-gold);
}

.jpg-cta-actions .jpg-btn-gold-outline:hover{
  background:var(--c-gold);
  color:var(--c-navy);
  border-color:var(--c-gold);
}

/* ============================================================
   BLOG SEARCH
   ============================================================ */
.jpg-blog-search{
  max-width:500px;
  margin:0 auto 32px;
}

.jpg-search-wrapper{
  position:relative;
  display:flex;
  align-items:center;
}

.jpg-search-icon{
  position:absolute;
  left:18px;
  color:var(--c-navy);
  pointer-events:none;
}

.jpg-search-input{
  width:100%;
  padding:14px 20px 14px 48px;
  font-family:var(--font-sans);
  font-size:15px;
  color:var(--c-navy);
  background:#fff;
  border:1px solid var(--c-border);
  border-radius:8px;
  transition:all 0.25s ease;
  outline:none;
}

.jpg-search-input:focus{
  border-color:var(--c-gold);
  box-shadow:0 0 0 3px rgba(201,169,97,.15);
}

.jpg-search-input::placeholder{
  color:#9a9a9a;
}

/* Blog categories chips */
.jpg-blog-categories{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
}

.jpg-cat-chip{
  padding:10px 20px;
  font-family:var(--font-sans);
  font-size:13px;
  font-weight:500;
  letter-spacing:0.03em;
  color:var(--c-navy);
  background:#fff;
  border:1px solid #d4d4d4;
  border-radius:30px;
  cursor:pointer;
  transition:all 0.25s ease;
  outline:none;
}

.jpg-cat-chip:hover{
  border-color:var(--c-gold);
  color:var(--c-gold);
  transform:translateY(-1px);
}

.jpg-cat-chip:focus-visible{
  border-color:var(--c-gold);
  box-shadow:0 0 0 3px rgba(201,169,97,.2);
}

.jpg-cat-chip.is-active{
  background:var(--c-navy);
  border-color:var(--c-navy);
  color:#fff;
}

.jpg-cat-chip.is-active:hover{
  background:var(--c-gold);
  border-color:var(--c-gold);
  color:#fff;
}

/* Results info */
.jpg-blog-results-info{
  text-align:center;
  font-family:var(--font-sans);
  font-size:13px;
  color:#666;
  margin-bottom:24px;
  min-height:20px;
  opacity:0;
  transition:opacity 0.3s ease;
}

.jpg-blog-results-info.is-visible{
  opacity:1;
}

/* Blog grid */
.jpg-blog-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
  transition:opacity 0.3s ease;
}

.jpg-blog-grid.is-loading{
  opacity:0.4;
  pointer-events:none;
}

/* Blog section */
.jpg-blog-section{
  padding:64px 0 80px;
  background:var(--c-bg);
}

/* Blog filters */
.jpg-blog-filters{
  margin-bottom:48px;
}

/* Blog hero extras */
.jpg-blog-hero-eyebrow{
  display:inline-block;
  font-family:var(--font-sans);
  font-size:12px;
  font-weight:600;
  letter-spacing:0.25em;
  color:var(--c-gold);
  text-transform:uppercase;
  margin-bottom:20px;
}

.jpg-blog-hero-divider{
  width:60px;
  height:2px;
  background:var(--c-gold);
  margin:0 auto 24px;
}

.jpg-blog-hero-subtitle{
  font-family:var(--font-sans);
  font-size:17px;
  line-height:1.7;
  color:rgba(255,255,255,0.85);
  margin:0;
  font-weight:300;
}

.jpg-blog-hero-content{
  position:relative;
  text-align:center;
  max-width:720px;
  margin:0 auto;
}

/* Blog pagination */
.jpg-blog-pagination{
  margin-top:64px;
  display:flex;
  justify-content:center;
}

.jpg-blog-pagination .page-numbers{
  display:flex;
  list-style:none;
  padding:0;
  margin:0;
  gap:6px;
  align-items:center;
}

.jpg-blog-pagination .page-numbers li a,
.jpg-blog-pagination .page-numbers li span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:42px;
  height:42px;
  padding:0 14px;
  font-family:var(--font-sans);
  font-size:14px;
  font-weight:500;
  color:var(--c-navy);
  background:#fff;
  border:1px solid var(--c-border);
  border-radius:6px;
  text-decoration:none;
  transition:all 0.25s ease;
}

.jpg-blog-pagination .page-numbers li a:hover{
  border-color:var(--c-gold);
  color:var(--c-gold);
}

.jpg-blog-pagination .page-numbers li .current{
  background:var(--c-navy);
  border-color:var(--c-navy);
  color:#fff;
}

.jpg-blog-pagination .page-numbers li .dots{
  border:none;
  background:transparent;
}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width:1100px){
  .jpg-share-bar{ display:none; }
}

@media (max-width:960px){
  .jpg-hero-grid{ grid-template-columns:1fr; gap:40px; }
  .jpg-stats-grid{ grid-template-columns:repeat(2, 1fr); gap:30px; }
  .jpg-posts-grid{ grid-template-columns:repeat(2, 1fr); gap:24px; }
  .jpg-areas-grid{ grid-template-columns:repeat(2, 1fr); gap:24px; }
  .jpg-foot-grid,
  .jpg-footer-inner{ grid-template-columns:1fr 1fr; gap:32px; }
  .jpg-area-services-grid{ grid-template-columns:1fr; }

  .jpg-main-navigation,
  .jpg-nav{
    display:none; position:absolute; top:100%; left:0; right:0;
    background:#fff; flex-direction:column; padding:20px;
    border-bottom:1px solid var(--c-border);
    box-shadow:var(--shadow-md); z-index:50;
  }
  .jpg-main-navigation.is-open,
  .jpg-nav.is-open{ display:flex; }
  .jpg-main-navigation .jpg-menu,
  .jpg-nav .jpg-menu{
    flex-direction:column; align-items:flex-start;
    gap:16px; width:100%;
  }
  .jpg-main-navigation .jpg-menu .sub-menu,
  .jpg-main-navigation .jpg-menu ul.children,
  .jpg-nav .sub-menu{
    position:static; opacity:1; visibility:visible;
    transform:none; box-shadow:none; border:0;
    padding-left:16px; min-width:auto; width:100%;
  }
  .jpg-menu-toggle,
  .jpg-hamburger{ display:flex; }
  .jpg-header-cta{ display:none; }

  .jpg-post-cta-inner{
    grid-template-columns:1fr; text-align:center; gap:20px;
  }
  .jpg-post-cta-icon{ margin:0 auto; }
  .jpg-post-cta .btn,
  .jpg-post-cta .jpg-btn{ width:100%; }

  /* Blog hero */
  .jpg-blog-hero-grid{
    grid-template-columns:1fr;
    gap:40px;
  }

  .jpg-blog-hero-aside{
    justify-content:center;
  }

  .jpg-expertise-card{
    max-width:480px;
  }

  /* Blog stats */
  .jpg-blog-stats .jpg-stats-grid{
    grid-template-columns:repeat(2,1fr);
    gap:24px;
  }

  /* Blog grid */
  .jpg-blog-grid{
    grid-template-columns:repeat(2,1fr);
    gap:24px;
  }
}

@media (max-width:600px){
  .jpg-hero{ padding:60px 20px 80px; }
  .jpg-posts-section{ padding:56px 20px; }
  .jpg-areas-section{ padding:56px 20px; }
  .jpg-cta{ padding:60px 20px; }
  .jpg-posts-grid{ grid-template-columns:1fr; }
  .jpg-areas-grid{ grid-template-columns:1fr; }
  .jpg-stats-grid{ grid-template-columns:1fr 1fr; }
  .jpg-hero-cta{ flex-direction:column; width:100%; }
  .jpg-hero-cta .btn,
  .jpg-hero-cta .jpg-btn{ width:100%; }
  .jpg-cta-buttons{ flex-direction:column; }
  .jpg-cta-buttons .btn,
  .jpg-cta-buttons .jpg-btn{ width:100%; }
  .jpg-foot-grid,
  .jpg-footer-inner{ grid-template-columns:1fr; gap:32px; }
  .jpg-foot-bottom{ flex-direction:column; text-align:center; }
  .jpg-custom-logo img,
  .jpg-site-branding img,
  .jpg-header-logo img,
  .jpg-logo-img{
    height:40px; max-width:170px;
  }
  .jpg-footer-brand-name{
    font-size:28px;
  }
  .jpg-footer-brand-sub{
    font-size:10px;
    letter-spacing:5px;
  }
  .jpg-wpp-float{
    width:54px; height:54px; bottom:18px; right:18px;
  }
  .jpg-wpp-float svg{ width:28px; height:28px; }
  .jpg-back-top,
  .jpg-back-to-top{
    bottom:84px; right:18px; width:40px; height:40px;
  }
  .jpg-post-hero{ padding:40px 20px 0; }
  .jpg-post-hero-meta{ gap:14px; }
  .jpg-post-content{ margin-top:40px; padding:0 20px; }
  .jpg-post-body{ font-size:17px; }
  .jpg-post-cta{ margin:40px auto; padding:0 20px; }
  .jpg-post-cta-inner{ padding:30px 24px; }
  .jpg-area-hero{ padding:60px 20px 80px; }
  .jpg-area-services{ margin:40px auto; padding:0 20px; }
  .jpg-header .jpg-header-inner,
  .jpg-header-inner{ padding:12px 16px; }

  /* Blog hero */
  .jpg-blog-hero{
    padding:60px 0 48px;
  }

  .jpg-blog-hero-grid{
    padding:0 20px;
  }

  .jpg-blog-hero-cta{
    flex-direction:column;
    width:100%;
  }

  .jpg-blog-hero-cta .jpg-btn,
  .jpg-blog-hero-cta .jpg-btn-wpp,
  .jpg-blog-hero-cta .jpg-btn-ghost-light{
    width:100%;
    text-align:center;
  }

  .jpg-expertise-card{
    max-width:100%;
    padding:24px 20px;
  }

  .jpg-expertise-head h3{
    font-size:19px;
  }

  .jpg-expertise-badge{
    font-size:10px;
    padding:3px 10px;
  }

  .jpg-expertise-name{
    font-size:14px;
  }

  /* Blog stats */
  .jpg-blog-stats .jpg-stats-grid{
    grid-template-columns:1fr 1fr;
    gap:20px;
  }

  .jpg-blog-stats{
    padding:32px 20px;
  }

  /* Blog filters */
  .jpg-blog-section .jpg-filters{
    justify-content:flex-start;
    overflow-x:auto;
    flex-wrap:nowrap;
    padding-bottom:8px;
    -webkit-overflow-scrolling:touch;
  }

  .jpg-pill{
    flex-shrink:0;
  }

  .jpg-blog-categories{
    justify-content:flex-start;
    overflow-x:auto;
    flex-wrap:nowrap;
    padding-bottom:8px;
    -webkit-overflow-scrolling:touch;
  }

  .jpg-cat-chip{
    flex-shrink:0;
  }

  /* Blog grid */
  .jpg-blog-grid{
    grid-template-columns:1fr;
    gap:20px;
  }

  /* CTA */
  .jpg-cta-section{
    padding:60px 20px;
  }

  .jpg-cta-actions{
    flex-direction:column;
    width:100%;
  }

  .jpg-cta-actions .jpg-btn,
  .jpg-cta-actions .jpg-btn-wpp,
  .jpg-cta-actions .jpg-btn-gold-outline{
    width:100%;
    text-align:center;
  }

  .jpg-blog-cta{
    padding:60px 0;
  }

  /* Header brand */
  .jpg-header-brand-logo{
    gap:10px;
  }
  .jpg-header-brand-name{
    font-size:22px;
  }
  .jpg-header-brand-divider{
    height:24px;
  }
  .jpg-header-brand-sub{
    font-size:9px;
    letter-spacing:4px;
  }
  .jpg-header span.jpg-header-brand-name{
    font-size:22px !important;
  }
  .jpg-header span.jpg-header-brand-divider{
    height:24px !important;
  }
  .jpg-header span.jpg-header-brand-sub{
    font-size:9px !important;
    letter-spacing:4px !important;
  }
}

@media (max-width:380px){
  .jpg-header-brand-sub,
  .jpg-header-brand-divider,
  .jpg-header span.jpg-header-brand-sub,
  .jpg-header span.jpg-header-brand-divider{
    display:none !important;
  }
}

@media (prefers-reduced-motion: reduce){
  body.jpg-blog-body *,
  body.jpg-blog-body *::before,
  body.jpg-blog-body *::after{
    transition:none!important;
    animation:none!important;
  }
}
/* ============================================================
   SINGLE POST — TEMPLATE ATUAL (single.php)
   Compatível com classes jpg-single-* e jpg-content
   AJUSTADO — JPGOMES
   ============================================================ */

/* ============================================================
   HERO
   ============================================================ */

.jpg-single-hero{
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-light) 52%, #0f4a8a 100%);
  color:#fff;
  padding:38px 0 42px;
}

.jpg-single-hero-bg{
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 18% 24%, rgba(201,169,97,.10) 0%, transparent 36%),
    radial-gradient(circle at 82% 72%, rgba(201,169,97,.08) 0%, transparent 34%);
}

.jpg-single-hero .jpg-container{
  position:relative;
  z-index:1;
  max-width:1180px;
  margin:0 auto;
  padding-left:24px;
  padding-right:24px;
  min-width:0;
}

.jpg-single-hero-content{
  width:100%;
  max-width:720px;
  min-width:0;
}

/* ============================================================
   BREADCRUMBS
   ============================================================ */

.jpg-single-hero .jpg-breadcrumbs,
.jpg-single-hero .breadcrumbs{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  margin:0 0 22px;
  font-size:13px;
  line-height:1.5;
  color:#b8c5d6;
  min-width:0;
}

.jpg-single-hero .jpg-breadcrumbs a,
.jpg-single-hero .breadcrumbs a{
  color:#d8e2ee;
  text-decoration:none;
}

.jpg-single-hero .jpg-breadcrumbs a:hover,
.jpg-single-hero .breadcrumbs a:hover{
  color:var(--c-gold);
  text-decoration:none;
}

.jpg-single-hero .jpg-breadcrumbs span,
.jpg-single-hero .breadcrumbs span{
  min-width:0;
}

.jpg-single-hero .jpg-breadcrumb-current,
.jpg-single-hero .breadcrumbs .current{
  color:#fff;
  font-weight:600;
  overflow-wrap:anywhere;
  word-break:break-word;
}

/* ============================================================
   CATEGORY BADGE
   ============================================================ */

.jpg-single-cat-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0 0 18px;
  padding:8px 14px;
  border-radius:var(--radius-pill);
  background:rgba(201,169,97,.16);
  border:1px solid rgba(201,169,97,.34);
  color:var(--c-gold-light);
  font-size:12px;
  font-weight:700;
  letter-spacing:.6px;
  text-transform:uppercase;
  text-decoration:none;
  transition:all .25s ease;
  max-width:100%;
}

.jpg-single-cat-badge:hover{
  color:#fff;
  border-color:rgba(201,169,97,.55);
  background:rgba(201,169,97,.24);
  text-decoration:none;
  transform:translateY(-1px);
}

.jpg-single-cat-badge svg{
  flex-shrink:0;
}

/* ============================================================
   TITLE / EXCERPT / META
   ============================================================ */

.jpg-single-title{
  display:block;
  width:100%;
  max-width:100%;
  min-width:0;
  margin:0 0 16px;
  font-family:var(--font-serif);
  font-size:clamp(30px, 4vw, 48px);
  line-height:1.12;
  font-weight:700;
  letter-spacing:-.6px;
  color:#fff;
  overflow-wrap:anywhere;
  word-break:break-word;
  hyphens:auto;
}

.jpg-single-excerpt{
  display:block;
  width:100%;
  max-width:680px;
  margin:0 0 22px;
  font-size:clamp(16px, 1.8vw, 19px);
  line-height:1.72;
  color:#dbe6f2;
  overflow-wrap:anywhere;
}

.jpg-single-meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px 14px;
  color:#c6d3e1;
  font-size:14px;
  line-height:1.5;
  min-width:0;
}

.jpg-meta-item{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:20px;
  min-width:0;
}

.jpg-meta-item svg{
  color:var(--c-gold);
  flex-shrink:0;
}

.jpg-meta-item span,
.jpg-meta-item time{
  min-width:0;
  overflow-wrap:anywhere;
}

.jpg-meta-divider{
  color:rgba(255,255,255,.35);
}

/* ============================================================
   ARTICLE / GRID
   ============================================================ */

.jpg-single-article{
  background:#fff;
}

.jpg-single-article .jpg-container{
  max-width:1180px;
  margin:0 auto;
  padding-left:24px;
  padding-right:24px;
}

.jpg-single-grid{
  display:grid;
  grid-template-columns:96px minmax(0, 760px);
  gap:36px;
  align-items:start;
  justify-content:center;
  padding:40px 0 0;
}

.jpg-single-main{
  min-width:0;
  width:100%;
}

/* ============================================================
   SHARE STICKY
   ============================================================ */

.jpg-share-sticky{
  position:relative;
  width:96px;
  min-width:96px;
}

.jpg-share-inner{
  position:sticky;
  top:108px;
  width:100%;
  max-width:88px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  padding:18px 10px;
  background:#fff;
  border:1px solid var(--c-border);
  border-radius:22px;
  box-shadow:var(--shadow-md);
}

.jpg-share-label{
  font-size:10px;
  line-height:1.2;
  font-weight:700;
  letter-spacing:1.4px;
  text-transform:uppercase;
  color:var(--c-text-light);
  text-align:center;
  margin-bottom:4px;
}

.jpg-share-btn{
  position:relative;
  width:42px;
  height:42px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  border:0;
  cursor:pointer;
  text-decoration:none;
  transition:transform .2s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
}

.jpg-share-btn:hover{
  transform:translateY(-2px) scale(1.04);
  text-decoration:none;
}

.jpg-share-btn svg{
  width:18px;
  height:18px;
}

.jpg-share-wpp{
  background:var(--c-wpp);
  color:#fff;
}

.jpg-share-wpp:hover{
  background:var(--c-wpp-dark);
  color:#fff;
}

.jpg-share-li{
  background:#0a66c2;
  color:#fff;
}

.jpg-share-li:hover{
  background:#084d92;
  color:#fff;
}

.jpg-share-fb{
  background:#1877f2;
  color:#fff;
}

.jpg-share-fb:hover{
  background:#0d5cbd;
  color:#fff;
}

.jpg-share-x{
  background:#111827;
  color:#fff;
}

.jpg-share-x:hover{
  background:#000;
  color:#fff;
}

.jpg-share-copy{
  background:var(--c-border-light);
  color:var(--c-navy);
}

.jpg-share-copy:hover{
  background:var(--c-gold);
  color:var(--c-navy);
}

.jpg-share-copy-feedback{
  position:absolute;
  left:calc(100% + 10px);
  top:50%;
  transform:translateY(-50%);
  background:var(--c-navy);
  color:#fff;
  padding:6px 10px;
  border-radius:8px;
  font-size:12px;
  font-weight:600;
  line-height:1;
  white-space:nowrap;
  opacity:0;
  visibility:hidden;
  transition:all .2s ease;
  box-shadow:var(--shadow-sm);
}

.jpg-share-copy-feedback.is-visible{
  opacity:1;
  visibility:visible;
}

/* ============================================================
   FEATURED IMAGE
   ============================================================ */

.jpg-single-featured{
  margin:0 0 34px;
  border-radius:22px;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  background:var(--c-bg);
}

.jpg-single-featured-img{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio:16/9;
  object-fit:cover;
}

/* ============================================================
   CONTENT / TYPOGRAPHY
   ============================================================ */

.jpg-content{
  width:100%;
  max-width:100%;
  min-width:0;
  color:var(--c-text);
  font-size:18px;
  line-height:1.85;
  word-wrap:break-word;
  overflow-wrap:break-word;
}

.jpg-content > *:first-child{
  margin-top:0 !important;
}

.jpg-content > p:first-of-type{
  font-size:1.22em;
  line-height:1.9;
  color:#445468;
}

.jpg-content p{
  margin:0 0 1.35em;
}

.jpg-content h2{
  margin:3rem 0 1rem;
  font-family:var(--font-serif);
  font-size:clamp(28px, 3vw, 36px);
  line-height:1.2;
  font-weight:700;
  letter-spacing:-.35px;
  color:var(--c-navy);
  overflow-wrap:anywhere;
}

.jpg-content h3{
  margin:2.1rem 0 .85rem;
  font-family:var(--font-serif);
  font-size:clamp(22px, 2.3vw, 28px);
  line-height:1.28;
  font-weight:700;
  letter-spacing:-.2px;
  color:var(--c-navy);
  overflow-wrap:anywhere;
}

.jpg-content h4{
  margin:1.6rem 0 .75rem;
  font-size:19px;
  line-height:1.35;
  font-weight:700;
  color:var(--c-navy);
  overflow-wrap:anywhere;
}

.jpg-content ul,
.jpg-content ol{
  margin:0 0 1.5em 1.3em;
  padding:0;
}

.jpg-content li{
  margin:0 0 .7em;
  padding-left:.1em;
}

.jpg-content ul li::marker{
  color:var(--c-gold);
}

.jpg-content ol li::marker{
  color:var(--c-navy);
  font-weight:700;
}

.jpg-content a{
  color:var(--c-gold-dark);
  text-decoration:underline;
  text-decoration-color:rgba(201,169,97,.45);
  text-underline-offset:3px;
  transition:color .2s ease, text-decoration-color .2s ease;
}

.jpg-content a:hover{
  color:var(--c-navy);
  text-decoration-color:var(--c-navy);
}

.jpg-content strong{
  color:var(--c-navy);
  font-weight:700;
}

.jpg-content blockquote{
  margin:2rem 0;
  padding:1.35rem 1.5rem;
  background:linear-gradient(180deg, #fbfcfe 0%, #f6f8fb 100%);
  border:1px solid #e8edf3;
  border-left:4px solid var(--c-gold);
  border-radius:0 16px 16px 0;
  color:#4a5b70;
  font-style:italic;
  box-shadow:var(--shadow-sm);
}

.jpg-content blockquote p:last-child{
  margin-bottom:0;
}

.jpg-content img{
  display:block;
  max-width:100%;
  height:auto;
  margin:2rem auto;
  border-radius:18px;
  box-shadow:var(--shadow-md);
}

.jpg-content figure{
  margin:2rem 0;
  max-width:100%;
}

.jpg-content figcaption{
  margin-top:.8rem;
  font-size:14px;
  line-height:1.5;
  color:var(--c-text-light);
  text-align:center;
}

.jpg-content table{
  width:100%;
  border-collapse:collapse;
  margin:2rem 0;
  overflow:hidden;
  border-radius:16px;
  box-shadow:var(--shadow-sm);
  font-size:15px;
  display:block;
  overflow-x:auto;
}

.jpg-content table th{
  background:var(--c-navy);
  color:#fff;
  text-align:left;
  padding:14px 16px;
  font-weight:700;
}

.jpg-content table td{
  padding:12px 16px;
  border-bottom:1px solid var(--c-border);
  background:#fff;
}

.jpg-content table tr:nth-child(even) td{
  background:#fbfcfd;
}

.jpg-content table tr:last-child td{
  border-bottom:0;
}

.jpg-content hr{
  border:0;
  height:1px;
  background:var(--c-border);
  margin:2.25rem 0;
}

.jpg-content code{
  background:#f3f5f8;
  color:var(--c-navy);
  padding:2px 8px;
  border-radius:6px;
  font-size:.92em;
}

.jpg-content pre{
  margin:1.75rem 0;
  padding:18px 20px;
  background:#0d1d31;
  color:#e8eef6;
  border-radius:16px;
  overflow:auto;
}

.jpg-content pre code{
  background:transparent;
  color:inherit;
  padding:0;
}

.jpg-content .wp-block-image,
.jpg-content .wp-block-quote,
.jpg-content .wp-block-table,
.jpg-content .wp-block-columns{
  margin:2rem 0;
  max-width:100%;
}

.jpg-content .wp-block-separator{
  margin:2.2rem 0;
  border:0;
  border-top:1px solid var(--c-border);
}

.jpg-content .wp-block-pullquote{
  margin:2rem 0;
  padding:1.6rem;
  border-top:2px solid var(--c-gold);
  border-bottom:2px solid var(--c-gold);
  background:#fbfcfe;
}

.jpg-content .wp-block-pullquote blockquote{
  margin:0;
  padding:0;
  border:0;
  background:transparent;
  box-shadow:none;
  border-radius:0;
}

.jpg-content .wp-block-cover{
  overflow:hidden;
  border-radius:20px;
}

.jpg-content .wp-block-button__link{
  border-radius:12px;
  text-decoration:none;
}

.jpg-content .wp-block-button__link:hover{
  text-decoration:none;
}

/* ============================================================
   TAGS
   ============================================================ */

.jpg-single-tags{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  margin:40px 0 0;
  padding-top:24px;
  border-top:1px solid var(--c-border);
}

.jpg-tags-label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:14px;
  color:var(--c-text-light);
  font-weight:600;
}

.jpg-tags-label svg{
  color:var(--c-gold-dark);
}

.jpg-tag-chip{
  display:inline-flex;
  align-items:center;
  padding:7px 13px;
  border-radius:var(--radius-pill);
  border:1px solid var(--c-border);
  background:#fff;
  color:var(--c-text);
  font-size:13px;
  font-weight:600;
  text-decoration:none;
  transition:all .2s ease;
}

.jpg-tag-chip:hover{
  background:var(--c-navy);
  border-color:var(--c-navy);
  color:#fff;
  text-decoration:none;
}

/* ============================================================
   CTA NO POST
   ============================================================ */

.jpg-single-cta{
  margin:42px 0 0;
  padding:28px 28px;
  border-radius:22px;
  background:linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-light) 100%);
  color:#fff;
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:22px;
  align-items:center;
  box-shadow:var(--shadow-lg);
  position:relative;
  overflow:hidden;
}

.jpg-single-cta::before{
  content:"";
  position:absolute;
  top:-45%;
  right:-10%;
  width:280px;
  height:280px;
  background:radial-gradient(circle, rgba(201,169,97,.20) 0%, transparent 70%);
  pointer-events:none;
}

.jpg-single-cta > *{
  position:relative;
  z-index:1;
}

.jpg-single-cta-icon{
  width:64px;
  height:64px;
  border-radius:18px;
  background:rgba(201,169,97,.16);
  border:1px solid rgba(201,169,97,.28);
  color:var(--c-gold);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.jpg-single-cta-text h3{
  margin:0 0 6px;
  font-family:var(--font-serif);
  font-size:26px;
  line-height:1.2;
  color:#fff;
}

.jpg-single-cta-text p{
  margin:0;
  color:#d8e2ee;
  font-size:15px;
  line-height:1.65;
}

.jpg-single-cta .jpg-btn{
  white-space:nowrap;
}

/* ============================================================
   AUTHOR BOX
   ============================================================ */

.jpg-author-box{
  margin:34px 0 0;
  padding:24px;
  border:1px solid var(--c-border);
  border-radius:20px;
  background:linear-gradient(180deg, #ffffff 0%, #fbfcfe 100%);
  display:grid;
  grid-template-columns:auto 1fr;
  gap:18px;
  align-items:start;
}

.jpg-author-avatar{
  width:68px;
  height:68px;
  border-radius:18px;
  background:var(--c-cream);
  color:var(--c-gold-dark);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.jpg-author-label{
  display:inline-block;
  margin:0 0 6px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.8px;
  text-transform:uppercase;
  color:var(--c-gold-dark);
}

.jpg-author-name{
  margin:0 0 8px;
  font-family:var(--font-serif);
  font-size:24px;
  line-height:1.2;
  color:var(--c-navy);
  overflow-wrap:anywhere;
}

.jpg-author-bio{
  margin:0;
  color:var(--c-text-light);
  font-size:15px;
  line-height:1.65;
}

.jpg-author-social{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:12px;
  font-size:14px;
  font-weight:600;
  color:var(--c-gold-dark);
  text-decoration:none;
}

.jpg-author-social:hover{
  color:var(--c-navy);
  text-decoration:none;
}

/* ============================================================
   POST NAV
   ============================================================ */

.jpg-post-nav{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin:34px 0 0;
  padding-top:28px;
  border-top:1px solid var(--c-border);
}

.jpg-post-nav-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  min-height:100%;
  padding:18px 18px;
  border:1px solid var(--c-border);
  border-radius:18px;
  background:#fff;
  text-decoration:none;
  color:inherit;
  transition:all .22s ease;
}

.jpg-post-nav-link:hover{
  border-color:#d4dce6;
  box-shadow:var(--shadow-sm);
  transform:translateY(-2px);
  text-decoration:none;
}

.jpg-post-nav-prev{
  text-align:left;
}

.jpg-post-nav-next{
  text-align:right;
}

.jpg-post-nav-content{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:0;
}

.jpg-post-nav-label{
  font-size:12px;
  font-weight:700;
  letter-spacing:.7px;
  text-transform:uppercase;
  color:var(--c-gold-dark);
}

.jpg-post-nav-title{
  font-family:var(--font-serif);
  font-size:18px;
  line-height:1.35;
  color:var(--c-navy);
  overflow-wrap:anywhere;
  word-break:break-word;
}

.jpg-post-nav-arrow{
  flex-shrink:0;
  width:38px;
  height:38px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#f7f9fb;
  color:var(--c-navy);
}

/* ============================================================
   AJUSTES GERAIS
   ============================================================ */

.jpg-single-main > .jpg_oab_disclaimer,
.jpg-single-main > .jpg-oab-disclaimer,
.jpg-single-main > [class*="disclaimer"]{
  margin-top:32px;
}

.jpg-single-main > * + .jpg-single-cta{
  margin-top:34px;
}

/* ============================================================
   RESPONSIVO
   ============================================================ */

@media (max-width: 1180px){
  .jpg-single-article .jpg-container,
  .jpg-single-hero .jpg-container{
    padding-left:22px;
    padding-right:22px;
  }

  .jpg-single-grid{
    grid-template-columns:minmax(0, 1fr);
    gap:0;
  }

  .jpg-share-sticky{
    display:none;
  }

  .jpg-single-hero-content{
    max-width:760px;
  }
}

@media (max-width: 920px){
  .jpg-single-hero{
    padding:34px 0 36px;
  }

  .jpg-single-hero-content{
    max-width:100%;
  }

  .jpg-single-title{
    font-size:clamp(28px, 6vw, 40px);
  }

  .jpg-single-excerpt{
    font-size:17px;
    line-height:1.7;
  }

  .jpg-single-meta{
    font-size:13px;
  }

  .jpg-content{
    font-size:17px;
    line-height:1.8;
  }

  .jpg-single-cta{
    grid-template-columns:1fr;
    text-align:left;
    padding:24px;
  }

  .jpg-single-cta-icon{
    width:58px;
    height:58px;
  }
}

@media (max-width: 767px){
  .jpg-single-hero{
    padding:28px 0 30px;
  }

  .jpg-single-hero .jpg-container,
  .jpg-single-article .jpg-container{
    padding-left:20px;
    padding-right:20px;
  }

  .jpg-single-title{
    margin-bottom:14px;
    letter-spacing:-.4px;
    font-size:clamp(26px, 7.2vw, 34px);
    line-height:1.14;
  }

  .jpg-single-excerpt{
    margin-bottom:18px;
    font-size:16px;
  }

  .jpg-single-meta{
    gap:8px 12px;
    font-size:13px;
  }

  .jpg-meta-divider{
    display:none;
  }

  .jpg-single-grid{
    padding-top:28px;
  }

  .jpg-single-featured{
    margin-bottom:24px;
    border-radius:18px;
  }

  .jpg-content{
    font-size:16px;
    line-height:1.8;
  }

  .jpg-content > p:first-of-type{
    font-size:1.1em;
  }

  .jpg-content h2{
    margin-top:2.3rem;
    font-size:clamp(24px, 7vw, 30px);
  }

  .jpg-content h3{
    font-size:clamp(20px, 6vw, 24px);
  }

  .jpg-single-tags{
    margin-top:28px;
    padding-top:20px;
  }

  .jpg-author-box{
    grid-template-columns:1fr;
    padding:20px;
  }

  .jpg-post-nav{
    grid-template-columns:1fr;
  }

  .jpg-post-nav-link{
    padding:16px;
  }

  .jpg-post-nav-title{
    font-size:17px;
  }
}

@media (max-width: 480px){
  .jpg-single-hero .jpg-container,
  .jpg-single-article .jpg-container{
    padding-left:16px;
    padding-right:16px;
  }

  .jpg-single-cat-badge{
    font-size:11px;
    padding:7px 12px;
  }

  .jpg-single-title{
    font-size:29px;
  }

  .jpg-single-excerpt{
    font-size:15px;
  }

  .jpg-content{
    font-size:15.5px;
  }

  .jpg-single-cta{
    padding:20px 18px;
    border-radius:18px;
  }

  .jpg-single-cta-text h3{
    font-size:22px;
  }

  .jpg-author-name{
    font-size:21px;
  }
}
/* ============================================================
   SINGLE POST — PATCH CATEGORY BADGE + REMOCAO DO X
   ============================================================ */

.jpg-single-cat-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  max-width:100%;
  min-height:42px;
  padding:10px 16px;
  border-radius:999px;
  background:rgba(201,169,97,.16);
  border:1px solid rgba(201,169,97,.34);
  color:var(--c-gold-light);
  font-size:12px;
  font-weight:700;
  letter-spacing:.3px;
  line-height:1.2;
  text-align:center;
  text-decoration:none;
  white-space:normal;
  overflow-wrap:anywhere;
  word-break:break-word;
  transition:all .25s ease;
}

.jpg-single-cat-badge:hover{
  color:#fff;
  border-color:rgba(201,169,97,.55);
  background:rgba(201,169,97,.24);
  text-decoration:none;
  transform:translateY(-1px);
}

.jpg-single-cat-badge svg{
  flex:0 0 auto;
  width:14px;
  height:14px;
  margin-top:1px;
}

/* remove o botao X do share */
.jpg-share-x{
  display:none !important;
}

@media (min-width: 768px){
  .jpg-single-cat-badge{
    max-width:340px;
  }
}

@media (max-width: 767px){
  .jpg-single-cat-badge{
    max-width:100%;
    padding:9px 14px;
    font-size:11px;
    letter-spacing:.2px;
  }
}
/* ============================================================
   ============================================================
   JPGOMES V2.0 — COMPONENTES DO ARTIGO + REFINAMENTOS SINGLE
   ============================================================
   Adicionado em: 2026-05
   Objetivo: Equiparar visual JPGomes ao padrão CSE Contábil
   Compatível com: single.php v2.0.0
   ============================================================ */


/* ============================================================
   1. LEAD — Primeiro parágrafo destacado do artigo
   ============================================================ */
.jpg-post-body .jpg-lead{
  font-size:20px;
  line-height:1.65;
  color:var(--c-text);
  margin:0 0 32px;
  padding:24px 28px;
  background:linear-gradient(135deg, var(--c-cream) 0%, #fff 100%);
  border-left:4px solid var(--c-gold);
  border-radius:0 var(--radius) var(--radius) 0;
  font-weight:400;
}

.jpg-post-body .jpg-lead strong{
  color:var(--c-navy);
  font-weight:700;
}


/* ============================================================
   2. TOC — Índice navegável
   ============================================================ */
.jpg-post-body .jpg-toc{
  background:var(--c-bg);
  border:1px solid var(--c-border);
  border-radius:var(--radius);
  padding:24px 28px;
  margin:32px 0 40px;
  position:relative;
}

.jpg-post-body .jpg-toc::before{
  content:"";
  position:absolute;
  top:0; left:0;
  width:4px; height:100%;
  background:var(--c-gold);
  border-radius:var(--radius) 0 0 var(--radius);
}

.jpg-post-body .jpg-toc h4{
  font-family:var(--font-serif);
  font-size:18px;
  color:var(--c-navy);
  font-weight:700;
  margin:0 0 16px;
  padding-bottom:12px;
  border-bottom:1px solid var(--c-border);
}

.jpg-post-body .jpg-toc ol{
  margin:0;
  padding:0 0 0 20px;
  counter-reset:toc-counter;
  list-style:none;
}

.jpg-post-body .jpg-toc ol li{
  counter-increment:toc-counter;
  position:relative;
  padding:8px 0 8px 28px;
  margin:0;
  border-bottom:1px solid var(--c-border-light);
  line-height:1.5;
}

.jpg-post-body .jpg-toc ol li:last-child{
  border-bottom:0;
}

.jpg-post-body .jpg-toc ol li::before{
  content:counter(toc-counter, decimal-leading-zero);
  position:absolute;
  left:0; top:8px;
  font-family:var(--font-serif);
  font-size:14px;
  font-weight:700;
  color:var(--c-gold-dark);
}

.jpg-post-body .jpg-toc ol li a{
  color:var(--c-text);
  text-decoration:none;
  font-size:15px;
  font-weight:500;
  transition:color .2s, padding .2s;
  display:inline-block;
}

.jpg-post-body .jpg-toc ol li a:hover{
  color:var(--c-gold-dark);
  text-decoration:none;
  padding-left:4px;
}


/* ============================================================
   3. INFO BOX — "Você sabia?" (azul informativo)
   ============================================================ */
.jpg-post-body .jpg-info-box{
  background:#eff6ff;
  border:1px solid #bfdbfe;
  border-left:4px solid #3b82f6;
  border-radius:var(--radius);
  padding:20px 24px;
  margin:32px 0;
  position:relative;
}

.jpg-post-body .jpg-info-box h4{
  font-family:var(--font-serif);
  font-size:17px;
  color:#1e40af;
  font-weight:700;
  margin:0 0 10px;
  display:flex;
  align-items:center;
  gap:8px;
}

.jpg-post-body .jpg-info-box p{
  color:#1e3a8a;
  font-size:16px;
  line-height:1.6;
  margin:0;
}

.jpg-post-body .jpg-info-box p strong{
  color:#1e3a8a;
  font-weight:700;
}


/* ============================================================
   4. SUCCESS BOX — "Vantagem estratégica" (verde sucesso)
   ============================================================ */
.jpg-post-body .jpg-success-box{
  background:#f0fdf4;
  border:1px solid #bbf7d0;
  border-left:4px solid #16a34a;
  border-radius:var(--radius);
  padding:20px 24px;
  margin:32px 0;
}

.jpg-post-body .jpg-success-box h4{
  font-family:var(--font-serif);
  font-size:17px;
  color:#15803d;
  font-weight:700;
  margin:0 0 10px;
  display:flex;
  align-items:center;
  gap:8px;
}

.jpg-post-body .jpg-success-box p{
  color:#14532d;
  font-size:16px;
  line-height:1.6;
  margin:0;
}

.jpg-post-body .jpg-success-box p strong{
  color:#14532d;
  font-weight:700;
}


/* ============================================================
   5. WARNING BOX — "Atenção" (âmbar/dourado JPGomes)
   ============================================================ */
.jpg-post-body .jpg-warning-box{
  background:#fef3c7;
  border:1px solid #fde68a;
  border-left:4px solid var(--c-gold);
  border-radius:var(--radius);
  padding:20px 24px;
  margin:32px 0;
}

.jpg-post-body .jpg-warning-box h4{
  font-family:var(--font-serif);
  font-size:17px;
  color:#92400e;
  font-weight:700;
  margin:0 0 10px;
  display:flex;
  align-items:center;
  gap:8px;
}

.jpg-post-body .jpg-warning-box p{
  color:#78350f;
  font-size:16px;
  line-height:1.6;
  margin:0;
}

.jpg-post-body .jpg-warning-box p strong{
  color:#78350f;
  font-weight:700;
}


/* ============================================================
   6. QUOTE BOX — Citação destacada (navy + dourado)
   ============================================================ */
.jpg-post-body .jpg-quote{
  background:linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-light) 100%);
  border-left:4px solid var(--c-gold);
  border-radius:0 var(--radius) var(--radius) 0;
  padding:32px 36px;
  margin:40px 0;
  position:relative;
  overflow:hidden;
}

.jpg-post-body .jpg-quote::before{
  content:"";
  position:absolute;
  top:-30px;
  right:-20px;
  width:200px;
  height:200px;
  background:radial-gradient(circle, rgba(201,169,97,.15) 0%, transparent 70%);
  pointer-events:none;
}

.jpg-post-body .jpg-quote p{
  font-family:var(--font-serif);
  font-size:20px;
  font-style:italic;
  color:#fff;
  line-height:1.5;
  margin:0 0 14px;
  position:relative;
  z-index:1;
}

.jpg-post-body .jpg-quote p strong{
  color:var(--c-gold-light);
  font-weight:700;
}

.jpg-post-body .jpg-quote cite{
  display:block;
  font-size:14px;
  color:var(--c-gold);
  font-style:normal;
  font-weight:600;
  letter-spacing:.5px;
  text-transform:uppercase;
  position:relative;
  z-index:1;
}


/* ============================================================
   7. CTA BOX — Caixa dourada de chamada dentro do texto
   ============================================================ */
.jpg-post-body .jpg-cta-box{
  background:linear-gradient(135deg, var(--c-gold) 0%, var(--c-gold-dark) 100%);
  border-radius:var(--radius-lg);
  padding:36px 40px;
  margin:48px 0;
  text-align:center;
  box-shadow:var(--shadow-gold);
  position:relative;
  overflow:hidden;
}

.jpg-post-body .jpg-cta-box::before{
  content:"";
  position:absolute;
  top:-50%;
  right:-10%;
  width:300px;
  height:300px;
  background:radial-gradient(circle, rgba(255,255,255,.15) 0%, transparent 70%);
  pointer-events:none;
}

.jpg-post-body .jpg-cta-box > *{
  position:relative;
  z-index:1;
}

.jpg-post-body .jpg-cta-box h3{
  font-family:var(--font-serif);
  font-size:24px;
  color:var(--c-navy);
  font-weight:700;
  margin:0 0 12px;
  line-height:1.3;
  letter-spacing:-.3px;
}

.jpg-post-body .jpg-cta-box p{
  font-size:16px;
  color:var(--c-navy);
  line-height:1.6;
  margin:0 0 24px;
  opacity:.92;
}

.jpg-post-body .jpg-cta-box .jpg-btn{
  background:var(--c-navy);
  color:#fff;
  padding:14px 32px;
  border-radius:var(--radius);
  font-weight:700;
  font-size:15px;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:10px;
  transition:all .25s;
  border:0;
  text-decoration-color:transparent !important;
}

.jpg-post-body .jpg-cta-box .jpg-btn:hover{
  background:var(--c-navy-dark);
  color:#fff;
  text-decoration:none;
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(10,37,64,.3);
}


/* ============================================================
   8. DIVIDER — Linha dourada entre seções H2
   ============================================================ */
.jpg-post-body hr.jpg-divider{
  border:0;
  height:auto;
  background:transparent;
  margin:56px auto;
  text-align:center;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
}

.jpg-post-body hr.jpg-divider::before,
.jpg-post-body hr.jpg-divider::after{
  content:"";
  flex:1;
  height:1px;
  background:linear-gradient(90deg, transparent 0%, var(--c-gold) 50%, transparent 100%);
}

.jpg-post-body hr.jpg-divider::after{
  /* já coberto pelo gradient */
}

/* Versão simplificada se o ::before/::after não funcionar bem */
.jpg-post-body hr.jpg-divider{
  border:0;
  height:1px;
  background:linear-gradient(90deg, transparent 0%, var(--c-gold) 50%, transparent 100%);
  margin:56px 0;
  display:block;
}


/* ============================================================
   9. CHECKLIST — Lista com check dourado
   ============================================================ */
.jpg-post-body ul.jpg-checklist{
  list-style:none;
  margin:28px 0;
  padding:0;
}

.jpg-post-body ul.jpg-checklist li{
  position:relative;
  padding:14px 16px 14px 48px;
  margin:0 0 8px;
  background:var(--c-bg);
  border-radius:var(--radius);
  border-left:3px solid var(--c-gold);
  font-size:16px;
  line-height:1.5;
  color:var(--c-text);
  transition:all .2s;
}

.jpg-post-body ul.jpg-checklist li::marker{
  content:"";
}

.jpg-post-body ul.jpg-checklist li::before{
  content:"";
  position:absolute;
  left:16px;
  top:50%;
  transform:translateY(-50%);
  width:22px;
  height:22px;
  border-radius:50%;
  background:var(--c-gold) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%230a2540' stroke='%230a2540' stroke-width='3'><path d='M20 6 9 17l-5-5'/></svg>") center/14px no-repeat;
}

.jpg-post-body ul.jpg-checklist li:hover{
  background:#fff;
  box-shadow:var(--shadow-sm);
  transform:translateX(4px);
}

.jpg-post-body ul.jpg-checklist li strong{
  color:var(--c-navy);
  font-weight:700;
}


/* ============================================================
   10. STATS — Grid de 3 cards de estatísticas
   ============================================================ */
.jpg-post-body .jpg-stats{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
  margin:36px 0;
  padding:0;
  background:transparent;
}

.jpg-post-body .jpg-stat-card{
  background:linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-light) 100%);
  border-radius:var(--radius-lg);
  padding:28px 20px;
  text-align:center;
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow-md);
  transition:transform .25s;
}

.jpg-post-body .jpg-stat-card::before{
  content:"";
  position:absolute;
  top:-30px;
  right:-30px;
  width:120px;
  height:120px;
  background:radial-gradient(circle, rgba(201,169,97,.2) 0%, transparent 70%);
  pointer-events:none;
}

.jpg-post-body .jpg-stat-card:hover{
  transform:translateY(-4px);
}

.jpg-post-body .jpg-stat-number{
  display:block;
  font-family:var(--font-serif);
  font-size:38px;
  font-weight:700;
  color:var(--c-gold);
  line-height:1;
  margin-bottom:8px;
  letter-spacing:-.5px;
  position:relative;
  z-index:1;
}

.jpg-post-body .jpg-stat-label{
  display:block;
  font-size:13px;
  color:#d8e2ee;
  font-weight:500;
  line-height:1.4;
  position:relative;
  z-index:1;
}


/* ============================================================
   11. TABLE — Sobrescreve tabela padrão para destaque premium
   ============================================================ */
.jpg-post-body table.jpg-table{
  width:100%;
  border-collapse:collapse;
  margin:32px 0;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-md);
  font-size:15px;
  background:#fff;
  border:1px solid var(--c-border);
}

.jpg-post-body table.jpg-table thead{
  background:linear-gradient(135deg, var(--c-navy) 0%, var(--c-navy-light) 100%);
}

.jpg-post-body table.jpg-table th{
  background:transparent;
  color:#fff;
  padding:16px 18px;
  text-align:left;
  font-weight:700;
  font-size:14px;
  letter-spacing:.3px;
  text-transform:uppercase;
  border-bottom:3px solid var(--c-gold);
}

.jpg-post-body table.jpg-table td{
  padding:14px 18px;
  border-bottom:1px solid var(--c-border-light);
  color:var(--c-text);
  vertical-align:top;
}

.jpg-post-body table.jpg-table tbody tr:last-child td{
  border-bottom:0;
}

.jpg-post-body table.jpg-table tbody tr:nth-child(even){
  background:var(--c-bg);
}

.jpg-post-body table.jpg-table tbody tr:hover{
  background:var(--c-cream);
}

.jpg-post-body table.jpg-table td strong{
  color:var(--c-navy);
}


/* ============================================================
   12. AUTHOR BOX — Bloco "Publicado por"
   ============================================================ */
.jpg-author-box{
  max-width:760px;
  margin:48px auto 0;
  padding:28px 32px;
  background:linear-gradient(135deg, var(--c-cream) 0%, #fff 100%);
  border:1px solid var(--c-border);
  border-left:4px solid var(--c-gold);
  border-radius:var(--radius);
  display:flex;
  gap:20px;
  align-items:flex-start;
}

.jpg-author-avatar{
  width:64px;
  height:64px;
  border-radius:50%;
  background:var(--c-navy);
  color:var(--c-gold);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

.jpg-author-info{
  flex:1;
}

.jpg-author-label{
  display:block;
  font-size:11px;
  color:var(--c-text-light);
  font-weight:700;
  letter-spacing:1.2px;
  text-transform:uppercase;
  margin-bottom:6px;
}

.jpg-author-name{
  font-family:var(--font-serif);
  font-size:20px;
  color:var(--c-navy);
  font-weight:700;
  margin:0 0 8px;
  line-height:1.2;
}

.jpg-author-bio{
  font-size:14px;
  color:var(--c-text);
  line-height:1.5;
  margin:0 0 12px;
}

.jpg-author-social{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:14px;
  color:var(--c-gold-dark);
  font-weight:600;
  text-decoration:none;
  transition:color .2s;
}

.jpg-author-social:hover{
  color:var(--c-navy);
  text-decoration:none;
}


/* ============================================================
   13. POST NAVIGATION — Anterior / Próximo
   ============================================================ */
.jpg-post-nav{
  max-width:760px;
  margin:40px auto 0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.jpg-post-nav-link{
  display:flex;
  align-items:center;
  gap:14px;
  padding:18px 20px;
  background:#fff;
  border:1px solid var(--c-border);
  border-radius:var(--radius);
  text-decoration:none;
  color:var(--c-text);
  transition:all .25s;
}

.jpg-post-nav-link:hover{
  border-color:var(--c-gold);
  background:var(--c-cream);
  text-decoration:none;
  color:var(--c-text);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}

.jpg-post-nav-prev{
  text-align:left;
}

.jpg-post-nav-next{
  text-align:right;
  flex-direction:row;
  justify-content:flex-end;
}

.jpg-post-nav-arrow{
  width:36px;
  height:36px;
  border-radius:50%;
  background:var(--c-cream);
  color:var(--c-gold-dark);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  transition:all .25s;
}

.jpg-post-nav-link:hover .jpg-post-nav-arrow{
  background:var(--c-gold);
  color:var(--c-navy);
}

.jpg-post-nav-content{
  display:flex;
  flex-direction:column;
  gap:4px;
  flex:1;
  min-width:0;
}

.jpg-post-nav-label{
  font-size:11px;
  color:var(--c-text-light);
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
}

.jpg-post-nav-title{
  font-family:var(--font-serif);
  font-size:15px;
  color:var(--c-navy);
  font-weight:700;
  line-height:1.3;
  overflow:hidden;
  text-overflow:ellipsis;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
}


/* ============================================================
   14. DISCLAIMER OAB — Espaçamento padronizado
   ============================================================ */
.jpg-post-disclaimer{
  max-width:760px;
  margin:48px auto 0;
}

.jpg-oab-disclaimer{
  background:var(--c-bg);
  border:1px solid var(--c-border);
  border-radius:var(--radius);
  padding:18px 24px;
  font-size:13px;
  color:var(--c-text-light);
  line-height:1.6;
}

.jpg-oab-disclaimer p{
  margin:0;
}

.jpg-oab-disclaimer strong{
  color:var(--c-navy);
  font-weight:700;
}


/* ============================================================
   15. BACK TO TOP — Versão DOURADA (override do CSS atual)
   ============================================================ */
.jpg-back-top{
  position:fixed;
  bottom:96px;
  right:24px;
  width:48px;
  height:48px;
  border-radius:50%;
  background:var(--c-gold);
  border:0;
  color:var(--c-navy);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:var(--shadow-gold);
  z-index:98;
  opacity:0;
  visibility:hidden;
  transform:translateY(10px);
  transition:all .25s;
}

.jpg-back-top.visible{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

.jpg-back-top:hover{
  background:var(--c-gold-dark);
  color:var(--c-navy);
  transform:translateY(-3px);
  box-shadow:0 10px 28px rgba(201,169,97,.45);
}


/* ============================================================
   16. SHARE COPY — Feedback "Copiado!" tooltip
   ============================================================ */
.jpg-share-copy.copied::after{
  content:"Copiado!";
  position:absolute;
  left:50px;
  top:50%;
  transform:translateY(-50%);
  background:var(--c-navy);
  color:#fff;
  padding:6px 12px;
  border-radius:6px;
  font-size:12px;
  white-space:nowrap;
  font-weight:600;
  animation:jpgFadeOut 2s forwards;
  z-index:51;
}


/* ============================================================
   17. RESPONSIVO — Componentes do artigo + Single
   ============================================================ */
@media (max-width:1100px){
  .jpg-share-bar{
    display:none;
  }
}

@media (max-width:768px){

  .jpg-post-body .jpg-lead{
    font-size:18px;
    padding:20px 22px;
  }

  .jpg-post-body .jpg-toc{
    padding:20px 22px;
  }

  .jpg-post-body .jpg-info-box,
  .jpg-post-body .jpg-success-box,
  .jpg-post-body .jpg-warning-box{
    padding:18px 20px;
  }

  .jpg-post-body .jpg-quote{
    padding:24px 26px;
  }

  .jpg-post-body .jpg-quote p{
    font-size:18px;
  }

  .jpg-post-body .jpg-cta-box{
    padding:28px 24px;
  }

  .jpg-post-body .jpg-cta-box h3{
    font-size:20px;
  }

  .jpg-post-body .jpg-stats{
    grid-template-columns:1fr;
    gap:14px;
  }

  .jpg-post-body .jpg-stat-number{
    font-size:32px;
  }

  .jpg-post-body table.jpg-table{
    font-size:13px;
    display:block;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }

  .jpg-post-body table.jpg-table th,
  .jpg-post-body table.jpg-table td{
    padding:10px 12px;
  }

  .jpg-author-box{
    flex-direction:column;
    text-align:center;
    padding:24px 20px;
  }

  .jpg-author-avatar{
    margin:0 auto;
  }

  .jpg-post-nav{
    grid-template-columns:1fr;
  }

  .jpg-post-nav-next{
    flex-direction:row;
    text-align:left;
    justify-content:flex-start;
  }

  .jpg-post-cta-inner{
    grid-template-columns:1fr !important;
    text-align:center;
    gap:20px;
  }

  .jpg-post-cta-icon{
    margin:0 auto;
  }

  .jpg-back-top{
    bottom:84px;
    right:18px;
    width:42px;
    height:42px;
  }
}


/* ============================================================
   FIM DO BLOCO V2.0 — COMPONENTES DO ARTIGO
   ============================================================ */
/* ============================================================
   BREADCRUMBS — FIX CONTRASTE NO HERO NAVY
   ============================================================ */
.jpg-post-hero .jpg-breadcrumbs,
.jpg-post-hero nav.jpg-breadcrumbs{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  font-size:13px;
  margin-bottom:24px;
  color:#b8c5d6 !important;
}

.jpg-post-hero .jpg-breadcrumbs a,
.jpg-post-hero nav.jpg-breadcrumbs a{
  color:#d8e2ee !important;
  text-decoration:none !important;
  font-weight:500;
  transition:color .2s;
}

.jpg-post-hero .jpg-breadcrumbs a:hover,
.jpg-post-hero nav.jpg-breadcrumbs a:hover{
  color:var(--c-gold) !important;
  text-decoration:none !important;
}

.jpg-post-hero .jpg-breadcrumbs span[aria-hidden],
.jpg-post-hero nav.jpg-breadcrumbs span[aria-hidden]{
  color:var(--c-gold) !important;
  font-weight:600;
  opacity:.7;
}

.jpg-post-hero .jpg-breadcrumb-current{
  color:#ffffff !important;
  font-weight:600 !important;
}
