/*
Theme Name: CG Notícias
Theme URI: https://centrodoguilherme.com.br
Author: Centro do Guilherme
Author URI: https://centrodoguilherme.com.br
Description: Portal de notícias oficial de Centro do Guilherme — MA. Layout editorial responsivo com enquetes, Stories e slider de patrocinadores.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cg-noticias
Tags: news, blog, responsive, custom-menu, featured-images, custom-colors
*/

/* ── RESET & TOKENS ───────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --cg-red:        #cc1414;
  --cg-red-light:  #fdf0f0;
  --cg-green:      #1a7a1a;
  --cg-green-light:#f0f7f0;
  --cg-yellow:     #f5c800;
  --cg-yellow-light:#fffbea;
  --cg-blue:       #1a2e8c;
  --cg-blue-light: #eef1fb;
  --cg-bg:         #fafaf8;
  --cg-bg2:        #f4f3ef;
  --cg-border:     #e6e4de;
  --cg-text:       #1c1b18;
  --cg-muted:      #5a5750;
  --cg-muted2:     #9a9790;
  --cg-max:        1200px;
  --cg-font-head:  'Syne', sans-serif;
  --cg-font-body:  'DM Sans', sans-serif;
}

/* ── BASE ─────────────────────────────────────────────────────────────────── */
html {
  font-family: var(--cg-font-body);
  font-size: 16px;
  background: var(--cg-bg);
  color: var(--cg-text);
  -webkit-text-size-adjust: 100%;
}
body { min-height: 100vh; background: var(--cg-bg); }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--cg-red); }
ul, ol { list-style: none; }

/* ── LAYOUT ───────────────────────────────────────────────────────────────── */
.cg-wrap {
  max-width: var(--cg-max);
  margin: 0 auto;
  padding: 0 24px;
}
.cg-main-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 32px;
  padding: 32px 0;
}
@media (max-width: 900px) {
  .cg-main-grid { grid-template-columns: 1fr; }
}

/* Banner patrocinador */
.cg-banner-wrap {
  background: var(--cg-bg2);
  border-bottom: 1px solid var(--cg-border);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 24px;
}
.cg-banner-slot {
  width: 100%;
  max-width: 1280px;
  height: 90px;
  border: 1px dashed var(--cg-muted2);
  border-radius: 3px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  overflow: hidden;
}
.cg-banner-slot img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cg-banner-label { font-family: var(--cg-font-head); font-size: 11px; font-weight: 700; letter-spacing: 0.1em; color: var(--cg-muted2); text-transform: uppercase; }
.cg-banner-size  { font-size: 11px; color: var(--cg-muted2); font-family: var(--cg-font-body); }

/* ── TOP BAR ──────────────────────────────────────────────────────────────── */
#cg-topbar {
  background: var(--cg-red);
  color: #fff;
  font-size: 11px;
  font-family: var(--cg-font-body);
  padding: 6px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#cg-topbar .cg-social a { color: #fff; margin-left: 16px; opacity: 0.85; font-size: 11px; transition: opacity 0.15s; }
#cg-topbar .cg-social a:hover { opacity: 1; }

/* ── TICKER ───────────────────────────────────────────────────────────────── */
#cg-ticker { background: var(--cg-bg2); border-bottom: 1px solid var(--cg-border); overflow: hidden; height: 34px; display: flex; align-items: center; }
.cg-ticker-label { background: var(--cg-yellow); color: var(--cg-text); font-family: var(--cg-font-head); font-weight: 700; font-size: 11px; padding: 0 14px; height: 100%; display: flex; align-items: center; letter-spacing: 0.06em; flex-shrink: 0; white-space: nowrap; }
.cg-ticker-track { overflow: hidden; flex: 1; }
.cg-ticker-inner { display: inline-flex; gap: 3rem; white-space: nowrap; animation: cgTicker 35s linear infinite; font-size: 12px; font-family: var(--cg-font-body); }
.cg-ticker-inner:hover { animation-play-state: paused; }
.cg-ticker-sep { color: var(--cg-muted2); margin: 0 1.5rem; }
@keyframes cgTicker { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ── HEADER ───────────────────────────────────────────────────────────────── */
#cg-header { background: var(--cg-text); border-bottom: 1px solid rgba(255,255,255,0.08); position: sticky; top: 0; z-index: 100; box-shadow: 0 2px 8px rgba(0,0,0,0.08); }
#cg-header .cg-header-inner { display: flex; align-items: center; justify-content: space-between; height: 64px; }

/* Logo */
.cg-logo { display: flex; align-items: center; gap: 12px; }
.cg-logo-flag { width: 42px; height: 28px; border-radius: 3px; overflow: hidden; display: flex; flex-direction: column; box-shadow: 0 1px 4px rgba(0,0,0,0.3); flex-shrink: 0; }
.cg-logo-flag-g { flex: 1; background: var(--cg-green); }
.cg-logo-flag-y { flex: 1; background: var(--cg-yellow); display: flex; align-items: center; }
.cg-logo-flag-b { width: 18px; height: 100%; background: var(--cg-blue); display: flex; align-items: center; justify-content: center; }
.cg-logo-flag-b svg { width: 11px; height: 11px; }
.cg-logo-flag-r { flex: 1; background: var(--cg-red); }
.cg-logo-text { font-family: var(--cg-font-head); font-weight: 800; font-size: 17px; letter-spacing: -0.01em; color: #fff; line-height: 1.1; }
.cg-logo-text span { color: var(--cg-red); }

/* Nav desktop */
#cg-nav { display: flex; align-items: center; gap: 4px; }
#cg-nav > a {
  font-family: var(--cg-font-head); font-size: 13px; font-weight: 600;
  color: rgba(255,255,255,0.85); letter-spacing: 0.02em;
  padding: 8px 14px; border-radius: 3px;
  transition: background 0.15s, color 0.15s;
}
#cg-nav > a:hover { background: rgba(255,255,255,0.08); color: #fff; }
#cg-nav .cg-ao-vivo { color: var(--cg-red) !important; display: flex; align-items: center; gap: 6px; }
.cg-live-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--cg-red); display: inline-block; animation: pulse 1.5s infinite; }

/* Dropdown Categorias */
.cg-cat-dropdown { position: relative; }
.cg-cat-dropdown-btn {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--cg-font-head); font-size: 13px; font-weight: 600;
  color: rgba(255,255,255,0.85); letter-spacing: 0.02em;
  padding: 8px 14px; border-radius: 3px;
  background: none; border: none; cursor: pointer;
  transition: background 0.15s;
}
.cg-cat-dropdown-btn:hover,
.cg-cat-dropdown-btn.open { background: rgba(255,255,255,0.08); color: #fff; }
.cg-cat-dropdown-btn svg { opacity: 0.6; transition: transform 0.2s; }
.cg-cat-dropdown-btn.open svg { transform: rotate(180deg); }
.cg-cat-dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  background: #fff;
  border: 1px solid var(--cg-border);
  border-radius: 4px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12);
  min-width: 200px;
  z-index: 200;
  overflow: hidden;
  animation: cgFadeUp 0.15s ease;
}
.cg-cat-dropdown-menu.open { display: block; }
@keyframes cgFadeUp { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.cg-cat-dropdown-menu a {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 18px;
  font-family: var(--cg-font-head); font-size: 13px; font-weight: 500;
  color: var(--cg-text);
  border-bottom: 1px solid var(--cg-border);
  transition: background 0.12s;
}
.cg-cat-dropdown-menu a:last-child { border-bottom: none; }
.cg-cat-dropdown-menu a:hover { background: var(--cg-bg2); }
.cg-cat-dropdown-menu a.current { background: var(--cg-red-light); color: var(--cg-red); font-weight: 700; }
.cg-cat-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--cg-muted2); flex-shrink: 0; }
.cg-cat-dropdown-menu a.current .cg-cat-dot { background: var(--cg-red); }

/* Hambúrguer */
.cg-hamburger { display: none; background: none; border: none; color: #fff; font-size: 22px; cursor: pointer; padding: 4px; line-height: 1; }
#cg-nav-mobile {
  display: none;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 12px 0 16px;
}
#cg-nav-mobile.open { display: block; }
#cg-nav-mobile a {
  display: block; padding: 12px 4px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  font-family: var(--cg-font-head); font-size: 14px; font-weight: 600;
  color: rgba(255,255,255,0.85);
  transition: color 0.15s;
}
#cg-nav-mobile a:hover { color: #fff; }
#cg-nav-mobile a.cg-ao-vivo { color: var(--cg-red); }

/* Right controls */
.cg-header-right { display: flex; align-items: center; gap: 8px; }
.cg-search-toggle { background: none; border: none; cursor: pointer; color: #fff; font-size: 20px; padding: 4px; line-height: 1; }
#cg-search-box {
  display: none;
  border: 1px solid var(--cg-border); border-radius: 3px;
  padding: 6px 10px; font-size: 13px; font-family: var(--cg-font-body);
  background: rgba(255,255,255,0.1); color: #fff; outline: none; width: 180px;
}
#cg-search-box::placeholder { color: rgba(255,255,255,0.4); }
#cg-search-box.open { display: block; }

/* ── CATEGORY TABS ────────────────────────────────────────────────────────── */
.cg-cat-bar { display: flex; gap: 6px; flex-wrap: wrap; border-bottom: 2px solid var(--cg-border); padding-bottom: 14px; margin-bottom: 20px; }
.cg-cat-bar a { background: transparent; color: var(--cg-muted); border: 1px solid transparent; border-radius: 2px; padding: 6px 14px; font-size: 12px; font-family: var(--cg-font-head); font-weight: 600; letter-spacing: 0.04em; transition: all 0.15s; white-space: nowrap; }
.cg-cat-bar a:hover, .cg-cat-bar a.active { background: var(--cg-red); color: #fff; border-color: var(--cg-red); }

/* ── BADGES ───────────────────────────────────────────────────────────────── */
.cg-badge { display: inline-block; font-family: var(--cg-font-head); font-size: 10px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; padding: 3px 8px; border-radius: 2px; }
.cg-badge-red    { background: var(--cg-red-light);    color: var(--cg-red); }
.cg-badge-green  { background: var(--cg-green-light);  color: var(--cg-green); }
.cg-badge-yellow { background: var(--cg-yellow-light); color: #7a6000; }
.cg-badge-blue   { background: var(--cg-blue-light);   color: var(--cg-blue); }

/* ── LAYOUT ───────────────────────────────────────────────────────────────── */
.cg-wrap { max-width: var(--cg-max); margin: 0 auto; padding: 0 24px; }
.cg-main-grid { display: grid; grid-template-columns: 1fr 320px; gap: 32px; padding: 32px 0; }

/* ── HERO POST ────────────────────────────────────────────────────────────── */
.cg-hero { display: grid; grid-template-columns: 1fr 1fr; background: #fff; border: 1px solid var(--cg-border); border-radius: 4px; overflow: hidden; margin-bottom: 24px; transition: box-shadow 0.2s; }
.cg-hero:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.08); }
.cg-hero-img { aspect-ratio: 4/3; object-fit: cover; width: 100%; height: 100%; }
.cg-hero-img-placeholder { aspect-ratio: 4/3; background: var(--cg-bg2); display: flex; align-items: center; justify-content: center; color: var(--cg-muted2); font-size: 12px; }
.cg-hero-body { padding: 40px; display: flex; flex-direction: column; justify-content: space-between; }
.cg-hero-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.cg-hero-label { font-size: 12px; color: var(--cg-muted); }
.cg-hero-title { font-family: var(--cg-font-head); font-size: 28px; font-weight: 800; line-height: 1.15; color: var(--cg-text); margin-bottom: 14px; transition: color 0.2s; text-wrap: pretty; }
.cg-hero:hover .cg-hero-title { color: var(--cg-red); }
.cg-hero-excerpt { font-size: 15px; line-height: 1.65; color: var(--cg-muted); text-wrap: pretty; }
.cg-hero-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 28px; padding-top: 18px; border-top: 1px solid var(--cg-border); }
.cg-hero-time { font-size: 12px; color: var(--cg-muted2); }
.cg-read-more { font-size: 12px; font-weight: 600; color: var(--cg-red); font-family: var(--cg-font-head); letter-spacing: 0.04em; }

/* ── MEDIUM CARDS ─────────────────────────────────────────────────────────── */
.cg-cards-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 24px; }
.cg-card { background: #fff; border: 1px solid var(--cg-border); border-radius: 4px; overflow: hidden; transition: box-shadow 0.2s, transform 0.2s; }
.cg-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,0.08); transform: translateY(-2px); }
.cg-card-img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.cg-card-img-placeholder { width: 100%; aspect-ratio: 16/9; background: var(--cg-bg2); display: flex; align-items: center; justify-content: center; color: var(--cg-muted2); font-size: 11px; }
.cg-card-body { padding: 20px; }
.cg-card-title { font-family: var(--cg-font-head); font-size: 16px; font-weight: 700; line-height: 1.25; margin: 10px 0; transition: color 0.2s; text-wrap: pretty; }
.cg-card:hover .cg-card-title { color: var(--cg-red); }
.cg-card-excerpt { font-size: 13px; color: var(--cg-muted); line-height: 1.6; text-wrap: pretty; }
.cg-card-time { font-size: 11px; color: var(--cg-muted2); margin-top: 14px; }

/* ── LIST POSTS ───────────────────────────────────────────────────────────── */
.cg-list-section { background: #fff; border: 1px solid var(--cg-border); border-radius: 4px; padding: 20px 24px; margin-bottom: 24px; }
.cg-section-title { font-family: var(--cg-font-head); font-weight: 800; font-size: 13px; letter-spacing: 0.06em; color: var(--cg-text); padding-bottom: 12px; border-bottom: 2px solid var(--cg-red); display: inline-block; margin-bottom: 4px; }
.cg-list-item { display: grid; grid-template-columns: 90px 1fr; gap: 14px; padding: 16px 0; border-bottom: 1px solid var(--cg-border); transition: opacity 0.2s; }
.cg-list-item:last-child { border-bottom: none; }
.cg-list-item:hover { opacity: 0.8; }
.cg-list-thumb { width: 90px; height: 70px; object-fit: cover; border-radius: 2px; }
.cg-list-thumb-placeholder { width: 90px; height: 70px; background: var(--cg-bg2); border-radius: 2px; display: flex; align-items: center; justify-content: center; font-size: 10px; color: var(--cg-muted2); }
.cg-list-title { font-family: var(--cg-font-head); font-size: 14px; font-weight: 700; line-height: 1.3; margin-top: 6px; transition: color 0.2s; text-wrap: pretty; }
.cg-list-item:hover .cg-list-title { color: var(--cg-red); }
.cg-list-time { font-size: 11px; color: var(--cg-muted2); margin-top: 6px; }

/* ── PAGINATION ───────────────────────────────────────────────────────────── */
.cg-pagination { display: flex; gap: 8px; justify-content: center; margin: 32px 0; flex-wrap: wrap; }
.cg-pagination a, .cg-pagination span { display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border: 1px solid var(--cg-border); border-radius: 2px; font-family: var(--cg-font-head); font-size: 13px; font-weight: 600; background: #fff; color: var(--cg-text); transition: all 0.15s; }
.cg-pagination a:hover, .cg-pagination .current { background: var(--cg-red); color: #fff; border-color: var(--cg-red); }

/* ── SIDEBAR ──────────────────────────────────────────────────────────────── */
.cg-sidebar { display: flex; flex-direction: column; gap: 24px; }
.cg-widget { background: #fff; border: 1px solid var(--cg-border); border-radius: 4px; padding: 20px 24px; }
.cg-widget-title { font-family: var(--cg-font-head); font-weight: 800; font-size: 13px; letter-spacing: 0.06em; color: var(--cg-text); padding-bottom: 12px; border-bottom: 2px solid var(--cg-red); display: block; margin-bottom: 4px; }
.cg-trending-item { display: flex; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--cg-border); transition: opacity 0.2s; }
.cg-trending-item:last-child { border-bottom: none; }
.cg-trending-item:hover { opacity: 0.75; }
.cg-trending-num { font-family: var(--cg-font-head); font-size: 22px; font-weight: 800; color: var(--cg-red-light); min-width: 32px; line-height: 1; }
.cg-trending-title { font-family: var(--cg-font-head); font-size: 13px; font-weight: 600; line-height: 1.35; color: var(--cg-text); transition: color 0.2s; text-wrap: pretty; }
.cg-trending-item:hover .cg-trending-title { color: var(--cg-red); }
.cg-widget-wa { background: var(--cg-text); border-radius: 4px; padding: 28px 24px; color: #fff; }
.cg-widget-wa h3 { font-family: var(--cg-font-head); font-size: 16px; font-weight: 800; line-height: 1.2; margin-bottom: 10px; }
.cg-widget-wa p { font-size: 13px; color: rgba(255,255,255,0.65); line-height: 1.5; margin-bottom: 16px; }
.cg-btn-wa { display: block; width: 100%; background: var(--cg-green); color: #fff; border: none; border-radius: 3px; padding: 10px; font-family: var(--cg-font-head); font-weight: 700; font-size: 13px; letter-spacing: 0.04em; text-align: center; cursor: pointer; transition: opacity 0.15s; }
.cg-btn-wa:hover { opacity: 0.88; color: #fff; }
.cg-ad-placeholder { background: var(--cg-bg2); border: 1px dashed var(--cg-border); border-radius: 4px; height: 280px; display: flex; align-items: center; justify-content: center; font-size: 11px; color: var(--cg-muted2); letter-spacing: 0.05em; text-transform: uppercase; }

/* ── SINGLE POST ──────────────────────────────────────────────────────────── */
.cg-single-header { margin-bottom: 28px; }
.cg-single-title { font-family: var(--cg-font-head); font-size: 36px; font-weight: 800; line-height: 1.15; margin: 14px 0 10px; text-wrap: pretty; }
.cg-single-meta { font-size: 13px; color: var(--cg-muted2); margin-bottom: 24px; }
.cg-single-meta strong { color: var(--cg-muted); }
.cg-single-feat-img { width: 100%; max-height: 480px; object-fit: cover; border-radius: 4px; margin-bottom: 32px; }
.cg-single-content { font-size: 17px; line-height: 1.8; color: var(--cg-text); max-width: 720px; }
.cg-single-content p { margin-bottom: 20px; text-wrap: pretty; }
.cg-single-content h2 { font-family: var(--cg-font-head); font-size: 24px; font-weight: 800; margin: 36px 0 14px; }
.cg-single-content h3 { font-family: var(--cg-font-head); font-size: 19px; font-weight: 700; margin: 28px 0 10px; }
.cg-single-content blockquote { border-left: 4px solid var(--cg-red); padding: 12px 24px; background: var(--cg-red-light); border-radius: 0 4px 4px 0; margin: 28px 0; font-style: italic; color: var(--cg-muted); }
.cg-single-content img { border-radius: 4px; margin: 20px 0; }
.cg-single-content a { color: var(--cg-red); text-decoration: underline; }
.cg-share-bar { display: flex; gap: 12px; margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--cg-border); flex-wrap: wrap; }
.cg-share-btn { background: var(--cg-bg2); border: 1px solid var(--cg-border); border-radius: 3px; padding: 8px 16px; font-size: 12px; font-family: var(--cg-font-body); font-weight: 600; cursor: pointer; color: var(--cg-text); transition: all 0.15s; }
.cg-share-btn:hover { background: var(--cg-red); color: #fff; border-color: var(--cg-red); }

/* ── FOOTER ───────────────────────────────────────────────────────────────── */
#cg-footer { background: var(--cg-text); color: rgba(255,255,255,0.6); margin-top: 60px; padding: 48px 24px 24px; }
.cg-footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 48px; max-width: var(--cg-max); margin: 0 auto 40px; }
.cg-footer-about-logo { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.cg-footer-brand { font-family: var(--cg-font-head); font-weight: 800; color: #fff; font-size: 16px; }
.cg-footer-desc { font-size: 13px; line-height: 1.65; max-width: 320px; }
.cg-footer-col-title { font-family: var(--cg-font-head); font-weight: 700; color: #fff; font-size: 12px; letter-spacing: 0.06em; margin-bottom: 14px; display: block; }
.cg-footer-col li { margin-bottom: 8px; }
.cg-footer-col li a { font-size: 13px; color: rgba(255,255,255,0.6); transition: color 0.15s; }
.cg-footer-col li a:hover { color: #fff; }
.cg-footer-socials { display: flex; gap: 10px; margin-top: 16px; }
.cg-footer-soc { width: 32px; height: 32px; border: 1px solid rgba(255,255,255,0.15); border-radius: 2px; display: flex; align-items: center; justify-content: center; font-size: 11px; font-family: var(--cg-font-head); font-weight: 700; color: #fff; transition: border-color 0.15s; }
.cg-footer-soc:hover { border-color: var(--cg-red); color: var(--cg-red); }
.cg-footer-bottom { border-top: 1px solid rgba(255,255,255,0.08); padding-top: 20px; display: flex; justify-content: space-between; align-items: center; font-size: 11px; max-width: var(--cg-max); margin: 0 auto; }

/* ── SEARCH FORM ──────────────────────────────────────────────────────────── */
.cg-search-form { display: flex; gap: 8px; margin-bottom: 28px; }
.cg-search-input { flex: 1; border: 1px solid var(--cg-border); border-radius: 3px; padding: 10px 14px; font-size: 14px; font-family: var(--cg-font-body); background: #fff; color: var(--cg-text); outline: none; }
.cg-search-input:focus { border-color: var(--cg-red); }
.cg-search-btn { background: var(--cg-red); color: #fff; border: none; border-radius: 3px; padding: 10px 18px; font-family: var(--cg-font-head); font-weight: 700; font-size: 13px; cursor: pointer; letter-spacing: 0.04em; transition: opacity 0.15s; }
.cg-search-btn:hover { opacity: 0.88; }

/* ── 404 ──────────────────────────────────────────────────────────────────── */
.cg-no-posts { text-align: center; padding: 80px 20px; color: var(--cg-muted); }
.cg-no-posts h2 { font-family: var(--cg-font-head); font-size: 20px; font-weight: 700; margin-bottom: 8px; }

/* ── UTILITIES ────────────────────────────────────────────────────────────── */
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }

/* ── RESPONSIVE ───────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .cg-main-grid { grid-template-columns: 1fr; }
  .cg-sidebar { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
  #cg-nav { display: none; }
  .cg-hamburger { display: block; }
}
@media (max-width: 768px) {
  #cg-topbar { display: none; }
  #cg-header .cg-header-inner { height: 56px; }
  .cg-logo-flag { width: 34px; height: 22px; }
  .cg-logo-flag-b { width: 14px; }
  .cg-logo-text { font-size: 13px; }
  .cg-hero { grid-template-columns: 1fr; }
  .cg-hero-body { padding: 20px; }
  .cg-hero-title { font-size: 20px; }
  .cg-hero-excerpt { font-size: 13px; }
  .cg-cards-grid { grid-template-columns: 1fr; }
  .cg-sidebar { grid-template-columns: 1fr; }
  .cg-footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .cg-footer-bottom { flex-direction: column; gap: 8px; text-align: center; }
  .cg-single-title { font-size: 26px; }
  .cg-wrap { padding: 0 16px; }
  .cg-main-grid { padding: 16px 0; }
  .cg-banner-wrap { padding: 10px 16px; }
  .cg-banner-slot { max-width: 262px; height: 120px; }
}
@media (max-width: 480px) {
  .cg-cat-bar a { padding: 5px 10px; font-size: 11px; }
  #cg-search-box { width: 130px; }
}

  background: var(--cg-bg2);
  border-bottom: 1px solid var(--cg-border);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 24px;
}
.cg-banner-slot {
  width: 100%;
  max-width: 1280px;
  height: 90px;
  border: 1px dashed var(--cg-muted2);
  border-radius: 3px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  overflow: hidden;
}
.cg-banner-slot img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.cg-banner-label {
  font-family: var(--cg-font-head);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--cg-muted2);
  text-transform: uppercase;
}
.cg-banner-size {
  font-size: 11px;
  color: var(--cg-muted2);
  font-family: var(--cg-font-body);
}

#cg-topbar {
  background: var(--cg-red);
  color: #fff;
  font-size: 11px;
  font-family: var(--cg-font-body);
  padding: 6px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#cg-topbar .cg-social a {
  color: #fff;
  margin-left: 16px;
  opacity: 0.85;
  font-size: 11px;
  transition: opacity 0.15s;
}
#cg-topbar .cg-social a:hover { opacity: 1; }

/* ── TICKER ───────────────────────────────────────────────────────────────── */
#cg-ticker {
  background: var(--cg-bg2);
  border-bottom: 1px solid var(--cg-border);
  overflow: hidden;
  height: 34px;
  display: flex;
  align-items: center;
}
.cg-ticker-label {
  background: var(--cg-yellow);
  color: var(--cg-text);
  font-family: var(--cg-font-head);
  font-weight: 700;
  font-size: 11px;
  padding: 0 14px;
  height: 100%;
  display: flex;
  align-items: center;
  letter-spacing: 0.06em;
  flex-shrink: 0;
  white-space: nowrap;
}
.cg-ticker-track { overflow: hidden; flex: 1; }
.cg-ticker-inner {
  display: inline-flex;
  gap: 3rem;
  white-space: nowrap;
  animation: cgTicker 35s linear infinite;
  font-size: 12px;
  font-family: var(--cg-font-body);
}
.cg-ticker-inner:hover { animation-play-state: paused; }
.cg-ticker-sep { color: var(--cg-muted2); margin: 0 1.5rem; }
@keyframes cgTicker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── HEADER ───────────────────────────────────────────────────────────────── */
#cg-header {
  background: var(--cg-text);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  position: sticky;
  top: 0;
  z-index: 100;
}
#cg-header .cg-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
}
/* Logo */
.cg-logo { display: flex; align-items: center; gap: 12px; }
.cg-logo-flag {
  width: 42px;
  height: 28px;
  border-radius: 3px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 1px 4px rgba(0,0,0,0.3);
  flex-shrink: 0;
}
.cg-logo-flag-g { flex: 1; background: var(--cg-green); }
.cg-logo-flag-y {
  flex: 1;
  background: var(--cg-yellow);
  display: flex;
  align-items: center;
}
.cg-logo-flag-b {
  width: 18px;
  height: 100%;
  background: var(--cg-blue);
  display: flex;
  align-items: center;
  justify-content: center;
}
.cg-logo-flag-b svg { width: 11px; height: 11px; }
.cg-logo-flag-r { flex: 1; background: var(--cg-red); }
.cg-logo-text {
  font-family: var(--cg-font-head);
  font-weight: 800;
  font-size: 17px;
  letter-spacing: -0.01em;
  color: #fff;
  line-height: 1.1;
}
.cg-logo-text span { color: var(--cg-red); }
/* Nav */
#cg-nav ul {
  display: flex;
  gap: 24px;
  align-items: center;
}
#cg-nav ul li a {
  font-family: var(--cg-font-head);
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.02em;
  transition: color 0.15s;
}
#cg-nav ul li a:hover,
#cg-nav ul li.current-menu-item a { color: var(--cg-red); }
@media (max-width: 768px) {
  #cg-nav { display: none; }
}

/* ── CATEGORY TABS ────────────────────────────────────────────────────────── */
.cg-cat-bar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  border-bottom: 2px solid var(--cg-border);
  padding-bottom: 16px;
  margin-bottom: 28px;
}
.cg-cat-bar a {
  background: transparent;
  color: var(--cg-muted);
  border: 1px solid transparent;
  border-radius: 2px;
  padding: 6px 14px;
  font-size: 12px;
  font-family: var(--cg-font-head);
  font-weight: 600;
  letter-spacing: 0.04em;
  transition: all 0.15s;
}
.cg-cat-bar a:hover,
.cg-cat-bar a.active {
  background: var(--cg-red);
  color: #fff;
  border-color: var(--cg-red);
}

/* ── BADGES ───────────────────────────────────────────────────────────────── */
.cg-badge {
  display: inline-block;
  font-family: var(--cg-font-head);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
}
.cg-badge-red    { background: var(--cg-red-light);    color: var(--cg-red); }
.cg-badge-green  { background: var(--cg-green-light);  color: var(--cg-green); }
.cg-badge-yellow { background: var(--cg-yellow-light); color: #7a6000; }
.cg-badge-blue   { background: var(--cg-blue-light);   color: var(--cg-blue); }

/* ── HERO POST ────────────────────────────────────────────────────────────── */
.cg-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: #fff;
  border: 1px solid var(--cg-border);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 28px;
  transition: box-shadow 0.2s;
}
.cg-hero:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.08); }
.cg-hero-img {
  aspect-ratio: 4/3;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.cg-hero-img-placeholder {
  aspect-ratio: 4/3;
  background: var(--cg-bg2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cg-muted2);
  font-size: 12px;
}
.cg-hero-body {
  padding: 40px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.cg-hero-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
}
.cg-hero-label {
  font-size: 12px;
  color: var(--cg-muted);
  font-family: var(--cg-font-body);
}
.cg-hero-title {
  font-family: var(--cg-font-head);
  font-size: 28px;
  font-weight: 800;
  line-height: 1.15;
  color: var(--cg-text);
  margin-bottom: 16px;
  transition: color 0.2s;
  text-wrap: pretty;
}
.cg-hero:hover .cg-hero-title { color: var(--cg-red); }
.cg-hero-excerpt {
  font-size: 15px;
  line-height: 1.65;
  color: var(--cg-muted);
  text-wrap: pretty;
}
.cg-hero-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 32px;
  padding-top: 20px;
  border-top: 1px solid var(--cg-border);
}
.cg-hero-time { font-size: 12px; color: var(--cg-muted2); }
.cg-read-more {
  font-size: 12px;
  font-weight: 600;
  color: var(--cg-red);
  font-family: var(--cg-font-head);
  letter-spacing: 0.04em;
}
@media (max-width: 768px) {
  .cg-hero { grid-template-columns: 1fr; }
  .cg-hero-body { padding: 24px; }
  .cg-hero-title { font-size: 22px; }
}

/* ── MEDIUM CARDS GRID ────────────────────────────────────────────────────── */
.cg-cards-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 28px;
}
@media (max-width: 600px) {
  .cg-cards-grid { grid-template-columns: 1fr; }
}
.cg-card {
  background: #fff;
  border: 1px solid var(--cg-border);
  border-radius: 4px;
  overflow: hidden;
  transition: box-shadow 0.2s, transform 0.2s;
}
.cg-card:hover {
  box-shadow: 0 6px 24px rgba(0,0,0,0.08);
  transform: translateY(-2px);
}
.cg-card-img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
}
.cg-card-img-placeholder {
  width: 100%;
  aspect-ratio: 16/9;
  background: var(--cg-bg2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cg-muted2);
  font-size: 11px;
}
.cg-card-body { padding: 20px; }
.cg-card-title {
  font-family: var(--cg-font-head);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.25;
  margin: 10px 0;
  transition: color 0.2s;
  text-wrap: pretty;
}
.cg-card:hover .cg-card-title { color: var(--cg-red); }
.cg-card-excerpt {
  font-size: 13px;
  color: var(--cg-muted);
  line-height: 1.6;
  text-wrap: pretty;
}
.cg-card-time { font-size: 11px; color: var(--cg-muted2); margin-top: 14px; }

/* ── LIST POSTS ───────────────────────────────────────────────────────────── */
.cg-list-section {
  background: #fff;
  border: 1px solid var(--cg-border);
  border-radius: 4px;
  padding: 20px 24px;
  margin-bottom: 28px;
}
.cg-section-title {
  font-family: var(--cg-font-head);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--cg-text);
  padding-bottom: 12px;
  border-bottom: 2px solid var(--cg-red);
  display: inline-block;
  margin-bottom: 4px;
}
.cg-list-item {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 14px;
  padding: 16px 0;
  border-bottom: 1px solid var(--cg-border);
  transition: opacity 0.2s;
}
.cg-list-item:last-child { border-bottom: none; }
.cg-list-item:hover { opacity: 0.8; }
.cg-list-thumb {
  width: 90px;
  height: 70px;
  object-fit: cover;
  border-radius: 2px;
}
.cg-list-thumb-placeholder {
  width: 90px;
  height: 70px;
  background: var(--cg-bg2);
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: var(--cg-muted2);
}
.cg-list-info {}
.cg-list-title {
  font-family: var(--cg-font-head);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.3;
  margin-top: 6px;
  transition: color 0.2s;
  text-wrap: pretty;
}
.cg-list-item:hover .cg-list-title { color: var(--cg-red); }
.cg-list-time { font-size: 11px; color: var(--cg-muted2); margin-top: 6px; }

/* ── PAGINATION ───────────────────────────────────────────────────────────── */
.cg-pagination {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin: 32px 0;
}
.cg-pagination a,
.cg-pagination span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid var(--cg-border);
  border-radius: 2px;
  font-family: var(--cg-font-head);
  font-size: 13px;
  font-weight: 600;
  background: #fff;
  color: var(--cg-text);
  transition: all 0.15s;
}
.cg-pagination a:hover,
.cg-pagination .current {
  background: var(--cg-red);
  color: #fff;
  border-color: var(--cg-red);
}

/* ── SIDEBAR ──────────────────────────────────────────────────────────────── */
.cg-sidebar { display: flex; flex-direction: column; gap: 24px; }
.cg-widget {
  background: #fff;
  border: 1px solid var(--cg-border);
  border-radius: 4px;
  padding: 20px 24px;
}
.cg-widget-title {
  font-family: var(--cg-font-head);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--cg-text);
  padding-bottom: 12px;
  border-bottom: 2px solid var(--cg-red);
  display: inline-block;
  margin-bottom: 4px;
  width: 100%;
}
/* Trending widget */
.cg-trending-item {
  display: flex;
  gap: 16px;
  padding: 14px 0;
  border-bottom: 1px solid var(--cg-border);
  transition: opacity 0.2s;
  cursor: pointer;
}
.cg-trending-item:last-child { border-bottom: none; }
.cg-trending-item:hover { opacity: 0.75; }
.cg-trending-num {
  font-family: var(--cg-font-head);
  font-size: 22px;
  font-weight: 800;
  color: var(--cg-red-light);
  min-width: 32px;
  line-height: 1;
}
.cg-trending-title {
  font-family: var(--cg-font-head);
  font-size: 13px;
  font-weight: 600;
  line-height: 1.35;
  color: var(--cg-text);
  transition: color 0.2s;
  text-wrap: pretty;
}
.cg-trending-item:hover .cg-trending-title { color: var(--cg-red); }
/* WhatsApp CTA */
.cg-widget-wa {
  background: var(--cg-text);
  border-radius: 4px;
  padding: 28px 24px;
  color: #fff;
}
.cg-widget-wa h3 {
  font-family: var(--cg-font-head);
  font-size: 16px;
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 10px;
}
.cg-widget-wa p {
  font-size: 13px;
  color: rgba(255,255,255,0.65);
  line-height: 1.5;
  margin-bottom: 16px;
}
.cg-btn-wa {
  display: block;
  width: 100%;
  background: var(--cg-green);
  color: #fff;
  border: none;
  border-radius: 3px;
  padding: 10px;
  font-family: var(--cg-font-head);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.04em;
  text-align: center;
  cursor: pointer;
  transition: opacity 0.15s;
}
.cg-btn-wa:hover { opacity: 0.88; color: #fff; }
/* Ad placeholder */
.cg-ad-placeholder {
  background: var(--cg-bg2);
  border: 1px dashed var(--cg-border);
  border-radius: 4px;
  height: 280px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: var(--cg-muted2);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* ── SINGLE POST ──────────────────────────────────────────────────────────── */
.cg-single-header { margin-bottom: 28px; }
.cg-single-title {
  font-family: var(--cg-font-head);
  font-size: 36px;
  font-weight: 800;
  line-height: 1.15;
  margin: 14px 0 10px;
  text-wrap: pretty;
}
@media (max-width: 768px) {
  .cg-single-title { font-size: 26px; }
}
.cg-single-meta {
  font-size: 13px;
  color: var(--cg-muted2);
  margin-bottom: 24px;
}
.cg-single-meta strong { color: var(--cg-muted); }
.cg-single-feat-img {
  width: 100%;
  max-height: 480px;
  object-fit: cover;
  border-radius: 4px;
  margin-bottom: 32px;
}
.cg-single-content {
  font-size: 17px;
  line-height: 1.8;
  color: var(--cg-text);
  max-width: 720px;
}
.cg-single-content p { margin-bottom: 20px; text-wrap: pretty; }
.cg-single-content h2 {
  font-family: var(--cg-font-head);
  font-size: 24px;
  font-weight: 800;
  margin: 36px 0 14px;
}
.cg-single-content h3 {
  font-family: var(--cg-font-head);
  font-size: 19px;
  font-weight: 700;
  margin: 28px 0 10px;
}
.cg-single-content blockquote {
  border-left: 4px solid var(--cg-red);
  padding: 12px 24px;
  background: var(--cg-red-light);
  border-radius: 0 4px 4px 0;
  margin: 28px 0;
  font-style: italic;
  color: var(--cg-muted);
}
.cg-single-content img {
  border-radius: 4px;
  margin: 20px 0;
}
.cg-single-content a { color: var(--cg-red); text-decoration: underline; }
/* Share bar */
.cg-share-bar {
  display: flex;
  gap: 12px;
  margin-top: 40px;
  padding-top: 24px;
  border-top: 1px solid var(--cg-border);
  flex-wrap: wrap;
}
.cg-share-btn {
  background: var(--cg-bg2);
  border: 1px solid var(--cg-border);
  border-radius: 3px;
  padding: 8px 16px;
  font-size: 12px;
  font-family: var(--cg-font-body);
  font-weight: 600;
  cursor: pointer;
  color: var(--cg-text);
  transition: all 0.15s;
}
.cg-share-btn:hover { background: var(--cg-red); color: #fff; border-color: var(--cg-red); }

/* ── FOOTER ───────────────────────────────────────────────────────────────── */
#cg-footer {
  background: var(--cg-text);
  color: rgba(255,255,255,0.6);
  margin-top: 60px;
  padding: 48px 24px 24px;
}
.cg-footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 40px;
  max-width: var(--cg-max);
  margin: 0 auto 40px;
}
@media (max-width: 768px) {
  .cg-footer-grid { grid-template-columns: 1fr; gap: 32px; }
}
.cg-footer-about-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
}
.cg-footer-brand {
  font-family: var(--cg-font-head);
  font-weight: 800;
  color: #fff;
  font-size: 16px;
}
.cg-footer-desc { font-size: 13px; line-height: 1.65; max-width: 320px; }
.cg-footer-col-title {
  font-family: var(--cg-font-head);
  font-weight: 700;
  color: #fff;
  font-size: 12px;
  letter-spacing: 0.06em;
  margin-bottom: 14px;
}
.cg-footer-col li { margin-bottom: 8px; }
.cg-footer-col li a {
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  transition: color 0.15s;
}
.cg-footer-col li a:hover { color: #fff; }
.cg-footer-socials {
  display: flex;
  gap: 10px;
  margin-top: 16px;
}
.cg-footer-soc {
  width: 32px;
  height: 32px;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-family: var(--cg-font-head);
  font-weight: 700;
  color: #fff;
  transition: border-color 0.15s;
}
.cg-footer-soc:hover { border-color: var(--cg-red); color: var(--cg-red); }
.cg-footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
  max-width: var(--cg-max);
  margin: 0 auto;
}
@media (max-width: 600px) {
  .cg-footer-bottom { flex-direction: column; gap: 8px; text-align: center; }
}

/* ── SEARCH ───────────────────────────────────────────────────────────────── */
.cg-search-form {
  display: flex;
  gap: 8px;
  margin-bottom: 28px;
}
.cg-search-input {
  flex: 1;
  border: 1px solid var(--cg-border);
  border-radius: 3px;
  padding: 10px 14px;
  font-size: 14px;
  font-family: var(--cg-font-body);
  background: #fff;
  color: var(--cg-text);
  outline: none;
}
.cg-search-input:focus { border-color: var(--cg-red); }
.cg-search-btn {
  background: var(--cg-red);
  color: #fff;
  border: none;
  border-radius: 3px;
  padding: 10px 18px;
  font-family: var(--cg-font-head);
  font-weight: 700;
  font-size: 13px;
  cursor: pointer;
  letter-spacing: 0.04em;
  transition: opacity 0.15s;
}
.cg-search-btn:hover { opacity: 0.88; }

/* ── NO POSTS ─────────────────────────────────────────────────────────────── */
.cg-no-posts {
  text-align: center;
  padding: 80px;
  color: var(--cg-muted);
}
.cg-no-posts h2 { font-family: var(--cg-font-head); font-size: 20px; font-weight: 700; margin-bottom: 8px; }

/* ── RESPONSIVE HEADER NAV ────────────────────────────────────────────────── */
.cg-hamburger {
  display: none;
  background: none;
  border: none;
  color: #fff;
  font-size: 22px;
  cursor: pointer;
  padding: 4px;
}
@media (max-width: 768px) {
  .cg-hamburger { display: block; }
  #cg-nav.open {
    display: block;
    position: absolute;
    top: 64px;
    left: 0;
    right: 0;
    background: var(--cg-text);
    border-top: 1px solid rgba(255,255,255,0.08);
    padding: 16px 24px;
    z-index: 99;
  }
  #cg-nav.open ul { flex-direction: column; gap: 16px; }
  #cg-header { position: relative; }
}

/* ── UTILITIES ────────────────────────────────────────────────────────────── */
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }


/* Story Button */
.cg-story-btn {
  display: inline-flex; align-items: center; gap: 5px;
  background: transparent; border: 1px solid var(--cg-red);
  border-radius: 3px; padding: 5px 10px;
  font-family: var(--cg-font-head); font-size: 11px; font-weight: 700;
  color: var(--cg-red); cursor: pointer; letter-spacing: .03em;
  transition: all .15s; white-space: nowrap; flex-shrink: 0;
}
.cg-story-btn:hover { background: var(--cg-red); color: #fff; }
.cg-story-btn svg { flex-shrink: 0; }

/* ═══════════════════════════════════════════════════════════════════════════
   ENQUETES
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── POLL SLIDER ─────────────────────────────────────────────────────────── */
.cg-poll-slider { background: var(--cg-text); position: relative; overflow: hidden; }
.cg-ps-slide { display: none; position: relative; }
.cg-ps-slide.active { display: block; animation: cgFadeUp .35s ease; }
@keyframes cgFadeUp { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }
.cg-ps-bg { position:absolute; inset:0; background:radial-gradient(ellipse at 80% 50%, rgba(204,20,20,.15) 0%, transparent 70%); pointer-events:none; }
.cg-ps-grid { display:grid; grid-template-columns:1fr 1fr; gap:0; min-height:300px; }
.cg-ps-left { padding:36px 40px 36px 0; display:flex; flex-direction:column; justify-content:center; border-right:1px solid rgba(255,255,255,.06); }
.cg-ps-right { padding:36px 0 36px 40px; display:flex; flex-direction:column; justify-content:center; }
.cg-ps-meta { display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.cg-ps-label { font-family:var(--cg-font-head); font-size:11px; font-weight:700; letter-spacing:.1em; color:rgba(255,255,255,.4); text-transform:uppercase; }
.cg-ps-question { font-family:var(--cg-font-head); font-size:22px; font-weight:800; color:#fff; line-height:1.25; margin-bottom:14px; text-wrap:pretty; }
.cg-ps-info { display:flex; gap:16px; flex-wrap:wrap; font-size:12px; color:rgba(255,255,255,.45); }
.cg-ps-vote-label { font-family:var(--cg-font-head); font-size:11px; font-weight:700; letter-spacing:.08em; color:rgba(255,255,255,.4); text-transform:uppercase; margin-bottom:10px; }
.cg-ps-opt-btn { display:block; width:100%; text-align:left; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:4px; padding:10px 14px; margin-bottom:7px; cursor:pointer; font-family:var(--cg-font-body); font-size:14px; color:rgba(255,255,255,.85); transition:all .15s; }
.cg-ps-opt-btn:hover { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.25); }
.cg-ps-result-row { margin-bottom:10px; }
.cg-ps-result-head { display:flex; justify-content:space-between; margin-bottom:4px; font-size:13px; color:rgba(255,255,255,.65); }
.cg-ps-winner .cg-ps-result-head { color:#fff; font-weight:600; }
.cg-ps-pct { font-family:var(--cg-font-head); font-weight:700; color:rgba(255,255,255,.4); }
.cg-ps-winner .cg-ps-pct { color:var(--cg-yellow); }
.cg-ps-bar-wrap { height:6px; background:rgba(255,255,255,.08); border-radius:3px; overflow:hidden; }
.cg-ps-bar { height:100%; border-radius:3px; background:rgba(255,255,255,.25); transition:width .8s ease; }
.cg-ps-winner .cg-ps-bar { background:var(--cg-yellow); }
.cg-ps-total { font-size:11px; color:rgba(255,255,255,.35); margin-top:8px; }
.cg-ps-controls { display:flex; align-items:center; justify-content:center; gap:12px; padding:16px 0; }
.cg-ps-prev, .cg-ps-next { background:rgba(255,255,255,.1); border:none; color:#fff; width:30px; height:30px; border-radius:50%; cursor:pointer; font-size:16px; display:flex; align-items:center; justify-content:center; transition:background .15s; flex-shrink:0; }
.cg-ps-prev:hover, .cg-ps-next:hover { background:rgba(255,255,255,.2); }
.cg-ps-dots { display:flex; gap:6px; align-items:center; }
.cg-ps-dot { width:8px; height:8px; border-radius:4px; border:none; cursor:pointer; background:rgba(255,255,255,.25); transition:all .3s; padding:0; }
.cg-ps-dot.active { width:24px; background:var(--cg-yellow); }

/* ── PÁGINA DE ENQUETES ───────────────────────────────────────────────────── */
.cg-enquetes-layout { display:grid; grid-template-columns:1fr 360px; gap:32px; padding:32px 0 64px; }
.cg-enquetes-header { margin-bottom:24px; }
.cg-enquetes-title { font-family:var(--cg-font-head); font-size:28px; font-weight:800; margin-bottom:6px; }
.cg-enquetes-desc { color:var(--cg-muted); font-size:15px; }
.cg-tabs { display:flex; gap:0; margin-bottom:24px; border-bottom:2px solid var(--cg-border); }
.cg-tab { background:none; border:none; cursor:pointer; padding:10px 18px; font-family:var(--cg-font-head); font-size:13px; font-weight:700; color:var(--cg-muted); border-bottom:2px solid transparent; margin-bottom:-2px; transition:color .15s; }
.cg-tab.active { color:var(--cg-red); border-bottom-color:var(--cg-red); }

/* Poll cards */
.cg-poll-card { background:#fff; border:1px solid var(--cg-border); border-radius:4px; overflow:hidden; margin-bottom:16px; transition:box-shadow .2s,transform .2s; }
.cg-poll-card:hover { box-shadow:0 6px 24px rgba(0,0,0,.07); transform:translateY(-1px); }
.cg-poll-card-stripe { height:3px; }
.cg-cat-stripe-política,.cg-cat-stripe-saude,.cg-cat-stripe-segurança { background:var(--cg-red); }
.cg-cat-stripe-esportes,.cg-cat-stripe-economia,.cg-cat-stripe-comunidade { background:var(--cg-green); }
.cg-cat-stripe-cultura,.cg-cat-stripe-geral { background:var(--cg-yellow); }
.cg-cat-stripe-tecnologia { background:var(--cg-blue); }
.cg-poll-card-body { padding:20px 24px; }
.cg-poll-card-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; flex-wrap:wrap; gap:8px; }
.cg-poll-date { font-size:11px; color:var(--cg-muted2); }
.cg-poll-question { font-family:var(--cg-font-head); font-size:16px; font-weight:700; line-height:1.3; margin-bottom:16px; text-wrap:pretty; }
.cg-poll-status { font-family:var(--cg-font-head); font-size:10px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:3px 8px; border-radius:2px; }
.cg-status-active   { background:var(--cg-green-light); color:var(--cg-green); }
.cg-status-pending  { background:var(--cg-yellow-light); color:#7a6000; }
.cg-status-rejected { background:var(--cg-red-light); color:var(--cg-red); }
.cg-status-closed   { background:var(--cg-bg2); color:var(--cg-muted2); }
.cg-poll-opt { display:block; width:100%; text-align:left; background:var(--cg-bg2); border:1px solid var(--cg-border); border-radius:3px; padding:9px 14px; margin-bottom:6px; cursor:pointer; font-family:var(--cg-font-body); font-size:13px; color:var(--cg-text); transition:all .15s; }
.cg-poll-opt:hover { background:var(--cg-red-light); border-color:var(--cg-red); color:var(--cg-red); }
.cg-poll-count { font-size:11px; color:var(--cg-muted2); margin-top:8px; }
.cg-res-row { margin-bottom:10px; }
.cg-res-head { display:flex; justify-content:space-between; margin-bottom:3px; font-size:13px; color:var(--cg-text); }
.cg-res-winner .cg-res-head { font-weight:700; }
.cg-res-pct { font-family:var(--cg-font-head); font-weight:700; color:var(--cg-muted2); }
.cg-res-winner .cg-res-pct { color:var(--cg-red); }
.cg-res-bar-wrap { height:6px; background:var(--cg-bg2); border-radius:3px; overflow:hidden; }
.cg-res-bar { height:100%; border-radius:3px; background:var(--cg-muted2); transition:width .8s ease; }
.cg-res-winner .cg-res-bar { background:var(--cg-red); }
.cg-poll-notice { border-radius:3px; padding:12px 14px; font-size:13px; line-height:1.5; }
.cg-notice-pending  { background:var(--cg-yellow-light); color:#7a6000; }
.cg-notice-rejected { background:var(--cg-red-light); color:var(--cg-red); }
.cg-poll-card-foot { display:flex; justify-content:space-between; align-items:center; margin-top:16px; padding-top:14px; border-top:1px solid var(--cg-border); font-size:11px; color:var(--cg-muted2); }

/* Formulário sugerir */
.cg-form-row { margin-bottom:16px; }
.cg-form-label { display:block; font-family:var(--cg-font-head); font-size:11px; font-weight:700; letter-spacing:.04em; color:var(--cg-text); margin-bottom:6px; }
.cg-form-input { width:100%; border:1px solid var(--cg-border); border-radius:3px; padding:9px 12px; font-size:13px; font-family:var(--cg-font-body); background:#fff; color:var(--cg-text); outline:none; transition:border .15s; box-sizing:border-box; }
.cg-form-input:focus { border-color:var(--cg-red); }
.cg-form-error { display:block; font-size:11px; color:var(--cg-red); margin-top:3px; min-height:14px; }
.cg-sq-add-btn { background:var(--cg-bg2); border:1px dashed var(--cg-border); border-radius:3px; padding:7px 12px; font-size:12px; font-family:var(--cg-font-head); font-weight:600; color:var(--cg-muted); cursor:pointer; transition:all .15s; margin-top:2px; }
.cg-sq-add-btn:hover { border-color:var(--cg-red); color:var(--cg-red); }
.cg-sq-submit-btn { width:100%; background:var(--cg-red); color:#fff; border:none; border-radius:3px; padding:11px; font-family:var(--cg-font-head); font-weight:700; font-size:13px; cursor:pointer; letter-spacing:.04em; transition:opacity .15s; margin-top:4px; }
.cg-sq-submit-btn:hover { opacity:.88; }

/* Responsive enquetes */
@media (max-width: 1024px) {
  .cg-enquetes-layout { grid-template-columns:1fr; }
  .cg-enquetes-aside { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
}
@media (max-width: 768px) {
  .cg-ps-grid { grid-template-columns:1fr; }
  .cg-ps-left { padding:24px 0 16px; border-right:none; border-bottom:1px solid rgba(255,255,255,.06); }
  .cg-ps-right { padding:16px 0 24px; }
  .cg-ps-question { font-size:18px; }
  .cg-enquetes-aside { grid-template-columns:1fr; }
}
