/* ============================================================
   Article page — Circuito Car design system
   Layered on /css/circuito-car-tokens.css (loaded by base-cc).
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { background: var(--cc-paper); color: var(--cc-ink); overflow-x: hidden; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.cc-wrap { max-width: 1280px; margin: 0 auto; padding: 0 32px; }

/* ===== TOPBAR + HEADER + FOOTER + DOCK (mirrors homepage) ===== */
.cc-topbar { background: var(--cc-ink); color: var(--cc-asphalt-300); font-size: var(--cc-fs-xs); border-bottom: 1px solid var(--cc-asphalt-800); }
.cc-topbar__inner { max-width: 1280px; margin: 0 auto; padding: 8px 32px; display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; }
.cc-topbar__pill { display: inline-flex; align-items: center; gap: 8px; font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-bold); letter-spacing: var(--cc-tracking-wider); text-transform: uppercase; color: var(--cc-yellow); }
.cc-topbar__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--cc-yellow); animation: ccPulse 2.2s ease-in-out infinite; }
@keyframes ccPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.45;transform:scale(.7)} }
.cc-topbar__links { display: flex; gap: 20px; }
.cc-topbar__links a { color: var(--cc-asphalt-300); transition: color var(--cc-dur-fast) var(--cc-ease-out); }
.cc-topbar__links a:hover { color: var(--cc-yellow); }

.cc-header { position: sticky; top: 0; z-index: 50; background: color-mix(in srgb, var(--cc-ink) 84%, transparent); backdrop-filter: blur(12px) saturate(140%); -webkit-backdrop-filter: blur(12px) saturate(140%); border-bottom: 1px solid var(--cc-asphalt-800); will-change: transform; }
.cc-header__inner { max-width: 1280px; margin: 0 auto; padding: 14px 32px; display: flex; align-items: center; gap: 24px; }
.cc-header__logo img { height: 32px; width: auto; }
.cc-header__brand-tag { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-bold); font-size: var(--cc-fs-xs); color: var(--cc-yellow); letter-spacing: var(--cc-tracking-wider); text-transform: uppercase; padding: 3px 7px; border: 1px solid var(--cc-yellow); border-radius: var(--cc-radius-xs); }
.cc-header__nav { display: flex; gap: 28px; margin-left: auto; }
.cc-header__nav a { color: var(--cc-paper); font-family: var(--cc-font-body); font-size: var(--cc-fs-sm); font-weight: var(--cc-fw-semibold); letter-spacing: var(--cc-tracking-wide); text-transform: uppercase; padding: 6px 0; border-bottom: 2px solid transparent; transition: color var(--cc-dur-fast) var(--cc-ease-out), border-color var(--cc-dur-fast) var(--cc-ease-out); }
.cc-header__nav a:hover { color: var(--cc-yellow); border-bottom-color: var(--cc-yellow); }
.cc-header__cta { display: inline-flex; align-items: center; gap: 6px; background: var(--cc-yellow); color: var(--cc-ink); border: 0; font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-black); font-size: var(--cc-fs-sm); letter-spacing: var(--cc-tracking-wide); text-transform: uppercase; padding: 9px 14px; border-radius: var(--cc-radius-sm); box-shadow: 0 0 0 2px rgba(13,31,60,0.18), 0 0 14px rgba(13,31,60,0.14); transition: background var(--cc-dur-fast) var(--cc-ease-out), color var(--cc-dur-fast) var(--cc-ease-out), box-shadow var(--cc-dur-fast) var(--cc-ease-out); }
.cc-header__cta:hover { background: var(--cc-yellow-hot); color: var(--cc-blue-light); box-shadow: 0 0 0 2px rgba(30,74,138,0.55), 0 0 20px rgba(30,74,138,0.7), 0 0 40px rgba(30,74,138,0.3); }
.cc-header__cta i { width: 16px; height: 16px; }

.cc-footer { background: var(--cc-ink); color: var(--cc-asphalt-300); padding: 56px 0 32px; border-top: 1px solid var(--cc-asphalt-800); }
.cc-footer__inner { max-width: 1280px; margin: 0 auto; padding: 0 32px; }
.cc-footer__grid { display: grid; grid-template-columns: 1.5fr repeat(3, 1fr); gap: 32px; margin-bottom: 36px; }
.cc-footer__brand p { font-family: var(--cc-font-body); font-size: var(--cc-fs-sm); line-height: var(--cc-lh-loose); color: var(--cc-asphalt-400); margin: 14px 0 0; }
.cc-footer__logo { height: 36px; width: auto; }
.cc-footer__col h4 { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-bold); text-transform: uppercase; font-size: var(--cc-fs-sm); color: var(--cc-yellow); letter-spacing: var(--cc-tracking-wider); margin: 0 0 14px; }
.cc-footer__col a { display: block; font-family: var(--cc-font-body); font-size: var(--cc-fs-sm); color: var(--cc-asphalt-300); padding: 4px 0; transition: color var(--cc-dur-fast) var(--cc-ease-out); }
.cc-footer__col a:hover { color: var(--cc-yellow); }
.cc-footer__col p { font-family: var(--cc-font-body); font-size: var(--cc-fs-sm); color: var(--cc-asphalt-400); line-height: 1.6; }
.cc-footer__bottom { border-top: 1px solid var(--cc-asphalt-800); padding-top: 20px; display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap; font-size: var(--cc-fs-xs); color: var(--cc-asphalt-500); }
.cc-credit { text-align: center; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--cc-asphalt-800); }
.cc-credit a { font-family: var(--cc-font-body); font-size: 11px; font-style: italic; color: var(--cc-asphalt-500); text-decoration: none; letter-spacing: 0.09em; display: inline-flex; align-items: center; gap: 5px; transition: color var(--cc-dur-fast) var(--cc-ease-out); }
.cc-credit a:hover { color: var(--cc-yellow); }
.cc-credit i { width: 11px; height: 11px; }

.cc-mobile-dock { display: none; position: fixed; bottom: 0; left: 0; right: 0; z-index: 60; background: color-mix(in srgb, var(--cc-ink) 92%, transparent); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-top: 1px solid var(--cc-asphalt-800); padding: 8px 0 calc(8px + env(safe-area-inset-bottom)); justify-content: space-around; }
.cc-mobile-dock a { display: flex; flex-direction: column; align-items: center; gap: 3px; color: var(--cc-asphalt-300); font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-bold); font-size: 10px; letter-spacing: var(--cc-tracking-wide); text-transform: uppercase; flex: 1; padding: 4px; transition: color var(--cc-dur-fast) var(--cc-ease-out); }
.cc-mobile-dock a:hover, .cc-mobile-dock a:active { color: var(--cc-yellow); }
.cc-mobile-dock i { width: 20px; height: 20px; }

/* ===== POST HERO (dark band) ===== */
.cc-post-hero { background: var(--cc-ink); color: var(--cc-paper); padding: 72px 0 56px; position: relative; overflow: hidden; }
.cc-post-hero__inner { max-width: 880px; margin: 0 auto; padding: 0 32px; text-align: left; position: relative; z-index: 2; }
.cc-post-hero__eyebrow { display: inline-flex; align-items: center; gap: 10px; color: var(--cc-yellow); font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-bold); font-size: var(--cc-fs-xs); letter-spacing: var(--cc-tracking-wider); text-transform: uppercase; margin-bottom: 22px; }
.cc-post-hero__eyebrow::before { content: ''; display: inline-block; width: 32px; height: 2px; background: var(--cc-yellow); }
.cc-post-hero h1 { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-black); text-transform: uppercase; color: var(--cc-paper); font-size: clamp(36px, 4.6vw, 64px); line-height: 0.98; letter-spacing: var(--cc-tracking-tight); margin: 0 0 20px; text-wrap: balance; }
.cc-post-hero h1 em { color: var(--cc-yellow); font-style: italic; }
.cc-post-hero__lead { color: var(--cc-asphalt-300); font-size: var(--cc-fs-lg); line-height: var(--cc-lh-loose); max-width: 760px; }
.cc-post-hero__meta { display: flex; gap: 14px; align-items: center; margin-top: 28px; padding-top: 22px; border-top: 1px solid var(--cc-asphalt-800); color: var(--cc-asphalt-400); font-size: var(--cc-fs-sm); flex-wrap: wrap; }
.cc-post-hero__meta i { width: 14px; height: 14px; vertical-align: -2px; margin-right: 4px; }
.cc-post-hero__meta a { color: var(--cc-yellow); text-decoration: none; }
.cc-post-hero__actions { display: flex; gap: 10px; margin-top: 24px; flex-wrap: wrap; }
.cc-post-hero__chevron { position: absolute; bottom: -42px; right: -80px; width: 540px; height: 8px; background: var(--cc-yellow); transform: skewX(-28deg); opacity: 0.9; z-index: 1; }

/* Cover image — bleeds out of hero */
.cc-post-cover { max-width: 1100px; margin: -40px auto 0; padding: 0 32px; position: relative; z-index: 3; }
.cc-post-cover a { display: block; }
.cc-post-cover__img { width: 100%; aspect-ratio: 16/9; object-fit: cover; border-radius: var(--cc-radius-lg); border: 1px solid var(--cc-border); background: var(--cc-paper-card); transition: transform var(--cc-dur-base) var(--cc-ease-out); }
.cc-post-cover a:hover .cc-post-cover__img { transform: translateY(-3px); }

/* ===== TWO-COL LAYOUT ===== */
.cc-post-wrap { max-width: 1180px; margin: 0 auto; padding: 64px 32px 96px; display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 56px; align-items: start; }

/* ===== PROSE ===== */
.cc-prose { max-width: 720px; overflow-wrap: break-word; }
.cc-prose > *:first-child { margin-top: 0; }
.cc-prose h2 { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-black); text-transform: uppercase; font-size: clamp(26px, 2.4vw, 36px); line-height: 1.05; letter-spacing: var(--cc-tracking-tight); color: var(--cc-ink); margin: 56px 0 16px; text-wrap: balance; }
.cc-prose h3 { font-family: var(--cc-font-body); font-weight: var(--cc-fw-bold); font-size: var(--cc-fs-xl); color: var(--cc-ink); margin: 36px 0 12px; line-height: 1.3; }
.cc-prose p { font-family: var(--cc-font-body); font-size: var(--cc-fs-md); line-height: var(--cc-lh-loose); margin: 0 0 20px; color: var(--cc-fg); text-wrap: pretty; }
.cc-prose p strong, .cc-prose li strong { color: var(--cc-ink); font-weight: var(--cc-fw-bold); }
.cc-prose ul, .cc-prose ol { font-family: var(--cc-font-body); font-size: var(--cc-fs-md); line-height: var(--cc-lh-loose); margin: 0 0 24px; padding-left: 24px; color: var(--cc-fg); }
.cc-prose li { margin-bottom: 8px; }
.cc-prose li::marker { color: var(--cc-yellow-deep); font-weight: bold; }
.cc-prose blockquote { border-left: 4px solid var(--cc-yellow); padding: 6px 0 6px 24px; margin: 32px 0; font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-bold); font-size: var(--cc-fs-xl); line-height: var(--cc-lh-snug); color: var(--cc-ink); }
.cc-prose a:not(.btn):not(.cc-btn) { color: var(--cc-ink); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; text-decoration-color: var(--cc-yellow); font-weight: var(--cc-fw-semibold); transition: color var(--cc-dur-fast) var(--cc-ease-out); }
.cc-prose a:not(.btn):not(.cc-btn):hover { color: var(--cc-yellow-deep); text-decoration-thickness: 2px; }
.cc-prose hr { border: 0; border-top: 1px solid var(--cc-border); margin: 40px 0; }

/* Inline article CTA block (used in markdown via <div class="cta-inline">) */
.cta-inline { background: var(--cc-paper-warm); border: 1px solid var(--cc-border); border-left: 4px solid var(--cc-blue); border-radius: var(--cc-radius-md); padding: 24px 28px; margin: 36px 0; }
.cta-inline h3 { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-black); text-transform: uppercase; font-size: var(--cc-fs-xl); line-height: 1.05; color: var(--cc-ink); margin: 0 0 8px; }
.cta-inline p { margin: 0 0 16px; color: var(--cc-fg-muted); font-size: var(--cc-fs-base); }
.cta-actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* ===== BUTTONS (cc-btn family + legacy aliases for markdown content) ===== */
.cc-btn, .btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 20px; min-height: 46px; max-width: 100%; border-radius: var(--cc-radius-sm); border: 0; cursor: pointer; font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-black); font-size: var(--cc-fs-sm); letter-spacing: var(--cc-tracking-wide); text-transform: uppercase; text-align: center; transition: background var(--cc-dur-fast) var(--cc-ease-out), color var(--cc-dur-fast) var(--cc-ease-out), transform var(--cc-dur-fast) var(--cc-ease-out); white-space: normal; line-height: 1.12; text-decoration: none; }
.cc-btn:active, .btn:active { transform: scale(0.98); }
.cc-btn i, .btn i { width: 16px; height: 16px; }
.cc-btn--yellow, .btn-primary { background: var(--cc-yellow); color: var(--cc-ink); box-shadow: 0 0 0 2px rgba(13,31,60,0.18), 0 0 14px rgba(13,31,60,0.14); }
.cc-btn--yellow:hover, .btn-primary:hover { background: var(--cc-yellow-hot); color: var(--cc-blue-light); box-shadow: 0 6px 16px -6px rgba(255,255,0,0.4), 0 0 0 2px rgba(30,74,138,0.55), 0 0 20px rgba(30,74,138,0.7), 0 0 40px rgba(30,74,138,0.3); }
.cc-btn--dark { background: var(--cc-ink); color: var(--cc-paper); border: 1px solid var(--cc-blue-light); box-shadow: 0 0 0 1px rgba(30,74,138,0.4), 0 0 16px rgba(30,74,138,0.55), 0 0 32px rgba(30,74,138,0.2); }
.cc-btn--dark:hover { background: var(--cc-asphalt-800); border-color: var(--cc-blue-light); box-shadow: 0 0 0 1px rgba(30,74,138,0.6), 0 0 24px rgba(30,74,138,0.75), 0 0 48px rgba(30,74,138,0.35); }
.cc-btn--ghost-light { background: transparent; color: var(--cc-paper); border: 1px solid var(--cc-asphalt-600); }
.cc-btn--ghost-light:hover { border-color: var(--cc-yellow); color: var(--cc-yellow); }
.cc-btn--ghost-dark, .btn-secondary { background: transparent; color: var(--cc-ink); border: 1px solid var(--cc-border-strong); }
.cc-btn--ghost-dark:hover, .btn-secondary:hover { border-color: var(--cc-ink); background: var(--cc-paper-warm); color: var(--cc-ink); }
.cc-btn--ghost-blue { background: transparent; color: var(--cc-blue-light); border: 1px solid rgba(22,53,96,0.35); }
.cc-btn--ghost-blue:hover { background: var(--cc-blue); color: var(--cc-paper); border-color: var(--cc-blue); }
.cc-btn--wa, .btn-whatsapp { background: #25D366; color: var(--cc-ink); border: 0; box-shadow: 0 0 0 1px rgba(37,211,102,0.4), 0 4px 20px rgba(37,211,102,0.5), 0 0 40px rgba(37,211,102,0.2); }
.cc-btn--wa i, .btn-whatsapp i { color: var(--cc-ink); transition: color var(--cc-dur-fast) var(--cc-ease-out); }
.cc-btn--wa:hover, .btn-whatsapp:hover { background: var(--cc-blue); color: var(--cc-yellow); box-shadow: 0 0 0 2px rgba(37,211,102,0.65), 0 0 24px rgba(37,211,102,0.7), 0 0 48px rgba(37,211,102,0.32); }
.cc-btn--wa:hover i, .btn-whatsapp:hover i { color: #25D366; }
.btn-phone { background: var(--cc-ink); color: var(--cc-paper); border: 1px solid var(--cc-asphalt-600); }
.btn-phone:hover { background: var(--cc-asphalt-800); color: var(--cc-paper); border-color: var(--cc-asphalt-500); }

/* Buttons inside dark hero need ghost-light styling */
.cc-post-hero__actions .btn-secondary { background: transparent; color: var(--cc-paper); border-color: var(--cc-asphalt-600); }
.cc-post-hero__actions .btn-secondary:hover { border-color: var(--cc-yellow); color: var(--cc-yellow); background: transparent; }

/* ===== SIDEBAR ===== */
.cc-sidebar { display: flex; flex-direction: column; gap: 18px; }
.cc-side-card { background: var(--cc-paper-card); border: 1px solid var(--cc-border); border-top: 3px solid var(--cc-blue); border-radius: var(--cc-radius-lg); padding: 22px 24px; }
.cc-side-card--warm { background: var(--cc-paper-warm); }
.cc-side-card--stock { border-top-color: var(--cc-yellow); background: var(--cc-yellow-tint); }
.cc-side-card--stock h3 { color: var(--cc-blue); }
.cc-side-card__eyebrow { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-bold); font-size: var(--cc-fs-xs); color: var(--cc-yellow-deep); letter-spacing: var(--cc-tracking-wider); text-transform: uppercase; display: inline-flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.cc-side-card__eyebrow::before { content: ''; display: inline-block; width: 18px; height: 2px; background: var(--cc-yellow); }
.cc-side-card h3 { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-black); text-transform: uppercase; font-size: var(--cc-fs-lg); line-height: 1.1; color: var(--cc-ink); margin: 0 0 8px; }
.cc-side-card p { font-family: var(--cc-font-body); font-size: var(--cc-fs-sm); line-height: var(--cc-lh-loose); color: var(--cc-fg-muted); margin: 0 0 12px; }
.cc-side-card p:last-child { margin-bottom: 0; }
.cc-side-card a.cc-side-link { display: block; padding: 8px 0; font-family: var(--cc-font-body); font-size: var(--cc-fs-sm); font-weight: var(--cc-fw-semibold); color: var(--cc-ink); border-bottom: 1px solid var(--cc-border); transition: color var(--cc-dur-fast) var(--cc-ease-out); }
.cc-side-card a.cc-side-link:last-child { border-bottom: 0; }
.cc-side-card a.cc-side-link:hover { color: var(--cc-blue-light); }

/* Sidebar seller block (mirrors homepage seller card) */
.cc-side-seller { background: var(--cc-paper-card); border: 1px solid var(--cc-border); border-radius: var(--cc-radius-md); padding: 16px; margin-top: 12px; }
.cc-side-seller__top { display: flex; justify-content: space-between; align-items: center; gap: 8px; margin-bottom: 8px; flex-wrap: wrap; }
.cc-side-seller__top strong { font-family: var(--cc-font-body); font-size: var(--cc-fs-base); font-weight: var(--cc-fw-bold); color: var(--cc-ink); }
.cc-side-seller__role, .pill { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-black); font-size: var(--cc-fs-2xs); text-transform: uppercase; letter-spacing: var(--cc-tracking-wider); padding: 3px 8px; border-radius: var(--cc-radius-xs); background: var(--cc-yellow); color: var(--cc-ink); }
.cc-side-seller p { font-family: var(--cc-font-body); font-size: var(--cc-fs-sm); color: var(--cc-fg-muted); margin: 0 0 12px; line-height: 1.5; }
.cc-side-seller .cta-actions { gap: 8px; }
.cc-side-seller .cta-actions .btn, .cc-side-seller .cta-actions .cc-btn { flex: 1; padding: 9px 12px; min-height: 44px; font-size: var(--cc-fs-xs); }

/* Legacy compat: .sidebar-card, .seller, .seller-head, .badge — used in old article.njk */
.sidebar-card { background: var(--cc-paper-card); border: 1px solid var(--cc-border); border-radius: var(--cc-radius-lg); padding: 22px 24px; margin-bottom: 18px; }
.sidebar-card h3 { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-black); text-transform: uppercase; font-size: var(--cc-fs-lg); color: var(--cc-ink); margin: 0 0 10px; }
.sidebar-card p { font-family: var(--cc-font-body); font-size: var(--cc-fs-sm); color: var(--cc-fg-muted); margin: 0 0 10px; line-height: 1.6; }
.badge { display: inline-block; font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-bold); font-size: var(--cc-fs-xs); color: var(--cc-yellow-deep); letter-spacing: var(--cc-tracking-wider); text-transform: uppercase; margin-bottom: 8px; }
.seller { padding: 14px 0; border-top: 1px solid var(--cc-border); }
.seller:first-of-type { border-top: 0; padding-top: 6px; }
.seller-head { display: flex; justify-content: space-between; align-items: center; gap: 8px; margin-bottom: 6px; flex-wrap: wrap; }
.seller-head strong { font-family: var(--cc-font-body); font-size: var(--cc-fs-base); font-weight: var(--cc-fw-bold); color: var(--cc-ink); }
.footer-links { display: flex; flex-direction: column; gap: 4px; }
.footer-links a { display: block; padding: 6px 0; font-family: var(--cc-font-body); font-size: var(--cc-fs-sm); font-weight: var(--cc-fw-semibold); color: var(--cc-ink); border-bottom: 1px solid var(--cc-border); transition: color var(--cc-dur-fast) var(--cc-ease-out); }
.footer-links a:last-child { border-bottom: 0; }
.footer-links a:hover { color: var(--cc-yellow-deep); }

/* ===== RELATED ARTICLES BAND (paper-warm) ===== */
.cc-related { background: var(--cc-paper-warm); padding: 64px 0; border-top: 3px solid var(--cc-blue); }
.cc-related__inner { max-width: 1180px; margin: 0 auto; padding: 0 32px; }
.cc-related h2 { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-black); text-transform: uppercase; font-size: clamp(26px, 2.6vw, 38px); line-height: 1.05; color: var(--cc-ink); margin: 0 0 28px; }
.cc-related__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; align-items: stretch; }
.cc-related-card { background: var(--cc-paper-card); border: 1px solid var(--cc-border); border-radius: var(--cc-radius-lg); padding: 20px 22px; min-width: 0; transition: transform var(--cc-dur-base) var(--cc-ease-out), border-color var(--cc-dur-fast) var(--cc-ease-out); }
.cc-related-card:hover { transform: translateY(-2px); border-color: var(--cc-blue-mid); }
.cc-related-card:hover .cc-related-card__title { color: var(--cc-yellow-deep); }
.cc-related-card__eyebrow { display: inline-flex; align-items: center; gap: 8px; font-family: var(--cc-font-body); font-size: var(--cc-fs-xs); font-weight: var(--cc-fw-bold); letter-spacing: 0.14em; text-transform: uppercase; color: var(--cc-fg-muted); margin-bottom: 8px; }
.cc-related-card__eyebrow::before { content: ''; display: inline-block; width: 18px; height: 2px; background: var(--cc-yellow-deep); }
.cc-related-card__title { font-family: var(--cc-font-body); font-size: var(--cc-fs-md); font-weight: var(--cc-fw-bold); line-height: 1.25; color: var(--cc-ink); margin: 0; transition: color var(--cc-dur-fast) var(--cc-ease-out); }

/* ===== REDUCED MOTION ===== */
@media (prefers-reduced-motion: reduce) {
  .cc-topbar__dot { animation: none; }
  .cc-post-cover a:hover .cc-post-cover__img,
  .cc-related-card { transition: none; transform: none !important; }
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1000px) {
  .cc-post-wrap { grid-template-columns: 1fr; gap: 40px; padding: 48px 32px 80px; }
  .cc-sidebar { position: static; }
  .cc-related__grid { grid-template-columns: 1fr 1fr; }
  .cc-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 820px) {
  .cc-wrap { padding: 0 20px; }
  .cc-topbar__inner, .cc-header__inner, .cc-footer__inner { padding-left: 20px; padding-right: 20px; }
  .cc-post-hero { padding: 48px 0 40px; }
  .cc-post-hero__inner, .cc-post-cover { padding-left: 20px; padding-right: 20px; }
  .cc-post-cover__img { aspect-ratio: 4/3; object-fit: contain; background: #ececec; }
  .cc-post-wrap { padding: 40px 20px 64px; }
  .cc-header__nav { display: none; }
  .cc-header__brand-tag { margin-left: auto; }
  .cc-related { padding: 48px 0; }
  .cc-related__inner { padding: 0 20px; }
  .cc-related__grid { grid-template-columns: 1fr; }
  .cc-footer__grid { grid-template-columns: 1fr; gap: 28px; }
  .cc-mobile-dock { display: flex; }
  body { padding-bottom: 72px; }
}
@media (max-width: 520px) {
  .cc-topbar__pill { display: none; }
  .cta-inline { padding: 18px 20px; }
  .cc-post-hero__actions .cc-btn, .cc-post-hero__actions .btn,
  .cta-actions .cc-btn, .cta-actions .btn { width: 100%; }
  .cc-side-card, .sidebar-card { padding: 20px; }
}

/* ===== ARTICLE SHARE COMPONENT ===== */
.article-share { border-top: 1px solid var(--cc-border); border-bottom: 1px solid var(--cc-border); background: var(--cc-paper); }
.article-share__inner { max-width: 1180px; margin: 0 auto; padding: 12px 32px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; row-gap: 8px; }
.article-share__label { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-bold); font-size: var(--cc-fs-xs); color: var(--cc-fg-subtle); letter-spacing: var(--cc-tracking-wider); text-transform: uppercase; white-space: nowrap; flex-shrink: 0; }
.article-share__buttons { display: flex; gap: 5px; flex-wrap: wrap; align-items: center; }
.article-share__button { display: inline-flex; align-items: center; justify-content: center; gap: 5px; padding: 6px 13px; min-height: 44px; min-width: 44px; background: var(--cc-paper-card); color: var(--cc-fg-muted); border: 1px solid var(--cc-border); border-radius: 100px; font-family: var(--cc-font-body); font-size: var(--cc-fs-xs); font-weight: var(--cc-fw-semibold); cursor: pointer; text-decoration: none; transition: background var(--cc-dur-fast) var(--cc-ease-out), color var(--cc-dur-fast) var(--cc-ease-out), border-color var(--cc-dur-fast) var(--cc-ease-out); white-space: nowrap; line-height: 1; -webkit-tap-highlight-color: transparent; }
.article-share__button:hover { background: var(--cc-ink); color: var(--cc-paper); border-color: var(--cc-ink); }
.article-share__button:focus-visible { outline: 2px solid var(--cc-blue-light); outline-offset: 2px; background: var(--cc-ink); color: var(--cc-paper); border-color: var(--cc-ink); }
.article-share__button i { width: 13px; height: 13px; flex-shrink: 0; }
/* WhatsApp: subtle green accent on hover — #177245 is WhatsApp brand dark-green */
.article-share__button[data-share="whatsapp"]:hover { background: var(--cc-paper-warm); color: #177245; border-color: #25D366; }
/* Native share: dark-filled, most prominent */
.article-share__button--native { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-black); letter-spacing: var(--cc-tracking-wide); text-transform: uppercase; background: var(--cc-ink); color: var(--cc-paper); border-color: var(--cc-asphalt-700); }
.article-share__button--native:hover { background: var(--cc-asphalt-800); color: var(--cc-paper); border-color: var(--cc-asphalt-600); }
/* Copy feedback */
.article-share__feedback { display: none; color: var(--cc-yellow-deep); font-weight: var(--cc-fw-bold); font-size: 10px; letter-spacing: 0.05em; }
.article-share__button--copy.is-copied { background: var(--cc-paper-warm); border-color: var(--cc-yellow); color: var(--cc-ink); }
.article-share__button--copy.is-copied .article-share__text { display: none; }
.article-share__button--copy.is-copied .article-share__feedback { display: inline; }
/* Bottom variant */
.article-share--bottom { background: var(--cc-paper-warm); }
.article-share--bottom .article-share__inner { padding-top: 18px; padding-bottom: 18px; }
.article-share--bottom .article-share__button { min-height: 44px; padding: 8px 15px; }
.article-share--bottom .article-share__label { font-size: var(--cc-fs-sm); color: var(--cc-fg-muted); }
@media (max-width: 820px) {
  .article-share__inner { padding-left: 20px; padding-right: 20px; }
}
@media (max-width: 520px) {
  .article-share__button--native { order: -1; width: 100%; }
}

/* ===== REVIEWS (componente reutilizável — cidades + página dedicada) ===== */
.cc-reviews { background: var(--cc-paper-card); border-top: 1px solid var(--cc-border); border-bottom: 1px solid var(--cc-border); padding: 56px 0; }
.cc-reviews__inner { max-width: 1280px; margin: 0 auto; padding: 0 32px; }
.cc-reviews__eyebrow { display: inline-flex; align-items: center; gap: 10px; color: var(--cc-yellow-deep); font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-bold); font-size: var(--cc-fs-xs); letter-spacing: var(--cc-tracking-wider); text-transform: uppercase; margin-bottom: 12px; }
.cc-reviews__eyebrow::before { content: ''; display: inline-block; width: 32px; height: 2px; background: var(--cc-yellow-deep); }
.cc-reviews__title { font-family: var(--cc-font-display); font-style: italic; font-weight: var(--cc-fw-black); text-transform: uppercase; font-size: var(--cc-fs-2xl); color: var(--cc-ink); margin: 0 0 6px; line-height: 1; }
.cc-reviews__sub { font-family: var(--cc-font-body); font-size: var(--cc-fs-sm); color: var(--cc-fg-muted); margin: 0 0 28px; }
.cc-reviews__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 28px; }
.cc-review { display: flex; flex-direction: column; gap: 12px; background: var(--cc-paper); border: 1px solid var(--cc-border); border-radius: var(--cc-radius-lg); padding: 22px 24px; }
.cc-review__stars { display: inline-flex; gap: 2px; }
.cc-review__stars i, .cc-review__stars svg { width: 16px; height: 16px; fill: var(--cc-yellow-deep); stroke: var(--cc-yellow-deep); }
.cc-review__text { font-family: var(--cc-font-body); font-size: var(--cc-fs-base); line-height: var(--cc-lh-loose); color: var(--cc-fg); margin: 0; flex: 1; }
.cc-review__meta { display: flex; flex-direction: column; gap: 2px; margin-top: 4px; }
.cc-review__name { font-family: var(--cc-font-body); font-weight: var(--cc-fw-bold); font-size: var(--cc-fs-sm); color: var(--cc-ink); }
.cc-review__src { display: inline-flex; align-items: center; gap: 5px; font-size: var(--cc-fs-xs); color: var(--cc-fg-subtle); letter-spacing: 0.04em; }
.cc-review__src i, .cc-review__src svg { width: 13px; height: 13px; stroke: var(--cc-blue-mid); }
.cc-reviews__actions { display: flex; flex-wrap: wrap; gap: 12px; }
@media (max-width: 1024px) { .cc-reviews__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .cc-reviews { padding: 44px 0; } .cc-reviews__inner { padding: 0 20px; } .cc-reviews__grid { grid-template-columns: 1fr; } }
