/*
Theme Name: Josue Cover Premium
Theme URI: https://josuecover.com/
Author: Yensel
Author URI: https://yensel.com/
Description: Tema editorial premium para Josué Cover — periodista, abogado y economista. Diseño Nocturne Editorial inspirado en Bloomberg, The Economist y grandes medios internacionales.
Version: 1.0.1
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: josue-cover-premium
Tags: editorial, dark, premium, magazine, journalism, one-column, two-columns, custom-colors, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ============================================================
   DESIGN SYSTEM — Nocturne Editorial
   Josué Cover Premium Theme v1.0.0
   ============================================================ */

/* --- CSS Custom Properties (Design Tokens) --- */
/* NOTE: Google Fonts are loaded via wp_enqueue_style() in functions.php */
:root {
  /* Backgrounds */
  --bg-base:               #050505;
  --bg-surface:            #131313;
  --bg-charcoal:           #121212;
  --bg-slate:              #1E2222;
  --bg-lowest:             #0E0E0E;
  --bg-low:                #1C1B1B;
  --bg-container:          #201F1F;
  --bg-container-high:     #2A2A2A;
  --bg-container-highest:  #353534;
  --bg-bright:             #3A3939;

  /* Gold Accent */
  --gold:                  #F2CA50;
  --gold-dim:              #E9C349;
  --gold-refined:          #D4AF37;
  --gold-deep:             #735C00;
  --gold-on:               #3C2F00;

  /* Text */
  --text-primary:          #E5E2E1;
  --text-secondary:        #D0C5AF;
  --text-silver:           #C6C6C6;
  --text-muted:            #999999;
  --text-outline:          #99907C;

  /* Borders */
  --border:                #333333;
  --border-variant:        #4D4635;

  /* Typography */
  --font-display:          'Playfair Display', Georgia, 'Times New Roman', serif;
  --font-body:             'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-label:            'Geist', 'Courier New', monospace;

  /* Font Sizes */
  --fs-display:            72px;
  --fs-display-mobile:     48px;
  --fs-headline-xl:        48px;
  --fs-headline-lg:        32px;
  --fs-body-lg:            18px;
  --fs-body-md:            16px;
  --fs-label:              12px;

  /* Line Heights */
  --lh-display:            80px;
  --lh-display-mobile:     56px;
  --lh-headline-xl:        56px;
  --lh-headline-lg:        40px;
  --lh-body-lg:            32px;
  --lh-body-md:            28px;
  --lh-label:              16px;

  /* Spacing */
  --section-gap:           160px;
  --margin-desktop:        80px;
  --margin-mobile:         24px;
  --gutter:                32px;
  --stack:                 8px;

  /* Border Radius */
  --radius-sm:             0.125rem;
  --radius:                0.25rem;
  --radius-md:             0.375rem;
  --radius-lg:             0.5rem;

  /* Transitions */
  --transition-fast:       all 300ms ease;
  --transition-slow:       all 500ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-ultra:      all 700ms cubic-bezier(0.4, 0, 0.2, 1);

  /* Shadows */
  --shadow-card:           0 4px 40px rgba(0,0,0,0.4);
  --shadow-gold:           0 0 30px rgba(242, 202, 80, 0.15);
}

/* ============================================================
   RESET & BASE
   ============================================================ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  background-color: var(--bg-base) !important;
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

body, .wp-site-blocks, #page, #wrapper, .editor-styles-wrapper {
  background-color: var(--bg-base) !important;
  color: var(--text-primary) !important;
  font-family: var(--font-body);
  font-size: var(--fs-body-md);
  line-height: var(--lh-body-md);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  width: 100%;
  max-width: 100%;
}

::selection {
  background-color: var(--gold);
  color: var(--gold-on);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

ul, ol {
  list-style: none;
}

button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit;
}

/* ============================================================
   TYPOGRAPHY SYSTEM
   ============================================================ */

.jc-display {
  font-family: var(--font-display);
  font-size: var(--fs-display);
  line-height: var(--lh-display);
  font-weight: 700;
  letter-spacing: -0.02em;
}

.jc-display-mobile {
  font-family: var(--font-display);
  font-size: var(--fs-display-mobile);
  line-height: var(--lh-display-mobile);
  font-weight: 700;
  letter-spacing: -0.01em;
}

.jc-headline-xl {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5.5vw, var(--fs-headline-xl));
  line-height: 1.2;
  font-weight: 600;
  word-break: break-word;
  overflow-wrap: break-word;
}

.jc-headline-lg {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, var(--fs-headline-lg));
  line-height: 1.25;
  font-weight: 600;
  word-break: break-word;
  overflow-wrap: break-word;
}

.jc-body-lg {
  font-family: var(--font-body);
  font-size: var(--fs-body-lg);
  line-height: var(--lh-body-lg);
  font-weight: 400;
}

.jc-body-md {
  font-family: var(--font-body);
  font-size: var(--fs-body-md);
  line-height: var(--lh-body-md);
  font-weight: 400;
}

.jc-label {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  line-height: var(--lh-label);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* ============================================================
   UTILITIES
   ============================================================ */

.jc-container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 var(--margin-desktop);
}

.jc-container--narrow {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--margin-desktop);
}

.jc-section {
  padding: var(--section-gap) 0;
}

.jc-gold {
  color: var(--gold);
}

.jc-text-gradient {
  background: linear-gradient(180deg, #E5E2E1 0%, #999999 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ============================================================
   NAVIGATION
   ============================================================ */

.jc-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--stack) var(--margin-desktop);
  background: rgba(19, 19, 19, 0.8);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  transition: var(--transition-slow);
}

.jc-header.is-scrolled {
  background: rgba(18, 18, 18, 0.95);
  backdrop-filter: blur(30px);
  -webkit-backdrop-filter: blur(30px);
}

.jc-header__logo {
  font-family: var(--font-display);
  font-size: var(--fs-headline-lg);
  font-weight: 700;
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  line-height: 1;
}

.jc-nav {
  display: flex;
  align-items: center;
  gap: var(--gutter);
}

.jc-nav__link {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-secondary);
  transition: var(--transition-fast);
  padding-bottom: 2px;
}

.jc-nav__link:hover,
.jc-nav__link.is-active {
  color: var(--text-primary);
}

.jc-nav__link.is-current {
  color: var(--gold);
  border-bottom: 1px solid var(--gold);
}

.jc-btn {
  display: inline-block;
  font-family: var(--font-label);
  font-size: var(--fs-label);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: var(--transition-fast);
  border-radius: var(--radius-sm);
}

.jc-btn--primary {
  background: var(--gold);
  color: var(--gold-on);
  padding: 10px var(--gutter);
}

.jc-btn--primary:hover {
  background: var(--gold-dim);
}

.jc-btn--ghost {
  border: 1px solid var(--text-silver);
  color: var(--text-silver);
  padding: 10px var(--gutter);
}

.jc-btn--ghost:hover {
  background: rgba(255,255,255,0.05);
}

/* Mobile Hamburger */
.jc-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 4px;
}

.jc-hamburger__line {
  width: 24px;
  height: 1px;
  background: var(--text-primary);
  transition: var(--transition-fast);
}

.jc-mobile-nav {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 280px;
  background: var(--bg-charcoal);
  border-left: 1px solid var(--border);
  z-index: 999;
  padding: 80px var(--gutter) var(--gutter);
  display: flex;
  flex-direction: column;
  gap: 24px;
  transform: translateX(100%);
  transition: var(--transition-slow);
}

.jc-mobile-nav.is-open {
  transform: translateX(0);
}

.jc-mobile-nav__overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  z-index: 998;
  opacity: 0;
  pointer-events: none;
  transition: var(--transition-fast);
}

.jc-mobile-nav__overlay.is-open {
  opacity: 1;
  pointer-events: all;
}

.jc-mobile-nav__link {
  font-family: var(--font-label);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-secondary);
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
  transition: var(--transition-fast);
}

.jc-mobile-nav__link:hover {
  color: var(--gold);
}

.jc-mobile-nav__link.is-current {
  color: var(--gold);
  border-bottom-color: var(--gold);
}

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

.jc-hero {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 600px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.jc-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.jc-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.55) contrast(1.05) saturate(1.05);
  transform-origin: center;
  transition: transform 10s ease-out;
}

.jc-hero__gradient {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(5,5,5,0.1) 0%, rgba(5,5,5,0.7) 60%, #050505 100%),
              linear-gradient(to bottom, rgba(5,5,5,0.2) 0%, #050505 100%);
}

.jc-hero__content {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 0 var(--margin-mobile);
  max-width: 1200px;
  width: 100%;
}

.jc-hero__title {
  font-family: var(--font-display);
  font-size: clamp(3rem, 16vw, 5rem);
  line-height: 1.1;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--text-primary);
  text-transform: uppercase;
  margin-bottom: 24px;
}

.jc-hero__subtitle {
  font-family: var(--font-body);
  font-size: var(--fs-body-lg);
  line-height: var(--lh-body-lg);
  color: var(--text-silver);
  letter-spacing: 0.05em;
  margin-bottom: 56px;
  text-align: center;
}

.jc-hero__ctas {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 24px;
  width: 100%;
}

.jc-hero__scroll {
  position: absolute;
  bottom: 48px;
  left: 50%;
  transform: translateX(-50%);
  animation: bounce 2s infinite;
  color: var(--gold);
  font-size: 32px;
}

@keyframes bounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50% { transform: translateX(-50%) translateY(8px); }
}

/* ============================================================
   BIO SECTION
   ============================================================ */

.jc-bio {
  padding: var(--section-gap) 0;
}

.jc-bio__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--gutter);
  align-items: center;
}

.jc-bio__image-wrapper {
  position: relative;
}

.jc-bio__image-frame {
  position: absolute;
  inset: -16px;
  border: 1px solid var(--border-variant);
  opacity: 0.3;
  transition: var(--transition-slow);
  pointer-events: none;
}

.jc-bio__image-wrapper:hover .jc-bio__image-frame {
  opacity: 0.7;
}

.jc-bio__image {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  transition: var(--transition-slow);
  filter: contrast(1.1) brightness(0.95) sepia(0.2) saturate(1.1) hue-rotate(-5deg);
}

.jc-bio__image-wrapper::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(242, 202, 80, 0.05) 0%, rgba(13, 15, 17, 0.4) 100%);
  mix-blend-mode: multiply;
  pointer-events: none;
}

.jc-bio__label {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
  display: block;
}

.jc-bio__heading {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5.5vw, var(--fs-headline-xl));
  line-height: 1.2;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--gutter);
  word-break: break-word;
  overflow-wrap: break-word;
}

.jc-bio__text {
  color: var(--text-secondary);
  font-size: var(--fs-body-lg);
  line-height: var(--lh-body-lg);
  margin-bottom: 16px;
}

.jc-bio__stats {
  display: flex;
  gap: 48px;
  padding-top: var(--gutter);
}

.jc-bio__stat-number {
  font-family: var(--font-display);
  font-size: var(--fs-headline-xl);
  line-height: 1;
  color: var(--gold);
  font-weight: 700;
}

.jc-bio__stat-label {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-top: 4px;
}

/* ============================================================
   AREAS SECTION
   ============================================================ */

.jc-areas {
  padding: var(--section-gap) 0;
  background: var(--bg-charcoal);
}

.jc-areas__header {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 64px;
}

.jc-areas__grid {
  display: grid;
  grid-template-columns: 1fr;
  border: 1px solid var(--border-variant);
}

.jc-area-card {
  padding: 56px 48px;
  border-bottom: 1px solid var(--border-variant);
  border-top: 1px solid transparent;
  border-left: 1px solid transparent;
  border-right: 1px solid transparent;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: all 400ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.jc-area-card:last-child {
  border-bottom: none;
}

.jc-area-card:hover {
  background: var(--bg-slate);
  border-color: rgba(242, 202, 80, 0.15);
}

.jc-area-card__icon {
  font-size: 36px;
  color: var(--gold);
  margin-bottom: 28px;
  display: block;
  transition: transform 0.3s ease;
}

.jc-area-card:hover .jc-area-card__icon {
  transform: translateY(-4px);
}

.jc-area-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-headline-lg);
  line-height: var(--lh-headline-lg);
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 16px;
}

.jc-area-card__text {
  font-size: var(--fs-body-md);
  line-height: var(--lh-body-md);
  color: var(--text-secondary);
  margin-bottom: var(--gutter);
}

.jc-area-card__link {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: var(--transition-fast);
}

.jc-area-card__link:hover {
  gap: 12px;
}

/* ============================================================
   MEDIA CAROUSEL
   ============================================================ */

.jc-media {
  padding: var(--section-gap) 0;
  overflow: hidden;
}

.jc-media__header {
  padding: 0 var(--margin-desktop);
  margin-bottom: 48px;
}

.jc-media__scroll {
  display: flex;
  gap: var(--gutter);
  padding: 0 var(--margin-desktop) var(--gutter);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.jc-media__scroll::-webkit-scrollbar {
  display: none;
}

.jc-media-item {
  flex: 0 0 300px;
  scroll-snap-align: start;
  cursor: pointer;
}

.jc-media-item__thumb {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
  margin-bottom: 24px;
}

.jc-media-item__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: contrast(1.05) brightness(0.95) saturate(0.95);
  transition: var(--transition-slow);
}

.jc-media-item:hover .jc-media-item__thumb img {
  filter: contrast(1.1) brightness(1.05) saturate(1.1);
  transform: scale(1.05);
}

.jc-media-item__play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.4);
  backdrop-filter: blur(4px);
  opacity: 0;
  transition: var(--transition-slow);
}

.jc-media-item:hover .jc-media-item__play {
  opacity: 1;
}

.jc-media-item__play-icon {
  font-size: 64px;
  color: white;
}

.jc-media-item__type {
  font-family: var(--font-label);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 8px;
}

.jc-media-item__title {
  font-family: var(--font-display);
  font-size: var(--fs-headline-lg);
  line-height: var(--lh-headline-lg);
  font-weight: 600;
  color: var(--text-primary);
}

/* ============================================================
   ARTICLES SECTION
   ============================================================ */

.jc-articles {
  padding: var(--section-gap) 0;
}

.jc-articles__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 64px;
}

.jc-articles__view-all {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-silver);
  transition: var(--transition-fast);
}

.jc-articles__view-all:hover {
  color: var(--gold);
}

.jc-articles__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--gutter);
}

/* Featured article */
.jc-article-featured {
  cursor: pointer;
}

.jc-article-featured__thumb {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
  margin-bottom: var(--gutter);
}

.jc-article-featured__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-slow);
}

.jc-article-featured:hover .jc-article-featured__thumb img {
  transform: scale(1.05);
}

.jc-article-featured__category {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
}

.jc-article-featured__title {
  font-family: var(--font-display);
  font-size: var(--fs-headline-xl);
  line-height: var(--lh-headline-xl);
  font-weight: 600;
  color: var(--text-primary);
  margin: 16px 0 24px;
  transition: var(--transition-slow);
}

.jc-article-featured:hover .jc-article-featured__title {
  color: var(--gold);
}

.jc-article-featured__excerpt {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-body-lg);
  color: var(--text-secondary);
}

/* Side article list */
.jc-article-list {
  display: flex;
  flex-direction: column;
  gap: var(--gutter);
}

.jc-article-list-item {
  cursor: pointer;
}

.jc-article-list-item__category {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-silver);
}

.jc-article-list-item__title {
  font-family: var(--font-display);
  font-size: var(--fs-headline-lg);
  line-height: var(--lh-headline-lg);
  font-weight: 600;
  color: var(--text-primary);
  margin-top: 8px;
  transition: var(--transition-slow);
}

.jc-article-list-item:hover .jc-article-list-item__title {
  color: var(--gold);
}

.jc-article-list-item__divider {
  height: 1px;
  width: 100%;
  background: var(--border-variant);
  margin-top: 24px;
}

/* ============================================================
   MANIFESTO SECTION
   ============================================================ */

.jc-manifesto {
  padding: var(--section-gap) 0;
  background: var(--bg-low);
  position: relative;
  overflow: hidden;
}

.jc-manifesto__dots {
  position: absolute;
  inset: 0;
  opacity: 0.08;
  pointer-events: none;
  background-image: radial-gradient(#D4AF37 1px, transparent 1px);
  background-size: 40px 40px;
}

.jc-manifesto__content {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 0 var(--margin-desktop);
}

.jc-manifesto__label {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  display: block;
  margin-bottom: 48px;
}

.jc-manifesto__quote {
  font-family: var(--font-display);
  font-size: clamp(36px, 5vw, 72px);
  line-height: 1.15;
  font-style: italic;
  color: var(--text-primary);
  max-width: 1100px;
  margin: 0 auto;
}

.jc-manifesto__quote .highlight {
  color: var(--gold);
  font-style: normal;
}

.jc-manifesto__line {
  width: 1px;
  height: 64px;
  background: var(--gold);
  margin: 48px auto 0;
}

/* ============================================================
   BLOG ARCHIVE
   ============================================================ */

.jc-blog-header {
  padding: var(--gutter) var(--margin-desktop);
  margin-bottom: 64px;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 128px;
}

.jc-blog-header__accent {
  display: inline-block;
  border-left: 2px solid var(--gold);
  padding-left: 24px;
  margin-bottom: var(--stack);
}

.jc-blog-featured {
  position: relative;
  height: 600px;
  overflow: hidden;
  background: var(--bg-charcoal);
  margin: 0 var(--margin-desktop) var(--section-gap);
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
}

.jc-blog-featured img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.8;
  transition: transform 1s ease-out;
}

.jc-blog-featured:hover img {
  transform: scale(1.05);
}

.jc-blog-featured__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, #050505, transparent);
}

.jc-blog-featured__content {
  position: absolute;
  bottom: 48px;
  left: 48px;
  right: 48px;
  max-width: 640px;
}

/* Category filter */
.jc-category-filter {
  position: sticky;
  top: 68px;
  z-index: 40;
  padding: 0 var(--margin-desktop);
  margin-bottom: var(--stack);
}

.jc-category-filter__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 24px 0;
  background: rgba(19, 19, 19, 0.9);
  backdrop-filter: blur(12px);
}

.jc-category-filter__tabs {
  display: flex;
  gap: 48px;
  overflow-x: auto;
  scrollbar-width: none;
}

.jc-category-filter__tabs::-webkit-scrollbar { display: none; }

.jc-filter-btn {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-secondary);
  padding-bottom: 4px;
  white-space: nowrap;
  transition: var(--transition-fast);
}

.jc-filter-btn.is-active,
.jc-filter-btn:hover {
  color: var(--gold);
}

.jc-filter-btn.is-active {
  border-bottom: 2px solid var(--gold);
}

/* Cards Grid */
.jc-blog-grid {
  display: flex;
  gap: var(--gutter);
  padding: 64px var(--margin-desktop);
  max-width: 1280px;
  margin: 0 auto;
  align-items: start;
}

.jc-blog-main {
  flex: 0 0 calc(66.666% - var(--gutter) / 2);
}

.jc-blog-main__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gutter);
}

.jc-blog-sidebar {
  flex: 0 0 calc(33.333% - var(--gutter) / 2);
  display: flex;
  flex-direction: column;
  gap: 48px;
}

/* Tonal card */
.jc-tonal-card {
  background: var(--bg-charcoal);
  border: 1px solid var(--border);
  transition: var(--transition-slow);
  display: flex;
  flex-direction: column;
}

.jc-tonal-card:hover {
  border-color: var(--gold);
  background: #161616;
}

.jc-tonal-card__thumb {
  overflow: hidden;
  aspect-ratio: 16/9;
}

.jc-tonal-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: contrast(1.05) brightness(0.95) sepia(0.1);
  transition: filter 0.5s ease, transform 0.5s ease;
}

.jc-tonal-card:hover .jc-tonal-card__thumb img {
  filter: contrast(1.1) brightness(1.02) sepia(0);
  transform: scale(1.03);
}

.jc-tonal-card__body {
  padding: 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.jc-tonal-card__category {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
}

.jc-tonal-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-headline-lg);
  line-height: var(--lh-headline-lg);
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 16px;
  flex: 1;
}

.jc-tonal-card__excerpt {
  font-size: var(--fs-body-md);
  line-height: var(--lh-body-md);
  color: var(--text-muted);
  margin-bottom: 24px;
}

.jc-tonal-card__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}

.jc-tonal-card__date {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-outline);
}

.jc-tonal-card__arrow {
  color: var(--gold);
  font-size: 20px;
  transition: transform 0.3s ease;
}

.jc-tonal-card:hover .jc-tonal-card__arrow {
  transform: scale(1.2);
}

/* Wide card (col-span-2) */
.jc-tonal-card--wide {
  flex-direction: row;
  grid-column: 1 / -1;
}

.jc-tonal-card--wide .jc-tonal-card__thumb {
  flex: 0 0 50%;
  aspect-ratio: auto;
}

.jc-tonal-card--wide .jc-tonal-card__body {
  justify-content: center;
}

/* Sidebar styles */
.jc-sidebar-newsletter {
  background: var(--bg-slate);
  padding: var(--gutter);
  border: 1px solid var(--border-variant);
}

.jc-sidebar-newsletter__title {
  font-family: var(--font-display);
  font-size: var(--fs-headline-lg);
  line-height: var(--lh-headline-lg);
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 16px;
}

.jc-sidebar-newsletter__text {
  font-size: var(--fs-body-md);
  color: var(--text-secondary);
  margin-bottom: var(--gutter);
}

.jc-input {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--border-variant);
  padding: 12px 0;
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-primary);
  outline: none;
  transition: border-color 0.3s ease;
  margin-bottom: 16px;
}

.jc-input::placeholder {
  color: var(--text-outline);
}

.jc-input:focus {
  border-bottom-color: var(--gold);
}

.jc-sidebar-section__title {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-outline);
  border-bottom: 1px solid var(--border-variant);
  padding-bottom: 8px;
  margin-bottom: var(--gutter);
}

.jc-most-read__item {
  display: flex;
  gap: 16px;
  margin-bottom: var(--gutter);
  cursor: pointer;
}

.jc-most-read__number {
  font-family: var(--font-display);
  font-size: 48px;
  font-weight: 700;
  color: var(--bg-container-highest);
  opacity: 0.5;
  line-height: 1;
  flex-shrink: 0;
  transition: var(--transition-fast);
}

.jc-most-read__item:hover .jc-most-read__number {
  color: var(--gold);
  opacity: 1;
}

.jc-most-read__category {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  display: block;
  margin-bottom: 4px;
}

.jc-most-read__title {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-body-lg);
  color: var(--text-primary);
  transition: var(--transition-fast);
}

.jc-most-read__item:hover .jc-most-read__title {
  color: var(--text-silver);
}

/* ============================================================
   SINGLE POST
   ============================================================ */

.jc-reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 2px;
  background: var(--gold);
  width: 0%;
  z-index: 9999;
  transition: width 0.1s linear;
}

.jc-post-hero {
  position: relative;
  width: 100%;
  height: 90vh;
  min-height: 600px;
  display: flex;
  align-items: flex-end;
  padding-bottom: var(--section-gap);
  overflow: hidden;
}

.jc-post-hero__bg {
  position: absolute;
  inset: 0;
}

.jc-post-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.5);
}

.jc-post-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, var(--bg-surface) 20%, rgba(19,19,19,0.2) 80%, transparent);
}

.jc-post-hero__content {
  position: relative;
  z-index: 10;
  width: 100%;
  padding: 0 var(--margin-desktop);
  max-width: 1280px;
  margin: 0 auto;
}

.jc-post-category-badge {
  display: inline-block;
  padding: 6px 12px;
  background: rgba(242, 202, 80, 0.1);
  border: 1px solid rgba(242, 202, 80, 0.2);
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
}

.jc-post-title {
  font-family: var(--font-display);
  font-size: clamp(36px, 5vw, var(--fs-display));
  line-height: 1.1;
  font-weight: 700;
  letter-spacing: -0.02em;
  background: linear-gradient(180deg, #E5E2E1 0%, #999999 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  max-width: 900px;
  margin-bottom: 24px;
}

.jc-post-meta {
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}

.jc-post-meta__author {
  display: flex;
  align-items: center;
  gap: 12px;
}

.jc-post-meta__avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid var(--border-variant);
}

.jc-post-meta__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.jc-post-meta__name {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-primary);
}

.jc-post-meta__role {
  font-family: var(--font-label);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.jc-post-meta__divider {
  width: 1px;
  height: 32px;
  background: var(--border-variant);
}

.jc-post-meta__reading {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.jc-post-meta__date {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}

/* Post Layout */
.jc-post-layout {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--gutter);
  padding: var(--gutter) var(--margin-desktop);
  max-width: 1280px;
  margin: 0 auto;
}

.jc-post-social {
  display: none;
  flex-direction: column;
  gap: var(--stack);
  position: sticky;
  top: 96px;
  align-self: start;
}

.jc-post-social__btn {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  color: var(--text-muted);
  transition: var(--transition-fast);
}

.jc-post-social__btn:hover {
  border-color: var(--gold);
  color: var(--gold);
}

/* Article Content */
.jc-article-content {
  font-family: var(--font-body);
  font-size: var(--fs-body-lg);
  line-height: var(--lh-body-lg);
  color: var(--text-primary);
  max-width: 720px;
}

.jc-article-content p {
  margin-bottom: 24px;
  color: rgba(229, 226, 225, 0.85);
}

.jc-article-content p:first-of-type::first-letter {
  float: left;
  font-family: var(--font-display);
  font-size: 72px;
  line-height: 0.8;
  margin-right: 12px;
  margin-top: 8px;
  color: var(--gold);
  font-weight: 700;
}

.jc-article-content h2 {
  font-family: var(--font-display);
  font-size: var(--fs-headline-xl);
  line-height: var(--lh-headline-xl);
  font-weight: 600;
  color: var(--text-primary);
  margin: 48px 0 24px;
}

.jc-article-content h3 {
  font-family: var(--font-display);
  font-size: var(--fs-headline-lg);
  line-height: var(--lh-headline-lg);
  font-weight: 600;
  color: var(--text-primary);
  margin: 32px 0 16px;
}

.jc-article-content blockquote {
  border-left: 4px solid var(--gold);
  padding-left: var(--gutter);
  padding-top: 16px;
  padding-bottom: 16px;
  margin: 32px 0;
}

.jc-article-content blockquote p {
  font-family: var(--font-display);
  font-size: var(--fs-headline-lg);
  line-height: var(--lh-headline-lg);
  font-style: italic;
  color: var(--text-silver);
}

.jc-article-content img {
  width: 100%;
  border: 1px solid var(--border);
  margin: var(--gutter) 0;
}

.jc-article-content ul,
.jc-article-content ol {
  margin-bottom: 24px;
  padding-left: 24px;
}

.jc-article-content ul li {
  list-style: disc;
  margin-bottom: 8px;
  color: rgba(229, 226, 225, 0.85);
}

.jc-article-content ol li {
  list-style: decimal;
  margin-bottom: 8px;
  color: rgba(229, 226, 225, 0.85);
}

.jc-article-content a {
  color: var(--gold);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.jc-article-content strong {
  font-weight: 600;
  color: var(--text-primary);
}

/* Post Tags */
.jc-post-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 48px;
}

.jc-post-tag {
  display: inline-block;
  padding: 8px 16px;
  background: var(--bg-container-high);
  font-family: var(--font-label);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-secondary);
  transition: var(--transition-fast);
}

.jc-post-tag:hover {
  background: rgba(242, 202, 80, 0.1);
  color: var(--gold);
}

/* Post Navigation */
.jc-post-nav {
  width: 100%;
  border-top: 1px solid var(--border);
  background: var(--bg-lowest);
}

.jc-post-nav__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 64px var(--margin-desktop);
  gap: var(--gutter);
  max-width: 1280px;
  margin: 0 auto;
}

.jc-post-nav__link {
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: transform 0.5s ease;
  flex: 1;
}

.jc-post-nav__link:hover {
  transform: translateX(16px);
}

.jc-post-nav__link--prev:hover {
  transform: translateX(-16px);
}

.jc-post-nav__label {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
}

.jc-post-nav__title {
  font-family: var(--font-display);
  font-size: var(--fs-headline-xl);
  line-height: var(--lh-headline-xl);
  font-weight: 600;
  color: var(--text-primary);
}

.jc-post-nav__arrow {
  font-size: 64px;
  color: var(--border-variant);
  transition: var(--transition-slow);
}

.jc-post-nav__link:hover .jc-post-nav__arrow {
  color: var(--gold);
  transform: scale(1.1);
}

/* Related Posts */
.jc-related {
  padding: var(--section-gap) var(--margin-desktop);
  background: var(--bg-surface);
}

.jc-related__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: var(--gutter);
}

.jc-related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gutter);
}

.jc-related-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
  cursor: pointer;
}

.jc-related-card__thumb {
  aspect-ratio: 4/5;
  overflow: hidden;
  background: var(--bg-charcoal);
}

.jc-related-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: contrast(1.05) brightness(0.95) sepia(0.1);
  transition: var(--transition-ultra);
}

.jc-related-card:hover .jc-related-card__thumb img {
  filter: contrast(1.1) brightness(1.02) sepia(0);
  transform: scale(1.05);
}

.jc-related-card__category {
  font-family: var(--font-label);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
}

.jc-related-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-headline-lg);
  line-height: var(--lh-headline-lg);
  font-weight: 600;
  color: var(--text-primary);
}

.jc-related-card__excerpt {
  font-size: var(--fs-body-md);
  color: var(--text-muted);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ============================================================
   FOOTER
   ============================================================ */

.jc-footer {
  background: var(--bg-lowest);
  border-top: 1px solid var(--border-variant);
  padding: var(--section-gap) var(--margin-desktop);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--gutter);
}

.jc-footer__logo {
  font-family: var(--font-display);
  font-size: clamp(36px, 5vw, var(--fs-display));
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  text-transform: uppercase;
}

.jc-footer__nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px var(--gutter);
}

.jc-footer__link {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-secondary);
  transition: var(--transition-fast);
}

.jc-footer__link:hover {
  color: var(--text-primary);
}

.jc-footer__link--active {
  color: var(--gold);
}

.jc-footer__social {
  display: flex;
  align-items: center;
  gap: 24px;
}

.jc-footer__social-link {
  color: var(--text-secondary);
  font-size: 20px;
  transition: var(--transition-fast);
}

.jc-footer__social-link:hover {
  color: var(--gold);
}

.jc-footer__copy {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-silver);
  margin-top: 32px;
}

/* ============================================================
   SOCIAL CARD REFINEMENTS
   ============================================================ */

.jc-social-card {
  transition: all 600ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.jc-social-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 40px rgba(0,0,0,0.5), 0 0 60px rgba(242, 202, 80, 0.03);
  border-color: rgba(242, 202, 80, 0.15) !important;
}

.jc-social-card__media img,
.jc-social-card img {
  transition: transform 600ms cubic-bezier(0.25, 0.46, 0.45, 0.94), filter 500ms ease;
}

.jc-social-card:hover .jc-social-card__media img,
.jc-social-card:hover img {
  transform: scale(1.03);
  filter: contrast(1.05) brightness(1.02);
}

/* ============================================================
   YOUTUBE CARD — Presencia Digital
   ============================================================ */

.jc-youtube-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--gutter);
}

.jc-youtube-card {
  background: var(--bg-charcoal);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: all 600ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  position: relative;
}

.jc-youtube-card::after {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  pointer-events: none;
  opacity: 0;
  transition: opacity 600ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.jc-youtube-card:hover {
  border-color: rgba(242, 202, 80, 0.15);
  transform: translateY(-2px);
  box-shadow: 0 8px 40px rgba(0,0,0,0.5), 0 0 60px rgba(242, 202, 80, 0.03);
}

.jc-youtube-card:hover::after {
  opacity: 1;
}

.jc-youtube-card__link {
  display: block;
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
}

.jc-youtube-card__thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-slow);
}

.jc-youtube-card:hover .jc-youtube-card__thumb {
  transform: scale(1.05);
}

.jc-youtube-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, transparent 50%, rgba(0,0,0,0.1) 100%);
  transition: var(--transition-slow);
  pointer-events: none;
}

.jc-youtube-card:hover .jc-youtube-card__overlay {
  background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, transparent 40%, rgba(0,0,0,0.2) 100%);
}

.jc-youtube-card__play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 56px;
  height: 56px;
  background: rgba(255, 0, 0, 0.9);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-slow);
  pointer-events: none;
}

.jc-youtube-card:hover .jc-youtube-card__play {
  background: #FF0000;
  transform: translate(-50%, -50%) scale(1.1);
  box-shadow: 0 0 30px rgba(255, 0, 0, 0.4);
}

.jc-youtube-card__play-icon {
  color: white;
  font-size: 28px;
  font-variation-settings: 'FILL' 1;
}

.jc-youtube-card__body {
  padding: 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.jc-youtube-card__meta {
  font-family: var(--font-label);
  font-size: 9px;
  color: var(--text-muted);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 4px;
}

.jc-youtube-card__platform {
  color: #FF0000;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 600;
}

.jc-youtube-card__separator {
  color: var(--border);
}

.jc-youtube-card__date {
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.jc-youtube-card__title {
  font-family: var(--font-display);
  font-size: 18px;
  line-height: 1.3;
  margin-bottom: 12px;
  flex: 1;
}

.jc-youtube-card__title-link {
  color: var(--text-primary);
  transition: color 0.3s;
}

.jc-youtube-card__title-link:hover {
  color: var(--gold);
}

.jc-youtube-card__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  margin-top: auto;
}

.jc-youtube-card__footer-label {
  font-family: var(--font-label);
  font-size: 10px;
  font-weight: 700;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.jc-youtube-card__arrow {
  font-size: 12px;
  color: var(--gold);
}

.jc-youtube-card:hover .jc-youtube-card__arrow {
  transform: translateX(4px);
}

.jc-youtube-fallback {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 48px;
  border: 1px solid var(--border);
  background: var(--bg-charcoal);
  min-height: 200px;
}

.jc-youtube-fallback__icon {
  font-size: 36px;
  display: block;
  margin-bottom: 16px;
}

.jc-youtube-fallback__text {
  color: var(--text-secondary);
  max-width: 400px;
}

/* ============================================================
    ANIMATIONS & REVEALS
    ============================================================ */

.jc-reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.jc-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.jc-reveal--delay-1 { transition-delay: 0.1s; }
.jc-reveal--delay-2 { transition-delay: 0.2s; }
.jc-reveal--delay-3 { transition-delay: 0.3s; }
.jc-reveal--delay-4 { transition-delay: 0.4s; }

/* ============================================================
   PAGE TEMPLATES (About, Contact, 404, etc.)
   ============================================================ */

.jc-page-header {
  padding: 160px var(--margin-desktop) 80px;
  max-width: 1280px;
  margin: 0 auto;
}

.jc-page-content {
  padding: 0 var(--margin-desktop) var(--section-gap);
  max-width: 720px;
  margin: 0 auto;
}

/* Custom About Page Premium Modifications */
.jc-page-header--sobre {
  padding-top: 60px !important;
  padding-bottom: 24px !important;
}

.jc-page-content--wide {
  max-width: 1280px !important;
  width: 100% !important;
}

.jc-page-content--sobre {
  padding-bottom: 80px !important;
}

/* Reduces footer spacing on the About page */
.jc-page-sobre-cover .jc-footer {
  padding-top: 80px !important;
  padding-bottom: 80px !important;
}

/* About Grid Layout */
.jc-sobre-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: center;
}

@media (min-width: 1024px) {
  .jc-sobre-grid {
    grid-template-columns: minmax(420px, 520px) minmax(520px, 720px);
    gap: 72px;
  }
}

/* Premium Image Styling */
.jc-sobre-image-wrapper {
  position: relative;
  max-width: 520px;
  width: 100%;
  margin: 0 auto;
  z-index: 1;
}

.jc-sobre-image-wrapper::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 120%;
  height: 120%;
  background: radial-gradient(circle, rgba(242, 202, 80, 0.04) 0%, rgba(5, 5, 5, 0) 70%);
  z-index: -1;
  pointer-events: none;
}

.jc-sobre-image-frame {
  position: absolute;
  inset: -16px;
  border: 1px solid var(--border-variant);
  opacity: 0.3;
  transition: var(--transition-slow);
  pointer-events: none;
}

.jc-sobre-image-wrapper:hover .jc-sobre-image-frame {
  opacity: 0.7;
  transform: scale(1.02);
}

.jc-sobre-image {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  filter: grayscale(0.2) contrast(1.05) brightness(0.95);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.8);
  border: 1px solid rgba(242, 202, 80, 0.1);
  transition: var(--transition-slow);
}

.jc-sobre-image-wrapper:hover .jc-sobre-image {
  filter: grayscale(0) contrast(1.05) brightness(1.02);
  box-shadow: 0 20px 50px rgba(242, 202, 80, 0.08);
}

/* Premium Typography adjustments */
.jc-sobre-headline {
  margin-top: 8px;
  margin-bottom: var(--gutter);
  line-height: 1.0;
  letter-spacing: -0.03em;
}

.jc-sobre-description {
  color: var(--text-secondary);
  font-size: 18px;
  line-height: 1.9;
  max-width: 640px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Premium Metrics Grid */
.jc-sobre-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  padding-top: 32px;
  border-top: 1px solid rgba(242, 202, 80, 0.15);
  margin-top: 48px;
}

.jc-sobre-stat-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.jc-sobre-stat-number {
  font-family: var(--font-display);
  font-size: clamp(2.8rem, 4vw, 4rem);
  font-weight: 700;
  color: var(--gold);
  line-height: 1;
}

.jc-sobre-stat-label {
  color: var(--text-muted);
  font-size: 11px;
}

@media (max-width: 1023px) {
  .jc-page-header--sobre {
    padding-top: 30px !important;
  }
}

@media (max-width: 767px) {
  .jc-page-header--sobre {
    padding-top: 10px !important;
  }
  .jc-sobre-stats {
    gap: 16px;
    margin-top: 32px;
  }
  .jc-sobre-stat-number {
    font-size: clamp(2rem, 8vw, 2.8rem);
  }
}

.jc-404 {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--margin-desktop);
}

.jc-404__number {
  font-family: var(--font-display);
  font-size: 200px;
  font-weight: 700;
  color: var(--border);
  line-height: 1;
  margin-bottom: 24px;
}

/* ============================================================
   SEARCH
   ============================================================ */

.jc-search-form {
  display: flex;
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--section-gap);
}

.jc-search-form input[type="search"] {
  flex: 1;
  background: transparent;
  border: none;
  padding: 16px 0;
  font-family: var(--font-display);
  font-size: var(--fs-headline-lg);
  color: var(--text-primary);
  outline: none;
}

.jc-search-form button {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  padding: 16px 0 16px var(--gutter);
}

/* ============================================================
   ADMIN SETUP PAGE
   ============================================================ */

.jc-admin-wrap {
  max-width: 800px;
  margin: 40px auto;
  font-family: var(--font-body, 'Inter', sans-serif);
}

.jc-admin-btn {
  background: #F2CA50;
  color: #3c2f00;
  padding: 12px 28px;
  border-radius: 4px;
  font-weight: 600;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  cursor: pointer;
  border: none;
  transition: opacity 0.2s;
}

.jc-admin-btn:hover {
  opacity: 0.85;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

/* Tablet: 768px–1024px */
@media (max-width: 1024px) {
  :root {
    --margin-desktop: 48px;
    --section-gap: 96px;
  }

  .jc-header {
    padding: var(--stack) var(--margin-desktop);
  }

  .jc-nav {
    display: none;
  }

  .jc-hamburger {
    display: flex;
  }

  /* Tablet Hero Adjustments */
  .jc-hero {
    min-height: 78vh !important;
    padding-top: 96px !important;
    padding-bottom: 72px !important;
  }

  /* Tablet Bio & Areas Spacing */
  .jc-bio {
    padding-top: 96px !important;
    padding-bottom: 96px !important;
  }

  .jc-areas {
    padding-top: 96px !important;
    padding-bottom: 96px !important;
  }

  .jc-bio__grid {
    grid-template-columns: 1fr;
  }

  .jc-areas__grid {
    grid-template-columns: 1fr;
  }

  .jc-articles__grid {
    grid-template-columns: 1fr;
  }

  .jc-blog-grid {
    flex-direction: column;
  }

  .jc-blog-main {
    flex: none;
    width: 100%;
  }

  .jc-blog-sidebar {
    flex: none;
    width: 100%;
  }

  .jc-post-layout {
    grid-template-columns: 1fr;
  }

  .jc-post-social {
    display: none !important;
  }

  .jc-related__grid {
    grid-template-columns: 1fr 1fr;
  }

  .jc-post-nav__inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .jc-tonal-card--wide {
    flex-direction: column;
  }

  .jc-tonal-card--wide .jc-tonal-card__thumb {
    flex: none;
    aspect-ratio: 16/9;
  }
}

/* Mobile: <768px */
@media (max-width: 767px) {
  :root {
    --margin-desktop: var(--margin-mobile);
    --section-gap: 72px;
    --gutter: 24px;
  }

  /* Section Rhythm & Scroll Margins */
  section {
    scroll-margin-top: 90px;
  }

  /* General Premium Containers Width on Mobile (both jc- and generic containers) */
  .jc-container,
  .jc-container--narrow,
  .editorial-container,
  .section-container,
  .container,
  .site-container,
  .hero-container,
  .bio-container,
  .about-container,
  .areas-container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  @media (max-width: 375px) {
    .jc-container,
    .jc-container--narrow,
    .editorial-container,
    .section-container,
    .container,
    .site-container,
    .hero-container,
    .bio-container,
    .about-container,
    .areas-container {
      padding-left: 16px !important;
      padding-right: 16px !important;
    }
  }

  .jc-header {
    padding: var(--stack) var(--margin-mobile);
    max-width: 100% !important;
  }

  .jc-header__logo {
    font-size: 20px;
    max-width: 100% !important;
  }

  /* Hero Section Mobile Adjustments */
  .jc-hero,
  .hero,
  .hero-section {
    min-height: auto !important;
    height: auto !important;
    padding-top: 110px !important;
    padding-bottom: 72px !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .jc-hero__title,
  .hero-title {
    font-size: clamp(3.4rem, 16vw, 5rem) !important;
    line-height: 0.9 !important;
    letter-spacing: -0.04em !important;
    margin-bottom: 0 !important;
    max-width: 100% !important;
    word-break: normal !important;
  }

  .jc-hero__subtitle,
  .hero-subtitle {
    font-size: 1.05rem !important;
    line-height: 1.5 !important;
    margin-top: 20px !important;
    margin-bottom: 32px !important;
    max-width: 100% !important;
  }

  .jc-hero__ctas,
  .hero-actions {
    flex-direction: column !important;
    width: 100% !important;
    max-width: 100% !important;
    gap: 14px !important;
    align-items: center !important;
    display: flex !important;
  }

  .jc-hero__ctas .jc-btn,
  .hero-actions .btn,
  .hero-actions a {
    width: 100% !important;
    max-width: 100% !important;
    text-align: center !important;
  }

  .jc-hero__scroll {
    display: none !important; /* Avoid visual clutter on smaller mobile viewports */
  }

  /* Bio Section Mobile Adjustments */
  .jc-bio,
  .bio-section,
  .about-vision-section {
    padding-top: 64px !important;
    padding-bottom: 72px !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .jc-bio__grid,
  .bio-grid,
  .about-vision-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 32px !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .jc-bio__image-wrapper,
  .bio-image-wrapper,
  .bio-image,
  .about-image-wrapper,
  .about-image {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    position: relative !important;
  }

  .jc-bio__image,
  .bio-image img,
  .about-image img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    aspect-ratio: 4 / 5 !important;
    object-fit: cover !important;
    object-position: center top !important;
    display: block !important;
  }

  .jc-bio__image-frame {
    inset: -8px !important; /* Prevent collision with outer borders */
  }

  .jc-bio__heading,
  .bio-content h2,
  .about-content h2 {
    font-size: clamp(2.4rem, 11vw, 3.4rem) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.03em !important;
    max-width: 100% !important;
    text-align: left !important;
  }

  .jc-bio__text,
  .bio-content p,
  .about-content p {
    text-align: left !important;
    max-width: 100% !important;
    font-size: 1rem !important;
    line-height: 1.75 !important;
    overflow-wrap: break-word !important;
    word-break: normal !important;
  }

  .section-kicker,
  .eyebrow,
  .jc-bio__label {
    font-size: 0.75rem !important;
    letter-spacing: 0.12em !important;
  }

  .jc-bio__stats {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 16px !important;
    margin-top: 32px !important;
  }

  /* Areas of Action Mobile Adjustments */
  .jc-areas {
    padding-top: 72px !important;
    padding-bottom: 88px !important;
  }

  .jc-areas__header {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 20px !important;
    text-align: left !important;
  }

  .jc-areas__grid {
    grid-template-columns: 1fr !important;
  }

  .jc-area-card {
    padding: 28px !important;
    border-bottom: 1px solid var(--border-variant) !important;
  }

  /* International Coverage Mobile Grid Compaction */
  .jc-cobertura-item:nth-child(n+7) {
    display: none !important; /* Hide items beyond 6 on mobile viewports for premium cleanliness */
  }

  /* Blog & Articles Mobile Adjustments */
  .jc-articles__grid {
    grid-template-columns: 1fr !important;
  }

  .jc-article-featured {
    width: 100% !important;
  }

  .jc-article-featured__thumb {
    aspect-ratio: 16/10 !important;
  }

  .jc-article-list {
    width: 100% !important;
  }

  .jc-media-item {
    flex: 0 0 280px;
  }

  .jc-blog-featured {
    height: 400px;
    margin: 0 var(--margin-mobile) var(--section-gap);
  }

  .jc-blog-featured__content {
    left: 24px;
    right: 24px;
    bottom: 24px;
  }

  .jc-blog-main__grid {
    grid-template-columns: 1fr;
  }

  .jc-related__grid {
    grid-template-columns: 1fr;
  }

  .jc-post-hero {
    height: 60vh;
  }

  .jc-youtube-grid {
    grid-template-columns: 1fr;
  }

  .jc-manifesto__quote {
    font-size: 28px;
  }

  .jc-footer__logo {
    font-size: 36px;
  }

  .jc-category-filter__tabs {
    gap: 24px;
  }

  .jc-404__number {
    font-size: 100px;
  }

  .jc-post-nav__inner {
    padding: var(--gutter) var(--margin-mobile);
  }

  .jc-post-nav__title {
    font-size: var(--fs-headline-lg);
  }

  .jc-related {
    padding: var(--section-gap) var(--margin-mobile);
  }

  .jc-blog-header {
    padding: var(--gutter) var(--margin-mobile);
    padding-top: 100px;
  }

  .jc-category-filter {
    padding: 0 var(--margin-mobile);
  }

  .jc-blog-grid {
    padding: 48px var(--margin-mobile);
  }

  .jc-post-layout {
    padding: var(--gutter) var(--margin-mobile);
  }

  .jc-post-hero__content {
    padding: 0 var(--margin-mobile);
  }
}

/* Large screens */
@media (min-width: 1024px) {
  .jc-hero__title {
    font-size: clamp(4rem, 9vw, 9rem);
    line-height: 1.1;
    letter-spacing: -0.02em;
  }

  .jc-hero__ctas {
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 24px;
  }

  .jc-bio__grid {
    grid-template-columns: 5fr 7fr;
    gap: var(--gutter);
  }

  .jc-areas__grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .jc-areas__grid .jc-area-card {
    border-bottom: none;
    border-right: 1px solid var(--border-variant);
  }

  .jc-areas__grid .jc-area-card:last-child {
    border-right: none;
  }

  .jc-articles__grid {
    grid-template-columns: 8fr 4fr;
  }

  .jc-media-item {
    flex: 0 0 450px;
  }

  .jc-post-layout {
    grid-template-columns: 48px 1fr 340px;
  }

  .jc-post-social {
    display: flex;
  }

  .jc-areas__header {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
  }
}

/* ============================================================
   WORDPRESS CORE OVERRIDES
   ============================================================ */

/* Hide temporary domain branding */
body::before, body::after,
header::before, header::after,
footer::before, footer::after {
  display: none !important;
}

.wp-caption {
  max-width: 100%;
}

.wp-caption-text {
  font-family: var(--font-label);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  margin-top: 8px;
  text-align: center;
}

.gallery {
  display: grid;
  gap: var(--stack);
  grid-template-columns: repeat(3, 1fr);
}

.gallery-item img {
  width: 100%;
  height: auto;
}

.wp-block-quote {
  border-left: 4px solid var(--gold);
  padding-left: var(--gutter);
  margin: var(--gutter) 0;
}

.wp-block-quote p {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--text-silver);
}

/* Pagination */
.jc-pagination {
  display: flex;
  justify-content: center;
  gap: 8px;
  padding: var(--gutter) 0;
}

.jc-pagination a,
.jc-pagination span {
  font-family: var(--font-label);
  font-size: var(--fs-label);
  letter-spacing: 0.1em;
  padding: 8px 16px;
  border: 1px solid var(--border);
  color: var(--text-secondary);
  transition: var(--transition-fast);
}

.jc-pagination a:hover,
.jc-pagination .current {
  border-color: var(--gold);
  color: var(--gold);
}

/* Screen reader text */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  word-wrap: normal !important;
}

/* ============================================================
   COBERTURA INTERNACIONAL (Masonry Grid)
   ============================================================ */

.jc-cobertura {
  padding: var(--section-gap) 0;
  background: var(--bg-base);
}

.jc-cobertura__header {
  margin-bottom: 64px;
}

.jc-cobertura__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

@media (min-width: 768px) {
  .jc-cobertura__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
}

@media (min-width: 1024px) {
  .jc-cobertura__grid {
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 240px;
  }
  
  .jc-cobertura-item:nth-child(1) { grid-column: span 2; grid-row: span 2; }
  .jc-cobertura-item:nth-child(2) { grid-column: span 1; grid-row: span 1; }
  .jc-cobertura-item:nth-child(3) { grid-column: span 1; grid-row: span 2; }
  .jc-cobertura-item:nth-child(4) { grid-column: span 1; grid-row: span 1; }
  .jc-cobertura-item:nth-child(5) { grid-column: span 2; grid-row: span 1; }
  .jc-cobertura-item:nth-child(6) { grid-column: span 1; grid-row: span 2; }
  .jc-cobertura-item:nth-child(7) { grid-column: span 1; grid-row: span 1; }
  .jc-cobertura-item:nth-child(8) { grid-column: span 1; grid-row: span 1; }
}

.jc-cobertura-item {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(242, 202, 80, 0.1);
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
  transition: var(--transition-slow);
  height: 100%;
  display: flex;
  flex-direction: column;
}

@media (max-width: 1023px) {
  .jc-cobertura-item {
    aspect-ratio: 4 / 3;
    min-height: 160px;
  }
}

.jc-cobertura-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(0.3) brightness(0.85);
  transition: var(--transition-slow);
}

.jc-cobertura-item:hover img {
  filter: grayscale(0) brightness(1.0);
  transform: scale(1.03);
}

.jc-cobertura-item__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(5,5,5,0.9) 0%, rgba(5,5,5,0.4) 50%, transparent 100%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px;
  opacity: 0.9;
  transition: var(--transition-fast);
}

.jc-cobertura-item:hover .jc-cobertura-item__overlay {
  background: linear-gradient(to top, rgba(18,15,10,0.95) 0%, rgba(5,5,5,0.2) 100%);
}

.jc-cobertura-item__title {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
  letter-spacing: -0.01em;
}

.jc-cobertura-item__tag {
  font-family: var(--font-label);
  font-size: 10px;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 6px;
}
