/* =========================================================================
   Comunicagro — Componentes (header, footer, hero, single, forms)
   Depende dos tokens definidos em style.css
   ========================================================================= */

/* ============================== HEADER ================================= */
.ca-topbar {
  background: var(--ca-navy);
  color: rgba(255, 255, 255, .82);
  font-size: .82rem;
}
.ca-topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 40px; }
.ca-topbar a { color: rgba(255, 255, 255, .82); }
.ca-topbar a:hover { color: #fff; }
.ca-topbar__meta { display: flex; align-items: center; gap: 1.2rem; }
.ca-topbar__meta span { display: inline-flex; align-items: center; gap: .4rem; white-space: nowrap; }
.ca-topbar__meta svg { width: 15px; height: 15px; flex-shrink: 0; }
.ca-topbar__social { display: flex; align-items: center; gap: .85rem; }
.ca-topbar__social svg { width: 17px; height: 17px; }
@media (max-width: 720px) { .ca-topbar__meta .ca-hide-sm { display: none; } }

.ca-header {
  position: sticky; top: 0; z-index: 60;
  background: rgba(247, 246, 242, .85);
  backdrop-filter: saturate(150%) blur(12px);
  border-bottom: 1px solid var(--ca-line);
  transition: box-shadow .3s var(--ca-ease), background .3s var(--ca-ease);
}
.ca-header.is-stuck { box-shadow: 0 10px 30px -18px rgba(16, 28, 66, .35); background: rgba(255,255,255,.92); }
.ca-header__inner { display: flex; align-items: center; gap: 1.25rem; min-height: 76px; }
.ca-header__cta { white-space: nowrap; }
.ca-nav { flex-wrap: nowrap; }
.ca-brand { flex-shrink: 0; display: inline-flex; align-items: center; }
.ca-brand img { height: 38px; width: auto; }
.ca-brand--text { font-weight: 600; font-size: 1.4rem; color: var(--ca-navy); letter-spacing: -.02em; }

.ca-nav { display: flex; align-items: center; gap: .25rem; margin-left: auto; }
.ca-nav a {
  position: relative; display: inline-flex; align-items: center; gap: .35rem; white-space: nowrap;
  padding: .55rem .8rem; font-weight: 600; font-size: .95rem; color: var(--ca-navy); border-radius: 8px;
}
.ca-nav a:hover { color: var(--ca-green-700); background: rgba(73, 172, 96, .08); }
.ca-nav .current-menu-item > a, .ca-nav .current_page_item > a { color: var(--ca-green-700); }
.ca-nav li { position: relative; list-style: none; }
.ca-nav > ul { display: flex; align-items: center; gap: .15rem; margin: 0; padding: 0; }

/* Mega/Dropdown */
.ca-nav .sub-menu {
  position: absolute; top: calc(100% + 10px); left: 0; min-width: 230px;
  background: #fff; border: 1px solid var(--ca-line); border-radius: 14px; padding: .5rem;
  box-shadow: var(--ca-shadow-lg); opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: opacity .2s var(--ca-ease), transform .2s var(--ca-ease), visibility .2s; margin: 0;
}
.ca-nav li:hover > .sub-menu, .ca-nav li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: none; }
.ca-nav .sub-menu a { display: block; padding: .6rem .8rem; font-size: .92rem; border-radius: 8px; }
.ca-nav .menu-item-has-children > a::after { content: "▾"; font-size: .7em; opacity: .6; }

.ca-header__actions { display: flex; align-items: center; gap: .6rem; }
.ca-search-toggle, .ca-menu-toggle {
  width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--ca-line); background: #fff; border-radius: 12px; cursor: pointer; color: var(--ca-navy);
  transition: border-color .2s, color .2s, background .2s;
}
.ca-search-toggle:hover, .ca-menu-toggle:hover { border-color: var(--ca-navy); color: var(--ca-green-700); }
.ca-search-toggle svg, .ca-menu-toggle svg { width: 20px; height: 20px; }
.ca-menu-toggle { display: none; }

@media (max-width: 980px) {
  .ca-nav { display: none; }
  .ca-menu-toggle { display: inline-flex; }
  .ca-header__cta { display: none; }
}

/* Search overlay */
.ca-search-panel {
  position: fixed; inset: 0; z-index: 90; background: rgba(16, 28, 66, .55);
  backdrop-filter: blur(4px); display: flex; align-items: flex-start; justify-content: center;
  padding-top: 16vh; opacity: 0; visibility: hidden; transition: opacity .25s var(--ca-ease), visibility .25s;
}
.ca-search-panel.is-open { opacity: 1; visibility: visible; }
.ca-search-panel__box { width: min(620px, 90vw); background: #fff; border-radius: 18px; padding: 1.6rem; box-shadow: var(--ca-shadow-lg); transform: translateY(-14px); transition: transform .25s var(--ca-ease); }
.ca-search-panel.is-open .ca-search-panel__box { transform: none; }

/* Mobile drawer */
.ca-drawer {
  position: fixed; inset: 0 0 0 auto; width: min(360px, 86vw); z-index: 95;
  background: var(--ca-navy); color: #fff; padding: 1.5rem 1.4rem; transform: translateX(100%);
  transition: transform .32s var(--ca-ease); display: flex; flex-direction: column; gap: 1rem; overflow-y: auto;
}
.ca-drawer.is-open { transform: none; }
.ca-drawer__overlay { position: fixed; inset: 0; z-index: 94; background: rgba(16, 28, 66, .5); opacity: 0; visibility: hidden; transition: opacity .3s; }
.ca-drawer__overlay.is-open { opacity: 1; visibility: visible; }
.ca-drawer__head { display: flex; align-items: center; justify-content: space-between; }
.ca-drawer__head img { height: 34px; }
.ca-drawer nav ul { list-style: none; margin: 1rem 0 0; padding: 0; display: flex; flex-direction: column; }
.ca-drawer nav a { display: block; padding: .9rem .25rem; color: #fff; font-size: 1.1rem; font-weight: 600; border-bottom: 1px solid rgba(255,255,255,.1); }
.ca-drawer nav a:hover { color: var(--ca-green); }
.ca-drawer .sub-menu { padding-left: 1rem; }
.ca-drawer .sub-menu a { font-size: .98rem; font-weight: 500; opacity: .85; }
.ca-drawer__close { background: rgba(255,255,255,.12); border: 0; color: #fff; width: 40px; height: 40px; border-radius: 10px; cursor: pointer; font-size: 1.4rem; }

/* ============================== HERO HOME ============================= */
.ca-hero { position: relative; overflow: hidden; background: var(--ca-navy); color: #fff; isolation: isolate; }
.ca-hero::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(1100px 540px at 78% -10%, rgba(73, 172, 96, .28), transparent 60%),
    radial-gradient(800px 480px at 8% 110%, rgba(73, 172, 96, .14), transparent 55%);
}
/* textura sutil de “campo” — linhas finas, detalhe de marca, não decorativo vazio */
.ca-hero__pattern { position: absolute; inset: 0; z-index: -1; opacity: .5; pointer-events: none; }
.ca-hero__inner { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(28px, 5vw, 64px); align-items: center; padding-block: clamp(64px, 9vw, 120px); }
.ca-hero h1 { color: #fff; font-size: clamp(2.4rem, 5vw, 4rem); }
.ca-hero .ca-eyebrow { color: #8fe0a3; }
.ca-hero .ca-eyebrow::before { background: var(--ca-green); }
.ca-hero__lead { color: rgba(255,255,255,.82); font-size: clamp(1.08rem, 1.6vw, 1.28rem); max-width: 34ch; }
.ca-hero__actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.8rem; }
.ca-hero__stats { display: flex; gap: 2rem; margin-top: 2.6rem; flex-wrap: wrap; }
.ca-hero__stat strong { display: block; font-size: 2rem; font-weight: 600; color: #fff; letter-spacing: -.02em; }
.ca-hero__stat span { font-size: .85rem; color: rgba(255,255,255,.7); }

/* Card de notícia em destaque no hero (lado direito) */
.ca-hero__feature { position: relative; }
.ca-hero__feature-card {
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14); border-radius: var(--ca-radius-lg);
  overflow: hidden; backdrop-filter: blur(6px); box-shadow: var(--ca-shadow-lg);
}
.ca-hero__feature-card .ca-card__media { aspect-ratio: 16/10; }
.ca-hero__feature-card .ca-fc-body { padding: 1.3rem 1.4rem 1.5rem; }
.ca-hero__feature-card .ca-fc-title { color: #fff; font-size: 1.35rem; line-height: 1.25; margin: .6rem 0 0; }
.ca-hero__feature-card .ca-fc-title a { color: #fff; }
.ca-hero__feature-card .ca-fc-title a:hover { color: #8fe0a3; }
.ca-hero__feature-meta { color: rgba(255,255,255,.65); font-size: .82rem; margin-top: .8rem; }

@media (max-width: 880px) {
  .ca-hero__inner { grid-template-columns: 1fr; gap: 36px; }
  .ca-hero__feature { order: -1; }
}

/* ====================== Cabeçalho de seção ============================ */
.ca-sec-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1.5rem; margin-bottom: clamp(28px, 4vw, 48px); }
.ca-sec-head__text { max-width: 60ch; }
.ca-sec-head--center { flex-direction: column; align-items: center; text-align: center; }
.ca-sec-head p { color: var(--ca-muted); margin: .4rem 0 0; }

/* ====================== Faixa “Sobre” ================================ */
.ca-about { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.ca-about__media { position: relative; }
.ca-about__media img { border-radius: var(--ca-radius-lg); box-shadow: var(--ca-shadow-lg); width: 100%; aspect-ratio: 4/5; object-fit: cover; }
.ca-about__badge {
  position: absolute; bottom: -22px; left: -22px; background: #fff; border: 1px solid var(--ca-line);
  border-radius: 18px; padding: 1rem 1.3rem; box-shadow: var(--ca-shadow); display: flex; align-items: center; gap: .9rem;
}
.ca-about__badge img { width: 46px; height: 46px; border-radius: 0; box-shadow: none; aspect-ratio: 1; }
.ca-about__badge strong { display: block; color: var(--ca-navy); font-size: 1.05rem; }
.ca-about__badge span { font-size: .82rem; color: var(--ca-muted); }
.ca-checklist { list-style: none; margin: 1.4rem 0 0; padding: 0; display: grid; gap: .7rem; }
.ca-checklist li { display: flex; gap: .7rem; align-items: flex-start; color: var(--ca-ink-soft); }
.ca-checklist svg { flex-shrink: 0; width: 22px; height: 22px; color: var(--ca-green); margin-top: 2px; }
@media (max-width: 820px) { .ca-about { grid-template-columns: 1fr; } .ca-about__media { max-width: 460px; } }

/* ====================== Cards de serviço ============================= */
.ca-service {
  position: relative; background: var(--ca-surface); border: 1px solid var(--ca-line); border-radius: var(--ca-radius);
  padding: 1.7rem 1.6rem; transition: transform .25s var(--ca-ease), box-shadow .25s var(--ca-ease), border-color .25s; overflow: hidden;
}
.ca-service::after { content: ""; position: absolute; left: 0; top: 0; height: 100%; width: 4px; background: var(--ca-green); transform: scaleY(0); transform-origin: top; transition: transform .3s var(--ca-ease); }
.ca-service:hover { transform: translateY(-4px); box-shadow: var(--ca-shadow); border-color: var(--ca-line-strong); }
.ca-service:hover::after { transform: scaleY(1); }
.ca-service__icon { width: 52px; height: 52px; border-radius: 14px; background: var(--ca-green-50); color: var(--ca-green-700); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.ca-service__icon svg { width: 26px; height: 26px; }
.ca-service h3 { font-size: 1.18rem; margin-bottom: .4rem; }
.ca-service p { color: var(--ca-muted); font-size: .95rem; margin: 0; }

/* ====================== Faixa portal (escura) ======================= */
.ca-portal-strip { background: var(--ca-navy); color: #fff; border-radius: var(--ca-radius-lg); padding: clamp(28px, 4vw, 48px); }
.ca-cat-cloud { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1.4rem; }
.ca-cat-cloud a {
  display: inline-flex; align-items: center; gap: .4rem; padding: .5rem 1rem; border-radius: 999px;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.14); color: #fff; font-weight: 600; font-size: .9rem;
}
.ca-cat-cloud a:hover { background: var(--ca-green); border-color: var(--ca-green); color: #fff; }
.ca-cat-cloud a .n { opacity: .6; font-size: .8em; }

/* ====================== Logos de clientes =========================== */
.ca-logos { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: clamp(28px, 5vw, 64px); }
.ca-logos img { height: 38px; width: auto; filter: grayscale(1); opacity: .55; transition: filter .3s, opacity .3s; }
.ca-logos img:hover { filter: none; opacity: 1; }
.ca-logos__placeholder { color: var(--ca-muted); font-weight: 600; font-size: 1.3rem; opacity: .4; letter-spacing: .02em; }

/* ====================== CTA final =================================== */
.ca-cta-band {
  position: relative; overflow: hidden; background: var(--ca-green-700); color: #fff;
  border-radius: var(--ca-radius-lg); padding: clamp(40px, 6vw, 72px); text-align: center; isolation: isolate;
}
.ca-cta-band::before { content: ""; position: absolute; inset: 0; z-index: -1; background: radial-gradient(700px 360px at 50% -30%, rgba(255,255,255,.18), transparent 60%); }
.ca-cta-band h2 { color: #fff; }
.ca-cta-band p { color: rgba(255,255,255,.88); max-width: 56ch; margin-inline: auto; }
.ca-cta-band .ca-hero__actions { justify-content: center; }

/* ============================== FOOTER =============================== */
.ca-footer { background: var(--ca-navy); color: rgba(255,255,255,.72); padding-top: clamp(48px, 7vw, 84px); margin-top: clamp(40px, 6vw, 80px); }
.ca-footer a { color: rgba(255,255,255,.72); }
.ca-footer a:hover { color: #fff; }
.ca-footer__top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.3fr; gap: clamp(28px, 4vw, 56px); padding-bottom: 3rem; }
.ca-footer__brand img { height: 40px; margin-bottom: 1.1rem; }
.ca-footer__brand p { max-width: 34ch; font-size: .95rem; }
.ca-footer h4 { color: #fff; font-size: .82rem; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 1.1rem; }
.ca-footer ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .65rem; font-size: .95rem; }
.ca-footer__social { display: flex; gap: .7rem; margin-top: 1.3rem; }
.ca-footer__social a { width: 40px; height: 40px; border-radius: 10px; background: rgba(255,255,255,.08); display: inline-flex; align-items: center; justify-content: center; }
.ca-footer__social a:hover { background: var(--ca-green); }
.ca-footer__social svg { width: 18px; height: 18px; }
.ca-footer__bottom { border-top: 1px solid rgba(255,255,255,.1); padding-block: 1.5rem; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 1rem; font-size: .85rem; }
@media (max-width: 880px) { .ca-footer__top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .ca-footer__top { grid-template-columns: 1fr; } }

/* ============================== NEWSLETTER ========================== */
.ca-newsletter {
  background: linear-gradient(135deg, var(--ca-green-700), var(--ca-green)); color: #fff; border-radius: var(--ca-radius-lg);
  padding: clamp(32px, 5vw, 56px); display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items: center; overflow: hidden; position: relative;
}
.ca-newsletter h3 { color: #fff; font-size: clamp(1.5rem, 2.6vw, 2rem); }
.ca-newsletter p { color: rgba(255,255,255,.9); margin: 0; }
.ca-newsletter form { display: flex; gap: .6rem; flex-wrap: wrap; }
.ca-newsletter input[type=email] { flex: 1; min-width: 200px; border: 0; border-radius: 999px; padding: .95rem 1.3rem; font-size: 1rem; }
.ca-newsletter .ca-fine { font-size: .78rem; color: rgba(255,255,255,.78); margin-top: .7rem; }
@media (max-width: 720px) { .ca-newsletter { grid-template-columns: 1fr; } }

/* ============================== BREADCRUMB ========================== */
.ca-breadcrumb { font-size: .85rem; color: var(--ca-muted); padding-block: 1rem; }
.ca-breadcrumb ol { list-style: none; display: flex; flex-wrap: wrap; align-items: center; gap: .45rem; margin: 0; padding: 0; }
.ca-breadcrumb li { display: inline-flex; align-items: center; gap: .45rem; }
.ca-breadcrumb li:not(:last-child)::after { content: "/"; opacity: .45; }
.ca-breadcrumb a { color: var(--ca-muted); }
.ca-breadcrumb a:hover { color: var(--ca-green-700); }
.ca-breadcrumb [aria-current] { color: var(--ca-navy); font-weight: 600; }

/* ============================== SINGLE POST ========================= */
.ca-article-hero { background: var(--ca-surface-2); border-bottom: 1px solid var(--ca-line); }
.ca-article-hero__inner { max-width: 820px; margin-inline: auto; padding-block: clamp(28px, 5vw, 56px); }
.ca-article-hero h1 { font-size: clamp(2rem, 4.2vw, 3.1rem); margin: .8rem 0 1rem; }
.ca-article-hero .ca-lead { font-size: clamp(1.12rem, 1.7vw, 1.35rem); color: var(--ca-ink-soft); font-family: var(--ca-serif); font-weight: 400; line-height: 1.5; }
.ca-article-meta { display: flex; flex-wrap: wrap; align-items: center; gap: .85rem; margin-top: 1.6rem; font-size: .92rem; color: var(--ca-muted); }
.ca-article-meta .ca-author { display: flex; align-items: center; gap: .6rem; }
.ca-article-meta .ca-author img { width: 40px; height: 40px; border-radius: 50%; }
.ca-article-meta .ca-author strong { color: var(--ca-navy); font-weight: 600; display: block; line-height: 1.2; }
.ca-article-meta .dot { width: 3px; height: 3px; border-radius: 50%; background: currentColor; opacity: .5; }

.ca-featured-img { margin: 0 auto; max-width: var(--ca-container); }
.ca-featured-img img { width: 100%; max-height: 560px; object-fit: cover; border-radius: var(--ca-radius-lg); }
.ca-featured-img figcaption { font-size: .82rem; color: var(--ca-muted); text-align: center; margin-top: .7rem; }

.ca-article-layout { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: clamp(32px, 5vw, 64px); align-items: start; }
@media (max-width: 980px) { .ca-article-layout { grid-template-columns: 1fr; } .ca-sidebar { display: none; } }

/* ===== Single: conteúdo à esquerda + sidebar fixa do anúncio ===== */
.ca-single-layout { display: grid; grid-template-columns: minmax(0, 6fr) minmax(0, 4fr); gap: clamp(32px, 3.5vw, 52px); align-items: start; }
.ca-single-main { min-width: 0; }
.ca-single-head { margin-bottom: 1.8rem; }
.ca-single-head__tags { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.ca-single-head h1 { font-size: clamp(2rem, 3.4vw, 3rem); margin: .9rem 0 1rem; }
.ca-single-head .ca-lead { font-family: var(--ca-sans); font-weight: 500; color: var(--ca-ink-soft); max-width: 60ch; }
.ca-single-head__share { margin-top: 1.5rem; }
.ca-single-featured { margin: 0 0 2rem; }
.ca-single-featured img { width: 100%; max-height: 460px; object-fit: cover; border-radius: var(--ca-radius-lg); }
.ca-single-featured figcaption { font-size: .82rem; color: var(--ca-muted); margin-top: .6rem; }
/* prose ocupa a coluna toda, alinhada à esquerda */
.ca-prose--single { max-width: none; }
.ca-prose--single > * { margin-inline: 0; }

.ca-single-aside { display: grid; gap: 1.6rem; align-self: stretch; align-content: start; }
.ca-aside-stack { display: grid; gap: 1.6rem; }
/* o anúncio fica fixo acompanhando a rolagem */
.ca-ad-sticky { position: sticky; top: 92px; }
.ca-ad-sticky__label { display: inline-flex; align-items: center; gap: .4rem; font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .12em; color: var(--ca-muted); margin-bottom: .6rem; }
.ca-ad-sticky__label svg { width: 15px; height: 15px; }
.ca-sponsor--sidebar { margin: 0; }

/* Matéria sem anúncio: coluna única, conteúdo confortável à esquerda */
.ca-single-layout--full { grid-template-columns: minmax(0, 1fr); }
.ca-single-layout--full .ca-single-main { max-width: 820px; }

@media (max-width: 980px) {
  .ca-single-layout { grid-template-columns: 1fr; }
  .ca-single-aside { display: none; } /* mobile: ajustes virão depois */
}

/* ===== Fim de leitura: guia para mais conteúdo ===== */
.ca-readmore { background: var(--ca-surface-2); border-top: 1px solid var(--ca-line); }
.ca-readmore__cats { margin-bottom: clamp(36px, 5vw, 56px); }
.ca-cat-links { display: flex; flex-wrap: wrap; gap: .7rem; margin-top: 1.3rem; }
.ca-cat-links a {
  display: inline-flex; align-items: center; gap: .5rem; padding: .7rem 1.15rem; border-radius: 999px;
  background: #fff; border: 1px solid var(--ca-line); font-weight: 600; color: var(--ca-navy);
  transition: border-color .2s var(--ca-ease), color .2s, box-shadow .2s, transform .2s var(--ca-ease);
}
.ca-cat-links a:hover { border-color: var(--ca-green); color: var(--ca-green-700); box-shadow: var(--ca-shadow-sm); transform: translateY(-2px); }
.ca-cat-links a .n { color: var(--ca-muted); font-size: .82em; font-weight: 500; }

/* Conteúdo editorial */
.ca-prose { max-width: 720px; font-size: 1.12rem; line-height: 1.78; color: #25293a; }
.ca-prose > * { margin-inline: auto; }
.ca-prose p { margin: 0 0 1.4em; }
.ca-prose h2 { font-size: 1.7rem; margin: 2em 0 .6em; }
.ca-prose h3 { font-size: 1.34rem; margin: 1.6em 0 .5em; }
.ca-prose a { text-decoration: underline; text-decoration-color: rgba(73,172,96,.4); text-underline-offset: 3px; }
.ca-prose a:hover { text-decoration-color: var(--ca-green); }
.ca-prose img, .ca-prose figure { border-radius: var(--ca-radius); margin-block: 1.8em; }
.ca-prose figure img { border-radius: var(--ca-radius); }
.ca-prose figcaption { font-size: .85rem; color: var(--ca-muted); text-align: center; margin-top: .6rem; }
.ca-prose blockquote {
  border: 0; margin: 1.8em 0; padding: .4em 0 .4em 1.6rem; position: relative;
  font-family: var(--ca-serif); font-size: 1.4rem; line-height: 1.45; color: var(--ca-navy); font-style: italic;
}
.ca-prose blockquote::before { content: ""; position: absolute; left: 0; top: .2em; bottom: .2em; width: 4px; background: var(--ca-green); border-radius: 4px; }
.ca-prose ul, .ca-prose ol { margin: 0 0 1.4em; padding-left: 1.4rem; }
.ca-prose li { margin-bottom: .5em; }
.ca-prose ul li::marker { color: var(--ca-green); }
.ca-prose figure.wp-block-pullquote, .ca-prose hr { }
.ca-prose hr { border: 0; height: 1px; background: var(--ca-line); margin: 2.4em 0; }

/* Share */
.ca-share { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.ca-share span { font-size: .85rem; color: var(--ca-muted); font-weight: 600; }
.ca-share a { width: 42px; height: 42px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center; background: #fff; border: 1px solid var(--ca-line); color: var(--ca-navy); }
.ca-share a:hover { color: #fff; background: var(--ca-navy); border-color: var(--ca-navy); transform: translateY(-2px); }
.ca-share svg { width: 18px; height: 18px; }

/* Share flutuante mobile */
.ca-share-float { position: fixed; left: 0; right: 0; bottom: 0; z-index: 50; background: #fff; border-top: 1px solid var(--ca-line); padding: .6rem clamp(14px,4vw,20px); display: none; align-items: center; justify-content: space-between; gap: .6rem; box-shadow: 0 -8px 24px -16px rgba(16,28,66,.4); }
.ca-share-float .ca-share { gap: .45rem; }
.ca-share-float a { width: 38px; height: 38px; }
@media (max-width: 980px) { .ca-share-float { display: flex; } body.single { padding-bottom: 64px; } }

/* ============================== BLOCO PATROCINADO =================== */
.ca-sponsor {
  position: relative; border: 1px solid var(--ca-amber); border-radius: var(--ca-radius-lg);
  background: linear-gradient(180deg, #fffdf6, #fff); padding: clamp(20px, 3vw, 32px); margin: 2.5em 0; overflow: hidden;
}
.ca-sponsor::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 5px; background: var(--ca-amber); }
.ca-sponsor__head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1.2rem; }
.ca-sponsor__company { display: flex; align-items: center; gap: .9rem; }
.ca-sponsor__company img { width: 56px; height: 56px; border-radius: 12px; object-fit: contain; background: #fff; border: 1px solid var(--ca-line); padding: 4px; }
.ca-sponsor__company strong { display: block; color: var(--ca-navy); font-size: 1.15rem; }
.ca-sponsor__company span { font-size: .85rem; color: var(--ca-muted); }
.ca-sponsor__banner { border-radius: var(--ca-radius); overflow: hidden; margin-bottom: 1.1rem; }
.ca-sponsor__video { position: relative; aspect-ratio: 16/9; border-radius: var(--ca-radius); overflow: hidden; margin-bottom: 1.1rem; background: #000; }
.ca-sponsor__video iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.ca-sponsor p { color: var(--ca-ink-soft); }
.ca-sponsor__cta { margin-top: .4rem; }

/* ============================== AUTHOR BOX ========================== */
.ca-authorbox { display: flex; gap: 1.2rem; align-items: flex-start; background: var(--ca-surface); border: 1px solid var(--ca-line); border-radius: var(--ca-radius-lg); padding: 1.6rem; margin: 2.5em 0; }
.ca-authorbox img { width: 72px; height: 72px; border-radius: 50%; flex-shrink: 0; }
.ca-authorbox h4 { margin: 0 0 .3rem; font-size: 1.15rem; }
.ca-authorbox p { margin: 0; color: var(--ca-muted); font-size: .95rem; }
.ca-authorbox .ca-eyebrow { margin-bottom: .35rem; font-size: .85rem; }

/* ============================== SIDEBAR ============================= */
.ca-sidebar { position: sticky; top: 96px; display: grid; gap: 1.6rem; }
.ca-widget { background: var(--ca-surface); border: 1px solid var(--ca-line); border-radius: var(--ca-radius); padding: 1.4rem; }
.ca-widget__title { font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; color: var(--ca-navy); margin-bottom: 1rem; display: flex; align-items: center; gap: .5rem; }
.ca-widget__title::before { content: ""; width: 18px; height: 2px; background: var(--ca-green); }
.ca-widget ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 1rem; }

/* ============================== RELACIONADOS / NEWS LIST =========== */
.ca-related { border-top: 1px solid var(--ca-line); }

/* ============================== PAGINAÇÃO =========================== */
.ca-pagination { display: flex; flex-wrap: wrap; gap: .4rem; justify-content: center; margin-top: clamp(36px, 5vw, 56px); }
.ca-pagination .page-numbers {
  display: inline-flex; align-items: center; justify-content: center; min-width: 44px; height: 44px; padding: 0 .6rem;
  border-radius: 12px; border: 1px solid var(--ca-line); background: #fff; color: var(--ca-navy); font-weight: 600;
}
.ca-pagination .page-numbers:hover { border-color: var(--ca-navy); color: var(--ca-green-700); }
.ca-pagination .page-numbers.current { background: var(--ca-navy); border-color: var(--ca-navy); color: #fff; }
.ca-pagination .dots { border: 0; background: transparent; }

/* ============================== PÁGINA / FORMS ===================== */
.ca-page-hero { background: var(--ca-navy); color: #fff; position: relative; overflow: hidden; isolation: isolate; }
.ca-page-hero::before { content: ""; position: absolute; inset: 0; z-index: -1; background: radial-gradient(900px 400px at 80% -20%, rgba(73,172,96,.25), transparent 60%); }
.ca-page-hero__inner { padding-block: clamp(48px, 7vw, 88px); max-width: 760px; }
.ca-page-hero h1 { color: #fff; font-size: clamp(2.1rem, 4.4vw, 3.3rem); }
.ca-page-hero p { color: rgba(255,255,255,.82); font-size: 1.15rem; max-width: 56ch; margin: 0; }

.ca-form { display: grid; gap: 1.1rem; }
.ca-field { display: grid; gap: .4rem; }
.ca-field label { font-weight: 600; font-size: .92rem; color: var(--ca-navy); }
.ca-input, .ca-textarea, .ca-select {
  width: 100%; border: 1px solid var(--ca-line-strong); border-radius: 12px; padding: .85rem 1rem;
  font-size: 1rem; font-family: inherit; background: #fff; color: var(--ca-ink); transition: border-color .2s, box-shadow .2s;
}
.ca-input:focus, .ca-textarea:focus, .ca-select:focus { outline: 0; border-color: var(--ca-green); box-shadow: 0 0 0 3px rgba(73,172,96,.18); }
.ca-textarea { min-height: 150px; resize: vertical; }
.ca-field--row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
@media (max-width: 560px) { .ca-field--row { grid-template-columns: 1fr; } }

/* Contact split */
.ca-contact { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 64px); align-items: start; }
.ca-contact__info { display: grid; gap: 1.2rem; }
.ca-contact__item { display: flex; gap: .9rem; align-items: flex-start; }
.ca-contact__item svg { width: 22px; height: 22px; color: var(--ca-green); flex-shrink: 0; margin-top: 3px; }
.ca-contact__item strong { display: block; color: var(--ca-navy); }
.ca-contact__item span, .ca-contact__item a { color: var(--ca-muted); font-size: .96rem; }
@media (max-width: 820px) { .ca-contact { grid-template-columns: 1fr; } }

/* ============================== 404 ================================ */
.ca-404 { text-align: center; padding-block: clamp(60px, 12vw, 140px); }
.ca-404 .code { font-size: clamp(5rem, 16vw, 11rem); font-weight: 600; line-height: .9; color: var(--ca-navy); letter-spacing: -.04em; }
.ca-404 .code span { color: var(--ca-green); }

/* ============================== EMPRESAS / DIRETÓRIO =============== */
.ca-company { background: #fff; border: 1px solid var(--ca-line); border-radius: var(--ca-radius); overflow: hidden; transition: transform .25s var(--ca-ease), box-shadow .25s; display: flex; flex-direction: column; }
.ca-company:hover { transform: translateY(-4px); box-shadow: var(--ca-shadow); }
.ca-company__banner { aspect-ratio: 16/7; background: var(--ca-green-50); overflow: hidden; }
.ca-company__banner img { width: 100%; height: 100%; object-fit: cover; }
.ca-company__body { padding: 1.3rem; position: relative; }
.ca-company__logo { width: 64px; height: 64px; border-radius: 14px; background: #fff; border: 1px solid var(--ca-line); object-fit: contain; padding: 6px; position: absolute; top: -38px; left: 1.3rem; box-shadow: var(--ca-shadow-sm); }
.ca-company__body h3 { margin: 2rem 0 .3rem; font-size: 1.2rem; }
.ca-company__city { font-size: .85rem; color: var(--ca-muted); display: inline-flex; align-items: center; gap: .35rem; }
.ca-company__socials { display: flex; gap: .5rem; margin-top: 1rem; }
.ca-company__socials a { width: 38px; height: 38px; border-radius: 10px; border: 1px solid var(--ca-line); display: inline-flex; align-items: center; justify-content: center; color: var(--ca-navy); }
.ca-company__socials a:hover { background: var(--ca-green); border-color: var(--ca-green); color: #fff; }


/* ============================== BOTÕES FLUTUANTES ================== */
.ca-floats {
  position: fixed; right: clamp(14px, 2.5vw, 26px); bottom: clamp(14px, 2.5vw, 26px);
  z-index: 70; display: flex; flex-direction: column; gap: .7rem; align-items: flex-end;
}
.ca-float {
  position: relative; width: 56px; height: 56px; border-radius: 50%; border: 0; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; color: #fff;
  box-shadow: 0 10px 26px -8px rgba(16, 28, 66, .45);
  transition: transform .2s var(--ca-ease), box-shadow .2s var(--ca-ease), background .2s var(--ca-ease);
}
.ca-float svg { width: 26px; height: 26px; }
.ca-float:hover { transform: translateY(-3px); color: #fff; }

/* WhatsApp */
.ca-float--wa { background: #25D366; box-shadow: 0 10px 26px -8px rgba(37, 211, 102, .7); }
.ca-float--wa:hover { background: #1ebe5a; box-shadow: 0 16px 32px -10px rgba(37, 211, 102, .8); }
/* pulso sutil para chamar atenção, sem exagero */
.ca-float--wa::after {
  content: ""; position: absolute; inset: 0; border-radius: 50%; border: 2px solid #25D366;
  animation: ca-pulse 2.6s var(--ca-ease) infinite; opacity: 0;
}
@keyframes ca-pulse { 0% { transform: scale(1); opacity: .6; } 80%, 100% { transform: scale(1.5); opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .ca-float--wa::after { animation: none; } }

/* Tooltip do WhatsApp (desktop) */
.ca-float__tip {
  position: absolute; right: calc(100% + 12px); top: 50%; transform: translateY(-50%) translateX(6px);
  background: var(--ca-navy); color: #fff; font-size: .82rem; font-weight: 600; white-space: nowrap;
  padding: .5rem .8rem; border-radius: 10px; opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .2s var(--ca-ease), transform .2s var(--ca-ease); box-shadow: var(--ca-shadow);
}
.ca-float__tip::after { content: ""; position: absolute; left: 100%; top: 50%; transform: translateY(-50%); border: 6px solid transparent; border-left-color: var(--ca-navy); }
.ca-float--wa:hover .ca-float__tip { opacity: 1; visibility: visible; transform: translateY(-50%) translateX(0); }

/* Voltar ao topo — escondido até rolar */
.ca-float--top {
  background: var(--ca-navy); opacity: 0; visibility: hidden; transform: translateY(12px) scale(.9);
}
.ca-float--top.is-visible { opacity: 1; visibility: visible; transform: none; }
.ca-float--top:hover { background: var(--ca-green-700); }

@media (max-width: 640px) {
  .ca-float { width: 50px; height: 50px; }
  .ca-float svg { width: 23px; height: 23px; }
  .ca-float__tip { display: none; }
}
/* No single mobile, sobe acima da barra de compartilhar fixa */
@media (max-width: 980px) { body.single .ca-floats { bottom: 76px; } }

/* ---- Botão flutuante "Publicidade" (chamada do conteúdo patrocinado) ---- */
.ca-float-ad {
  display: inline-flex; align-items: center; gap: .6rem; cursor: pointer;
  background: linear-gradient(135deg, #FBB034, var(--ca-amber)); color: #3a2700; border: 0;
  padding: .6rem 1rem .6rem .65rem; border-radius: 999px; text-align: left;
  box-shadow: 0 12px 26px -8px rgba(249, 168, 37, .65);
  transition: transform .2s var(--ca-ease), box-shadow .2s var(--ca-ease);
  max-width: 230px; animation: ca-ad-bob 3.4s ease-in-out infinite;
}
.ca-float-ad:hover { transform: translateY(-3px); box-shadow: 0 18px 34px -10px rgba(249, 168, 37, .8); color: #3a2700; }
.ca-float-ad__icon { width: 38px; height: 38px; flex-shrink: 0; border-radius: 50%; background: rgba(255,255,255,.45); display: inline-flex; align-items: center; justify-content: center; }
.ca-float-ad__icon svg { width: 20px; height: 20px; }
.ca-float-ad__text { display: flex; flex-direction: column; line-height: 1.15; min-width: 0; }
.ca-float-ad__text small { font-size: .64rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; opacity: .8; }
.ca-float-ad__text strong { font-size: .88rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
@keyframes ca-ad-bob { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-4px); } }
@media (prefers-reduced-motion: reduce) { .ca-float-ad { animation: none; } }
@media (max-width: 640px) { .ca-float-ad { max-width: 190px; padding: .5rem .85rem .5rem .55rem; } .ca-float-ad__icon { width: 34px; height: 34px; } }
/* No desktop o anúncio vive na sidebar fixa, então o botão flutuante some (fica só no mobile) */
@media (min-width: 981px) { .ca-float-ad { display: none !important; } }

/* ---- Modal de Conteúdo Patrocinado ---- */
.ca-admodal {
  position: fixed; inset: 0; z-index: 100; display: flex; align-items: center; justify-content: center;
  padding: clamp(16px, 4vw, 40px); opacity: 0; visibility: hidden; transition: opacity .28s var(--ca-ease), visibility .28s;
}
.ca-admodal.is-open { opacity: 1; visibility: visible; }
.ca-admodal__overlay { position: absolute; inset: 0; background: rgba(16, 28, 66, .62); backdrop-filter: blur(4px); }
.ca-admodal__box {
  position: relative; width: min(560px, 100%); max-height: 90vh; overflow-y: auto;
  transform: translateY(16px) scale(.98); transition: transform .28s var(--ca-ease);
  border-radius: var(--ca-radius-lg); background: #fff; box-shadow: var(--ca-shadow-lg);
}
.ca-admodal.is-open .ca-admodal__box { transform: none; }
.ca-admodal__close {
  position: absolute; top: 12px; right: 12px; z-index: 2; width: 40px; height: 40px; border-radius: 50%;
  border: 0; background: rgba(16,28,66,.08); color: var(--ca-navy); font-size: 1.5rem; line-height: 1; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; transition: background .2s, color .2s;
}
.ca-admodal__close:hover { background: var(--ca-navy); color: #fff; }
/* o bloco patrocinado dentro do modal: sem margem e bordas externas */
.ca-sponsor--modal { margin: 0; border: 0; border-radius: var(--ca-radius-lg); }
.ca-sponsor--modal::before { display: none; }

/* Utilidades */
.ca-mt-0 { margin-top: 0; }
.ca-text-center { text-align: center; }
.ca-divider { height: 1px; background: var(--ca-line); border: 0; margin: 0; }
